Skip to content

vraj004/cellml_split_reaction_diffusion_equation

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

72 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CellML Split Reaction Diffusion Equation

This example solves the weak form of the one-dimensional reaction-diffusion equation using the Galerkin finite element method. The classical form of the governing partial differential eqiation (PDE) in three-dimension is given by,

3d_reaction_diffusion_equation

where u is a scalar dependent variable (e.g. concentration of a chemical species), conductivity_tensor is a rank-two diffusion tensor, R is the reaction term (function of the dependent variable u ) and x and t are spatial coordinates and time respectively.

The reaction term is obtained by solving the following ordinary differential equation (ODE).

rate_equation

where a is a constant. Here two different time steps are used for the time integration of PDE and ODE and this approach is known as the 'splitting' method.

Building the example

The fortran version of the example can be configured and built with CMake:

git clone https://github.com/OpenCMISS-Examples/cellml_split_reaction_diffusion_equation
mkdir cellml_split_reaction_diffusion_equation-build
cd cellml_split_reaction_diffusion_equation-build
cmake -DOpenCMISSLibs_DIR=/path/to/opencmisslib/install ../cellml_split_reaction_diffusion_equation
make

This will create the example executable "cellml_split_reaction_diffusion_equation" in ./src/fortran/ directory.

Running the example

Fortran version:

cd ./src/fortran/
./cellml_split_reaction_diffusion_equation

Verifying the example

Results can be visualised by running visualise.cmgui with the Cmgui visualiser.

The following figure shows the one-dimensional computational domain and solution of the primary variable, u .

figure1a  figure1b

Figure 1. (a) One-dimensional finite element mesh (b) Primary variable solution

The expected results from this example are available in expected_results folder.

Prerequisites

The ODE that determines the source/reaction term is solved using CellML and the ODE model is input via constant_rate.xml.

License

License applicable to this example is described in LICENSE.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Fortran 98.2%
  • CMake 1.8%