dynamic_abstract_class.hh 1.24 KB
Newer Older
1
/*
2
 * Copyright (C) 2010-2014 Dynare Team
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
 *
 * 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 _DYNAMICMODELAC_HH
#define _DYNAMICMODELAC_HH

#include "k_ord_dynare.hh"

class DynamicModelAC
{
public:
Sébastien Villemot's avatar
Sébastien Villemot committed
28
  virtual ~DynamicModelAC() = default;
29
  static void unpackSparseMatrixAndCopyIntoTwoDMatData(mxArray *sparseMat, TwoDMatrix *tdm);
30
  static void copyDoubleIntoTwoDMatData(double *dm, TwoDMatrix *tdm, int rows, int cols);
31
  virtual void eval(const Vector &y, const Vector &x, const Vector &params, const Vector &ySteady,
Sébastien Villemot's avatar
Sébastien Villemot committed
32
                    Vector &residual, TwoDMatrix *g1, TwoDMatrix *g2, TwoDMatrix *g3) noexcept(false) = 0;
33 34
};
#endif