134 qInfo(
"\tcomputing normals\n");
136 MatrixX3f r1(
tris.rows(),3); MatrixX3f r2(
tris.rows(),3); MatrixX3f r3(
tris.rows(),3);
138 for(qint32 i = 0; i <
tris.rows(); ++i)
140 r1.row(i) =
rr.row(
tris(i, 0));
141 r2.row(i) =
rr.row(
tris(i, 1));
142 r3.row(i) =
rr.row(
tris(i, 2));
145 MatrixX3f x = r2 - r1;
146 MatrixX3f y = r3 - r1;
147 MatrixX3f tri_nn(x.rows(),y.cols());
148 tri_nn.col(0) = x.col(1).cwiseProduct(y.col(2)) - x.col(2).cwiseProduct(y.col(1));
149 tri_nn.col(1) = x.col(2).cwiseProduct(y.col(0)) - x.col(0).cwiseProduct(y.col(2));
150 tri_nn.col(2) = x.col(0).cwiseProduct(y.col(1)) - x.col(1).cwiseProduct(y.col(0));
153 MatrixX3f tmp = tri_nn.cwiseProduct(tri_nn);
154 VectorXf normSize = tmp.rowwise().sum();
155 normSize = normSize.cwiseSqrt();
157 for(qint32 i = 0; i < normSize.size(); ++i)
159 tri_nn.row(i) /= normSize(i);
161 MatrixX3f
nn = MatrixX3f::Zero(
rr.rows(), 3);
163 for(qint32 p = 0; p <
tris.rows(); ++p)
165 Vector3i verts =
tris.row(p);
166 for(qint32 j = 0; j < verts.size(); ++j)
167 nn.row(verts(j)) = tri_nn.row(p);
170 tmp =
nn.cwiseProduct(
nn);
171 normSize = tmp.rowwise().sum();
172 normSize = normSize.cwiseSqrt();
174 for(qint32 i = 0; i < normSize.size(); ++i)
176 nn.row(i) /= normSize(i);
211 QFile t_File(p_sFile);
213 if (!t_File.open(QIODevice::ReadOnly))
215 qWarning(
"\tError: Couldn't open the surface file");
219 qInfo(
"Reading surface...\n");
222 qint32 t_NameIdx = 0;
223 if(p_sFile.contains(
"lh."))
224 t_NameIdx = p_sFile.indexOf(
"lh.");
225 else if(p_sFile.contains(
"rh."))
226 t_NameIdx = p_sFile.indexOf(
"rh.");
230 p_Surface.m_sFilePath = p_sFile.mid(0,t_NameIdx);
231 p_Surface.m_sFileName = p_sFile.mid(t_NameIdx,p_sFile.size()-t_NameIdx);
233 QDataStream t_DataStream(&t_File);
234 t_DataStream.setByteOrder(QDataStream::BigEndian);
259 qInfo(
"\t%s is a quad file (nvert = %d nquad = %d)\n", p_sFile.toUtf8().constData(),nvert,nquad);
261 qInfo(
"\t%s is a new quad file (nvert = %d nquad = %d)\n", p_sFile.toUtf8().constData(),nvert,nquad);
264 verts.resize(nvert, 3);
268 for(qint32 i = 0; i < nvert; ++i)
270 for(qint32 j = 0; j < 3; ++j)
272 t_DataStream >> iVal;
274 verts(i,j) = ((float)iVal) / 100;
280 t_DataStream.readRawData((
char *)verts.data(), nvert*3*
sizeof(
float));
281 for(qint32 i = 0; i < nvert; ++i)
282 for(qint32 j = 0; j < 3; ++j)
287 MatrixXi quads_new(4, nquad);
289 for(qint32 j = 0; j < quads.cols(); ++j)
291 for(qint32 i = 0; i < quads.rows(); ++i)
293 quads_new(i,j) = quads(count, 0);
297 quads = quads_new.transpose();
301 faces = MatrixXi::Zero(2*nquad,3);
302 for(qint32 k = 0; k < nquad; ++k)
304 RowVectorXi quad = quads.row(k);
305 if ((quad[0] % 2) == 0)
307 faces(nface,0) = quad[0];
308 faces(nface,1) = quad[1];
309 faces(nface,2) = quad[3];
312 faces(nface,0) = quad[2];
313 faces(nface,1) = quad[3];
314 faces(nface,2) = quad[1];
319 faces(nface,0) = quad(0);
320 faces(nface,1) = quad(1);
321 faces(nface,2) = quad(2);
324 faces(nface,0) = quad(0);
325 faces(nface,1) = quad(2);
326 faces(nface,2) = quad(3);
333 QString s = t_File.readLine();
336 t_DataStream >> nvert;
337 t_DataStream >> nface;
341 qInfo(
"\t%s is a triangle file (nvert = %d ntri = %d)\n", p_sFile.toUtf8().constData(), nvert, nface);
342 qInfo(
"\t%s", s.toUtf8().constData());
345 verts.resize(3, nvert);
346 t_DataStream.readRawData((
char *)verts.data(), nvert*3*
sizeof(
float));
347 for(qint32 i = 0; i < 3; ++i)
348 for(qint32 j = 0; j < nvert; ++j)
352 faces.resize(nface, 3);
354 for(qint32 i = 0; i < nface; ++i)
356 for(qint32 j = 0; j < 3; ++j)
358 t_DataStream >> iVal;
366 qWarning(
"Bad magic number (%d) in surface file %s",magic,p_sFile.toUtf8().constData());
370 verts.transposeInPlace();
371 verts.array() *= 0.001f;
373 p_Surface.m_matRR = verts.block(0,0,verts.rows(),3);
374 p_Surface.m_matTris = faces.block(0,0,faces.rows(),3);
377 p_Surface.m_matNN =
compute_normals(p_Surface.m_matRR, p_Surface.m_matTris);
380 if(t_File.fileName().contains(
"lh."))
381 p_Surface.m_iHemi = 0;
382 else if(t_File.fileName().contains(
"rh."))
383 p_Surface.m_iHemi = 1;
386 p_Surface.m_iHemi = -1;
391 p_Surface.m_sSurf = t_File.fileName().mid((t_NameIdx+3),t_File.fileName().size() - (t_NameIdx+3));
396 QString t_sCurvatureFile = QString(
"%1%2.curv").arg(p_Surface.m_sFilePath).arg(p_Surface.m_iHemi == 0 ?
"lh" :
"rh");
402 qInfo(
"\tRead a surface with %d vertices from %s\n[done]\n",nvert,p_sFile.toUtf8().constData());
413 qInfo(
"Reading curvature...");
414 QFile t_File(p_sFileName);
416 if (!t_File.open(QIODevice::ReadOnly))
418 qWarning(
"\tError: Couldn't open the curvature file");
422 QDataStream t_DataStream(&t_File);
423 t_DataStream.setByteOrder(QDataStream::BigEndian);
426 qint32 NEW_VERSION_MAGIC_NUMBER = 16777215;
428 if(vnum == NEW_VERSION_MAGIC_NUMBER)
430 qint32 fnum, vals_per_vertex;
431 t_DataStream >> vnum;
433 t_DataStream >> fnum;
434 t_DataStream >> vals_per_vertex;
436 curv.resize(vnum, 1);
437 t_DataStream.readRawData((
char *)
curv.data(), vnum*
sizeof(
float));
438 for(qint32 i = 0; i < vnum; ++i)
446 curv.resize(vnum, 1);
447 for(qint32 i = 0; i < vnum; ++i)
449 t_DataStream >> iVal;
451 curv(i) = ((float)iVal) / 100;