37#ifndef MNE_FORWARD_SOLUTION_H
38#define MNE_FORWARD_SOLUTION_H
71#include <QSharedPointer>
118 QString t_sDistMeasure;
120 t_sDistMeasure = QString(
"cityblock");
131 t_kMeans.
calculate(this->matRoiGWhitened, this->nClusters, p_RegionDataOut.
roiIdx, p_RegionDataOut.
ctrs, p_RegionDataOut.
sumd, p_RegionDataOut.
D);
133 Eigen::MatrixXd newCtrs = Eigen::MatrixXd::Zero(p_RegionDataOut.
ctrs.rows(), p_RegionDataOut.
ctrs.cols());
134 for(qint32 c = 0; c < p_RegionDataOut.
ctrs.rows(); ++c)
138 for(qint32 idx = 0; idx < p_RegionDataOut.
roiIdx.size(); ++idx)
140 if(c == p_RegionDataOut.
roiIdx[idx])
142 newCtrs.row(c) += this->matRoiG.row(idx);
148 newCtrs.row(c) /= num;
150 p_RegionDataOut.
ctrs = newCtrs;
153 t_kMeans.
calculate(this->matRoiG, this->nClusters, p_RegionDataOut.
roiIdx, p_RegionDataOut.
ctrs, p_RegionDataOut.
sumd, p_RegionDataOut.
D);
157 return p_RegionDataOut;
163static Eigen::MatrixXd defaultD;
174 typedef QSharedPointer<MNEForwardSolution>
SPtr;
175 typedef QSharedPointer<const MNEForwardSolution>
ConstSPtr;
176 typedef std::unique_ptr<MNEForwardSolution>
UPtr;
197 bool force_fixed =
false,
199 const QStringList& include = FIFFLIB::defaultQStringList,
200 const QStringList& exclude = FIFFLIB::defaultQStringList,
201 bool bExcludeBads =
false);
260 qint32 p_iClusterSize,
261 Eigen::MatrixXd& p_D = defaultD,
264 QString p_sMethod =
"cityblock")
const;
295 const Eigen::MatrixXd &patch_areas = FIFFLIB::defaultConstMatrixXd,
296 bool limit_depth_chs =
false);
334 const QStringList& exclude = FIFFLIB::defaultQStringList)
const;
361 const QStringList& include = FIFFLIB::defaultQStringList,
362 const QStringList& exclude = FIFFLIB::defaultQStringList)
const;
381 Eigen::MatrixXd &gain,
383 Eigen::MatrixXd &p_outWhitener,
384 qint32 &p_outNumNonZero)
const;
392 Eigen::MatrixXi triSelect = p_vecIdxSelection.transpose().replicate(3,1).array() * 3;
393 triSelect.row(1).array() += 1;
394 triSelect.row(2).array() += 2;
395 Eigen::VectorXi retTriSelect(triSelect.cols()*3);
396 for(
int i = 0; i < triSelect.cols(); ++i)
397 retTriSelect.block(i*3,0,3,1) = triSelect.col(i);
417 static bool read(QIODevice& p_IODevice,
419 bool force_fixed =
false,
420 bool surf_ori =
false,
421 const QStringList& include = FIFFLIB::defaultQStringList,
422 const QStringList& exclude = FIFFLIB::defaultQStringList,
423 bool bExcludeBads =
true);
439 bool write(QIODevice& p_IODevice)
const;
450 MNEForwardSolution reduce_forward_solution(qint32 p_iNumDipoles, Eigen::MatrixXd& p_D)
const;
459 static void restrict_gain_matrix(Eigen::MatrixXd &G,
const FIFFLIB::FiffInfo &info);
496 Eigen::MatrixX3f getSourcePositionsByLabel(
const QList<FSLIB::FsLabel> &lPickedLabels,
539 return this->
nchan <= 0;
553 out <<
"#### MNE Forward Solution ####\n";
555 out <<
"\n source_ori: " << p_MNEForwardSolution.
source_ori << std::endl;
556 out <<
"\n coord_frame: " << p_MNEForwardSolution.
coord_frame << std::endl;
557 out <<
"\n nsource: " << p_MNEForwardSolution.
nsource << std::endl;
558 out <<
"\n nchan: " << p_MNEForwardSolution.
nchan << std::endl;
559 out <<
"\n sol:\n\t" << *p_MNEForwardSolution.
sol.data() << std::endl;
560 out <<
"\n sol_grad:\n\t" << *p_MNEForwardSolution.
sol_grad.data() << std::endl;
#define FIFFV_MNE_FIXED_ORI
FiffInfoBase class declaration.
FiffCov class declaration.
Old fiff_type declarations - replace them.
FiffCoordTrans class declaration.
bool operator==(const BIDSPath &a, const BIDSPath &b)
MNESourceSpaces class declaration.
mne library export/import macros.
FsAnnotationSet class declaration.
KMeans class declaration.
Core MNE data structures (source spaces, source estimates, hemispheres).
std::ostream & operator<<(std::ostream &out, const MNELIB::MNEForwardSolution &p_MNEForwardSolution)
bool operator==(const MNEClusterInfo &a, const MNEClusterInfo &b)
Coordinate transformation description.
QSharedPointer< FiffDirNode > SPtr
Universally unique identifier.
FIFF measurement file information.
QSharedDataPointer< FiffNamedMatrix > SDPtr
QSharedPointer< FiffStream > SPtr
A hemisphere set of surfaces.
bool calculate(const Eigen::MatrixXd &X, qint32 kClusters, Eigen::VectorXi &idx, Eigen::MatrixXd &C, Eigen::VectorXd &sumD, Eigen::MatrixXd &D)
Output of a cluster-based forward solution computation for a single cortical region.
Input parameters for cluster-based forward solution computation on a single cortical region.
Eigen::MatrixXd matRoiGWhitened
Eigen::MatrixXd matRoiGOrig
RegionDataOut cluster() const
FIFFLIB::fiff_int_t nsource
FIFFLIB::FiffInfoBase info
static FIFFLIB::FiffCov compute_depth_prior(const Eigen::MatrixXd &Gain, const FIFFLIB::FiffInfo &gain_info, bool is_fixed_ori, double exp=0.8, double limit=10.0, const Eigen::MatrixXd &patch_areas=FIFFLIB::defaultConstMatrixXd, bool limit_depth_chs=false)
MNELIB::MNESourceSpaces src
MNEForwardSolution cluster_forward_solution(const FSLIB::FsAnnotationSet &p_AnnotationSet, qint32 p_iClusterSize, Eigen::MatrixXd &p_D=defaultD, const FIFFLIB::FiffCov &p_pNoise_cov=defaultCov, const FIFFLIB::FiffInfo &p_pInfo=defaultInfo, QString p_sMethod="cityblock") const
FIFFLIB::fiff_int_t source_ori
MNEForwardSolution & operator=(const MNEForwardSolution &other)
void prepare_forward(const FIFFLIB::FiffInfo &p_info, const FIFFLIB::FiffCov &p_noise_cov, bool p_pca, FIFFLIB::FiffInfo &p_outFwdInfo, Eigen::MatrixXd &gain, FIFFLIB::FiffCov &p_outNoiseCov, Eigen::MatrixXd &p_outWhitener, qint32 &p_outNumNonZero) const
FIFFLIB::FiffCoordTrans mri_head_t
QSharedPointer< MNEForwardSolution > SPtr
MNEForwardSolution pick_channels(const QStringList &include=FIFFLIB::defaultQStringList, const QStringList &exclude=FIFFLIB::defaultQStringList) const
FIFFLIB::FiffNamedMatrix::SDPtr sol_grad
bool isFixedOrient() const
MNEForwardSolution & operator=(MNEForwardSolution &&other)=default
Eigen::VectorXi tripletSelection(const Eigen::VectorXi &p_vecIdxSelection) const
std::unique_ptr< MNEForwardSolution > UPtr
MNEForwardSolution(MNEForwardSolution &&other)=default
Eigen::MatrixX3f source_nn
QSharedPointer< const MNEForwardSolution > ConstSPtr
Eigen::MatrixX3f source_rr
FIFFLIB::FiffCov compute_orient_prior(float loose=0.2)
MNEForwardSolution pick_regions(const QList< FSLIB::FsLabel > &p_qListLabels) const
FIFFLIB::fiff_int_t coord_frame
FIFFLIB::fiff_int_t nchan
MNEForwardSolution pick_types(bool meg, bool eeg, const QStringList &include=FIFFLIB::defaultQStringList, const QStringList &exclude=FIFFLIB::defaultQStringList) const
FIFFLIB::FiffNamedMatrix::SDPtr sol
Source Space descritpion.