56 lines
1.4 KiB
C++
56 lines
1.4 KiB
C++
#ifndef _MOD_FILE_HH
|
|
#define _MOD_FILE_HH
|
|
|
|
using namespace std;
|
|
|
|
#include <ostream>
|
|
|
|
#include "SymbolTable.hh"
|
|
#include "NumericalConstants.hh"
|
|
#include "ModelTree.hh"
|
|
#include "VariableTable.hh"
|
|
#include "Statement.hh"
|
|
|
|
//! The abstract representation of a "mod" file
|
|
class ModFile
|
|
{
|
|
public:
|
|
ModFile();
|
|
~ModFile();
|
|
//! Symbol table
|
|
SymbolTable symbol_table;
|
|
//! Numerical constants table
|
|
NumericalConstants num_constants;
|
|
//! Expressions outside model block
|
|
DataTree expressions_tree;
|
|
//! Model equations and their derivatives
|
|
ModelTree model_tree;
|
|
//! Option linear
|
|
bool linear;
|
|
//! Global evaluation context
|
|
/*! Filled using initval blocks and parameters initializations */
|
|
eval_context_type global_eval_context;
|
|
|
|
private:
|
|
//! List of statements
|
|
vector<Statement *> statements;
|
|
//! Structure of the mod file
|
|
ModFileStructure mod_file_struct;
|
|
|
|
public:
|
|
//! Add a statement
|
|
void addStatement(Statement *st);
|
|
//! Do some checking and fills mod_file_struct
|
|
void checkPass();
|
|
//! Execute computations
|
|
void computingPass();
|
|
//! Writes Matlab/Scilab output files
|
|
/*!
|
|
\param basename The base name used for writing output files. Should be the name of the mod file without its extension
|
|
\param clear_all Should a "clear all" instruction be written to output ?
|
|
*/
|
|
void writeOutputFiles(const string &basename, bool clear_all) const;
|
|
};
|
|
|
|
#endif // ! MOD_FILE_HH
|