caching.memory¶
Module: caching.memory
¶
Inheritance diagram for nipype.caching.memory
:

Using nipype with persistence and lazy recomputation but without explicit name-steps pipeline: getting back scope in command-line based programming.
Classes¶
Memory
¶
-
class
nipype.caching.memory.
Memory
(base_dir)¶ Bases:
object
Memory context to provide caching for interfaces
Parameters: - base_dir: string
The directory name of the location for the caching
Methods
cache
(interface)Returns a callable that caches the output of an interface clear_previous_runs
([warn])Remove all the cache that where not used in the latest run of the memory object: i.e. clear_previous_runs
([warn])Remove all the cache that where not used in the latest run of the memory object: i.e. -
__init__
(base_dir)¶ Initialize self. See help(type(self)) for accurate signature.
-
cache
(interface)¶ Returns a callable that caches the output of an interface
Parameters: - interface: nipype interface
The nipype interface class to be wrapped and cached
Returns: - pipe_func: a PipeFunc callable object
An object that can be used as a function to apply the interface to arguments. Inputs of the interface are given as keyword arguments, bearing the same name as the name in the inputs specs of the interface.
Examples
>>> from tempfile import mkdtemp >>> mem = Memory(mkdtemp()) >>> from nipype.interfaces import fsl
Here we create a callable that can be used to apply an fsl.Merge interface to files
>>> fsl_merge = mem.cache(fsl.Merge)
Now we apply it to a list of files. We need to specify the list of input files and the dimension along which the files should be merged.
>>> results = fsl_merge(in_files=['a.nii', 'b.nii'], ... dimension='t') # doctest: +SKIP
We can retrieve the resulting file from the outputs: >>> results.outputs.merged_file # doctest: +SKIP ‘…’
-
clear_previous_runs
(warn=True)¶ Remove all the cache that where not used in the latest run of the memory object: i.e. since the corresponding Python object was created.
Parameters: - warn: boolean, optional
If true, echoes warning messages for all directory removed
-
clear_runs_since
(day=None, month=None, year=None, warn=True)¶ Remove all the cache that where not used since the given date
Parameters: - day, month, year: integers, optional
The integers specifying the latest day (in localtime) that a node should have been accessed to be kept. If not given, the current date is used.
- warn: boolean, optional
If true, echoes warning messages for all directory removed
PipeFunc
¶
-
class
nipype.caching.memory.
PipeFunc
(interface, base_dir, callback=None)¶ Bases:
object
Callable interface to nipype.interface objects
Use this to wrap nipype.interface object and call them specifying their input with keyword arguments:
fsl_merge = PipeFunc(fsl.Merge, base_dir='.') out = fsl_merge(in_files=files, dimension='t')
Methods
__call__
(**kwargs)Call self as a function. -
__init__
(interface, base_dir, callback=None)¶ Parameters: - interface: a nipype interface class
The interface class to wrap
- base_dir: a string
The directory in which the computation will be stored
- callback: a callable
An optional callable called each time after the function is called.
-
Functions¶
-
nipype.caching.memory.
read_log
(filename, run_dict=None)¶
-
nipype.caching.memory.
rm_all_but
(base_dir, dirs_to_keep, warn=False)¶ Remove all the sub-directories of base_dir, but those listed
Parameters: - base_dir: string
The base directory
- dirs_to_keep: set
The names of the directories to keep