83 if(connectivitySettings.
isEmpty()) {
84 qDebug() <<
"GrangerCausality::calculate - Input data is empty";
91 const int nTrials = connectivitySettings.
size();
92 MatrixXd matDataAvg = connectivitySettings.
at(0).
matData;
93 for(
int t = 1; t < nTrials; ++t) {
94 matDataAvg += connectivitySettings.
at(t).
matData;
96 matDataAvg /=
static_cast<double>(nTrials);
98 const int nCh =
static_cast<int>(matDataAvg.rows());
99 const int iNfft = connectivitySettings.
getFFTSize();
100 const int iNFreqs =
static_cast<int>(std::floor(iNfft / 2.0)) + 1;
106 RowVectorXf rowVert = RowVectorXf::Zero(3);
107 for(
int i = 0; i < nCh; ++i) {
108 rowVert = RowVectorXf::Zero(3);
119 model.
fit(matDataAvg);
122 VectorXd vecFreqs = VectorXd::LinSpaced(iNFreqs, 0.0, 0.5);
125 MatrixXd matSigma = model.
noiseCov();
130 for(
int i = 0; i < nCh; ++i) {
131 for(
int j = 0; j < nCh; ++j) {
136 MatrixXd matWeight(iNFreqs, 1);
138 const double gammaIJ = matSigma(j, j) - (matSigma(i, j) * matSigma(i, j)) / matSigma(i, i);
140 for(
int fi = 0; fi < iNFreqs; ++fi) {
141 const double sII = vecS[fi](i, i).real();
142 const double hIJ2 = std::norm(vecH[fi](i, j));
143 const double denom = sII - gammaIJ * hIJ2;
145 if(denom > 0.0 && sII > 0.0) {
146 matWeight(fi, 0) = std::log(sII / denom);
148 matWeight(fi, 0) = 0.0;
152 QSharedPointer<NetworkEdge> pEdge =
153 QSharedPointer<NetworkEdge>(
new NetworkEdge(j, i, matWeight));
155 finalNetwork.
getNodeAt(j)->append(pEdge);
156 finalNetwork.
getNodeAt(i)->append(pEdge);
157 finalNetwork.
append(pEdge);