51#if defined(__LITTLE_ENDIAN__)
54#define BIG_ENDIAN_ARCH
59#if defined(__hpux) || defined(__Lynx__) || defined(__sun)
60#define BIG_ENDIAN_ARCH
62#if defined(__linux) || defined(WIN32) || defined(__APPLE__)
69#define NATIVE_ENDIAN FIFFV_LITTLE_ENDIAN
72#define NATIVE_ENDIAN FIFFV_LITTLE_ENDIAN
76#define NATIVE_ENDIAN FIFFV_BIG_ENDIAN
99#include <Eigen/SparseCore>
108#include <QSharedPointer>
133#define IS_MATRIX 0xFFFF0000
134#define MATRIX_CODING_DENSE 0x00004000
135#define MATRIX_CODING_CCS 0x00004010
136#define MATRIX_CODING_RCS 0x00004020
137#define DATA_TYPE 0x0000FFFF
155 typedef QSharedPointer<FiffTag>
SPtr;
250 inline quint8*
toByte()
const;
268 inline qint16*
toShort()
const;
286 inline qint32*
toInt()
const;
379 inline QList< QSharedPointer<FiffDirEntry> >
toDirEntry()
const;
540 return (quint8*)this->data();
550 return (quint16*)this->data();
560 return (qint16*)this->data();
570 return (quint32*)this->data();
578 printf(
"Expected an integer tag : %d (found data type %d instead)\n",this->
kind,this->
getType());
582 return (qint32*)this->data();
590 printf(
"Expected a julian tag : %d (found data type %d instead)\n",this->
kind,this->
getType());
594 return (qint32*)this->data();
604 return (
float*)this->data();
614 return (
double*)this->data();
634 return (qint16*)this->data();
680 const qint32* t_pInt32 = (qint32*)this->data();
682 p_fiffID.
version = t_pInt32[0];
683 p_fiffID.
machid[0] = t_pInt32[1];
684 p_fiffID.
machid[1] = t_pInt32[2];
699 return t_fiffDigPoint;
702 qint32* t_pInt32 = (qint32*)this->data();
705 t_fiffDigPoint.
kind = t_pInt32[0];
706 t_fiffDigPoint.
ident = t_pInt32[1];
708 float* t_pFloat = (
float*)this->data();
709 t_fiffDigPoint.
r[0] = t_pFloat[2];
710 t_fiffDigPoint.
r[1] = t_pFloat[3];
711 t_fiffDigPoint.
r[2] = t_pFloat[4];
714 return t_fiffDigPoint;
725 return p_FiffCoordTrans;
728 qint32* t_pInt32 = (qint32*)this->data();
729 p_FiffCoordTrans.
from = t_pInt32[0];
730 p_FiffCoordTrans.
to = t_pInt32[1];
732 p_FiffCoordTrans.
trans.setIdentity(4,4);
733 float* t_pFloat = (
float*)this->data();
736 for (r = 0; r < 3; ++r) {
737 p_FiffCoordTrans.
trans(r,3) = t_pFloat[11+r];
738 for (c = 0; c < 3; ++c) {
739 p_FiffCoordTrans.
trans(r,c) = t_pFloat[2+count];
744 p_FiffCoordTrans.
invtrans.setIdentity(4,4);
746 for (r = 0; r < 3; ++r) {
747 p_FiffCoordTrans.
invtrans(r,3) = t_pFloat[23+r];
748 for (c = 0; c < 3; ++c) {
749 p_FiffCoordTrans.
invtrans(r,c) = t_pFloat[14+count];
754 return p_FiffCoordTrans;
770 qint32* t_pInt32 = (qint32*)this->data();
771 p_FiffChInfo.
scanNo = t_pInt32[0];
772 p_FiffChInfo.
logNo = t_pInt32[1];
773 p_FiffChInfo.
kind = t_pInt32[2];
774 float* t_pFloat = (
float*)this->data();
775 p_FiffChInfo.
range = t_pFloat[3];
776 p_FiffChInfo.
cal = t_pFloat[4];
785 for (r = 0; r < 3; ++r)
786 p_FiffChInfo.
chpos.
r0[r] = t_pFloat[6+r];
788 for (r = 0; r < 3; ++r)
789 p_FiffChInfo.
chpos.
ex[r] = t_pFloat[6+3+r];
791 for (r = 0; r < 3; ++r)
792 p_FiffChInfo.
chpos.
ey[r] = t_pFloat[6+6+r];
794 for (r = 0; r < 3; ++r)
795 p_FiffChInfo.
chpos.
ez[r] = t_pFloat[6+9+r];
806 for (r = 0; r < 3; ++r)
809 for (r = 0; r < 3; ++r)
812 for (r = 0; r < 3; ++r)
815 for (r = 0; r < 3; ++r)
822 if (p_FiffChInfo.
chpos.
ex.norm() > 0) {
823 p_FiffChInfo.
eeg_loc.block(0,0,3,1) = p_FiffChInfo.
chpos.
r0.block(0,0,3,1);
824 p_FiffChInfo.
eeg_loc.block(0,1,3,1) = p_FiffChInfo.
chpos.
ex.block(0,0,3,1);
827 p_FiffChInfo.
eeg_loc.block(0,0,3,1) = p_FiffChInfo.
chpos.
r0.block(0,0,3,1);
834 p_FiffChInfo.
unit = t_pInt32[18];
835 p_FiffChInfo.
unit_mul = t_pInt32[19];
840 char* orig = (
char*)this->data();
841 p_FiffChInfo.
ch_name = QString::fromUtf8(orig + 80).replace(
" ",
"");
861 QList< QSharedPointer<FiffDirEntry> > p_ListFiffDir;
863 return p_ListFiffDir;
866 QSharedPointer<FiffDirEntry> t_pFiffDirEntry;
867 qint32* t_pInt32 = (qint32*)this->data();
868 for (
int k = 0; k < this->size()/16; ++k)
870 t_pFiffDirEntry = QSharedPointer<FiffDirEntry>(
new FiffDirEntry);
871 t_pFiffDirEntry->kind = t_pInt32[k*4];
872 t_pFiffDirEntry->type = t_pInt32[k*4+1];
873 t_pFiffDirEntry->size = t_pInt32[k*4+2];
874 t_pFiffDirEntry->pos = t_pInt32[k*4+3];
875 p_ListFiffDir.append(t_pFiffDirEntry);
878 return p_ListFiffDir;
890 return Eigen::MatrixXi();
893 QVector<qint32> dims;
898 printf(
"Only two-dimensional matrices are supported at this time");
899 return Eigen::MatrixXi();
904 Eigen::MatrixXi p_Matrix(Eigen::Map<Eigen::MatrixXi>( (
int*)this->data(),dims[0], dims[1]));
914 return Eigen::MatrixXf();
918 printf(
"Error in FiffTag::toFloatMatrix(): Matrix is not dense!\n");
919 return Eigen::MatrixXf();
923 QVector<qint32> dims;
928 printf(
"Only two-dimensional matrices are supported at this time");
929 return Eigen::MatrixXf();
933 Eigen::MatrixXf p_Matrix((Eigen::Map<Eigen::MatrixXf>( (
float*)this->data(),dims[0], dims[1])));
943 return Eigen::SparseMatrix<double>();
947 printf(
"Error in FiffTag::toSparseFloatMatrix(): Matrix is not sparse!\n");
948 return Eigen::SparseMatrix<double>();
952 QVector<qint32> dims;
957 printf(
"Only two-dimensional matrices are supported at this time");
958 return Eigen::SparseMatrix<double>();
961 qint32 nnz = dims[0];
962 qint32 nrow = dims[1];
963 qint32 ncol = dims[2];
965 typedef Eigen::Triplet<double> T;
966 std::vector<T> tripletList;
967 tripletList.reserve(nnz);
969 float *t_pFloat = (
float*)this->data();
970 int *t_pInt = (
int*)this->data();
971 qint32 offset1 = nnz;
972 qint32 offset2 = 2*nnz;
978 qWarning(
"Warning in FiffTag::toSparseFloatMatrix(): CCS has to be debugged - never done before.");
980 for(qint32 j = 0; j < ncol; ++j)
982 while( p < t_pInt[offset2+j+1])
985 tripletList.push_back(T(t_pInt[offset1+p], j, (
double)(t_pFloat[p])));
996 for(qint32 j = 0; j < nrow; ++j)
998 while( p < t_pInt[offset2+j+1])
1001 tripletList.push_back(T(j, t_pInt[offset1+p], (
double)(t_pFloat[p])));
1012 Eigen::SparseMatrix<double> p_Matrix(nrow, ncol);
1013 p_Matrix.setFromTriplets(tripletList.begin(), tripletList.end());
FiffChPos class declaration.
Fiff library export/import macros.
#define FIFFSHARED_EXPORT
#define FIFFV_COORD_DEVICE
#define FIFFV_COORD_UNKNOWN
FiffDirEntry class declaration.
fiff_int_t fiff_type_base(fiff_int_t type)
fiff_int_t fiff_type_matrix_coding(fiff_int_t type)
fiff_int_t fiff_type_fundamental(fiff_int_t type)
FiffChInfo class declaration.
FiffId class declaration.
Header file describing the numerical values used in fif files.
#define FIFFT_CH_INFO_STRUCT
#define FIFFT_DIR_ENTRY_STRUCT
#define FIFFT_COORD_TRANS_STRUCT
#define FIFFT_DIG_POINT_STRUCT
Old fiff_type declarations - replace them.
FiffCoordTrans class declaration.
FiffDigPoint class declaration.
FIFF file I/O and data structures (raw, epochs, evoked, covariance, forward).
Eigen::Matrix< float, 3, 2, Eigen::DontAlign > eeg_loc
Eigen::Matrix< float, 4, 4, Eigen::DontAlign > coil_trans
Measurement channel position and coil type.
Coordinate transformation description.
Eigen::Matrix< float, 4, 4, Eigen::DontAlign > trans
Eigen::Matrix< float, 4, 4, Eigen::DontAlign > invtrans
Digitization point description.
Directory entry description.
Universally unique identifier.
static fiff_int_t fiff_type_matrix_coding(fiff_int_t type)
Eigen::MatrixXf toFloatMatrix() const
quint32 * toUnsignedInt() const
FiffTag(FiffTag &&other)=default
FiffCoordTrans toCoordTrans() const
qint32 * toJulian() const
static void convert_matrix_to_file_data(FiffTag::SPtr tag)
fiff_int_t getMatrixCoding() const
Eigen::MatrixXi toIntMatrix() const
quint16 * toUnsignedShort() const
FiffChInfo toChInfo() const
qint16 * toDauPack16() const
FiffDigPoint toDigPoint() const
QSharedPointer< FiffTag > SPtr
FiffTag & operator=(FiffTag &&other)=default
double * toDouble() const
fiff_int_t getType() const
Eigen::SparseMatrix< double > toSparseFloatMatrix() const
QSharedPointer< const FiffTag > ConstSPtr
static qint32 storageSize()
FiffTag & operator=(const FiffTag &other)=default
static void convert_matrix_from_file_data(FiffTag::SPtr tag)
static void convert_ch_pos(FiffChPos *pos)
FiffTag(const FiffTag &p_FiffTag)=default
bool getMatrixDimensions(qint32 &p_ndim, QVector< qint32 > &p_Dims) const
static void convert_tag_data(FiffTag::SPtr tag, int from_endian, int to_endian)
QList< QSharedPointer< FiffDirEntry > > toDirEntry() const