From 77e510492a722d4a946305311d74b0e1018a62b7 Mon Sep 17 00:00:00 2001 From: Robert Carlsen Date: Tue, 31 Jan 2012 12:33:24 -0600 Subject: [PATCH] cleaned up obsolete files and fixed 'make clean' to do a proper cleaning. --- CyclusIntroduction.html | 327 ------------------ Makefile | 6 +- _images/logo.png | Bin 3916 -> 0 bytes _sources/CyclusIntroduction.txt | 233 ------------- _sources/basics/Decay.txt | 128 ------- _sources/basics/style_guide.txt | 66 ---- _sources/devdoc/CyclusStyleGuidelines.txt | 74 ---- _sources/main.txt | 34 -- _sources/wiki/CyclusIntroduction.txt | 233 ------------- _sources/wiki/CyclusStyleGuidelines.txt | 74 ---- _sources/wiki/Decay.txt | 128 ------- _sources/wiki/DeploymentRegion.txt | 34 -- _sources/wiki/DevelopersDocumentation.txt | 50 --- _sources/wiki/ExpGrowthRegion.txt | 36 -- _sources/wiki/GettingAndBuildingCyclus.txt | 97 ------ ...elinesForImplementingNewFacilityModels.txt | 16 - ...GuidelinesForImplementingNewInstModels.txt | 19 - ...idelinesForImplementingNewMarketModels.txt | 18 - .../GuidelinesForImplementingNewModels.txt | 89 ----- ...idelinesForImplementingNewRegionModels.txt | 29 -- .../wiki/InstallingDependenciesOnUnix.txt | 40 --- .../wiki/InstallingDependenciesOnWindows.txt | 84 ----- _sources/wiki/IntegrationTests.txt | 8 - _sources/wiki/MilestoneGenRepo.txt | 313 ----------------- _sources/wiki/MilestoneNullSimulation.txt | 43 --- _sources/wiki/MilestoneOneInpro.txt | 20 -- _sources/wiki/MilestoneTwoNWTRB.txt | 305 ---------------- _sources/wiki/MilestoneZero.txt | 20 -- _sources/wiki/OutputDatabase.txt | 125 ------- .../ProgramFlowAndDataStructureOverview.txt | 75 ---- _sources/wiki/UserDocumentation.txt | 16 - _sources/wiki/main.txt | 34 -- _static/default.css | 256 -------------- _static/logo.png | Bin 3916 -> 0 bytes _static/sidebar.js | 151 -------- basics/Decay.html | 224 ------------ basics/decay.html | 10 +- basics/style_guide.html | 181 ---------- devdoc/CyclusStyleGuidelines.html | 183 ---------- doctrees/CyclusIntroduction.doctree | Bin 44635 -> 0 bytes doctrees/basics/Decay.doctree | Bin 21045 -> 0 bytes doctrees/basics/decay.doctree | Bin 21980 -> 21985 bytes doctrees/basics/dependencies_windows.doctree | Bin 25820 -> 25825 bytes doctrees/basics/introduction.doctree | Bin 44637 -> 44642 bytes doctrees/basics/main.doctree | Bin 3239 -> 3237 bytes doctrees/basics/style_guide.doctree | Bin 13564 -> 0 bytes doctrees/devdoc/CyclusStyleGuidelines.doctree | Bin 13836 -> 0 bytes doctrees/devdoc/main.doctree | Bin 11264 -> 11269 bytes doctrees/devdoc/make-models/facility.doctree | Bin 9092 -> 9087 bytes doctrees/environment.pickle | Bin 43472 -> 42778 bytes doctrees/index.doctree | Bin 7126 -> 7121 bytes doctrees/main.doctree | Bin 4796 -> 0 bytes doctrees/wiki/CyclusIntroduction.doctree | Bin 44645 -> 0 bytes doctrees/wiki/CyclusStyleGuidelines.doctree | Bin 13793 -> 0 bytes doctrees/wiki/Decay.doctree | Bin 21039 -> 0 bytes doctrees/wiki/DeploymentRegion.doctree | Bin 12305 -> 0 bytes doctrees/wiki/DevelopersDocumentation.doctree | Bin 13860 -> 0 bytes doctrees/wiki/ExpGrowthRegion.doctree | Bin 13800 -> 0 bytes .../wiki/GettingAndBuildingCyclus.doctree | Bin 29185 -> 0 bytes ...esForImplementingNewFacilityModels.doctree | Bin 8765 -> 0 bytes ...elinesForImplementingNewInstModels.doctree | Bin 6874 -> 0 bytes ...inesForImplementingNewMarketModels.doctree | Bin 9125 -> 0 bytes ...GuidelinesForImplementingNewModels.doctree | Bin 50978 -> 0 bytes ...inesForImplementingNewRegionModels.doctree | Bin 11692 -> 0 bytes .../wiki/InstallingDependenciesOnUnix.doctree | Bin 17921 -> 0 bytes .../InstallingDependenciesOnWindows.doctree | Bin 21974 -> 0 bytes doctrees/wiki/IntegrationTests.doctree | Bin 2652 -> 0 bytes doctrees/wiki/MilestoneGenRepo.doctree | Bin 57358 -> 0 bytes doctrees/wiki/MilestoneNullSimulation.doctree | Bin 11047 -> 0 bytes doctrees/wiki/MilestoneOneInpro.doctree | Bin 5699 -> 0 bytes doctrees/wiki/MilestoneTwoNWTRB.doctree | Bin 66566 -> 0 bytes doctrees/wiki/MilestoneZero.doctree | Bin 8613 -> 0 bytes doctrees/wiki/OutputDatabase.doctree | Bin 55658 -> 0 bytes ...rogramFlowAndDataStructureOverview.doctree | Bin 18733 -> 0 bytes doctrees/wiki/UserDocumentation.doctree | Bin 6575 -> 0 bytes doctrees/wiki/main.doctree | Bin 4334 -> 0 bytes main.html | 104 ------ searchindex.js | 2 +- 78 files changed, 11 insertions(+), 3874 deletions(-) delete mode 100644 CyclusIntroduction.html delete mode 100644 _images/logo.png delete mode 100644 _sources/CyclusIntroduction.txt delete mode 100644 _sources/basics/Decay.txt delete mode 100644 _sources/basics/style_guide.txt delete mode 100644 _sources/devdoc/CyclusStyleGuidelines.txt delete mode 100644 _sources/main.txt delete mode 100644 _sources/wiki/CyclusIntroduction.txt delete mode 100644 _sources/wiki/CyclusStyleGuidelines.txt delete mode 100644 _sources/wiki/Decay.txt delete mode 100644 _sources/wiki/DeploymentRegion.txt delete mode 100644 _sources/wiki/DevelopersDocumentation.txt delete mode 100644 _sources/wiki/ExpGrowthRegion.txt delete mode 100644 _sources/wiki/GettingAndBuildingCyclus.txt delete mode 100644 _sources/wiki/GuidelinesForImplementingNewFacilityModels.txt delete mode 100644 _sources/wiki/GuidelinesForImplementingNewInstModels.txt delete mode 100644 _sources/wiki/GuidelinesForImplementingNewMarketModels.txt delete mode 100644 _sources/wiki/GuidelinesForImplementingNewModels.txt delete mode 100644 _sources/wiki/GuidelinesForImplementingNewRegionModels.txt delete mode 100644 _sources/wiki/InstallingDependenciesOnUnix.txt delete mode 100644 _sources/wiki/InstallingDependenciesOnWindows.txt delete mode 100644 _sources/wiki/IntegrationTests.txt delete mode 100644 _sources/wiki/MilestoneGenRepo.txt delete mode 100644 _sources/wiki/MilestoneNullSimulation.txt delete mode 100644 _sources/wiki/MilestoneOneInpro.txt delete mode 100644 _sources/wiki/MilestoneTwoNWTRB.txt delete mode 100644 _sources/wiki/MilestoneZero.txt delete mode 100644 _sources/wiki/OutputDatabase.txt delete mode 100644 _sources/wiki/ProgramFlowAndDataStructureOverview.txt delete mode 100644 _sources/wiki/UserDocumentation.txt delete mode 100644 _sources/wiki/main.txt delete mode 100644 _static/default.css delete mode 100644 _static/logo.png delete mode 100644 _static/sidebar.js delete mode 100644 basics/Decay.html delete mode 100644 basics/style_guide.html delete mode 100644 devdoc/CyclusStyleGuidelines.html delete mode 100644 doctrees/CyclusIntroduction.doctree delete mode 100644 doctrees/basics/Decay.doctree delete mode 100644 doctrees/basics/style_guide.doctree delete mode 100644 doctrees/devdoc/CyclusStyleGuidelines.doctree delete mode 100644 doctrees/main.doctree delete mode 100644 doctrees/wiki/CyclusIntroduction.doctree delete mode 100644 doctrees/wiki/CyclusStyleGuidelines.doctree delete mode 100644 doctrees/wiki/Decay.doctree delete mode 100644 doctrees/wiki/DeploymentRegion.doctree delete mode 100644 doctrees/wiki/DevelopersDocumentation.doctree delete mode 100644 doctrees/wiki/ExpGrowthRegion.doctree delete mode 100644 doctrees/wiki/GettingAndBuildingCyclus.doctree delete mode 100644 doctrees/wiki/GuidelinesForImplementingNewFacilityModels.doctree delete mode 100644 doctrees/wiki/GuidelinesForImplementingNewInstModels.doctree delete mode 100644 doctrees/wiki/GuidelinesForImplementingNewMarketModels.doctree delete mode 100644 doctrees/wiki/GuidelinesForImplementingNewModels.doctree delete mode 100644 doctrees/wiki/GuidelinesForImplementingNewRegionModels.doctree delete mode 100644 doctrees/wiki/InstallingDependenciesOnUnix.doctree delete mode 100644 doctrees/wiki/InstallingDependenciesOnWindows.doctree delete mode 100644 doctrees/wiki/IntegrationTests.doctree delete mode 100644 doctrees/wiki/MilestoneGenRepo.doctree delete mode 100644 doctrees/wiki/MilestoneNullSimulation.doctree delete mode 100644 doctrees/wiki/MilestoneOneInpro.doctree delete mode 100644 doctrees/wiki/MilestoneTwoNWTRB.doctree delete mode 100644 doctrees/wiki/MilestoneZero.doctree delete mode 100644 doctrees/wiki/OutputDatabase.doctree delete mode 100644 doctrees/wiki/ProgramFlowAndDataStructureOverview.doctree delete mode 100644 doctrees/wiki/UserDocumentation.doctree delete mode 100644 doctrees/wiki/main.doctree delete mode 100644 main.html diff --git a/CyclusIntroduction.html b/CyclusIntroduction.html deleted file mode 100644 index 9bf993248..000000000 --- a/CyclusIntroduction.html +++ /dev/null @@ -1,327 +0,0 @@ - - - - - - - - - - Introduction to the Cyclus Fuel Cycle Simulator — Cyclus - - - - - - - - - - - - -
- -
- -
-
-
-
- -
-

Introduction to the Cyclus Fuel Cycle Simulator

-

The Computational Nuclear Engineering Research Group (CNERG) of the University -of Wisconsin-Madison (UW) has been developing a next generation nuclear fuel -cycle simulation platform called Cyclus whose genesis was driven by a variety -of gaps seen in previous fuel cycle simulation efforts. Three major design and -development philosophies encompass the current fleet of fuel cycle simulators:

-
-
    -
  1. A desire for usability, thus developing a tool which begins with a simple -model in a visual development environment that aims to provide an intuitive -user interface (e.g. DYMOND, DANESS, VISION)
  2. -
  3. A desire for rapid prototyping, thus developing a tool which begins with -simple models in a scripting language that allows for quick answers to early -problems (e.g. CAFCA, GENIUS v1)
  4. -
  5. A desire for detail/fidelity, thus developing a tool with an ad-hoc -combination of existing complex analysis tools (e.g. COSI)
  6. -
-
-

Experience has demonstrated that each of these philosophies are hindered from -simulating interesting problems due to complexity limits. In most cases this -complexity constrains first the usability of the tool followed by its -extendability due to increasingly convoluted dependencies. The final victim is -performance, as the ability to quickly solve simple problems is lost to the -desire to solve more complex ones.

-

In addition to these technical challenges, there is also an institutional -challenge. A combination of closed development platforms and closed -development processes has made it difficult for an individual researcher to -incorporate their ideas into a fuel cycle systems analysis. The ability to -combine existing systems simulation tools with data about new facilities or -fuel cycle concepts is so challenging that many researchers either choose to -avoid systems analysis altogether or to write their own simplified tool -(usually in category 2 above). These new, special purpose fuel cycle -simulation tools involve a duplication of effort and generally lack any robust -benchmarking.

