dynare/dynare++/sylv/cc/KronUtils.cpp

54 lines
1.4 KiB
C++

/* $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);
}
}