DPV Toolbox is a Matlab toolbox with an object-oriented programming framework. This toolbox is able to process large data sets, allows the development of new analysis algorithms for user-defined objects, and provides a Graphical User Interface to inspect the analysis results. This toolbox is suitable for data sets with a defined hierarchy/level. The names of the items/directories in the same level should follow a certain pattern.
This toolbox consists of the following items:
- Two parent classes, @nptdata and @nptgroup;
- Assistant class @event
- Child class template @dirfiles
- Category gui
- Category miscellaneous
The user may create their desired objects using the template @dirfiles and then use the parent class functions to process the data sets to obtain the object in each directory.
First of all, make sure Matlab has been installed on the computer. Then do the following steps.
Step 1: Get a copy of the DPV.
Step 2: Create a directory where you would like to store DPV, and save the toolbox in that directory.
Step 3: Add path.
- Start MATLAB
- Change directories to the DPV directory:
>> cd ~/matlab/DPV
- Add the sub-directories to your path:
>> nptAddPath
- Go to File -> Set Path;
- In the dialog box, click “Save” and “Close”;
Step 4: Set up the configuration file.
- In the “Current Directory” Window, select the directory that contains the toolbox
- Copy the file named ConfigurationTemplate.txt
- In “Command Window”, type
>> cd(prefdir)
. The “Current Directory” Window now shows the preference directory. - Paste ConfigurationTemplate.txt in the directory, and rename it to be Configuration.txt.
- In “Command Window”, run the function ModifyConfig.m to modify the
configuration file. You may type the following command in “Command Window” to get help on how to use this function (see Section 3.2)
>> help modifyConfig
.
The configuration file created in DPV Toolbox is used to save the data hierarchy (level) information:
- nptDataDir – the root directory used to store the data sets;
- Level names – Contains the name of each level in the data hierarchy;
- Abbreviations of level names – the abbreviations of level names used when creating directories;
- String pattern of level names – the way to name the directory in each level. This information is useful for the program to figure out the individual directories when in a combination directory (e.g.: the string pattern of directories in Cluster level is ‘cluster01s’);
- Equivalent level names – in case one level has some equivalent levels.
The configuration file is saved in the preference directory, returned by the command ‘prefdir’. If more than one user share a single copy of Matlab in one computer, these users can still keep their own preferences.
The configuration file needs to be set up by the individual users respectively. A template configuration file is provided in DPV, named ‘ConfigurationTemplate.txt’. This file contains the default data hierarchy information. If the user does not set up his own configuration file, the default information will be read during processing.
The default values are listed below. nptDataDir – /var/automount/opt/data/cat; Level names – Cluster, Group, Session, Site, Day, Days; Abbreviations of level names – c -> Cluster; g -> Group; n -> Session; s -> Site; 2 String pattern of level names – cluster00s -> Cluster, group0000 -> Group, session00 -> Session, site00 -> Site. Equivalent level names – Group/Sort/HighPass/Eye/EyeFilt/Lfp.
The function ConfigModify.m enables the users to modify any number of the five components at one time.
ModifyConfig(‘nptDataDir’, ‘/var/automount/opt/data/cat’);
levelNames
should be assigned as a cell array with the lowest level coming first and highest level coming last.
ModifyConfig(‘levelNames’, {‘Cluster’, ‘Group’, ‘Session’, ‘Site’, ‘Day’, ‘Days’});
levelAbbr
and NamePattern
also need to be assigned in order of the levels ModifyConfig(‘levelAbbr’, ‘cgns’);
ModifyConfig(‘NamePattern’, {‘cluster00s’, ‘group0000’, ‘session00’, ‘site00’})
For ‘EqualName’, the common-used name of certain level should be in the first place followed by ‘/’ and the equivalent names. The equivalent names should be separated by ‘/’ as well.
ModifyConfig(‘EqualName’, {‘Group/Sort/HighPass/Eye/EyeFilt/Lfp’});
When calling ModifyConfig.m, it is highly recommended to modify one component at a time. It reduces the length of the command, and reduces the likelihood of making typo errors.
DPV Toolbox provides a child class template @dirfiles. You may simply copy this class, paste it in the proper directory, and rename the class as well as the constructor function. There are two examples in the toolbox, @checkFiles and @plusFiles.
The class @dirfiles has the following functions.
- Constructor – used to create an object with the appropriate input arguments
passed. The constructor has the same name as the class. It is able to handle three possible combinations of input arguments:
- No input argument – the constructor should create a default object
- Object input argument – if the first argument in the argument list is an object of the same class, the constructor simply returns the object
- Data input argument – the constructor creates the object using the input data
- get.m – used to access class properties
- plus.m – used to combine two objects in the same class to get the combined object
- plot.m – used to create plots using the input object, with different input arguments producing plots for visualizing different analysis results
- subsasgn.m and subsref.m – used to define the behavior of indexing for the class
Usually, only the constructor and plot.m need to be modified for each user-defined object.
There are two tutorial classes in the toolbox, @checkFiles and @plusFiles. @checkFiles tests single data set analysis, and checks how many files are in each directory, and keeps track of the total number of ‘.mat’ files, ‘.bin’ files, and ‘.txt’ files. @plusFiles tests analyses with multiple data sets, and checks the sum of the files in specific directories that are the same as @checkFiles. The constructors of the two test classes are created strictly by modifying the template of child class constructor, and the plot.m functions are created by modifying the template of plot.m in @dirfiles.
There are five ways in total for template constructors to obtain the objects, with either createEmptyObject.m or createObject.m being called.
- Create empty object using arguments only;
- No input arguments, create empty object;
- If the first argument passed is just an object of the same class, return the very object;
- If the previously saved object has the same requested arguments, load the previously saved object;
- If none of 1), 2), 3) and 4) is satisfied, create object according to the input arguments.
In the fourth way, the proggram will perform argument checking and comparison. However, some input arguments do not affect object creation, like ‘RedoLevels’ and ‘SaveLevels’. These arguments will be neglected during argument checking. You need to specify them at the beginning of the constructor.
Args.DataCheckArgs = {'GridSteps'};
The main modifications will be the two functions createEmptyObject.m and createObject.m. They need to be developed carefully for object creation. If the object creation requires additional calculation before calling the two functions, the calculation should be added to the section indicated by “IMPORTANT NOTICE!” in the template constructor.
This function provides two types of plots, individual plot and population plot. Individual plot plots one data set at a time, while population plot plots all the data together. You may see the codes in the template plot.m. Please add code where it says “add code for plot options here”.
Two process functions are provided in DPV Toolbox, ProcessLevel.m and ProcessDirs.m.
NPTDATA/PROCESSLEVEL NPTDATA/PROCESSCOMBINATION
Checks the subdirectories for data to process, and returns the processed object, which could be a collection of the analysis results for individual data sets, or results that combine multiple data sets.
[robj,data] = ProcessLevel(obj,varargin);
[robj,data] = ProcessCombination(obj,varargin);
Input Argument Name | Explanation |
---|---|
Levels | Specifies the name of the highest processed level. |
Include | Process selected items instead of all items found in the local directory, followed by a directory name or a cell array containing a list of directories. This only works for items in the local directory. |
Exclude | Skips the directories or items specified, followed by a directory name or a cell array containing a list of directories. |
LevelObject | Indicates that the object should be instantiated at a specific level |
AnalysisLevel | Specifies the AnalysisLevel property of the object. Accepted values: ‘Single’, ‘All’, ‘Pairs’, ‘AllIntra’, ‘AllPairs’. |
DataInit | Specifies the initial value of any arbitrary data that will be returned by the function. |
nptLevelCmd | Specifies the level in which to perform the following command. |
DataPlusCmd | Command used to add arbitrary data returned from different levels. |