-
Notifications
You must be signed in to change notification settings - Fork 369
Processing large datasets
The purpose of this page is to explain how to use the constrained NMF algorithm to process large datasets that create memory issues. The main steps of this process which is implemented in the file demo_patches.py
are explained below:
This process has to be executed once for every new dataset. The data is loaded into memory in chunks and then saved incrementally in a .mmap
file in format pixels X frames. The name of the saved file contains information about the original size and array reading order. For instance a file named
Yr_d1_483_d2_492_order_F_frames_1600_.mmap
has frame shape (483,492), has 1600 frames, and is stored in 'F' order. These files can be read with the utility function load_memmap in the utilities submodule.
There are two functions for performing this memory mapping and retrieval procedure:
-
utilities.save_memmap
: This function assumes that the whole dataset is stored in a list of.tif
files. You should have at least enough memory to open one such file. The function allows also to downsample each movie in any of the x,y,z directions, to remove portions of the beginning of each movie, and to only select a subset of pixels (see documentation) -
utilities.load_memmap
: This function provides a memory mapped version of the file passed as path. On this file you can do several numpy operations without having to load the file into memory.
Once the dataset is saved in a .mmap
format we can now apply the CNMF algorithm on spatially overlapping patches in parallel. The logic of the parcelization and parallel execution is embedded into the map_reduce.run_CNMF_patches function. The function takes as input
-
an option dictionary: exactly as in the case of the demo.py example. However, in this case one should take into account that these are the options parameters related to a single patch. Important parameters that should be specified are:
- the expected number of components per patch K
- the expected size of neurons as specified by gSig (gSig=[5,5] means that the neurons are approximately 11 pixels in x and y)
- the threshold for merging neurons
- the p parameter of the autoregressive model
- memory_fact representing the fraction of patch to be processed in a single memory load (decrease this number to optimize memory usage)
-
The geometric parameters describing the patches:
- the half size receptive field rf (rf=10 means that the patches cover an area of 20x20 pixels)
- the stride representing the amount of overlap among patches in pixels
The parallel processing of the different patches is performed with the function map_reduce.run_CNMF_patches
Then the standard CNMF procedure is performed on each patch (preprocessing, initialization, update spatial, update temporal, merge, update spatial, update temporal) and the results for each patch are returned in the variables
- A_tot: matrix of spatial filters including all the components found in all the patches and represented in the coordinate frame of the whole frame
- C_tot: matrix of calcium traces corresponding to elements in A_tot
- sn_tot: per pixel noise estimates
- optional_outputs: dictionary containing the outputs of the algorithm per patch
Equalization: An added benefit of processing different spatial patches separately is that the algorithm is looking for cells in an unbiased way throughout the field of view and not only in the brightest areas which is a property of the greedy initialization algorithm. However, this also creates a large number of false positive cells. To deal with this we classify the components using a simple procedure explained below.
Merging: After the processing of all the patches is finished the results are combined and the components are merged using the standard merge_components
function.
Classification (TO DO): As mentioned above, applying the method on overlapping patches forces the algorithm to (initially) identify a specified number of components in each patch regardless of the number of (active) cells that exist in each patch. This in practice can create a large number of false positive components. To deal with problem we will need to use (Work in progress) a simple classification approach.
Once run_CNMF_patches
is complete we need to update the components once more, since merging the results accounts for the data twice over the overlapping regions. To do this update_spatial_components
and update_temporal_components
have been modified so that they can handle memory mapped data as well.