Combustion Toolbox: An open-source thermochemical code for gas- and condensed-phase problems involving chemical equilibrium
Authors Alberto Cuadra, César Huete, Marcos Vera
Affiliations Departamento de Ingeniería Térmica y de Fluidos, Universidad Carlos III de Madrid, Spain
Corresponding author acuadra@ing.uc3m.es (A. Cuadra)
Website for online documentation https://combustion-toolbox-website.readthedocs.io/en/latest/
Repository for source code https://github.com/CombustionToolbox/combustion_toolbox
Note: This README file is written in Markdown. Please use a Markdown editor to visualize it properly. Otherwise, you can use the online version of this file.
MATLAB R2021a or higher is required to run the code using the GUI. Otherwise, use the standalone (royalte-free) version of the GUI.
The source code of the Combustion Toolbox (CT) contains the following folders and files in the main directory:
.combustion_toolbox
|-- +combustiontoolbox
|-- databases
|-- examples
|-- gui
|-- installer
|-- utils
|-- validations
|-- run_test.m
|-- CODE_OF_CONDUCT.md
|-- CONTENTS.m
|-- CONTRIBUTING.md
|-- CONTRIBUTORS.md
|-- INSTALL.m
|-- LICENSE.md
`-- README.md
The +combustiontoolbox
folder encapsulates the different modules (namespaces) implemented in CT, such as CT-EQUIL (+equilibrium), CT-SD (+shockdetonation), and CT-ROCKET (+rocket). The databases
folder mainly consists of raw data and .mat files that contain the thermochemical properties of the individual chemical species. The examples
folder includes various examples that demonstrate the wide variety of problems that can be solved with CT. The gui
folder contains the routines that are specifically designed for the GUI. The installer
folder contains all the installation files of the GUI: the MATLAB toolbox and the royalty-free stand-alone version for different operative systems. The utils
folder houses utility functions with different purposes. Finally, the validation
folder includes the routines used to validate CT with the results obtained with other codes, the unit testing files to ensure the correct functionality of the code, and all the graphs generated from these verifications.
Regarding the files in the main source folder, we have the following: the file run_test.m
runs the unit tests of CT. The file CONTENTS.m
is a script that briefly describes the problems that can be solved with CT. The file INSTALL.m
is a script that installs the CT code and the GUI. The file LICENSE.md
contains the license of CT (GNU General Public License v3.0). Finally, the file README.md
is the official description in the GitHub repository.
Additionally, we have included a sample
folder that contains two subfolders, input
and output
. The input
folder contains the input files for the examples described below in Sec. 3. The output
folder contains the expected figures to be obtained.
For an accurate description of each routine included in the code, please refer to the online documentation. For a detailed description of the output, please refer to the manuscript.
Lastly, if there is any question, unexpected behavior, or bug in the code, please use the add-on uifeedback (we do not collect any data from the sender, it can be totally anonymous, e.g., as email write @test.com). It can be started by writing in the prompt:
uifeedback()
Combustion Toolbox can be installed with the provided INSTALL.m
file. Here is how to install the toolbox:
- Navigate to the directory where the code is located.
- Run the
INSTALL.m
file using the following command in the MATLAB Command Window:
INSTALL()
- This will add the necessary folders to the MATLAB path and also install the Combustion Toolbox GUI.
For a more detailed description of the installation process, please refer to the online documentation.
As described in the manuscript, CT includes a wide variety of examples and validations in the examples
and validations
folders, respectively. In this section, we will describe how to run a simple using MATLAB's desktop environment and the GUI. Additionally, we will show how to run two of the validations carried out in the manuscript.
For this first case, we are going to perform a parametric study of the adiabatic isobaric combustion of acetylene and air at standard conditions (
Let's write the following code in the prompt (or run example_1.m
in the sample/input
folder):
% Import packages
import combustiontoolbox.databases.NasaDatabase
import combustiontoolbox.core.*
import combustiontoolbox.equilibrium.*
% Get Nasa database
DB = NasaDatabase();
% Define chemical system
system = ChemicalSystem(DB, 'soot formation extended');
% Initialize mixture
mix = Mixture(system);
% Define chemical state
set(mix, {'C2H2_acetylene'}, 'fuel', 1);
set(mix, {'N2', 'O2'}, 'oxidizer', [79, 21] / 21);
% Define properties
mixArray = setProperties(mix, 'T', 300, 'p', 1, 'equivalenceRatio', 0.5:0.01:4);
% Initialize solver
solver = EquilibriumSolver('problemType', 'HP');
% Solve problem
solver.solveArray(mixArray);
% Set displaySpecies
displaySpecies = {'CO2', 'CO', 'H2O', 'H2', 'O2', 'N2',...
'HCN','H','OH','O','CN','NH3','CH4','C2H4','CH3',...
'NO','HCO','NH2','NH','N','CH','Cbgrb'};
solver.plotConfig.displaySpecies = displaySpecies;
% Generate report
report(solver, mixArray);
This will show a summary of the thermodynamic properties and composition of the mixture in the MATLAB Command Window, and the following figures (the expected output is located in './sample/output/example_1' folder):
Figure 1. Variation of the molar fractions
Figure 2. Variation of different thermodynamic properties (from left to right): temperature,
Note: This parametric study should take at most 4-6 seconds.
The previous example can also be easly performed using the GUI. To do so, we need to run the GUI using the following command in the MATLAB
combustion_toolbox()
or running it directly from MATLAB's Apps tab.
Once the GUI is started, we should see something similar to the following window:
Figure 3. Example of how to configure the GUI to reproduce the results of Example 1.
As we can observe, the previous figure already includes the necessary inputs to perform the parametric study. The steps to complete the parametric analysis are the following:
- Go to the
Quick settings
sub-tab and check the item calledIdeal Air
. With this option, we consider that air is composed of 79% of N$_2$ and 21% of O$_2$ on molar basis. - Return to the
inputs
sub-tab and selectAcetylene + Air
as the reactant. - Select the list of possible species as products. In this case, we will select a predefined list of species called
Soot formation Extended
, which includes 94 species that typically appear in CHON reactions. - Define the parameter to be varied. In this case, we will vary the equivalence ratio
$\phi$ from 0.5 to 4 with a step of 0.05 (decreased to 0.01 for smoother plots). To specify a uniform grid distribution, writeXX:YY:ZZ
, whereXX
represents the start point,YY
the step size, andZZ
the final point. Thus, for this case we have to write0.5:0.01:4
. - Define the problem to be solved. In this case, we will solve the problem for an HP transformation called
HP: Adiabatic T and composition at constant P
. - Run the calculation by clicking the
Calculate
button. The default initial state of the mixture corresponds with the standard conditions ($T_1 = 300$ K,$p = 1$ bar).
Once the calculation is finished, the lamp located at the bottom of the window should turn green. The results can be visualized in the results
tab.
By clicking the sub-tab Parameters
and selecting the first case from the tree object, we should see the following:
Figure 4. Post-processing the results of Example 1
through the GUI (part I). In particular, the thermodynamic properties correspond to the case selected in the tree object (
By clicking the sub-tab Molar composition
we can observe the molar composition of the mixture (reactants and products):
Figure 5. Post-processing the results of Example 1
through the GUI (part II): In particular, the chemical composition corresponds to the case selected in the tree object (
Lastly, the GUI also allows us to visualize the results more interactively. To do so, we need to click the Custom Figures
sub-tab. Then by selecting the mixture to be plotted as the products (mix2), the equivalence ratio as the parameter to be varied in the x-axis (equivalenceRatio), and the temperature as the property to be plotted in the y-axis (T), we should obtain the following figure:
Figure 6. Post-processing the results of Example 1
through the GUI (part III).
This problem consists of a parametric study of a Si-C$_6$H$_5$OH mixture at atmospheric pressure (
Writing in the prompt:
run_validation_TP_CEA_6()
will show two predefined figures (the expected output is located in './sample/output/example_2' folder):
Figure 7. Variation of the molar fractions
Figure 8. Variation of different thermodynamic mixture properties (from left to right): density,
Note: This parametric study should take 5-7 seconds at most.
For this case, we will obtain the pressure ratio-deflection angle and the incidence angle-deflection angle shock polar diagrams for dry air (consisting of 78% N$_2$, 21% O$_2$, and 1% Ar) initially at room conditions (
Run the following script:
run_validation_SHOCK_POLAR_SDToolbox_2
which will show the following figures (the expected output is located in './sample/output/example_3' folder):
Figure 9. Pressure-deflection shock polar diagrams for air (78% N$_2$, 21% O$_2$, and 1% Ar) at pre-shock temperature
Figure 10. Wave angle-deflection ressure-deflection shock polar diagrams for air (78% N$_2$, 21% O$_2$, and 1% Ar) at pre-shock temperature
Figure 11. Post-shock velocity
Note: This parametric study should take 5-7 seconds at most.