2008-02-03 11:28:36 +01:00
/*
2010-04-14 15:03:41 +02:00
* Copyright ( C ) 2006 - 2010 Dynare Team
2008-02-03 11:28:36 +01:00
*
* This file is part of Dynare .
*
* Dynare is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* Dynare is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with Dynare . If not , see < http : //www.gnu.org/licenses/>.
*/
# ifndef _STATEMENT_HH
# define _STATEMENT_HH
using namespace std ;
# include <ostream>
# include <string>
# include <map>
2008-04-07 15:14:40 +02:00
# include "SymbolList.hh"
2008-02-03 11:28:36 +01:00
class ModFileStructure
{
public :
ModFileStructure ( ) ;
//! Wheter check is present
bool check_present ;
2010-01-08 12:06:25 +01:00
//! Wheter steady is present
bool steady_present ;
2008-02-03 11:28:36 +01:00
//! Whether a simul statement is present
bool simul_present ;
2008-09-29 12:16:13 +02:00
//! Whether a stoch_simul statement is present
bool stoch_simul_present ;
//! Whether an estimation statement is present
bool estimation_present ;
//! Whether an osr statement is present
bool osr_present ;
//! Whether a ramsey_policy statement is present
bool ramsey_policy_present ;
2009-10-20 18:17:27 +02:00
//! The value of the "order" option of stoch_simul, estimation, osr, ramsey_policy
2008-04-24 12:55:26 +02:00
//! Derivation order
/*! First initialized to zero. If user sets order option somewhere in the MOD file, it will be equal to the maximum of order options. Otherwise will default to 2 */
2008-02-03 11:28:36 +01:00
int order_option ;
2009-11-26 18:25:04 +01:00
//! Whether a bvar_density, bvar_forecast, sbvar, ms_sbvar statement is present
bool bvar_present ;
2009-12-04 22:32:19 +01:00
//! Whether an svar_identification statement is present
bool svar_identification_present ;
2009-10-14 18:16:43 +02:00
//! Whether an identification statement is present or the identification option of dynare_sensitivity statement is equal to one
2009-04-20 15:58:15 +02:00
bool identification_present ;
2009-10-20 18:55:31 +02:00
//! Whether the option partial_information is given to stoch_simul/estimation/osr/ramsey_policy
bool partial_information ;
2009-10-29 18:16:10 +01:00
//! Whether a shocks or mshocks block is present
/*! Used for the workaround for trac ticket #35 */
bool shocks_present ;
2009-12-09 12:50:58 +01:00
//! Whether the "k_order_solver" option is used (explictly, or implicitly if order >= 3)
bool k_order_solver ;
2010-04-14 15:03:41 +02:00
//! Whether there is a calibrated measurement error
bool calibrated_measurement_errors ;
2008-02-03 11:28:36 +01:00
} ;
class Statement
{
public :
virtual ~ Statement ( ) ;
//! Do some internal check, and fill the ModFileStructure class
virtual void checkPass ( ModFileStructure & mod_file_struct ) ;
virtual void computingPass ( ) ;
2009-03-24 17:29:58 +01:00
//! Write Matlab output code
2008-02-03 11:28:36 +01:00
/*!
\ param output is the output stream of the main matlab file
\ param basename is the name of the modfile ( without extension ) which can be used to build auxiliary files
*/
virtual void writeOutput ( ostream & output , const string & basename ) const = 0 ;
} ;
class NativeStatement : public Statement
{
private :
const string native_statement ;
public :
NativeStatement ( const string & native_statement_arg ) ;
virtual void writeOutput ( ostream & output , const string & basename ) const ;
} ;
class OptionsList
{
public :
typedef map < string , string > num_options_type ;
typedef map < string , pair < string , string > > paired_num_options_type ;
typedef map < string , string > string_options_type ;
2008-04-07 15:14:40 +02:00
typedef map < string , SymbolList > symbol_list_options_type ;
2009-12-10 23:49:50 +01:00
typedef map < string , vector < int > > vec_int_options_type ;
2008-02-03 11:28:36 +01:00
num_options_type num_options ;
paired_num_options_type paired_num_options ;
string_options_type string_options ;
2008-04-07 15:14:40 +02:00
symbol_list_options_type symbol_list_options ;
2009-12-10 23:49:50 +01:00
vec_int_options_type vector_int_options ;
2008-02-03 11:28:36 +01:00
void writeOutput ( ostream & output ) const ;
2008-04-05 12:52:58 +02:00
void writeOutput ( ostream & output , const string & option_group ) const ;
2008-02-03 11:28:36 +01:00
void clear ( ) ;
} ;
# endif // ! _STATEMENT_HH