File: GeneralSylvester.h

package info (click to toggle)
dynare 4.5.7-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 49,408 kB
  • sloc: cpp: 84,998; ansic: 29,058; pascal: 13,843; sh: 4,833; objc: 4,236; yacc: 3,622; makefile: 2,278; lex: 1,541; python: 236; lisp: 69; xml: 8
file content (82 lines) | stat: -rw-r--r-- 1,972 bytes parent folder | download
1
2
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/* $Header: /var/lib/cvs/dynare_cpp/sylv/cc/GeneralSylvester.h,v 1.1.1.1 2004/06/04 13:00:20 kamenik Exp $ */

/* Tag $Name:  $ */

#ifndef GENERAL_SYLVESTER_H
#define GENERAL_SYLVESTER_H

#include "SylvMatrix.h"
#include "SylvMemory.h"
#include "SimilarityDecomp.h"
#include "SylvesterSolver.h"

class GeneralSylvester
{
  SylvParams pars;
  SylvMemoryDriver mem_driver;
  int order;
  const SqSylvMatrix a;
  const SylvMatrix b;
  const SqSylvMatrix c;
  SylvMatrix d;
  bool solved;
  SchurDecompZero *bdecomp;
  SimilarityDecomp *cdecomp;
  SylvesterSolver *sylv;
public:
  /* construct with my copy of d*/
  GeneralSylvester(int ord, int n, int m, int zero_cols,
                   const double *da, const double *db,
                   const double *dc, const double *dd,
                   const SylvParams &ps);
  GeneralSylvester(int ord, int n, int m, int zero_cols,
                   const double *da, const double *db,
                   const double *dc, const double *dd,
                   bool alloc_for_check = false);
  /* construct with provided storage for d */
  GeneralSylvester(int ord, int n, int m, int zero_cols,
                   const double *da, const double *db,
                   const double *dc, double *dd,
                   bool alloc_for_check = false);
  GeneralSylvester(int ord, int n, int m, int zero_cols,
                   const double *da, const double *db,
                   const double *dc, double *dd,
                   const SylvParams &ps);
  virtual
  ~GeneralSylvester();
  int
  getM() const
  {
    return c.numRows();
  }
  int
  getN() const
  {
    return a.numRows();
  }
  const double *
  getResult() const
  {
    return d.base();
  }
  const SylvParams &
  getParams() const
  {
    return pars;
  }
  SylvParams &
  getParams()
  {
    return pars;
  }
  void solve();
  void check(const double *ds);
private:
  void init();
};

#endif /* GENERAL_SYLVESTER_H */

// Local Variables:
// mode:C++
// End: