Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 23 Next »

From 2015, CSPM uses a new file format for physiology. The old one was "hd2000", which ran separately, but which was very clunky.

Raw data

In the study data folder, the "raw" data is from whatever recording we had: Biopac, IFF-PHYS, instrunet,or WHH. The "phys" folder contains the data in a universal format. (The MRI equivalent is DICOM, PAR/REC, Analyze for the raw, and nifti for the converted.)

phys folder

Each channel is saved as a MATLAB timeseries object, with asynchronous (that is, not necessarily uniformly sampled) time values. 

FileStructureFieldsSubfieldsDescription
phys[protocol_id].matphys*.study_id

link to study in database

* saved as "-struct", so individual variables loaded with phys = load(...)



.name
name


.filename
filename of "timeseries" object, saved as "ts" variable in a MATLAB file


.ts (memory nly)
the timeseries when loaded from individual channel files; this is not saved in the file, and is only loaded when needed. It slows things down a lot if it gets loaded every time.


.start_time

(optional)


date-time: precise start time of recording

Optional because for some fMRI physiology we don't have this, or it's not synced with scanner.



.num_chans



.chan{1:N}
cell array of channels



.namechannel name



.type"rec" (recorded) or "calc" (calculated)



.filename

mat file of timeseries object; variable has channel name. File is located in phys folder). The channels are synchronized such that the time is equivalent (this is critical for events). The time should start at 0.

Time is in seconds.




.sample_rateempty for asynchronous



.offsettime offset from phys.start_time



.calc_sourcechansfor calculated channels; cell array of "rec" channel names used to calculate "calc" channel



.descrdescription (optional)



.unitsunits (optional)


.num_events
this includes states (events with non-zero duration)


.event{1:N}

Cell array of events or states; note that these are all events, not only those in the database. For analysis, we will use the database events and select segments of the timeseries. For this reason, the names don't matter too much, as we can select events for analysis and classify them at the same time we incorporate them into the database.




.timetime in seconds, relative to phys.start_time



.event_idevent_id from database



.durationempty or 0 for event, time for "state"



.type (optional?)

Example (phys file incorrect size - earlier version where timeseries was saved in phys object)

CSPM  functions that read/write in this format

  • phys_format_whh.m: converts raw WHH data.
  • db_convertphys2spm12 reads old into new data format.
  • No labels