88 float guessrad = 0.080;
89 std::unique_ptr<MNESourceSpace> guesses;
92 if (!guessname.isEmpty()) {
96 std::vector<std::unique_ptr<MNESourceSpace>> sp;
99 if (
static_cast<int>(sp.size()) != 1) {
100 qCritical(
"Incorrect number of source spaces in guess file");
103 qInfo(
"Read guesses from %s\n",guessname.toUtf8().constData());
104 guesses = std::move(sp[0]);
108 std::unique_ptr<MNESurface> inner_skull_owned;
109 Eigen::Vector3f r0 = f->
r0;
114 qInfo(
"Using inner skull surface from the BEM (%s)...\n",f->
bemname.toUtf8().constData());
118 else if (!guess_surfname.isEmpty()) {
119 qInfo(
"Reading inner skull surface from %s...\n",guess_surfname.toUtf8().data());
121 if (!inner_skull_owned)
123 inner_skull = inner_skull_owned.get();
130 std::vector<std::unique_ptr<MNESourceSpace>> guesses_vec;
131 guesses_vec.push_back(std::move(guesses));
134 guesses = std::move(guesses_vec[0]);
138 this->
nguess = guesses->nuse;
139 this->
rr.resize(guesses->nuse, 3);
140 for (k = 0, p = 0; k < guesses->np; k++)
141 if (guesses->inuse[k]) {
142 this->
rr.row(p) = guesses->rr.row(k);
147 qInfo(
"Go through all guess source locations...");
158 for (k = 0; k < this->
nguess; k++) {
164 qInfo(
"%f %f %f\n",sing[0],sing[1],sing[2]);
169 qInfo(
"[done %d sources]\n",p);
180 float guessrad = 0.080f;
181 std::unique_ptr<MNESourceSpace> guesses;
183 if (!guessname.isEmpty()) {
187 std::vector<std::unique_ptr<MNESourceSpace>> sp;
190 if (
static_cast<int>(sp.size()) != 1) {
191 qCritical(
"Incorrect number of source spaces in guess file");
194 qInfo(
"Read guesses from %s\n",guessname.toUtf8().constData());
195 guesses = std::move(sp[0]);
199 std::unique_ptr<MNESurface> inner_skull_owned;
200 Eigen::Vector3f r0 = f->
r0;
205 qInfo(
"Using inner skull surface from the BEM (%s)...\n",f->
bemname.toUtf8().constData());
209 else if (!guess_surfname.isEmpty()) {
210 qInfo(
"Reading inner skull surface from %s...\n",guess_surfname.toUtf8().data());
212 if (!inner_skull_owned)
214 inner_skull = inner_skull_owned.get();
223 if (guesses->nuse == 0) {
224 qCritical(
"No active guess locations remaining.");
227 if (guess_save_name) {
228 qCritical(
"###################DEBUG writing source spaces not yet implemented.");
237 std::vector<std::unique_ptr<MNESourceSpace>> guesses_vec;
238 guesses_vec.push_back(std::move(guesses));
241 guesses = std::move(guesses_vec[0]);
245 this->
nguess = guesses->nuse;
246 this->
rr.resize(guesses->nuse, 3);
247 for (k = 0, p = 0; k < guesses->np; k++)
248 if (guesses->inuse[k]) {
249 this->
rr.row(p) = guesses->rr.row(k);
275 qCritical(
"Data missing in compute_guess_fields");
279 qCritical(
"Noise covariance missing in compute_guess_fields");
282 qInfo(
"Go through all guess source locations...");
288 for (
int k = 0; k < this->
nguess; k++) {
297 qInfo(
"%f %f %f\n",sing[0],sing[1],sing[2]);
301 qInfo(
"[done %d sources]\n",this->nguess);
Dipole Fit Data class declaration.
InvDipoleForward class declaration.
InvGuessData class declaration.
#define FIFFV_BEM_SURF_ID_BRAIN
FiffStream class declaration.
FiffTag class declaration, which provides fiff tag I/O and processing methods.
MNESourceSpace class declaration.
MNESurface class declaration.
Core MNE data structures (source spaces, source estimates, hemispheres).
FIFF file I/O and data structures (raw, epochs, evoked, covariance, forward).
Inverse source estimation (MNE, dSPM, sLORETA, dipole fitting).
dipoleFitFuncsRec * dipoleFitFuncs
Pointer alias for dipoleFitFuncsRec, used throughout the dipole fitting module.
Forward modelling (BEM, MEG/EEG lead fields).
static std::unique_ptr< MNELIB::MNESurface > make_guesses(MNELIB::MNESurface *guess_surf, float guessrad, const Eigen::Vector3f &guess_r0, float grid, float exclude, float mindist)
Generate a set of dipole guess locations inside a boundary surface.
Dipole fit workspace holding sensor geometry, forward model, noise covariance, and projection data.
std::unique_ptr< FIFFLIB::FiffCoordTrans > mri_head_t
static InvDipoleForward * dipole_forward_one(InvDipoleFitData *d, const Eigen::Vector3f &rd, InvDipoleForward *old)
Compute the forward solution for a single dipole position.
std::unique_ptr< MNELIB::MNECovMatrix > noise
std::unique_ptr< dipoleFitFuncsRec > sphere_funcs
std::unique_ptr< FWDLIB::FwdBemModel > bem_model
std::unique_ptr< dipoleFitFuncsRec > mag_dipole_funcs
dipoleFitFuncsRec * funcs
std::vector< InvDipoleForward::UPtr > guess_fwd
Eigen::Matrix< float, Eigen::Dynamic, 3, Eigen::RowMajor > rr
bool compute_guess_fields(InvDipoleFitData *f)
This defines a source space.
static int read_source_spaces(const QString &name, std::vector< std::unique_ptr< MNESourceSpace > > &spaces)
static int transform_source_spaces_to(int coord_frame, const FIFFLIB::FiffCoordTrans &t, std::vector< std::unique_ptr< MNESourceSpace > > &spaces)
static std::unique_ptr< MNESurface > read_bem_surface(const QString &name, int which, bool add_geometry)
Eigen::MatrixX3f apply_inverse_trans(const Eigen::MatrixX3f &rr, bool do_move=true) const
static QString frame_name(int frame)