-

Each of these approaches lacks a design basis in computational science and -software development that can deliver the stated desired attributes of the -final software product:

-
-
    -
  • usability – accommodating a wide range of user sophistication
  • -
  • performance – solving simple problems in interactive time scales
  • -
  • fidelity – accommodating many levels of detail/fidelity, commensurate with a range of user sophistication
  • -
-
-

A complete nuclear fuel cycle simulator requires modeling efforts in a wide -variety of physical and social science domains. This places a premium on a -software development process that will facilitate fluid collaboration among a -large group of geographically dispersed developers. With this constraint in -mind, a number of software development practices can be identified as highly -valuable for this effort:

-
-
    -
  • openness – the process should have low institutional & technical obstacles to collaboration
  • -
  • modularity – a particular approach to modularity should be pursued to allow the core infrastructure to be independent of proprietary and/or sensitive data and/or models
  • -
  • extensibility – attention to both robustness and flexibility allows for myriad potential developer extensions
  • -
-
-
-

Mission

-

Cyclus will be a nuclear fuel cycle systems analysis software platform that -encourages collaboration among a diverse set of researchers. Emphasis will be -placed on both ease of collaboration through modularity as well as ubiquity in -order to analyze a significant number of possible future fuel cycle scenarios -succinctly and consistently.

-
-
-

Vision

-

In order to accomplish this mission, the Cyclus team has developed a vision -for the development of a next generation fuel cycle simulator that includes -elements of software architecture, software development process and -fundamental design paradigms.

-
-
-

Current Status

-

Cyclus is being developed in an open environment. For the current status of Cyclus, visit http://cyclus.github.com.

-
-

Software Process & Architecture

-

As indicated above, the software architecture and accompanying development -process are critical to a simultaneously robust and flexible analysis platform.

-
-

Open Source Development Process

-

The Cyclus development framework employs a modern, open source philosophy -that ensures transparency, attracts contributions from a varied community of -collaborators, and guarantees institution-independent access to all potential -users. In this development path, a public source code repository provides -unhindered access to the fundamental simulation framework and basic fuel -process models volunteered by developers. Granting unfettered access only to -the Cyclus engine allows for compartmentalization of the code and its input -data. Thus, secure and proprietary model developers can be similarly encouraged -to utilize the Cyclus framework. This modern development model passively -distributes specialized content to interested research groups, and facilitates -parallel model development efforts by institutions with complimentary goals. -The transparency inherent in this type of open source development path also -facilitates code review by exposing available content to verification and -validation by collaborators with diverse areas of specialization and levels of -expertise.

-

Another aspect of this development process is a preference for open source -third party libraries where additional functionality is necessary and available -from such libraries. This includes basic infrastructure such as file -input/output, as well as model-specific capabilities like integer programming -for network flow optimization.

-
-
-

Dynamically-loadable Modules

-

Dynamically-loadable modules are the primary mechanism for extending Cyclus -with new underlying models. The primary benefit of this approach is -encapsulation: the trunk of the code is completely independent of the -individual models and all customization and extension is implemented only in -the loadable module. A secondary benefit of this encapsulation is the ability -for contributors to choose different distribution and licensing strategies for -their contributions. Finally, this strategy allows an individual developers -to explore different levels of complexity within their modules, including -wrapping other simulation tools as loadable modules for Cyclus.

-
-
-

Use Cases & Visualization

-

Because of the wide array of use cases for Cyclus, flexibility in the user -interface is important to provide different kinds of users with different -experiences. This is true for input generation as well as output -visualization. A variety of graphical user interface modes have been designed -and will be implemented in parallel with the development of underlying modules. -The graphical interface should be extensible by loadable modules in the same -way as the core code to provide developers the same flexibility in managing -their input as they have in implementing their models. Output visualization is -also important - the discrete facility/discrete material paradigm generates a -large volume of small data that needs to be aggregated in various ways to -provide context to a variety of users.

-
-
-
-

Modeling Paradigm

-

The modeling paradigm adopted by Cyclus includes a number of deeply embedded -fundamental concepts. These basic design choices comprise the bedrock on which -most future design choices are made. The Cyclus team recognizes the -accompanying inflexibility to the code and therefore does not anticipate that -these attributes will change.

-
-

Discrete Facility & Discrete Material Objects

-

The modeling infrastructure is designed such that every facility in a global -nuclear fuel cycle is treated individually. While modeling options will exist -to allow collective action, this will be as a special case of the individual -facility basis. Each facility will have two fundamental tasks: to transact -nuclear material with other facilities and to transform that nuclear material -from an input form to an output form. These materials will be modeled as -discrete objects that exist for a finite time and whose composition and -transaction history is logged throughout the simulation.

-
-
-

Market-based Material Transactions

-

The transaction of nuclear materials will take place in “markets” that act as -brokers to match a set of requests for material with a set of offers for that -material. A variety of market models (see Vision: Software Architecture) will -be available to perform this broker role, but each market will act -independently of other markets. Markets will used to model a variety of -decision making behaviors, not restricted to behaviors that simulate economic -activity. Once the requests and offers have been matched, the facilities will -exchange material objects.

-
-
-

Region-Institution-Facility Hierarchy

-

Every discrete facility in Cyclus is owned by an institution that operates in -a geographic region. An institution can be used to represent any entity that -may own and operate a facility such as a private corporation, a government -agency, or a non-governmental agency, among others. A region can be used to -represent any geographic area, typically a politically relevant area such a -sub-national region (e.g. a U.S. State), a nation-state, or a super-national -region (e.g. the E.U.). While some performance parameters of the facility may -depend on its institutional ownership or geographical location, the more -important use of this capability is to control the way in which a facility -engages in a market for trade of nuclear material based on by whom it is owned -and/or operated.

-
-
-

Optimization and Sensitivity

-

While the market models that form the basis of material transactions represent -largely social constructs, there is an initial desire to minimize the direct -simulation of institutional decision making to seek optimal solutions. -Instead, the fundamental approach is to drive a single simulation with a large -multi-dimensional data set and then allow modern optimization technology to -seek globally optimal solutions based on global objective functions. Since -institutional decision making tends to seek an optimal solution only for the -actor making that decision (local optimization), it may not lead to an outcome -that optimizes for the largest population of stakeholders.

-
-
-
-
-

Research Areas

-

A number of research areas related to Cyclus have already been identified. -In some cases, there is a lead institution already engaged in such research, or -one or more institutions who have expressed interest:

-
-
    -
  1. Cyclus core infrastructure development lead: UW-Madison
  2. -
  3. Market model development interest: UW-Madison, UT-Austin
  4. -
  5. Region model development and deployment scenarios interest: Idaho
  6. -
  7. Reactor model development interest: UT-Austin
  8. -
  9. Separations model development
  10. -
  11. Geologic repository & waste form modeling lead: UW-Madison
  12. -
  13. Graphical interfaces for input and visualization interest: Utah
  14. -
  15. Social science to determine important metrics and measures interest: UW-Madison
  16. -
  17. Optimization and sensitivity infrastructure interest: NC State
  18. -
  19. Transportation
  20. -
  21. Non-proliferation analysis interest: UW
  22. -
-
-
-
- - -
-
-
-
-
- - - - \ No newline at end of file diff --git a/Makefile b/Makefile index 4b528d529..51f98e2af 100644 --- a/Makefile +++ b/Makefile @@ -39,7 +39,11 @@ help: @echo " doctest to run all doctests embedded in the documentation (if enabled)" clean: - -rm -rf $(BUILDDIR)/*.* + -rm -f $(BUILDDIR)/*.* + -rm -Rf $(BUILDDIR)/usrdoc + -rm -Rf $(BUILDDIR)/devdoc + -rm -Rf $(BUILDDIR)/basics + -rm -Rf $(BUILDDIR)/_* html: $(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR) diff --git a/_images/logo.png b/_images/logo.png deleted file mode 100644 index a1227cbc432a9f996f5365b847fea4c6be3f688b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3916 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 aIru-Y&3HI+zc7IS0000 allowedfacilities}}} : The facilities which are allowed within this region. - * For each allowed facility: - * {{{vector< vector < double > > deploysched}}} : An Nx2 matrix where for each n, - * a,,n,0,, = time - * a,,n,1,, = total build demand for the facility - -= Optional Parameters = - -DeploymentRegion behavior may also be specified with the following optional parameters which have default values listed here. - - * string name : A non-generic name for this region. - -= Detailed Behavior = - -The DeploymentRegion is initiated at the beginning of the simulation and persists until the end of the simulation. The region is created with an Nx2 matrix which dictates when facilities in the region should be built. An example of such a matrix is shown below. - -Let us consider a region which would like to produce light water reactors (LWRs). This region would like to begin building 1000 MW,,e,, capacity at the initial month of the simulation and 2000 MW,,e,, at 3 years into the simulation. The demand vector would have values: - {{{ -deploysched[0]=[0,1000] -deploysched[1]=[36,2000] // 3 years = 36 months - }}} - -When it receives a message, the DeploymentRegion simply passes that message either up the hierarchy to the market for which it was intended or down to the appropriate institution on the path to the recipient. \ No newline at end of file diff --git a/_sources/wiki/DevelopersDocumentation.txt b/_sources/wiki/DevelopersDocumentation.txt deleted file mode 100644 index 2e7cd9e28..000000000 --- a/_sources/wiki/DevelopersDocumentation.txt +++ /dev/null @@ -1,50 +0,0 @@ -#summary Documentation for Cyclus Developers -#labels Phase-Implementation - -Documentation to assist with the development of *Cyclus* will be maintained in a variety of forms. - -== Fundamental Concepts == - - * LogicianClass - * CommodityClass - * MaterialClass - * CommunicatorClass - * MessageClass - - * DynamicModule - * GuidelinesForImplementingNewMarketModels - * GuidelinesForImplementingNewRegionModels - * GuidelinesForImplementingNewInstModels - * GuidelinesForImplementingNewFacilityModels - * GuidelinesForImplementingNewConverterModels - -== Milestone Definitions == - -MilestoneNullSimulation - -MilestoneOneInpro - -MilestoneTwoNWTRB - -== Developers Wiki Notes == - -Some specific topics will also be described in the Google Code project wiki pages. - - * GuidelinesForImplementingNewModels - -== Doxygen Code Documentation == - -The definitive documentation of any software is the source code itself. *Cyclus* will relies on Doxygen for automation of rich documentation from appropriately formatted comments in the source code. Current Doxygen documentation can be found at http://cnerg.engr.wisc.edu/cyclus/docs/ . This page will be updated weekly during active development. - -In addition to following Doxygen comment notation in the source code, this relies on a properly configured Doxygen file. - * cyclus/trunk/src/doc/doxy.conf.in is a cmake template file for doxygen settings. - * To add or change options, edit this file and cyclus/trunk/src/doc/CMakeLists.txt - -Documentation is a make target in the cmake build system. Documentation will automatically be built when you "make all". You can build only the documentation by running "make cyclusdoc" instead of "make all" or "make". To avoid building documentation, use "make cyclus". - -== Diversions == - -Relevant xkcd comics: - - * [http://xkcd.com/927/ Standards] - * [http://xkcd.com/974/ The General Solution] diff --git a/_sources/wiki/ExpGrowthRegion.txt b/_sources/wiki/ExpGrowthRegion.txt deleted file mode 100644 index 71005b7a2..000000000 --- a/_sources/wiki/ExpGrowthRegion.txt +++ /dev/null @@ -1,36 +0,0 @@ -#summary Description of ExpGrowthRegion usage and implementation - -= Introduction = - -The ExpGrowthRegion is a region type in *Cyclus* that is associated with a list of allowed facilities. Any institution in that region must have only those facilities. It is instantiated at the beginning of the simulation and persists until the end of the simulation. - -A ExpGrowthRegion takes a build time, intial demand, and demand growth rate from the user to deploy specific facilities at specific times. - -= Model Parameters = - -ExpGrowthRegion behavior is comprehensively defined by the following parameters: - * {{{vector< Model > allowedfacilities}}} : The facilities which are allowed within this region. - * For each allowed facility: - * {{{vector< vector < double > > deploysched}}} : A matrix of size Nx3 where for each , - * a,,n,0,, = initial build time - * a,,n,1,, = initial build demand - * a,,n,2,, = exponential growth rate for further demand - -= Optional Parameters = - -ExpGrowthRegion behavior may also be specified with the following optional parameters which have default values listed here. - - * string name : A non-generic name for this region. - -= Detailed Behavior = - -The ExpGrowthRegion is initiated at the beginning of the simulation and persists until the end of the simulation. The region is created with a Nx3 matrix which dictates when facilities in the region should be built. An example of such a matrix is shown below. - -Let us consider a region which would like to produce light water reactors (LWRs). This region would like to begin building 1000 MW,,e,, capacity at 1 year into the simulation and would like to grow this demand at a rate of 1%. The region at year 3 would then like to begin building 5000 MW,,e,, capacity, if it has not already been reached, with a growth rate of 2% per month. Finally, at year 10, the region would like to maintain the current demand level, but no longer build any further reactors. The demand vector would have values: - {{{ -deploysched[0]=[0,1000,0.01]; // 1% -> 0.01 -deploysched[1]=[60,5000,0.02]; // 5 years = 60 months -deploysched[2]=[120,-1,0.0]; // 10 years = 120 months; -1 denotes current demand level - }}} - -When it receives a message, the ExpGrowthRegion simply passes that message either up the hierarchy to the market for which it was intended or down to the appropriate institution on the path to the recipient. \ No newline at end of file diff --git a/_sources/wiki/GettingAndBuildingCyclus.txt b/_sources/wiki/GettingAndBuildingCyclus.txt deleted file mode 100644 index efe05e377..000000000 --- a/_sources/wiki/GettingAndBuildingCyclus.txt +++ /dev/null @@ -1,97 +0,0 @@ -#summary Information on getting Cyclus from the repository and building it on a new system -#labels Phase-Deploy - -== Requirements == - -The Cyclus code requires the following software and libraries. - -||Package || Minimum Version || -|| `CMake` || 2.8 || -|| `HDF5` || 1.8.3 || -|| `libxml2` || 2 || -|| `boost` || 1.34.1 || -|| `lapack` || 3.4.0 || -|| `trilinos (teuchos)` || 10.8.4 || - -An overview of some more complicated package builds and installations (e.g. lapack, teuchos, etc.) can be found on the InstallingDependenciesOnUnix or InstallingDependenciesOnWindows wiki pages. - -== Repository == - -The Cyclus repository is version controlled using the subversion (SVN) version control system. It is hosted externally with googlecode and mirrored internally on the CNERG space. - * The main repository is located at http://cyclus.googlecode.com/svn/ - * There is a *read only* mirror at file:////home/cnerg/svn/cyclus-mirror - * Anyone may check out the code. - * You do not have to register with googlecode if you do not have a google id, but anonymous users may never commit. - * Note that the googlecode password for your google id is generated by google and you can find it at [https://code.google.com/hosting/settings] - * To check out the code follow the [https://code.google.com/p/cyclus/source/checkout googlecode checkout instructions] . - * Once you have checked out the code, you may commit a change to the google code repository if you are authorized as a committer . - * To become a committer, you must ask for permission via email from one of the project owners ( currently [https://code.google.com/u/katyhuff/ Katy] or [https://code.google.com/u/uwgonuke Paul] ) - * Committing happens from your checked out copy of the repository. - * For example, say you have the google username USERNAME and google password PASSWORD and are sitting in the cyclus/trunk/src directory of your checked out copy. You may want to commit your changes to a version controlled file called FILENAME. To do this you would type. -{{{ -svn commit FILENAME --username USERNAME --password PASSWORD -}}} - * Google may prompt you for your password if you do not include the --username and --password flags. - * Alternatively, if you are sitting in a directory in which you want to commit all of your changes at once, you would type: -{{{ -~ : svn commit -}}} - * If instead FILENAME is a brand new file, not yet under version control, you can use the svn command add: -{{{ -~: svn add FILENAME -~: svn commit -}}} - * For some users, svn commit and svn add will not work and you may need to use the import command: -{{{ -~: svn import FILENAME https://cyclus.googlecode.com/trunk/src/FILENAME --username USERNAME --password PASSWORD -}}} - * The two repositories (the trunk on the CNERG space and the trunk on googlecode) are synchronized using svnsync. - -== Build System == - -In order to facilitate future compatibility with multiple platforms, Cyclus is built using [link: http://www.cmake.org Cmake]. This relies on CMake version 2.6 or higher and the CMakeLists.txt file in /cyclus/trunk/src/. It is recommended that you use CMake to build the Cyclus executable external to the source code. To do this, execute the following steps: -{{{ -/cyclus/trunk/$ mkdir build -/cyclus/trunk/$ cd build -cyclus/trunk/build$ cmake ../src -}}} -You should see output like this: -{{{ -... -... ->> -- Configuring done ->> -- Generating done ->> -- Build files have been written to: /cyclus/trunk/build -/cyclus/trunk/build$ make cyclus ->> Scanning dependencies of target cyclus -... -... ->> [100%] Building CXX object CMakeFiles/cyclus.dir/SourceFac.cpp.o ->> Linking CXX executable cyclus ->> [100%] Built target cyclus -}}} -Now, you can make cyclus, and run it with some input file, for this example, call it input.xml. -{{{ -cyclus/trunk/build$ make -cyclus/trunk/build$ ./cyclus input.xml -}}} - -== Debugging Build == - -If you are a developer, you may be interested in building Cyclus in such a was as to facilitate debugging. It is recommended that you create second build directory in which you'll build a Cyclus executable for which optimizations are disabled and debug symbols are added. To do this, execute the following steps: -{{{ -/cyclus/trunk$ mkdir debug -/cyclus/trunk$ cd debug -/cyclus/trunk/debug$ cmake -DCMAKE_BUILD_TYPE:STRING=Debug ../src -}}} -As before, you should call make to actually build the cyclus executable. -{{{ -/cyclus/trunk/debug$ make -}}} -Now when you call gdb, ddd, or some other debugger within this debug directory it will recognize the target as a debuggable target. To debug a run for some input file input.xml, try the following: -{{{ -/cyclus/trunk/debug$ ddd ./cyclus input.xml -}}} - -== Environment == -In order to utlize the `RelaxNG` input schema, it is necessary to set an environment variable that directs our search algorithm to your cyclus.rng file. That is, before you run cyclus, you must set the environment variable CYCLUS_SRC_DIR to the path to your src directory. diff --git a/_sources/wiki/GuidelinesForImplementingNewFacilityModels.txt b/_sources/wiki/GuidelinesForImplementingNewFacilityModels.txt deleted file mode 100644 index 7125c9061..000000000 --- a/_sources/wiki/GuidelinesForImplementingNewFacilityModels.txt +++ /dev/null @@ -1,16 +0,0 @@ -#summary Developers notes for the implementation of a new FacilityModel -#labels Phase-Implementation - -= Introduction = - -After reading GuidelinesForImplementingNewModels, this should provide additional information specific to implementing a new FacilityModel. - -= Details = - -In addition to inheriting from the main dynamic loading base class `Model`, all FacilityModel models also inherit from `Communicator`. - -A FacilityModel is one of the primary actors in the *Cyclus* system. All offers and requests originate at an instance of a FacilityModel and all shipments are executed by an instance of a FacilityModel. - -While running, *Cyclus* will use a FacilityModel in two ways. First, it will read user input to define a template instance of a FacilityModel. A choice of a FacilityModel model combined with some distinct set of parameters for that model results in a facility that is available for deployment by an InstModel institution if allowed by that institution's RegionModel region. Second, *Cyclus* will create copies of the FacilityModel facilities as they are deployed by the institutions. For this reason, the FacilityModel class defines a data member `fac_name` that is the name of the individual deployed facility. - -All FacilityModel models should know which set of Commodity objects they trade and/or which MarketModel markets they participate in. Each FacilityModel model should implement a method named `sendMessages` to generate offer and request messages to send to their markets and methods named `sendMaterial` and `receiveMaterial` to process shipment messages that originate with their markets. \ No newline at end of file diff --git a/_sources/wiki/GuidelinesForImplementingNewInstModels.txt b/_sources/wiki/GuidelinesForImplementingNewInstModels.txt deleted file mode 100644 index 4d5900225..000000000 --- a/_sources/wiki/GuidelinesForImplementingNewInstModels.txt +++ /dev/null @@ -1,19 +0,0 @@ -#summary Developers notes for the implementation of a new InstModel -#labels Phase-Implementation - -= Introduction = - -After reading GuidelinesForImplementingNewModels, this should provide additional information specific to implementing a new InstModel. - -= Details = - -In addition to inheriting from the main dynamic loading base class `Model`, all InstModel models also inherit from `Communicator`. - -A InstModel's primary function is to - * refer to the set of facilities operating in this institution - -All InstModel models may also implement a reciveMessage function if messages need to be amended by the institution before being sent up to the region or down to the facility. This is a virtual (but not pure virtual) function, so implementation is optional. Default behavior is to ignore the message. - -InstModel models are sent a tick and tock signal at the beginning and end of each month, respectively. Monthly tasks, such as facility deployment or bookkeeping should be undertaken within the handleTick and handleTock functions. These are virtual (but not pure virtual), so implementation of these functions is optional. - -*The InstModel model type is not yet stable and additional interface and data members are expected to be added.* diff --git a/_sources/wiki/GuidelinesForImplementingNewMarketModels.txt b/_sources/wiki/GuidelinesForImplementingNewMarketModels.txt deleted file mode 100644 index 8e7750742..000000000 --- a/_sources/wiki/GuidelinesForImplementingNewMarketModels.txt +++ /dev/null @@ -1,18 +0,0 @@ -#summary Developers notes for the implementation of a new MarketModel - -= Introduction = - -After reading GuidelinesForImplementingNewModels, this should provide additional information specific to implementing a new MarketModel. - -= Details = - -In addition to inheriting from the main dynamic loading base class `Model`, all MarketModel models also inherit from `Communicator`. - -A MarketModel's primary function is to - * receive offers and requests from facilities, - * "_resolve_" the market by matching those offers and requests - * generate/execute a set of orders for shipments of material between facilities that results from resolving the market - -Therefore, all MarketModel models should implement their own version of `receiveOfferRequest` that registers incoming offers and requests in a way that is appropriate for this market implementation. All MarketModel models must also implement their own version of `resolve`. - -All MarketModel models have an STL `set` of pointers to the `OfferRequest` messages that have arrived and an STL `deque` of pointers to the `Shipment` messages that it is generating. MarketModel models are also free to have additional storage modes for `OfferRequest` messages or `Shipment` messages that facilitates the operation of that particular MarketModel paradigm. \ No newline at end of file diff --git a/_sources/wiki/GuidelinesForImplementingNewModels.txt b/_sources/wiki/GuidelinesForImplementingNewModels.txt deleted file mode 100644 index 35e0186c3..000000000 --- a/_sources/wiki/GuidelinesForImplementingNewModels.txt +++ /dev/null @@ -1,89 +0,0 @@ -#summary Some developers notes on implementing new dynamically loadable models - -= Introduction = - -The current code in `branches/paul-branch` has support for Markets, Facilities and Regions and loadable modules. The instructions here will describe both how to add specific modules within those types, as well as how to extend this to other types of loadable modules. - -= Creating New Models of the Existing Types = - -For each type of model, a set of stub files are available as skeletons for the new models. When creating a new model, it is important that all the functionality defined in these files remains in the final model definition. - -To create a new model, e.g. a new MarketModel of type !NewMarket: - * copy !StubMarket.h and !StubMarket.cpp to a new location, e.g. !NewMarket.h & !NewMarket.cpp, respectively - * change the internal references to !StubMarket to !NewMarket - * add a new `add_library` line to the CMakeLists.txt file in that directory - * add the XML input grammar for that model to the appropriate place in the [https://code.google.com/p/cyclus/source/browse/branches/paul-branch/src/cyclus.rng cyclus.rng] XML schema - -All models must provide the following: - * a method named 'init' to initialize an instance of the model from an XML node pointer (xmlNodePtr) - * this method must call the parent class method of the same name (e.g. MarketModel::init(cur)) - * this method should only initialize variables that are NOT members of the parent class - * a method named 'copy' to initialize an instance of the model from another instance of the same model - * this method must call the parent class method of the same name (e.g. MarketModel::copy(src)) - * this method should only initialize variables that are NOT members of the parent class - * a method named 'print' to print a description of the model - * this method should call the parent class method of the same name (e.g. MarketModel::print()) - * this method should only print information that is NOT part of the parent class(es) - * this method assumes that a dangling output line (no std::endl) is left from the parent class output - * two global functions `construct` and `destroy` that are used to instantiate objects of this model type. They are defined, for example, as follows: -{{{ -extern "C" Model* construct() { - return new NewMarket(); -} - -extern "C" void destruct(Model* p) { - delete p; -} -}}} - -For further details about creating new models of particular types, consult the Model-specific reference: - * GuidelinesForImplementingNewMarketModels - * GuidelinesForImplementingNewRegionModels - * GuidelinesForImplementingNewInstModels - * GuidelinesForImplementingNewFacilityModels - - -= Keeping Stub Files Current = - -It is very important to keep the Stub files in the Models directory (or in each of the model sub-directories) current. As the Model.h definition is improved/enhanced/developed, each of the model types will have to be updated to be consistent. Treat the StubModel and the StubCommModel in the same way as others to ensure it remains up-to-date. - -Similarly if a single model type is updated, e.g. !MarketModel.h, with new capability, each of the implemented models will need to be updated to be consistent. Treat the Stub`*` Models in each sub-directory in the same way as the others to ensure it remains up-to-date. - -= Extending Loadable Modules to Other Types = - -The current code already has support for loadable modules for MarketModel, FacilityModel, InstModel, and RegionModel. These are all derived from base class Model defined in [https://code.google.com/p/cyclus/source/browse/branches/paul-branch/src/Models/Model.h Model.h]. To support extension of this capability to other types of models, the files [https://code.google.com/p/cyclus/source/browse/branches/paul-branch/src/Models/StubModel.h StubModel.h] & [https://code.google.com/p/cyclus/source/browse/branches/paul-branch/src/Models/StubModel.cpp StubModel.cpp] is provided. (Stubs are also provided for new Models that are also Communicators: [https://code.google.com/p/cyclus/source/browse/branches/paul-branch/src/Models/StubCommModel.h StubCommModel.h] & [https://code.google.com/p/cyclus/source/browse/branches/paul-branch/src/Models/StubCommModel.cpp StubCommModel.cpp].) - -To extend to a new model type, e.g. !NewTypeModel: - * copy !StubModel.h & !StubModel.cpp to a new location, !NewTypeModel.h & !NewTypeModel.cpp, respectively - * change the internal references to StubModel to !NewTypeModel - * add !NewTypeModel.cpp to the list of sources in the top level CMakeLists.txt file - * add a sub-directory (e.g. NewType) to the Models directory for your models - * this directory name will become a keyword and should match the model name - * create a !StubNewType.h and !StubNewType.cpp file in that sub-directory that are stubs for new models of that type (you may want to copy the files Stub/StubStub.h and Stub/StubStub.cpp) - * follow the directions for creating a new model above to make a Stub for your !NewType model - -All new models types must include: - * a new `static int` variable called nextID that is initialized as 0 and provides a serialized ID for all instances of the models that are instantiated - * a default constructor that - * assigns the current value of nextID to the ID member variable and increments nextID - * assigns a string that matches the model name to `model_type` - * (for Communicators, this should also assign the correct value to `commType`) - * a method named 'init' to initialize an instance of the model from an XML node pointer (xmlNodePtr) - * this method must call the parent class method Model::init(cur) - * this method should only initialize variables that are NOT members of the parent class - * a method named 'copy' to initialize an instance of the model from another instance of the same model - * this method must call the parent class method Model::copy(src) - * (for Communicators, this method must call that parent class method Communicator::copy(src)) - * this method should only initialize variables that are NOT members of the parent class - * a method named 'print' to print a description of the model - * this method should call the parent class method of the same name (e.g. MarketModel::print()) - * this method should only print information that is NOT part of the parent class(es) - * this method assumes that a dangling output line (no std::endl) is left from the parent class output - -Other notes on introducing new Model types: - * You will probably need to extend the input parsing for this new Model type. Since the primary input for *Cyclus* uses XML, you will certainly need to add code to recognize and process primitives for this Model type. While you could, in theory, add a completely new input paradigm for Models of this type, you might need to extend the *Cyclus* grammar to include support for your Models. - * You will probably need to create a primary storage location for your new models in *Cyclus*. Currently, most models are somehow registered with the Logician (exception: InstModel are only registered with their containing Region). You will need to extend the code appropriately to give a home to your new models. - -= References = - # [http://oss.sgi.com/LDP/HOWTO/C++-dlopen/index.html C++ dlopen mini HOWTO] - # [http://www.yolinux.com/TUTORIALS/LibraryArchives-StaticAndDynamic.html Static, Shared Dynamic and Loadable Linux Libraries] \ No newline at end of file diff --git a/_sources/wiki/GuidelinesForImplementingNewRegionModels.txt b/_sources/wiki/GuidelinesForImplementingNewRegionModels.txt deleted file mode 100644 index 8a0282b16..000000000 --- a/_sources/wiki/GuidelinesForImplementingNewRegionModels.txt +++ /dev/null @@ -1,29 +0,0 @@ -#summary Developers notes for the implementation of a new RegionModel -#labels Phase-Implementation - -= Introduction = - -After reading GuidelinesForImplementingNewModels, this should provide additional information specific to implementing a new RegionModel. - -= Details = - -In addition to inheriting from the main dynamic loading base class `Model`, all RegionModel models also inherit from `Communicator`. - -A RegionModel's primary functions are to - * contain a set of institutions that operate in this region - * define a set of allowed facilities for those institutions - * Schedule the deployment of facilities by either - 1. Determining when new facilities need to be built, or - 2. deferring to an InstModel to make this determination. - * Manage the deployment of facilities by interacting with the Institutions to select a specific facility type and facility parameters - * Passing material offers/requests between a prescribed market and related facilities. - -All RegionModel models have an STL `set` of pointers to the `Model` instances that represent the allowed FacilityModel facilities. and an STL `vector` of pointers to the `Model` instances that represent the contained InstModel institutions. - -All RegionModel models may also implement a reciveMessage function if messages need to be amended by the region before being sent up to the market or down to the institution. This is a virtual (but not pure virtual) function, so implementation is optional. Default behavior is to ignore the message. - -RegionModel models are sent a tick and tock signal at the beginning and end of each month, respectively. Monthly tasks, such as facility deployment or bookkeeping should be undertaken within the handleTick and handleTock functions. These are virtual (but not pure virtual), so implementation of these functions is optional. - -= To Do = - -RegionModel models should be the mechanism for implementing demand growth. Different implementations of RegionModel models might implement different ways to model that growth. (Or is this all pre-processing?) diff --git a/_sources/wiki/InstallingDependenciesOnUnix.txt b/_sources/wiki/InstallingDependenciesOnUnix.txt deleted file mode 100644 index d96f5cec2..000000000 --- a/_sources/wiki/InstallingDependenciesOnUnix.txt +++ /dev/null @@ -1,40 +0,0 @@ -#summary Information on how to install some of the Cyclus dependencies - -== Overview == - -This page will provide a short walk-through of some of the non-standard installation requirements for *Cyclus* dependencies. *Cyclus* strives to be a modularly designed code that allows dynamic loading of modules at run time; therefore, dependencies must be built as shared object libraries instead of static libraries. This is done through the use of the -fPIC (position independent code) flag when building the required dependencies. For your edification, [http://tldp.org/HOWTO/Program-Library-HOWTO/shared-libraries.html this website] has a good review of shared libraries in general. - -== Some Quick Notes of Great Import == - - # The following procedures will NOT work correctly if you have already acquired Lapack, BLAS, or Trilinos via Ubuntu's Synaptic Package Manager. - * It is highly reccommended that you remove these libraries via Synaptic before reinstalling them in the following manner. - # It is highly reccommended (specifically for novice users) that you install these libraries in /usr/local - # Be very careful when using Teuchos. They have made the design decision to include definitions in their header files (due to heavy use of templates). Such header files can only be included in one location in the *Cyclus* source code. - -== Lapack == - -Lapack can be installed on your Unix machine using the following steps: - - # Download Lapack from its [http://www.netlib.org/lapack/ website] and untar it in a preferred location - # Make a build directory (e.g. one can place the source code in .../lapack/lapack-xx.yy.zz-Source and make the directory .../lapack/build) - # Copy the configure_lapack script located in the *Cyclus* repository located in /trunk/dependencies/lapack and place it in your build folder - # Change the configure script so that the last line points to your lapack source (e.g. .../lapack/lapack-xx.yy.zz-Source) - * Note, by default the script will install the library at /usr/local. - # Run the script (by typing ./configure_lapack.sh). Note that you may need to alter the script's permissions. To do so you can type "chmod 775 configure_lapack.sh". - # From the build directory, type "make" (or "make -jN" where N is the number of threads you want to use [this speeds up the process]) - # From the build directory, type "make install" - -Note that the making process can take some time. It is suggested that you make with the -j flag. - -== Teuchos == - -*Cyclus* uses the [http://trilinos.sandia.gov/packages/teuchos/ Teuchos] package of [http://trilinos.sandia.gov/ Trilinos]. Teuchos can be installed on your Unix machine using the following steps: - - # Download Trilinos from its [http://trilinos.sandia.gov/ website] and untar it in a preferred location - # Make a build directory (e.g. one can place the source code in .../trilinos/trilinos-xx.yy.zz-Source and make the directory .../trilinos/build) - # Copy the configure_trilinos script located in the *Cyclus* repository located in /svn/dependencies/trilinos and place it in your build folder - # Change the configure script so that the last line points to your trilinos source (e.g. .../trilinos/trilinos-xx.yy.zz-Source) - * Note, by default the script will install the library at /usr/local. - # Run the script (by typing ./configure_trilinos.sh). Note that you may need to alter the script's permissions. To do so you can type "chmod 775 configure_trilinos.sh". - # From the build directory, type "make" (or "make -jN" where N is the number of threads you want to use [this speeds up the process]) - # From the build directory, type "make install" \ No newline at end of file diff --git a/_sources/wiki/InstallingDependenciesOnWindows.txt b/_sources/wiki/InstallingDependenciesOnWindows.txt deleted file mode 100644 index eb2243e66..000000000 --- a/_sources/wiki/InstallingDependenciesOnWindows.txt +++ /dev/null @@ -1,84 +0,0 @@ -#summary Information on how to install some of the Cyclus dependencies - -== Overview == - -This page will provide a short walk-through of some of the installation requirements for *Cyclus* dependencies on a Windows platform. *Cyclus* strives to be a modularly designed code that allows dynamic loading of modules at run time; therefore, most dependencies must be built as shared object libraries instead of static libraries. - -== Cygwin == - -Cygwin is a terminal program that simulates a linux-like environment on Windows platforms. To install [http://cygwin.com Cygwin] you will need to download a setup file and run it according to the instructions at the [http://cygwin.com/install.html Cygwin Install Page]. - -Specifically, the Cygwin installation manager will walk through the installation process. - - # Select Install From Internet. - # Choose a directory to install cygwin. - # Choose a download mirror near you. - # Choose packages to install - * If you have two free gigabytes on your computer, the package configuration process can be simplified by choosing to download all packages. This will require clicking INSTALL the icon next to ALL. - * If space is restricted, you may be more selective about packages. When selecting packages, choose the default action for ALL packages. Then, search for and select install for specific packages that cyclus and its dependencies rely on : svn, gcc, g++, g77, cmake, make, lapack, libxml2, libidn. - # This will take some time to install - # When installed, check that these were installed correctly by using the 'which' command. A path will be returned if the package is found. If not, rerun Cygwin's setup.exe and install just the packages that are not found. - * To check for svn, open a Cygwin terminal and type 'which svn'. - * To check for gcc, open a Cygwin terminal and type 'which gcc' - * etc. - -== Boost == - -Cyclus depends on boost. You may install boost at [http://www.boost.org their website]. . -It is recommenced that Windows users use the boost installer executable rather than unpacking the binaries manually or building from source. So, download the installer. - - # When the installer asks what packages to install, be certain to include - * the program_options library - * the IOStream libraries - * and the date_time library - * in addition to the default header libraries. - # If you have surplus space on your computer, don't hesitate to install all of the libraries available, but be prepared for the installation to take up to an hour for all packages. - # The installer will ask what variants of the boost libraries to install. Be certain to install a dynamic and a static library. Threading is up to you. - -== HDF5 == - -HDF5 is a hierarchical database library that Cyclus uses for record keeping. To install HDF5 on Windows : - - # Go to the hdf5 website. - # Download the appropriate precompiled Windows binaries. - # Extract the full directory structure somewhere temporary. - # Move the contents of the resulting /bin directory to /usr/local/bin , or another preferred bin directory in your $PATH . - # Move the contents of the /lib directory to /usr/local/lib (or elsewhere in your $PATH). - # So too with the contents of the include directory, move them to /usr/local/include (or elsewhere). - # This can optionally be repeated with the share directory as well. - -Make sure the location you placed the binary files is in your $PATH environment variable. Finally, add an environment variable that states $HDF5_ROOT = /usr/local/lib (or your favorite other location). - -== Teuchos == - -Download the Trilinos source code to some location such as ~/trilinos_source . - -If CMake fails to find your c, cxx, or fortran compilers, double check that these are in your path. You may also inform CMake of your default compilers with environment variables that CMake pays attention to. To set the C compiler, for example, you would set the $CC environmet variable to /usr/bin/gcc-3 . - - -`` -cd ~/trilinos_source -cd ../ -mkdir trilinos_build -cd trilinos_bild -cmake-gui ../trilinos_source -`` - -From the gui (or via commandline flags, if you prefer), set the following advanced configuration flags for the Trilinos build : - - * BUILD_SHARED_LIBS=ON - * CMAKE_INSTALL_PREFIX=/usr/local/ (or elsewhere) - * Trilinos_ENABLE_TEUCHOS=ON - * BLAS_LIBRARY_DIRS=/usr/lib - * LAPACK_LIBRARY_DIRS=/usr/lib - * BLAS_LIBRARY_NAMES="blas" - * LAPACK_LIBRARY_NAMES="lapack" - -Finally, configure and generate the make file (in the gui, these are buttons). In the terminal type make, then type make install. - - - -== Cyclus == - -You're now ready to build cyclus. Onward to GettingAndBuildingCyclus. - diff --git a/_sources/wiki/IntegrationTests.txt b/_sources/wiki/IntegrationTests.txt deleted file mode 100644 index 8390ec39d..000000000 --- a/_sources/wiki/IntegrationTests.txt +++ /dev/null @@ -1,8 +0,0 @@ -#summary Guidelines for Cyclus Integration Tests - -== Known Input Files == - -== Python Script == - - - diff --git a/_sources/wiki/MilestoneGenRepo.txt b/_sources/wiki/MilestoneGenRepo.txt deleted file mode 100644 index 972900f3d..000000000 --- a/_sources/wiki/MilestoneGenRepo.txt +++ /dev/null @@ -1,313 +0,0 @@ -#summary Defining the capabilities to be demonstrated during Milestone-GenRepo -#labels Phase-Requirements - -= Introduction = - -This is a milestone for Cyclus development led by -[https://code.google.com/u/katyhuff/ Katy Huff]. It seeks to generate a generic -geology disposal system model appropriate for fuel cycle analysis. - -*Target Date: 12/2012* - -= Details = - -This development activity happens in four major phases and will be -presented as a PhD thesis from the University of Wisconsin - Madison upon -completion. - -Test problems will help comprehensively define and confirm each unit of the -module's functionality. In general, tests will include very basic calculation checks, -information passing tests, and more complex multiple subcomponent integration tests. Every -unit of functionality within the model will be tested as an integral part of development. - -When these unit tests pass, validation efforts will take place which show that the -complete model behaves in agreement with the more detailed model on which it was based. Some -simplification of the analytical model will occur based on both component level and system -level abstraction. If it does not behave as expected, sensitivity analyses, model -abstraction, and computational development will be iterated through until the model is -validated. - -Additional information on this work can be found in a -[http://homepages.cae.wisc.edu/~khuff/papers/prelim.pdf preliminary report]. - ----- - -= Phase I : Demonstration of Empty Infrastructure = - -This phase will generate an infrastructure for module loading and information -passing between subcomponents. It will demonstrate the interchangeability of pieces of -the repository and the calculation strategy that will later facilitate radionuclide -transport and heat transport required for capacity limited loading. - -*Target Date : 12/2011* - -== Phase Ia : GenericRepository Loading == - -Initial code development on the base case model has begun with creation of the -FacilityModel subclass, GenericRepository. This phase is intended to guarantee -that the subclass meets the requirements defined by the Cyclus FacilityModel -interface and can be dynamically loaded by the simulator. - -This requires a comprehensive definition of the interface between the -GenericRepository model and the rest of the Cyclus simulation. Fundamentally, -this entails fully formed send and receive material functions as well as a -function for making requests. - -A first phase in the demonstration milestone will be for the repository model -to successfully load its subcomponent models from user input (i.e. the waste -form, waste package, buffer, and lithology) with their corresponding defining -parameters. This will require a directory structure, empty component model -classes, a loading schema for components, and an interface between the -GenericRepository model and the Cyclus simulation. - -== Phase Ib : Interfaces For Each Component Model == - -A second phase will involve implementing an information exchange paradigm -between the subcomponents. This will build upon empty component models which can -be loaded via xml and will incoporate component loading according specific -instructions dictating the repository design and will implement a consistent -set of interal interfaces between components. - -The purpose of this information passing scheme will be to communicate sufficient -temperature fluxes and contaminant concentrations at the boundaries of the control -volumes for neighboring subcomponents to solve their internal transport calculations. - -When these aspects are implemented, a structure for the output database will be -defined and appropriate bookkeeping will be implemented sufficient to communicate -the heat and solute transport evolution within the repository. - -The component model class interfaces will be defined with care. -For example, the mixed cell model will need dimensions, solid mass, -degradation rate, etc. Apropriate input parameters for each component will be -defined as well. For example, the buffer will need to have a number of waste -packages within it. - - -== Phase I : Feature Requirements == - -This will build on the capabilities of MilestoneNullSimulation and -MilestoneOneInpro by adding : - * a GenericRepository facility class - * which can be loaded via xml - * according to specifications about subcomponents and models - * and interfaces smoothly with the Cyclus simulator - -This will require : - * a directory structure for component models - * definition of the GenericRepository interface with Cyclus - * definition of the base input parameters for loading - * a loading schema for GenericRepository model - * a component interface class - * a stub (empty) component model class - * empty component model classes for known future models - * loading schema for component models - * an internal interface between components - * input scheme for design specification - * definition of the output data structure - * generation of requests based on arbitrary capacity, for now - * a skeletal calculation timeline - -== Phase I : Tests == - -Test problems will help comprehensively define and confirm each unit of the -demonstration functionality. For this stage, tests will include very basic information -passing tests as well as more complex multiple subcomponent integration tests. Every -unit of functionality within the model will be tested as an integral part of development. - -=== Null Test === - -A null test of the demonstration case, for example, will release a single contaminant -radionuclide through each subcomponent sequentially. This test will pass if the bookkeeper -properly writes to the database its (aphysically unhindered) path through each control volume. - -=== Database Writing Test === - -The database writing test will determine whether an appropriate data table for the -repository facility is placed in the bookkeeper. - -=== Subcomponent Loading Test === - -Will determine whether all subcomponents were loaded properly. - -=== Subcomponent Interaction Tests === - -These tests will determine whether the subcomponents interact properly. - ----- - -= Phase II : Component Level Base Case Development= - - - -*Target Date: 6/2012* - -== Phase II : == - -== Phase IIa : MixedCell Component Model == - -Analytical Implementation. -Abstraction. - -== Phase IIb : OneDimPPM Component Model == - -Analytical Implementation. -Abstraction. - -== Phase IIc : TwoDimPPM Component Model == - -Analytical Implementation. -Abstraction. - -== Phase IId : ThreeDimPPM Component Model == - -Analytical Implementation. -Abstraction. - -== Phase IIe : LumpedRadNuc Component Model == - -Analytical Implementation. -Abstraction. - -== Phase IIf : LumpedHeat Component Model == - -Analytical Implementation. -Abstraction. - -== Phase II : Feature Requirements == - -This will build on the capabilities in Phase II by adding : - * Fleshed out models for a series of models of nuclide and heat transport - -== Phase II : Tests == - -Each component will be tested individually for computational accuracy. - ----- -= Phase III : System Level Base Case Development = - -== Phase IIIa : Data Collection and Validation == - - - -== Phase IIIb : System Level Abstraction == - -Analytical Implementation. -Abstraction. - -== Phase III : Feature Requirements === - -This will build on the capabilities in Phase II by adding : - * A comprehensive notion of the effect of each module on the total simulation - -== Phase II : Tests == - -All components will be tested in an integrated way for computational accuracy. - - - ----- - -= Phase IV : Extensions = - -*Target Date: 11/2012* - -== Phase IVa : Heat and Time Driven Coalescent Behavior == - -An anticipated extension will adapt the radionuclide transport model to -incorporate the effects of heat and time driven coalescent behavior in clay and salt. -This extension will focus on the porosity decrease in those media as time and heat -drive collapse around the waste packages. Time dependent coalescence will be addressed -fir, followed by temperature dependent coalescence. - -== Phase IVb : Dual Continuum Fracture Model == - -Next, the capability to model fracture features of granite and borehole environments -will be added to the modeling capability by adding a dual continuum fracture mode - -== Phase IVc : Intrusion Scenario or Fast Pathway == - -A final potential extension may be implemented that will address the issue of modeling -a disruption scenario with a fast advective pathway that intersects the repository. -A fast pathway model intended to demonstrate a disrupted scenario is modeled as a single -intersecting fracture in the clay matrix. - - ----- - -== Summary of Cyclus Readiness == - -The readiness level of cyclus capabilities with respect to the various phases -is summarized below. Capabilities are rated from 0 (no one has given significant -thought to this feature) to 10 (completely ready). - -|| *Phase 1* || *Phase 1* || *Phase 1* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Empty GenericRepository || 10 || issue63 || -|| Basic rng schema || 10 || issue64, r372 || -|| Subcomponent rng schema || 10 || issue65, || -|| Directory structure || 10 || issue66, r372 || -|| Component Interface class || 10 || issue67, r394, r395, 400 || -|| StubComponent class || 10 || issue68, r407 || -|| Process Logic || 5 || issue69, r426 || -|| Design spec. input schema || 1 || issue72, due 10/25 || -|| Database Table || 1 || issue73, due 10/30 || -|| Calculation Timeline || 1 || issue74, due 11/15 || -|| Empty MixedCell Class || 2 || issue75, due 11/20 || -|| Empty OneDimPPM Class || 2 || issue76, due 11/20 || -|| Empty TwoDimPPM Class || 2 || issue77, due 11/20 || -|| Empty ThreeDimPPM Class || 2 || issue78, due 11/20 || -|| Empty LumpedRadNuc Class || 2 || issue79, due 11/20 || -|| Empty LumpedHeat Class || 2 || issue80, due 11/20 || -|| Empty MixedCell Tests || 2 || issue81, due 11/25 || -|| Empty OneDimPPM Tests || 2 || issue82, due 11/25 || -|| Empty TwoDimPPM Tests || 2 || issue83, due 11/25 || -|| Empty ThreeDimPPM Tests || 2 || issue84, due 11/25 || -|| Empty LumpedRadNuc Tests || 2 || issue85, due 11/25 || -|| Empty LumpedHeat Tests || 2 || issue86, due 11/25 || -|| *Phase 2* || *Phase 2* || *Phase 2* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Phase 1 capabilities || || || -|| MixedCell Driving Tests || || || -|| MixedCell Abstraction || || || -|| MixedCell Implementation || || || -|| OneDimPPM Driving Tests || || || -|| OneDimPPM Abstraction || || || -|| OneDimPPM Implementation || || || -|| TwoDimPPM Driving Tests || || || -|| TwoDimPPM Abstraction || || || -|| TwoDimPPM Implementation || || || -|| ThreeDimPPM Driving Tests || || || -|| ThreeDimPPM Abstraction || || || -|| ThreeDimPPM Implementation || || || -|| LumpedRadNuc Driving Tests || || || -|| LumpedRadNuc Abstraction || || || -|| LumpedRadNuc Implementation|| || || -|| LumpedHeat Driving Tests || || || -|| LumpedHeat Abstraction || || || -|| LumpedHeat Implementation || || || -|| || || || -|| || || || -|| || || || -|| *Phase 3* || *Phase 3* || *Phase 3* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Phase 2 capabilities || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| *Phase 4* || *Phase 4* || *Phase 4* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Phase 3 capabilities || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || -|| || || || - diff --git a/_sources/wiki/MilestoneNullSimulation.txt b/_sources/wiki/MilestoneNullSimulation.txt deleted file mode 100644 index bab96fe59..000000000 --- a/_sources/wiki/MilestoneNullSimulation.txt +++ /dev/null @@ -1,43 +0,0 @@ -#summary Defining the capabilities to be demonstrated at Milestone NullSimulation -#labels Phase-Design,Phase-Requirements - -= Introduction = - -This is the first milestone for Cyclus development - -*Target Date: 2010.08.01* - -= Definition = - -The simplest possible simulation definition in Cyclus has a single SourceFacility trading in a NullMarket with a single SinkFacility. Each of the facilities will be owned by a FixedInst institution in a NullRegion region. - -Other simulations that must be supported by this milestone: - * SourceFacility -> NullMarket -> 2 x SinkFacility - * 2 x SourceFacility -> NullMarket -> SinkFacility - * 2 x SourceFacility -> NullMarket -> 2 x SinkFacility - * SourceFacility -> NullMarket A -> NullFacility -> NullMarket B -> SinkFacility - * SourceFacility -> NullMarket A -> 2 x NullFacility -> NullMarket B -> SinkFacility - -All of these models should be defined to give interesting and different results for the different cases described here. (issue 6) - -= Implementation = -A first round of test`*`.xml simulations supported by this milestone is in the null folder. - - -|| *File* || *Simulation* || -|| test1.xml || SourceFacility -> GreedyMarket -> SinkFacility || -|| test2.xml || SourceFacility -> GreedyMarket -> 2 x SinkFacility || -|| test3.xml || 2 x SourceFacility -> GreedyMarket -> SinkFacility || -|| test4.xml || 2 x SourceFacility -> GreedyMarket -> 2 x SinkFacility || -|| test5.xml || SourceFacility -> GreedyMarket A -> NullFacility -> GreedyMarket B -> SinkFacility || -|| test6.xml || SourceFacility -> GreedyMarket A -> 2 x NullFacility -> GreedyMarket B -> SinkFacility || -|| test1null.xml || SourceFacility -> NullMarket -> SinkFacility || -|| test2null.xml || SourceFacility -> NullMarket -> 2 x SinkFacility || -|| test3null.xml || 2 x SourceFacility -> NullMarket -> SinkFacility || -|| test4null.xml || 2 x SourceFacility -> NullMarket -> 2 x SinkFacility || -|| test5null.xml || SourceFacility -> NullMarket A -> NullFacility -> NullMarket B -> SinkFacility || -|| test6null.xml || SourceFacility -> NullMarket A -> 2 x NullFacility -> NullMarket B -> SinkFacility || - - -= Output Format = -Some output format must be defined for this milestone too, in order to parametrically tests input variation of these simulations. diff --git a/_sources/wiki/MilestoneOneInpro.txt b/_sources/wiki/MilestoneOneInpro.txt deleted file mode 100644 index 215f4c570..000000000 --- a/_sources/wiki/MilestoneOneInpro.txt +++ /dev/null @@ -1,20 +0,0 @@ -#summary Defining the capabilities to be demonstrated at Milestone INPRO_01 -#labels Phase-Requirements - -= Introduction = - -This is an early milestone for Cyclus development based on a simple once-through INPRO study. - -*Target Date: 8/31/2010* - -= Details = - -This will build on the capabilities of MilestoneNullSimulation by adding: - * EnrichmentFacility Model - * DeployInst Model (or DeploymentRegion Model) - * support for Decay in the Material class - * RecipeReactorFacility Model - -There will also need to be some output methods/formatting and minor post-processing. - -The INPRO cases are not freely available, but Paul Wilson can be contacted for details. diff --git a/_sources/wiki/MilestoneTwoNWTRB.txt b/_sources/wiki/MilestoneTwoNWTRB.txt deleted file mode 100644 index 45c30deb9..000000000 --- a/_sources/wiki/MilestoneTwoNWTRB.txt +++ /dev/null @@ -1,305 +0,0 @@ -#summary Defining the capabilities to be demonstrated during Milestone-NWTRB -#labels Phase-Requirements - -= Introduction = - -This is an early milestone for Cyclus development based on a set of Nuclear -Waste Technical Review Board scenario definitions and desired output measures. - -*Target Date: 5/16/2011* - -= Details = - -This benchmarking and demonstration activity happens in four phases and will be -presented at the NWTRB systems analysis workshop in June 2011. Details of -scenario descriptions and assumptions may be found in the file : - * !Scenarios_Final_04April2011.PDF - ----- - -= Phase I : Characteristics of Spent Fuel Inventory as of December 2009 = - -*Target Date : 4/11/2011* - -== Assumptions == - -Details of power plant characteristics and spent fuel inventories as of -December 2009 are provided internally to workshop participants in: - * !ExistingPlantData_06March2011.pdf - -== Phase I : Output Measures == - - # Total mass of spent fuel in Jan 2010 - # Total mass of ( 234, 235, 236, and 238 ) U in SNF in Jan 2010 Total mass - # of ( 238, 239, and 240 ) Pu in SNF in Jan 2010 - # Mass of FPs and MAs(Np, Am, Cm, Bk, Cf, Es, Fm) in SNF in Jan 2010 - -== Phase I : Cyclus Simulation Description == - -This will be a 1 month simulation, finding the spent fuel streams in January -2010 resulting from the state of domestic spent fuel streams in December 2009. -Reactors will be implemented as recipe based models. Storage facilities associated -with each reactor will contain current amounts of spent fuel. The only commodities will -be fresh and spent BWR and PWR assemblies. - -== Phase I : Feature Requirements == - -This will build on the capabilities of MilestoneNullSimulation and -MilestoneOneInpro by adding: - * a facility catalog of facility models representing the domestic reactor - fleet as of December 2009. - * a material catalog of fresh and spent BWR and PWR assemblies - * an in/out database system capable of keeping sufficient data about - transactions to give output measures. - * a bookkeeping system that records material changes and transactions into - the in/out database - * a storage facility capable of being instantiated with an initial quantity - of material - * Recipes : PWR I and BWR I ----- - -= Phase II : Spent Fuel Discharged Through 2100 = -*Target Date : 4/18/2011* - -== Phase II : Assumptions == - -Plants operate beginning on January 1 of the year of commercial operation and -all plants operatre for 60 years. - -Deployment is driven by maintenance of current fleet 100.3GWe . - - -== Phase II : Output Measures == - - # BWR assemblies discharged - # PWR assemblies discharged - # Total mass of ( 234, 235, 236, and 238 ) U in SNF during simulation - # Total mass of ( 238, 239, and 240 ) Pu in SNF during simulation - # Mass of FPs and MAs(Np, Am, Cm, Bk, Cf, Es, Fm) in SNF during simulation - -== Phase II : Cyclus Simulation Description == - -This will be a 1081 month (90 years + 1 month) simulation. The start time is -December 2009, the end time is January 1, 2100. Fresh and spent PWR and BWR -assemblies are the only four commodities. While there is no official -repository, a sink facility (or one for each reactor) should represent spent -fuel storage on site. - -== Phase II : Feature Requirements == - - -This will build on the capabilities in Phase I by adding : - * A facility model with finite lifetime (for 60 year shutdown). - * A region or institution capable of maintaining fleet power capacity as - reactors shut down. (!DemandDrivenDeployRegion ?) - * Institutions must report the power capacity of all reactors they own - * Reactors must record a timeline of their own power production - * Recipes : PWR II and BWR II - ----- - -= Phase III : Impact of Repository Disposal = - -*Target Date: 4/25/2011* - -== Phase III : Assumptions == - -*Repository* begins in 2040. Repository takes >10 year old fuel, and oldest -fuel first. Two scenarios: - * 1,500 MT/year repository capacity - * 3,000 MT/year repository capacity - - - -== Phase III : Output Measures == - - # BWR assemblies discharged - # PWR assemblies discharged - # natural uranium demand (for use in phase IV) - -== Phase III : Cyclus Simulation Description == - -This will be a 1081 month (90 years + 1 month) simulation. The start time is -December 2009, the end time is January 1, 2100. Fresh and spent PWR and BWR -assemblies are the only four commodities. Recipe-based reactor facilities and -capacity-limited sink facility to represent the repository. - -== Phase III : Feature Requirements == - -This will build on the capabilities in Phase II by adding : - * Tracking of assembly age. - * A market capable of handling competing spent fuel and new uranium as well - as material ages - ----- - -= Phase IV : Impact of Reprocessing and Repository Disposal = - -*Target Date: 5/16/2011* - -== Phase IV : Assumptions == - -This is a steady state scenario. The reprocessing capacity is enough to consume -all used fuel. - -Reprocessing takes >2 year old fuel, youngest first. Only single pass PWR fuel -will be reprocessed. The rest is stored immediately. PWR MOX is fabricated. -Re-enrichment is also undertaken to make PWR UOX. - -There is a steady state scenario: - * All plants are steady state, no new or replacement plants starting up - * Separating/Re-Enriching facility is at full capacity (sufficient?) - * MOX fuel fab and reUOX have sufficient capacity to recycle all separated - pu and u, respectively. - -There are six complexified scenarios : - # Separating/Re-Enriching capacity of 1,500MT/yr and all fuel 5 yrs old - # Separating/Re-Enriching capacity of 1,500MT/yr and all fuel 25 yrs old - # Separating/Re-Enriching capacity of 1,500MT/yr and all fuel 50 yrs old - # Separating/Re-Enriching capacity of 1,300MT/yr and all fuel 5 yrs old - # Separating/Re-Enriching capacity of 1,300MT/yr and all fuel 25 yrs old - # Separating/Re-Enriching capacity of 1,300MT/yr and all fuel 50 yrs old - - -== Phase IV : Output Measures == - - # Mass of PWR SNF Mass of BWR SNF Mass of FPs and MAs(Np, Am, Cm, Bk, Cf, - Es, Fm) in SNF in Jan 2010 - # Mass of PWR SNF reprocessed Mass of BWR SNF reprocessed - # Number, mass, and composition of assemblies fabricated - * new uranium PWR assemblies - * new uranium BWR assemblies - * recycled uranium PWR assemblies - * PWR MOX assemblies - # Mass of uranium tails generated - * new - * recycled - - -== Phase IV : Cyclus Simulation Description == - -This will be a 1081 month (90 years + 1 month) simulation. The start time is -December 2009, the end time is January 1, 2100. Fresh and spent PWR and BWR -assemblies are the only four commodities. Two infinite source facilities, -recipe-based reactor facilities and capacity limited sink facility must be -implemented. Markets capable of dealing with reprocessed fuel streams, -separations, MOX fabrication, re-enrichment, and enrichment facility models -must also be used. - -== Phase IV : Feature Requirements == - -This will build on the capabilities in Phase III by adding : - - - * Separations Facility - * Reprocessing Facility - * Appropriate markets for reprocessed fuel streams - * re-enrichment facility. Same as enrichment facility? - - ----- - -= Phase V : Impact of Reprocessing and Repository Disposal = - -*Target Date: 5/18/2011* - -== Phase V : Assumptions == - -*Reprocessing* begins in 2030. Two scenarios : - * 1,500 MT/year repository capacity - * 3,000 MT/year repository capacity - -Reprocessing takes >5 year old fuel, youngest first. Only single pass PWR fuel -will be reprocessed and all of it will be reprocessed eventually. The rest is -stored immediately. PWR MOX is fabricated. Re-enrichment is also undertaken -to make PWR UOX. - -*Repository* begins in 2040 at 1,500 MT/year repository capacity. Repository -accepts only >10 year old fuel, and oldest fuel first. - - -== Phase V : Output Measures == - - # Total mass of PWR spent fuel in repository - # Total mass of BWR spent fuel in repository - # Mass of FPs and MAs(Np, Am, Cm, Bk, Cf, Es, Fm) in SNF - # Mass of PWR SNF reprocessed Mass of BWR SNF reprocessed - # Percent reduction in total natural U demand - # Number, mass, and composition of assemblies fabricated - * new uranium PWR assemblies - * new uranium BWR assemblies - * recycled uranium PWR assemblies - * PWR MOX assemblies - # Mass of uranium tails generated - * new - * recycled - - -== Phase V : Cyclus Simulation Description == - -This will be a 1081 month (90 years + 1 month) simulation. The start time is -December 2009, the end time is January 1, 2100. Fresh and spent PWR and BWR -assemblies are the only four commodities. Two infinite source facilities, -recipe-based reactor facilities and capacity limited sink facility must be -implemented. Markets capable of dealing with reprocessed fuel streams, separations, MOX fabrication, -re-enrichment, and enrichment facility models must also be used. - -== Phase V : Feature Requirements == - -This will build on the capabilities in Phase IV by adding : - - * Appropriate markets for competing fresh and reprocessed fuel streams - - -== Summary of Cyclus Readiness == - -The readiness level of cyclus capabilities with respect to the various phases -is summarized below. Capabilities are rated from 0 (no one has given significant thought to this feature) to 10 (completely ready). - -|| *Phase 1* || *Phase 1* || *Phase 1* || -|| *Model or Capability* || *Readiness* || *Details* || -|| GreedyMarket || 10 || source material being 'infinite,' greedy market is an appropriate choice. || -|| NullRegion || 10 || This simulation is just for a month, so a deployregion isn't necessary, but would be superior.. || -|| FixedInst || 10 || the fixed inst is ready, perhaps until we go with the deployregion || -|| SourceFacility || 10 || The fuel fabrication facility is a simple source. || -|| ReceipeReactor || 8 || The recipe reactor needs a notion of its lifetime and capacity. || -|| SinkFacility || 10 || The material is actually stored at the reactors, but reported as a single amount. || -|| Facility Catalog || 10 || Roy is in charge. This includes all facilities to be included in the simulation.|| -|| Facility lifetimes || 0 || This should be a default behavior for all facilities. Not yet implemented. || -|| Recipes || 3 || Roy is working on this via scale/origen. || -|| Database || 8 || Transactions and Model tables are working. A material history table is left. || -|| PWR I || || PWR assemblies have initial uranium mass of 0.43 MTU, initial 235U enrichment of 3.43% and a burn-up of 39 GWd/MT. || -|| BWR I || || BWR assemblies have initial uranium mass of 0.18 MTU, initial 235U enrichment of 2.39% and a burn-up of 32 GWd/MT. || -|| *Phase 2* || *Phase 2* || *Phase 2* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Phase 1 capabilities || || || -|| GreedyMarket || 10 || When the source materal ceases to be infinite, this may no be the best choice || -|| DeployRegion || 9 || Perhaps not on critical path. May need to use capacity info to maintain capacity of 100.3 GWe|| -|| SourceFacility || 10 || The fuel fabrication facility is a simple source. || -|| StorageFacility (s) || 9 || Deifining this according to its relationship with reactors may be tricky, but is perhaps unnecessary. || -|| Capacity Factors || 0 || This may need to be a default behavior for all facilities. Enums may be necessary. || -|| Recipes || 3 || Roy is working on this via scale/origen. || -|| PWR II || || PWR assemblies with initial 235U enrichment of 4.4% and a burn-up of 55 GWd/MT. || -|| BWR II || || BWR assemblies with initial 235U enrichment of 4.35% and a burn-up of 55 GWd/MT. || -|| Decay Capability || 10 || There may be some issues with binning "other" isotopes. || -|| *Phase 3* || *Phase 3* || *Phase 3* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Phase 2 capabilities || || || -|| StorageFacility (s) || 9 || The material should actually just be stored at the reactors until 2040. Sink Facilities won't do. || -|| SinkFacility (repo) || 10 || The material starts to be sent to a repo facility from the storage facilities in 2040. || -|| *Phase 4* || *Phase 4* || *Phase 4* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Phase 3 capabilities || || || -|| SmartMarket || ? || A market needs to be able to handle competition between spent fuel and new uranium. || -|| ReEnrichmentFacility || 9 || While an EnrichmentFacility exists, it must be modified to do re-enrichment including impurities. || -|| SepMatrixFacility || 5 || Roy is in charge. This will need to separate plutonium from PWR II spent assemblies. || -|| ReprocessingFacility I || 0 || PWR MOX will mix fresh U tails (235U assay 0.2%) with spent Pu (max Pu content of 14%).|| -|| ReprocessingFacility II || 0 || PWR UOX from re-enriched spent U (any enrichment necessary for criticality) || -|| Recipes || 3 || Roy is working on this via scale/origen. || -|| PWR MOX || || made from spent PWRII, mixes fresh U tails (235U assay 0.2%) with spent Pu (max Pu content of 14%).|| -|| PWR UOX || || PWR UOX will be re-enriched spent U (any enrichment necessary for criticality) || -|| STEADY STATE || 0-10? || The request is to do a "steady state" calculation. Can we require the absence of transients? || -|| *Phase 5* || *Phase 5* || *Phase 5* || -|| *Model or Capability* || *Readiness* || *Details* || -|| Phase 4 || || This simulation is a repeat of phase 4, but dynamic, and includes a repository. || - diff --git a/_sources/wiki/MilestoneZero.txt b/_sources/wiki/MilestoneZero.txt deleted file mode 100644 index 74d7d0b6f..000000000 --- a/_sources/wiki/MilestoneZero.txt +++ /dev/null @@ -1,20 +0,0 @@ -#summary This wiki page documents progress on the first milestone. - -== Design material object data structure and creation = - -The material object is the main data object passed between black box facilities. An object structure is a necessary part of the interface between facilities. - -I like most of the functionality that Kyle set up in the Material class for GENIUS, so for this cyclus deadline, I'm going to mostly exactly replicate it. However, I have been working on aleviating one main area of concern, which has two main consequences. - - * The enumeration of commodities is not extensible. - * In the event that a user would like to invent a new link in the fuel cycle chain, he'll have to break the modularity of the code in order to introduce it, since enums cannot be written to once they are initialized. - * I am working on retooling this into some sort of more polymorphic enum-like structure (e.g. a map or a list) that allows reading and writing while continuing to allow some of the case switching that a lot of the rest of the code functions upon. - * GENIUS occaisionally uses a material constructor that can generate a material object by naming the type of commodity it is. This relies on specific case switching over commodities in the material class and is an inextensible quality of the code. It is not possible to reformulate this without breaking the encapsulation that cyclus is striving for. - -== Design region & institution data structures == - -The structure of the region and institution hierarchy should not deviate heavily from the GENIUS method, but may require modification in order to reference the runtime-generated map of facility and commodity types available for deployment. That is, since deployment of facilities may rely on these region and institution structures, the type maps may need to be available to the region/institution interfaces. TBD. - -== Design message passing infrastructure == - -For facilities to offer, request, recieve and send material, a message passing infrastructure must be created. This will likely be similar to the message passing infrastructure in GENIUS, but may require modification in order to reference the runtime-generated map of facility and commodity types. \ No newline at end of file diff --git a/_sources/wiki/OutputDatabase.txt b/_sources/wiki/OutputDatabase.txt deleted file mode 100644 index 44182d99c..000000000 --- a/_sources/wiki/OutputDatabase.txt +++ /dev/null @@ -1,125 +0,0 @@ -#summary Design Goals for the Output Database - -*Cyclus* simulations are comprised of three major constructs (the interaction of which we are interested in documenting). In *Cyclus*, *_Agents_* create *_Resources_* and then trade these resources via *_Transactions_*. Accordingly, the output database is nominally divided into three catagories: Agents, Resources, and Transactions. The *Cyclus* database has been designed with three key concepts in mind: we wish for *Cyclus* to be extensible, i.e. we do not want to hinder the development of a new module, we wish for the output data structures to be as straight-forward as possible to reduce hindrince of post-processing, and we wish for the database to be efficient. With these three goals in mind, we have developed a the database structure that sacrifices some amount of size (i.e., there are multiple entries per table which could be consolidated) in order to allow for greater flexibility and readability (i.e. natural intuition of where to look for a given data object). In this database paradigm, for example, an external developer has the ability to create a new agent type, and retrieve any information he/she wishes with regard to output. The database structure does not stunt a developer's ability or creativity. - -=Provenance= - -Good provenance will be provided by an output database with sufficient data to allow reproducibility of the results. This robust reproducibility is essential to the scientific effort. In the case of *Cyclus*, the inclusion of a complete notion of the input specifications in the output database will be sufficient to allow for result reproduction as well as facilitate knowledge sharing, post-simulation analysis and error-checking. Such input specifications include a complete description of the simulation parameters and model configurations defined in the input. - -=Database Structure= - -As previously mentioned, *Cyclus* deals in three basic constructs: agents, resources, and transactions. A transaction in *Cyclus* is relatively static, i.e. every transaction has the same basic information (for example: who is the sender, who is the receiever, what was transacted, etc.). Conversely, agents and resources are highly variable. We therefore allow for each /implementation/ of an agent (e.g. a Facility Agent) and each /type/ of resource (e.g. a Material) to have both *_Static_* and *_Dynamic_* tables associated with them. As will be outlined in detail below, the output database structure of a *Cyclus* simulation will have, in general, the following heirarchichal structure: - */output/agents - */output/agents/implementation/staticParams - */output/agents/implementation/variableParams - */output/resources - */output/resources/type/staticParams - */output/resources/type/variableParams - */output/transactions - -Accordingly, there are currently seven primary tables in the *Cyclus* output database: - * an [OutputDatabase#Agent_Description_Table agent description table] - * an [OutputDatabase#Agent_Static_State_Parameter_Table agent static parameter table] - * an [OutputDatabase#Agent_Variable_State_Parameter_Table agent dynamic parameter table] - * a [OutputDatabase#Resource_Description_Table resource description table] - * a [OutputDatabase#Resource_Static_State_Parameter_Table resource static parameter table] - * a [OutputDatabase#Resource_Variable_State_Parameter_Table resource dynamic parameter table] - * a [OutputDatabase#Transaction_Description_Table transaction description table] - -=Agent Description Table= - -This table contains the generic information of each agent and information regarding its time of creation and deletion. The table parameters are the following: - * the agent's unique ID - * the agent's parent's unique ID - * the agent's type (e.g., Region, Institution, Market, etc.) - * the agent's implementation (e.g., !SourceFacility, !NullRegion, !GreedyMarket, etc.) - * a timestamp of the agent's birth - * a timestamp of the agent's death - -Note that there is one entry for each unique agent. - -As an example, let us assume that a agent X of type is owned by an agent Y and is created at time t1. Agent X has type T and implementation I and ends its service at time t2. The table entry is as follows: - -|| Agent ID || Parent ID || Type || Implementation || Birth || Death || -|| X || Y || T || I || t1 || t2 || - -=Agent Static State Parameter Table= - -This table contains information about specific instances of agents that *_do not change_* with time. This table is unique to each different *_implementation_* of agent. For instance, a Reactor may have the following class hierarchy: Agent -> Facility -> Reactor. Accordingly, there will be a data entry for the Reactor in each table, with the reactor-specific information placed in the Reactor table. There are some tables which are associated with the *Cyclus* core, and thus will have an immutable form at each release (e.g. Regions, Institutions, Facilities, Markets). It is the responsibility of each developer to guarantee that their module output corresponds to this hierarchical structure if it is to be included in a *Cyclus* release. - -Let us take the !SourceFacility as it currently exists in *Cyclus*. It has, nominally, three static members: its monthly production capacity, its total inventory size, and its output commodity. For this example, let us assume that !SourceFacility X has a maximum production capacity of Y kg/month of commodity C and has a maximum inventory size of Z kg. Its static state parameter table, located at /output/agents/!SourceFacility/staticParams would therefore look like the following: - -|| Agent ID || Commodity || Capacity || Capacity Units || Inventory || Inventory Units || -|| X || C || Y || kg/month || Z || kg || - -=Agent Variable State Parameter Table= - -This table is similar to the static parameter table described above, containing information about specific instances of agents that *_do change_* with time. This table is unique to each different *_implementation_* of agent. For instance, a Reactor may have the following class hierarchy: Agent -> Facility -> Reactor. Accordingly, there will be a data entry for the Reactor in each table, with the reactor-specific information placed in the Reactor table. There are some tables which are associated with the *Cyclus* core, and thus will have an immutable form at each release (e.g. Regions, Institutions, Facilities, Markets). It is the responsibility of each developer to guarantee that their module output corresponds to this hierarchical structure if it is to be included in a *Cyclus* release. - -Let us continue with the above example. An optional parameter for the !SourceFacility is the capacity factor, i.e. the percentage of maximum capacity Y is the facility able to operate at some time t. For this example, let us assume that at time t1, !SourceFacility X begins operation with capacity factor 0.95 and must go down for maintenence at time t2, reducing its capacity factor to 0.00. Its variable state parameter table, located at /output/agents/!SourceFacility/variableParams would therefore look like the following: - -|| Agent ID || Capacity Factor || CF Units || Time || -|| X || 0.95 || decimal % || t1 || -|| X || 0.00 || decimal % || t2 || - -Note that there may be multiple entries per agent in this table. - -Additionally note that the timestamping works in the following manner: if the timestamp is equal to the agent's birth time stamp, then this is the first occurance of the variable parameter; if it is not, then one may assume that the parameter did not change during the period between two timestamps. - -=Resource Description Table= - -This table contains the generic information of each resource and information regarding its time of creation and deletion. The table parameters are the following: - * the resource's unique ID - * the resource's creating agent's unique ID - * the resource's type (material, man-hours, etc.) - * the resource's base unit (kg, hours, etc.) - * a timestamp of the resource's birth - * a timestamp of the resoruce's death (i.e., when it is consumed, etc.) - -For example, let us assume that facility with unique ID X, creates a resource of type T at time t1 whose unique ID is Y, in addition, let us assume that the base unit type is kilograms. Finally, let us assume that the resource is eventually consumed by a chemical process (e.g., used-fuel being reprocessed) at time t2. The table entry for this resource is as follows: - -|| Resource ID || Creating Agent || Type || Unit || Birth || Death || -|| R || X || T || kg || t1 || t2 || - -=Resource Static State Parameter Table= - -This table contains information about specific instances of resources that *_do not change_* with time. This table is unique to each different *_implementation_* of a resource. For instance, UO,,2,, may have the following class hierarchy: Resource -> Material -> UO2. Accordingly, there will be a data entry for the UO,,2,, in each table, with the UO,,2,,-specific information placed in the UO2 table. There are some tables which are associated with the *Cyclus* core, and thus will have an immutable form at each release (e.g. Material). It is the responsibility of each developer to guarantee that their module output corresponds to this hierarchical structure if it is to be included in a *Cyclus* release. - -Let us use the Material class as an example. The static table for the material resource is relatively straight-forward (most of the work is done by the dynamic table). As a convention in *Cyclus*, we do not allow Materials to change form (in order for a Material to change form, the original resource must be destroyed and a new resource created). Let us assume that some material resource with ID R (and type Material) has the form uo2. - -|| Resource ID || Form || -|| R || UO,,2,, || - -=Resource Variable State Parameter Table= - -This table contains information about specific instances of resources that *_do change_* with time. This table is unique to each different *_implementation_* of a resource. For instance, UO,,2,, may have the following class hierarchy: Resource -> Material -> UO2. Accordingly, there will be a data entry for the UO,,2,, in each table, with the UO,,2,,-specific information placed in the UO2 table. There are some tables which are associated with the *Cyclus* core, and thus will have an immutable form at each release (e.g. Material). It is the responsibility of each developer to guarantee that their module output corresponds to this hierarchical structure if it is to be included in a *Cyclus* release. - -We choose to provide the following example. Suppose some facility receives N kilograms of Used UO,,2,, at time t1 /and/ that Used UO,,2,, has the ability to decay, i.e. it is radioactive. Consider the following two scenarios: - # sufficient time has passed to take into account the decay of the Used UO,,2,, - # an amount, n, of the Used UO,,2,, is traded to another agent - -For simplicity, we assume that used UO,,2,, is comprised of only ^16^O and ^235^U. The decay isotopics are meaningless and only meant to be a qualitative example. - -|| Resource ID || Mass || Isotopics || Composition || Composition Units || Timestamp || -|| R || N || 8016, 92235 || 0.33, 0.67 || atomic || t1 || -|| R || N || 8016, 92235 || 0.34, 0.66 || atomic || t2 || -|| R || N - n || 8016, 92235 || 0.34, 0.66 || atomic || t3 || - -Note that there may be multiple entries per agent in this table. - -=Transaction Description Table= - -This table contains the generic information of each transaction. The table parameters are the following: - * the transaction's unique ID - * the sending agent's unique ID - * the receiving agent's unique ID - * the resource being transacted - * the price for the transaction (assumed going from receiver to sender) - * the timestamp of the transaction - -For example, let us assume agent X sends resource R to agent Y at time t for price P, and the transactions unique ID is U. The table entry, at /output/transactions/, would be as follows: - -|| Transaction ID || Sender || Receiver || Resource || Price || Timestamp || -|| U || X || Y || R || P || t || - -Note that it is assumed that the amount is in the resource's base unit. \ No newline at end of file diff --git a/_sources/wiki/ProgramFlowAndDataStructureOverview.txt b/_sources/wiki/ProgramFlowAndDataStructureOverview.txt deleted file mode 100644 index 01658b41a..000000000 --- a/_sources/wiki/ProgramFlowAndDataStructureOverview.txt +++ /dev/null @@ -1,75 +0,0 @@ -#summary Describe & Design Program Flow and Data Structures - -= Program Flow Overview = - - # Read input - # Setup model - # Start time steps - * Tick: collect offers/requests - * Market resolution - * Tock: distribute material objects - -== Problem Setup == - - # Load markets based on market models - # for each market - # check whether the model for this market has been loaded already, and load if necessary - # instantiate new market and initialize parameters - # Assign commodities to markets - # Load facilities based on facility models - # for each facility - # check whether the model for this facility has been loaded already, and load if necessary - # instantiate a template for a new facility based on input parameters - # assign commodities to facilities and cross-reference with markets - # add template to facility template map - # Load regions based on region models - # for each region - # check whether the model for this region has been loaded already, and load if necessary - # instantiate new region and initialize parameters - # create list of available facility templates for that region - # Load simulation parameters - -== Facility Deployment == - -When and how does facility deployment happen, based on the list of facility templates? - -== Tick == - - # cycle through Regions - # cycle through Institutions - # deploy new facilities as necessary - # cycle through facilities - # update facility state as appropriate - # prompt for requests/offers - -== Market Resolution == - - * convert sets of requests/offers into sets of material transactions - -== Tock == - - # cycle through Markets - # cycle through transactions - # preform material transactions - # update facility state as appropriate - -= Data Structure Overview = - -== Abstract Base Classes == - -=== Communicator === - -Provides all functionality for message passing among facilities and markets, including offers/requests and transactions. - -=== Facility === - -Provides base definition of facility and standard interface. All derived classes must implement this interface cleanly so that they can operate as plug-in modules. - -=== Market === - -Provides base definition of a market and standard interface. All derived classes must implement this interface cleanly so that they can operate as plug-in modules. - -=== Region === - -Provides base definition of a region and standard interface. All derived classes must implement this interface cleanly so that they can operate as plug-in modules. - diff --git a/_sources/wiki/UserDocumentation.txt b/_sources/wiki/UserDocumentation.txt deleted file mode 100644 index 833fa3138..000000000 --- a/_sources/wiki/UserDocumentation.txt +++ /dev/null @@ -1,16 +0,0 @@ -#summary Documentation for Cyclus Users -#labels Phase-Implementation - -Documentation to assist with the use of *Cyclus* will be maintained in a variety of forms. - -== Installation == - -An instruction manual for GettingAndBuildingCyclus is available on this wiki. Questions having to do with this process may be directed to [https://code.google.com/u/katyhuff/ Katy Huff]. - -== Model Definitions == - -Instance descriptions and parameter definitions for models available to *Cyclus* simulations are made available on this wiki and can be browsed from the TableOfContents to the left of this text. As new Models and Utility functions are defined, wiki pages will be added to describe them. - -== Doxygen Code Documentation == - -The definitive documentation of any software is the source code itself. *Cyclus* relies on Doxygen for automation of rich documentation from appropriately formatted comments in the source code. Current Doxygen documentation can be found at http://cnerg.engr.wisc.edu/cyclus/docs/ This page is automatically updated nightly. \ No newline at end of file diff --git a/_sources/wiki/main.txt b/_sources/wiki/main.txt deleted file mode 100644 index 75b053546..000000000 --- a/_sources/wiki/main.txt +++ /dev/null @@ -1,34 +0,0 @@ - -Wiki Contents: - -.. toctree:: - :maxdepth: 2 - - CyclusIntroduction - CyclusStyleGuidelines - Decay - -.. stuff not converted yet - - GettingAndBuildingCyclus - ProgramFlowAndDataStructureOverview - OutputDatabase - UserDocumentation - DevelopersDocumentation - - - these are within developer doc - - * [CyclusStyleGuidelines Style Guidelines] - * [GuidelinesForImplementingNewModels Guidelines for New Models] - * [GuidelinesForImplementingNewFacilityModels Facility] - * [GuidelinesForImplementingNewInstModels Inst] - * [GuidelinesForImplementingNewRegionModels Region] - * [GuidelinesForImplementingNewMarketModels Market] - - * Milestones - * [MilestoneZero Basic Functionality] - * [MilestoneNullSimulation 0: Null Simulation] - * [MilestoneOneInpro 1: Inpro Simulation] - * [MilestoneTwoNWTRB 2: NWTRB Simulations] - * [MilestoneGenRepo 3: Generic Repository] diff --git a/_static/default.css b/_static/default.css deleted file mode 100644 index 21f3f5098..000000000 --- a/_static/default.css +++ /dev/null @@ -1,256 +0,0 @@ -/* - * default.css_t - * ~~~~~~~~~~~~~ - * - * Sphinx stylesheet -- default theme. - * - * :copyright: Copyright 2007-2011 by the Sphinx team, see AUTHORS. - * :license: BSD, see LICENSE for details. - * - */ - -@import url("basic.css"); - -/* -- page layout ----------------------------------------------------------- */ - -body { - font-family: sans-serif; - font-size: 100%; - background-color: #11303d; - color: #000; - margin: 0; - padding: 0; -} - -div.document { - background-color: #1c4e63; -} - -div.documentwrapper { - float: left; - width: 100%; -} - -div.bodywrapper { - margin: 0 0 0 230px; -} - -div.body { - background-color: #ffffff; - color: #000000; - padding: 0 20px 30px 20px; -} - -div.footer { - color: #ffffff; - width: 100%; - padding: 9px 0 9px 0; - text-align: center; - font-size: 75%; -} - -div.footer a { - color: #ffffff; - text-decoration: underline; -} - -div.related { - background-color: #133f52; - line-height: 30px; - color: #ffffff; -} - -div.related a { - color: #ffffff; -} - -div.sphinxsidebar { -} - -div.sphinxsidebar h3 { - font-family: 'Trebuchet MS', sans-serif; - color: #ffffff; - font-size: 1.4em; - font-weight: normal; - margin: 0; - padding: 0; -} - -div.sphinxsidebar h3 a { - color: #ffffff; -} - -div.sphinxsidebar h4 { - font-family: 'Trebuchet MS', sans-serif; - color: #ffffff; - font-size: 1.3em; - font-weight: normal; - margin: 5px 0 0 0; - padding: 0; -} - -div.sphinxsidebar p { - color: #ffffff; -} - -div.sphinxsidebar p.topless { - margin: 5px 10px 10px 10px; -} - -div.sphinxsidebar ul { - margin: 10px; - padding: 0; - color: #ffffff; -} - -div.sphinxsidebar a { - color: #98dbcc; -} - -div.sphinxsidebar input { - border: 1px solid #98dbcc; - font-family: sans-serif; - font-size: 1em; -} - - - -/* -- hyperlink styles ------------------------------------------------------ */ - -a { - color: #355f7c; - text-decoration: none; -} - -a:visited { - color: #355f7c; - text-decoration: none; -} - -a:hover { - text-decoration: underline; -} - - - -/* -- body styles ----------------------------------------------------------- */ - -div.body h1, -div.body h2, -div.body h3, -div.body h4, -div.body h5, -div.body h6 { - font-family: 'Trebuchet MS', sans-serif; - background-color: #f2f2f2; - font-weight: normal; - color: #20435c; - border-bottom: 1px solid #ccc; - margin: 20px -20px 10px -20px; - padding: 3px 0 3px 10px; -} - -div.body h1 { margin-top: 0; font-size: 200%; } -div.body h2 { font-size: 160%; } -div.body h3 { font-size: 140%; } -div.body h4 { font-size: 120%; } -div.body h5 { font-size: 110%; } -div.body h6 { font-size: 100%; } - -a.headerlink { - color: #c60f0f; - font-size: 0.8em; - padding: 0 4px 0 4px; - text-decoration: none; -} - -a.headerlink:hover { - background-color: #c60f0f; - color: white; -} - -div.body p, div.body dd, div.body li { - text-align: justify; - line-height: 130%; -} - -div.admonition p.admonition-title + p { - display: inline; -} - -div.admonition p { - margin-bottom: 5px; -} - -div.admonition pre { - margin-bottom: 5px; -} - -div.admonition ul, div.admonition ol { - margin-bottom: 5px; -} - -div.note { - background-color: #eee; - border: 1px solid #ccc; -} - -div.seealso { - background-color: #ffc; - border: 1px solid #ff6; -} - -div.topic { - background-color: #eee; -} - -div.warning { - background-color: #ffe4e4; - border: 1px solid #f66; -} - -p.admonition-title { - display: inline; -} - -p.admonition-title:after { - content: ":"; -} - -pre { - padding: 5px; - background-color: #eeffcc; - color: #333333; - line-height: 120%; - border: 1px solid #ac9; - border-left: none; - border-right: none; -} - -tt { - background-color: #ecf0f3; - padding: 0 1px 0 1px; - font-size: 0.95em; -} - -th { - background-color: #ede; -} - -.warning tt { - background: #efc2c2; -} - -.note tt { - background: #d6d6d6; -} - -.viewcode-back { - font-family: sans-serif; -} - -div.viewcode-block:target { - background-color: #f4debf; - border-top: 1px solid #ac9; - border-bottom: 1px solid #ac9; -} \ No newline at end of file diff --git a/_static/logo.png b/_static/logo.png deleted file mode 100644 index a1227cbc432a9f996f5365b847fea4c6be3f688b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3916 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 aIru-Y&3HI+zc7IS0000