![]() |
ImFusion SDK 4.3
|
#include <ImFusion/ML/DataLoaders/PersistentCacheDataLoader.h>
Caches the dataset loaded until now in a persistent manner (on a disk location) More...
Caches the dataset loaded until now in a persistent manner (on a disk location)
Public Member Functions | |
PersistentCacheDataLoader (std::unique_ptr< DataLoader > loader, const std::string &location, bool lazy=true, bool reload=false, bool compression=false, bool shuffle=false, bool verbose=false) | |
Constructs the caching data loader. | |
PersistentCacheDataLoader (DataLoaderList dataLoaders, const Properties &prop) | |
std::optional< DataItem > | next () override |
Advance the loader by one iteration. | |
std::optional< size_t > | size () const override |
The size of the loader is always known after the cache is fully generated (either lazily or not) If caching lazily and not reloading, the size is the same as that of the underlying loader (unknown if Dynamic), until the cache is fully generated. | |
void | reset () override |
Resets the loader index but not the store cache This is to avoid reloading and caching the entire data set every time the iteration is consumed. | |
void | reinit () override |
Forces a cache destruction, i.e. | |
Cardinality | cardinality () const override |
After caching, the number of items in the cache is known, and thus the cardinality is Fixed. | |
![]() | |
DataLoader (std::string name, bool verbose=false) | |
Constructor to be used by DataReaders, as they are the first elements in the chain. | |
DataLoader (std::string name, std::unique_ptr< DataLoader > loader, bool verbose=false) | |
Constructor to be used by all other derived DataLoaders. | |
DataLoader (std::string name, DataLoaderList &&dataLoaders, bool verbose=false) | |
Constructor to be used by all other derived DataLoaders. | |
const std::string & | name () const |
Name of the loader. | |
DataLoader * | singleUnderlyingLoader () const |
Return a single underlying dataloader Expects there to be only one, returns a nullptr otherwise. | |
std::unique_ptr< DataLoader > | extractDataloader () |
Return a single underlying dataloader Expects there to be only one, throws an exception otherwise. | |
DataLoaderList & | loaders () |
DataLoaderList const & | loaders () const |
bool | verbose () const |
virtual void | setRandomSeed (unsigned int seed) |
void | configure (const Properties *properties) override |
Configure this object instance by de-serializing the given Properties. | |
virtual Status | canBePrefetched () const |
Indicates whether a loader is eligible for prefetching. | |
const std::string & | logDomain () const |
Log domain for AdvancedParameter. | |
![]() | |
virtual void | configuration (Properties *p) const |
Serialize the current object configuration into the given Properties object. | |
virtual void | configureDefaults () |
Retrieve the properties of this object, replaces values with their defaults and sets it again. | |
void | registerParameter (ParameterBase *param) |
Register the given Parameter or SubProperty, so that it will be configured during configure()/configuration(). | |
void | unregisterParameter (const ParameterBase *param) |
Remove the given Parameter or SubProperty from the list of registered parameters. | |
Configurable (const Configurable &rhs) | |
Configurable (Configurable &&rhs) noexcept | |
Configurable & | operator= (const Configurable &) |
Configurable & | operator= (Configurable &&) noexcept |
Additional Inherited Members | |
![]() | |
LoaderParam< bool > | m_verbose = {"verbose", false, this, ParamRequired::No} |
If enabled, print log messages with extra information like timings. | |
![]() | |
Signal | signalParametersChanged |
Emitted whenever one of the registered Parameters' or SubPropertys' signalValueChanged signal was emitted. | |
![]() | |
NotCopyable (NotCopyable &&) noexcept=default | |
NotCopyable & | operator= (NotCopyable &&) noexcept=default |
NotCopyable (const NotCopyable &)=delete | |
NotCopyable & | operator= (const NotCopyable &)=delete |
![]() | |
std::string | m_name |
Cardinality | m_cardinality = Cardinality::Fixed |
Random::Generator | m_randGenerator |
DataLoaderList | m_dataLoaders |
![]() | |
std::vector< Param > | m_params |
List of all registered Parameter and SubProperty instances. | |
|
explicit |
Constructs the caching data loader.
loader | previous loader |
location | path to the folder where all the data will be cached |
lazy | caches items when requested (otherwise caches the whole dataset at initialization) |
reload | try to reload the cache from a previous session |
compression | compresses the data when saving on disk |
shuffle | reshuffle the order of the cache every epoch |
DataLoaderException | if the nested loader is uncountable |
|
overridevirtual |
Advance the loader by one iteration.
The function must pull an item from the underlying node, process it and return it. If the underlyng loader is exhausted, returns an empty optional.
Implements DataLoader.
|
overridevirtual |
The size of the loader is always known after the cache is fully generated (either lazily or not) If caching lazily and not reloading, the size is the same as that of the underlying loader (unknown if Dynamic), until the cache is fully generated.
After that, the size is known regardless of the underlying loader size.
Implements DataLoader.
|
overridevirtual |
Resets the loader index but not the store cache This is to avoid reloading and caching the entire data set every time the iteration is consumed.
To force clear the cache, use PersistentCacheDataLoader::clearCache().
Reimplemented from DataLoader.
|
overridevirtual |
Forces a cache destruction, i.e.
delete all files from the folder The cache is created at the next call of next
.
Reimplemented from DataLoader.
|
overridevirtual |
After caching, the number of items in the cache is known, and thus the cardinality is Fixed.
When caching lazily and not reloading, the cardinality is the same of the underlying loader until the cache is fully generated (first epoch typically), then is Fixed.
Reimplemented from DataLoader.