93 if(connectivitySettings.
isEmpty()) {
94 qDebug() <<
"DebiasedSquaredWeightedPhaseLagIndex::calculate - Input data is empty";
104 #ifdef EIGEN_FFTW_DEFAULT
105 fftw_make_planner_thread_safe();
109 int rows = connectivitySettings.
at(0).
matData.rows();
110 RowVectorXf rowVert = RowVectorXf::Zero(3);
112 for(
int i = 0; i < rows; ++i) {
113 rowVert = RowVectorXf::Zero(3);
125 int iSignalLength = connectivitySettings.
at(0).
matData.cols();
126 int iNfft = connectivitySettings.
getFFTSize();
132 int iNRows = connectivitySettings.
at(0).
matData.rows();
133 int iNFreqs = int(floor(iNfft / 2.0)) + 1;
141 qDebug() <<
"DebiasedSquaredWeightedPhaseLagIndex::calculate - Resetting to full spectrum";
169 QFuture<void> result = QtConcurrent::map(connectivitySettings.
getTrialData(),
171 result.waitForFinished();
191 QVector<QPair<int,MatrixXcd> >& vecPairCsdSum,
192 QVector<QPair<int,MatrixXd> >& vecPairCsdImagAbsSum,
193 QVector<QPair<int,MatrixXd> >& vecPairCsdImagSqrdSum,
198 const QPair<MatrixXd, VectorXd>& tapers)
212 RowVectorXd vecInputFFT, rowData;
213 RowVectorXcd vecTmpFreq;
215 MatrixXcd matTapSpectrum(tapers.first.rows(), iNFreqs);
218 fft.SetFlag(fft.HalfSpectrum);
220 for (i = 0; i < iNRows; ++i) {
222 rowData.array() = inputData.
matData.row(i).array() - inputData.
matData.row(i).mean();
225 for(j = 0; j < tapers.first.rows(); j++) {
227 if (rowData.cols() < iNfft) {
228 vecInputFFT.setZero(iNfft);
229 vecInputFFT.block(0,0,1,rowData.cols()) = rowData.cwiseProduct(tapers.first.row(j));;
231 vecInputFFT = rowData.cwiseProduct(tapers.first.row(j));
235 fft.fwd(vecTmpFreq, vecInputFFT, iNfft);
236 matTapSpectrum.row(j) = vecTmpFreq * tapers.second(j);
247 bool bNfftEven =
false;
252 double denomCSD = sqrt(tapers.second.cwiseAbs2().sum()) * sqrt(tapers.second.cwiseAbs2().sum()) / 2.0;
254 for (i = 0; i < iNRows; ++i) {
255 for (j = i; j < iNRows; ++j) {
261 matCsd.row(j)(0) /= 2.0;
265 matCsd.row(j).tail(1) /= 2.0;
269 inputData.
vecPairCsd.append(QPair<int,MatrixXcd>(i,matCsd));
270 inputData.
vecPairCsdImagSqrd.append(QPair<int,MatrixXd>(i,matCsd.imag().array().square()));
271 inputData.
vecPairCsdImagAbs.append(QPair<int,MatrixXd>(i,matCsd.imag().cwiseAbs()));
276 if(vecPairCsdSum.isEmpty()) {
281 for (
int j = 0; j < vecPairCsdSum.size(); ++j) {
282 vecPairCsdSum[j].second += inputData.
vecPairCsd.at(j).second;
291 for (i = 0; i < inputData.
vecPairCsd.size(); ++i) {
297 if(vecPairCsdImagSqrdSum.isEmpty()) {
300 for (
int j = 0; j < vecPairCsdSum.size(); ++j) {
309 for (i = 0; i < inputData.
vecPairCsd.size(); ++i) {
315 if(vecPairCsdImagAbsSum.isEmpty()) {
318 for (
int j = 0; j < vecPairCsdSum.size(); ++j) {
341 MatrixXd matNom, matDenom;
343 QSharedPointer<NetworkEdge> pEdge;
346 for (
int i = 0; i < connectivitySettings.
at(0).matData.rows(); ++i) {
354 matDenom = (matDenom.array() == 0.).select(INFINITY, matDenom);
355 matDenom = matNom.cwiseQuotient(matDenom);
357 for(j = i; j < connectivitySettings.
at(0).matData.rows(); ++j) {
358 matWeight = matDenom.row(j).transpose();
360 pEdge = QSharedPointer<NetworkEdge>(
new NetworkEdge(i, j, matWeight));
362 finalNetwork.
getNodeAt(i)->append(pEdge);
363 finalNetwork.
getNodeAt(j)->append(pEdge);
364 finalNetwork.
append(pEdge);
static void compute(ConnectivitySettings::IntermediateTrialData &inputData, QVector< QPair< int, Eigen::MatrixXcd > > &vecPairCsdSum, QVector< QPair< int, Eigen::MatrixXd > > &vecPairCsdImagAbsSum, QVector< QPair< int, Eigen::MatrixXd > > &vecPairCsdImagSqrdSum, QMutex &mutex, int iNRows, int iNFreqs, int iNfft, const QPair< Eigen::MatrixXd, Eigen::VectorXd > &tapers)