83 if(connectivitySettings.
isEmpty()) {
84 qDebug() <<
"DirectedTransferFunction::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);
127 for(
int i = 0; i < nCh; ++i) {
128 for(
int j = 0; j < nCh; ++j) {
129 MatrixXd matWeight(iNFreqs, 1);
131 for(
int fi = 0; fi < iNFreqs; ++fi) {
133 double rowNorm = 0.0;
134 for(
int k = 0; k < nCh; ++k) {
135 rowNorm += std::norm(vecH[fi](i, k));
139 matWeight(fi, 0) = std::norm(vecH[fi](i, j)) / rowNorm;
141 matWeight(fi, 0) = 0.0;
145 QSharedPointer<NetworkEdge> pEdge =
146 QSharedPointer<NetworkEdge>(
new NetworkEdge(j, i, matWeight));
148 finalNetwork.
getNodeAt(j)->append(pEdge);
149 finalNetwork.
getNodeAt(i)->append(pEdge);
150 finalNetwork.
append(pEdge);