Skip to content
Snippets Groups Projects
Select Git revision
  • 1e40e0a8a1e1b0dbe97d4b91bc662e5ad545d3d4
  • master default protected
  • irf-matching-preprocessor-perfect-foresight
  • created_preprocessor_repo
4 results

DynareMain1.cc

Blame
  • Forked from Dynare / preprocessor
    2080 commits behind the upstream repository.
    • Houtan Bastani's avatar
      dff540df
      preprocessor: allow passing mod file as string. Closes #1509 · dff540df
      Houtan Bastani authored
      Usage: ./dynare_m $'<<mod file text>>'
      
      The $’’ expands special characters. This is necessary because our setup for native matlab statements require that they end with a newline. In other words, the rest of the mod file can be sent on one line, but if there is a native matlab statement you must enter a `\n` after it.
      
      NB: In this case, apostrophes must be escaped: ' becomes \'
      
      e.g., to run tests/example1.mod:
      ./dynare_m  $'//Example 1 from Collard\'s guide to Dynare\nvar y, c, k, a, h, b;varexo e, u;verbatim;% I want these comments included in\n% example1.m 1999q1 1999y\n%\nvar = 1;\nend;parameters beta, rho, alpha, delta, theta, psi, tau;alpha = 0.36;rho   = 0.95;tau   = 0.025;beta  = 0.99;delta = 0.025;psi   = 0;theta = 2.95;phi   = 0.1;\nmodel;c*theta*h^(1+psi)=(1-alpha)*y;k = beta*(((exp(b)*c)/(exp(b(+1))*c(+1)))*(exp(b(+1))*alpha*y(+1)+(1-delta)*k));y = exp(a)*(k(-1)^alpha)*(h^(1-alpha));k = exp(b)*(y-c)+(1-delta)*k(-1);a = rho*a(-1)+tau*b(-1) + e;b = tau*a(-1)+rho*b(-1) + u;end;initval;y = 1.08068253095672;c = 0.80359242014163;h = 0.29175631001732;k = 11.08360443260358;a = 0;b = 0;e = 0;u = 0;end;shocks;var e; stderr 0.009;var u; stderr 0.009;var e, u = phi*0.009*0.009;end; stoch_simul;'
      dff540df
      History
      preprocessor: allow passing mod file as string. Closes #1509
      Houtan Bastani authored
      Usage: ./dynare_m $'<<mod file text>>'
      
      The $’’ expands special characters. This is necessary because our setup for native matlab statements require that they end with a newline. In other words, the rest of the mod file can be sent on one line, but if there is a native matlab statement you must enter a `\n` after it.
      
      NB: In this case, apostrophes must be escaped: ' becomes \'
      
      e.g., to run tests/example1.mod:
      ./dynare_m  $'//Example 1 from Collard\'s guide to Dynare\nvar y, c, k, a, h, b;varexo e, u;verbatim;% I want these comments included in\n% example1.m 1999q1 1999y\n%\nvar = 1;\nend;parameters beta, rho, alpha, delta, theta, psi, tau;alpha = 0.36;rho   = 0.95;tau   = 0.025;beta  = 0.99;delta = 0.025;psi   = 0;theta = 2.95;phi   = 0.1;\nmodel;c*theta*h^(1+psi)=(1-alpha)*y;k = beta*(((exp(b)*c)/(exp(b(+1))*c(+1)))*(exp(b(+1))*alpha*y(+1)+(1-delta)*k));y = exp(a)*(k(-1)^alpha)*(h^(1-alpha));k = exp(b)*(y-c)+(1-delta)*k(-1);a = rho*a(-1)+tau*b(-1) + e;b = tau*a(-1)+rho*b(-1) + u;end;initval;y = 1.08068253095672;c = 0.80359242014163;h = 0.29175631001732;k = 11.08360443260358;a = 0;b = 0;e = 0;u = 0;end;shocks;var e; stderr 0.009;var u; stderr 0.009;var e, u = phi*0.009*0.009;end; stoch_simul;'
    DynareMain1.cc 1.53 KiB
    /*
     * Copyright (C) 2015 Dynare Team
     *
     * 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/>.
     */
    
    #include <sstream>
    #include <fstream>
    
    #include "macro/MacroDriver.hh"
    
    void
    main1(string &modfile, string &basename, string &modfiletxt, bool debug, bool save_macro, string &save_macro_file,
          bool no_line_macro, map<string, string> &defines, vector<string> &path, stringstream &macro_output)
    {
      // Do macro processing
      MacroDriver m;
    
      m.parse(modfile, modfiletxt, macro_output, debug, no_line_macro, defines, path);
      if (save_macro)
        {
          if (save_macro_file.empty())
            save_macro_file = basename + "-macroexp.mod";
          ofstream macro_output_file(save_macro_file.c_str());
          if (macro_output_file.fail())
            {
              cerr << "Cannot open " << save_macro_file << " for macro output" << endl;
              exit(EXIT_FAILURE);
            }
          macro_output_file << macro_output.str();
          macro_output_file.close();
        }
    }