File: SchurDecomp.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 (69 lines) | stat: -rw-r--r-- 1,120 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
/* $Header: /var/lib/cvs/dynare_cpp/sylv/cc/SchurDecomp.h,v 1.1.1.1 2004/06/04 13:00:44 kamenik Exp $ */

/* Tag $Name:  $ */

#ifndef SCHUR_DECOMP_H
#define SCHUR_DECOMP_H

#include "SylvMatrix.h"
#include "QuasiTriangular.h"

class QuasiTriangular;
class SchurDecomp
{
  bool q_destroy;
  SqSylvMatrix *q;
  bool t_destroy;
  QuasiTriangular *t;
public:
  SchurDecomp(const SqSylvMatrix &m);
  SchurDecomp(const QuasiTriangular &tr);
  SchurDecomp(QuasiTriangular &tr);
  const SqSylvMatrix &
  getQ() const
  {
    return *q;
  }
  const QuasiTriangular &
  getT() const
  {
    return *t;
  }
  SqSylvMatrix &
  getQ()
  {
    return *q;
  }
  QuasiTriangular &
  getT()
  {
    return *t;
  }
  virtual int getDim() const;
  virtual
  ~SchurDecomp();
};

class SchurDecompZero : public SchurDecomp
{
  GeneralMatrix ru; /* right upper matrix */
public:
  SchurDecompZero(const GeneralMatrix &m);
  const GeneralMatrix &
  getRU() const
  {
    return ru;
  }
  int getDim() const;
  int
  getZeroCols() const
  {
    return ru.numRows();
  }
};

#endif /* SCHUR_DECOMP_H */

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