ReactMiCP is a reactive transport simulator for variable porosity problem
SpecMiCP is a speciation solver
ReactMiCP is a reactive transport simulator for variable porosity problem
SpecMiCP is a speciation solver
Commit | Author | Details | Committed | ||||
---|---|---|---|---|---|---|---|
3e3001b7784a | georget | test:fix remove bad dependancy in io_hdf5_meshes | Nov 10 2017 | ||||
f915e6b208c1 | georget | build:fix YAML imported target for cmake < 3.7.0 | Nov 8 2017 | ||||
5f551f547deb | georget | docker: update docker files | Nov 7 2017 | ||||
d4fc19a685a4 | georget | test:fix move to Catch2 | Nov 7 2017 | ||||
ae89bd4c49f6 | georget | build:fix fix the fix for hdf5 | Nov 7 2017 | ||||
fcd46f4bbaa8 | georget | build:fix use correct hdf5 library path | Nov 1 2017 | ||||
cb0ab9a56b35 | georget | build:minor remove gcc7 warning with eigen includes | Nov 1 2017 | ||||
50d9a67908d3 | georget | build:fix PGO optimization | Oct 31 2017 | ||||
dee7f564bf24 | georget | fix: install specimcp_common/config.h header | Oct 31 2017 | ||||
45799c295e84 | georget | build:fix be sure to pass EIGEN3_UNSUPPORTED_FOUND definition | Oct 30 2017 | ||||
4fcb60e988fc | georget | dfpm:fix:minor correct typo | Oct 30 2017 | ||||
52bed7d1d852 | georget | Merge branch 'master' of bitbucket.org:specmicp/specmicp | Oct 29 2017 | ||||
3bbaea7497b8 | georget | build:feature add option to use lapacke in Eigen | Oct 29 2017 | ||||
c8b8d225dd2d | georget | build: fix yaml import target for cmake < 3.6 | Oct 27 2017 | ||||
921a58bdaf61 | georget | Some more comments | Oct 27 2017 |
SpecMiCP is a speciation solver to find the equilibrium state of a chemical system. The system is based on a mixed complementarity formulation of the equilibrium condition for minerals.
For a mineral with volume fraction Sm, the equilibrium condition is :
Sm >= 0, -log(IAPm/K) >= 0, -Sm*log(IAPm/K) = 0
where IAPm is the ion activity product and K the equilibrium constant. This condition is reformulated using the penalized Fischer-Burmeister C-function and the system is solved using a semismooth method.
ReactMiCP is a reactive transport solver built on top of specmicp. It uses the operator splitting approach to couple transport and chemistry.
SpecMiCP is not (yet) a program but a set of libraries that can be used to solve specific problems.
The following modules are already available :
The micpsolver and odeint modules can be use independantly.
Examples of use are provided in the examples directory.
To build and install SpecMiCP/ReactMiCP see the INSTALL file. To learn how to use the API the best is to look at the examples. The starting point should be the leaching in CO2-saturated examples : examples/reactmicp/saturated_react/carbonation.cpp. This file is heavily commented. Example of use of the Python interface can be found in the tests/cython directory.
A cmake module can be used to find SpecMiCP in your own project. It will be installed at
<prefix>/share/specmicp/cmake/FindSpecMiCP.cmake
The python module can be used directly if it is in your python path.
The API is documented with Doxygen and the documentation can be generated with the command :
make doc
A (maybe outdated) version of the doc can be found [here][3].
The code is in development and the API is not considered stable yet.
A python binding is available at the following address :
https://bitbucket.org/specmicp/specmicppy
SpecMiCP is developped by F. Georget (fabieng aT princeton DoT edu). It is part of my Ph.D. work. The purpose of the PhD is to develop a reactive transport model to model the coupling between hydration, drying and carbonation in cement paste.
This Ph.D. is funded by [Princeton university][6], [Lafarge][4] and the [CSTB][5].
References :
A list of the references used in the code can be found in the [documentation][7].
[2]: http://www.empa.ch/plugin/template/empa/*/62204/---/l=1
[3]: http://www.princeton.edu/~fabieng/specmicpdoc/index.html
[4]: http://www.lafarge.com/en
[5]: http://www.cstb.fr/
[6]: http://princeton.edu
[7]: http://www.princeton.edu/~fabieng/specmicpdoc/citelist.html