File: KronUtils.cpp

package info (click to toggle)
dynare 4.3.0-2
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 40,640 kB
  • sloc: fortran: 82,231; cpp: 72,734; ansic: 28,874; pascal: 13,241; sh: 4,300; objc: 3,281; yacc: 2,833; makefile: 1,288; lex: 1,162; python: 162; lisp: 54; xml: 8
file content (53 lines) | stat: -rw-r--r-- 1,458 bytes parent folder | download | duplicates (5)
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
/* $Header: /var/lib/cvs/dynare_cpp/sylv/cc/KronUtils.cpp,v 1.1.1.1 2004/06/04 13:00:31 kamenik Exp $ */

/* Tag $Name:  $ */

#include "KronUtils.h"

void KronUtils::multAtLevel(int level, const QuasiTriangular& t,
							KronVector& x)
{
	if (0 < level && level < x.getDepth()) {
		for (int i = 0; i < x.getM(); i++) {
			KronVector xi(x, i);
			multAtLevel(level, t, xi);
		}
	} else if (0 == level && 0 < x.getDepth()) {
		GeneralMatrix tmp(x.base(), x.getN(), power(x.getM(),x.getDepth()));
		t.multLeftOther(tmp);
	} else if (0 == level && 0 == x.getDepth()) {
		Vector b((const Vector&)x);
		t.multVec(x,b);
	} else { // 0 < level == depth
		t.multKron(x);
	}
}

void KronUtils::multAtLevelTrans(int level, const QuasiTriangular& t,
								 KronVector& x)
{
	if (0 < level && level < x.getDepth()) {
		for (int i = 0; i < x.getM(); i++) {
			KronVector xi(x, i);
			multAtLevelTrans(level, t, xi);
		}
	} else if (0 == level && 0 < x.getDepth()) {
		GeneralMatrix tmp(x.base(), x.getN(), power(x.getM(),x.getDepth()));
		t.multLeftOtherTrans(tmp);
	} else if (level == 0 && 0 == x.getDepth()) {
		Vector b((const Vector&)x);
		t.multVecTrans(x,b);
	} else { // 0 < level == depth
		t.multKronTrans(x);
	}
}

void KronUtils::multKron(const QuasiTriangular& f, const QuasiTriangular& k,
						 KronVector& x)
{
	multAtLevel(0, k, x);
	if (x.getDepth() > 0) {
		for (int level = 1; level <= x.getDepth(); level++)
			multAtLevelTrans(level, f, x);
	}
}