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

/* Tag $Name:  $ */

#ifndef ITERATIVE_SYLVESTER_H
#define ITERATIVE_SYLVESTER_H

#include "SylvesterSolver.h"
#include "KronVector.h"
#include "QuasiTriangular.h"
#include "SimilarityDecomp.h"

class IterativeSylvester : public SylvesterSolver
{
public:
  IterativeSylvester(const QuasiTriangular &k, const QuasiTriangular &f)
    : SylvesterSolver(k, f)
  {
  }
  IterativeSylvester(const SchurDecompZero &kdecomp, const SchurDecomp &fdecomp)
    : SylvesterSolver(kdecomp, fdecomp)
  {
  }
  IterativeSylvester(const SchurDecompZero &kdecomp, const SimilarityDecomp &fdecomp)
    : SylvesterSolver(kdecomp, fdecomp)
  {
  }
  void solve(SylvParams &pars, KronVector &x) const;
private:
  double performFirstStep(KronVector &x) const;
  static double performStep(const QuasiTriangular &k, const QuasiTriangular &f,
                            KronVector &x);
};

#endif /* ITERATIVE_SYLVESTER_H */

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