A command line tool for data-centric science and machine learning projects
Project description
α README
Label Database or LDB is an open-source tool for data-centric AI and machine learning projects. It works upstream from model training and intends to index data in the existing cloud storages or data lakes and use these data pointers to form datasets.
LDB aims to displace ad-hoc dataset management and de-duplication tools – such as file folders, spreadsheets and SQL databases. In the upstream direction, LDB can interface with labeling software, and in the downstream direction LDB integrates with model-based ML pipelines.
Key LDB features:
- MLOps-grade command line experience. Does not require installing and maintaining any databases.
- Lightweight management of data sources. Data objects can exist anywhere in S3, Google Cloud, Azure, or local storage. There is no need to move or duplicate data objects in order to create, share or modify a dataset.
- Advanced manipulation and versioning for datasets. Datasets can be cloned, queried, merged, and sampled. Every change in a dataset is tracked, and provenance of constituent objects can be verified at all times.
- Label-aware operations. Objects can be selected based on annotation metadata, file attributes, or custom ML model queries, and changes to ingress object metadata are versioned.
- LDB datasets are reproducible, shareable, and fast to materialize. A particular dataset version will always point to the same set of data objects and annotations. Datasets are cached during instantiation, so transfers from cloud locations are accelerated.
Contents
How LDB works
LDB indexes immutable storage locations and notes all unique data objects along with their associated annotations (if present). This index can then be queried to construct datasets that work like collections of sparse pointers into the storage. Note that LDB does not save data objects internally, and relies on persistent storage locations to serve (instantiate) the datasets for training.
The main use case for LDB is to create and maintain persistent collections of cloud-based objects. These collections (datasets) are defined by some logical criteria (e.g. annotated with a certain class, created at given time, contains a given number of event instances, etc).
These datasets can then be shared and versioned within LDB, which makes collaboration on dataset membership state (cloning, merging, splitting, adding, and removing objects) manageable and reproducible.
Whenever a dataset needs to be instantiated (for instance, to run a model experiment), LDB copies all relevant objects from storage into the model workspace and compiles linked annotations. Since storage is immutable and all dataset membership state is kept within LDB, the workspace can be safely erased after the experiment is complete.
Quick Start
Please refer to LDB workflow for more a detailed discussion of the Data-driven AI methodology.
LDB instance is a persistent structure where all information about known objects, labels and datasets is being stored. A private LDB instance will be created automatically in the ~/.ldb
directory the first time an LDB dataset is created or an LDB query is run. To set up a shared LDB instance for a team or organization, please follow LDB team setup.
Whenever a new dataset is required or an existing dataset needs an update, it must first be staged in the model workspace. Staging does not automatically instantiate the dataset, but creates a draft state of the dataset membership info and all metadata:
Stage a new dataset
Step | Command |
---|---|
Create a new dataset in the workspace | $ ldb stage ds:my-new-dataset ./ |
Check the status of staged data | $ ldb status |
All subsequent dataset manipulations will apply to this staged dataset.
Logical modifications to dataset staged in the workspace are usually made with ADD and DEL commands that may reference individual objects, other datasets, and employ annotation queries (see LDB queries for details).
Modifying a dataset
Step | Command |
---|---|
Add objects by annotation | $ ldb add s3://iterative/ImageNet-1K —-query class == "cat" |
Sample objects from a location | $ ldb add azure://iterative/OpenImage-1K --sample-rate 10 |
Check the status of a staged dataset | $ ldb list |
LDB is not limited to querying the existing annotations. Custom ML models can be employed for queries beyond JSON fields:
Step | Command |
---|---|
Add objects by ML query: | $ ldb add gs://iterative/COCO-3K —-sort 'CLIP "dog dance"' --limit 100 |
Check the status of a staged dataset | $ ldb list |
At this point, our workspace holds membership info for all cat images from ImageNet, randomly sampled images from COCO, and ten images that mostly resemble dancing dogs from OpenImage. Once this dataset is ready, it can be instantiated (materialized) in the desired output format to train the model.
Instantiation
Step | Command |
---|---|
Instantiate all objects into the workspace in COCO format | $ ldb instantiate --output-format coco |
See the resulting physical dataset | $ ls |
After examining the actual data objects, one might decide to add or remove data samples, or to edit their annotations. LDB can pick the resulting changes right from the workspace:
Notifying LDB on workspace modifications
Step | Command |
---|---|
Pick object list and annotation changes that happened in workspace | $ ldb add ./ |
To save staged dataset into LDB (with all the cumulative changes made so far), one needs to use the commit command.
Dataset saving and versioning
Step | Command |
---|---|
Push a new version of staged dataset to LDB | $ ldb commit |
Every new commit creates a new dataset version in LDB. By default, a reference to an LDB dataset assumes the latest version. Other dataset versions can be explicitly accessed with a version suffix:
Step | Command |
---|---|
Stage a particular version of a dataset | $ ldb stage ds:my-cats.v3 |
Compare current workspace to a previous dataset version | $ ldb diff ds:my-cats.v2 |
If newer annotations will become available for the data object, they can be readded to dataset by name. If all labels need to be updated, this can be done with the pull command.
Annotation versioning
Step | Command |
---|---|
Add an object with particular label version | $ ldb add —-label-version 2 aws://my-awesome-bucket/1.jpg |
Bump label version for an object to latest | $ ldb add aws://my-awesome-bucket/1.jpg |
Bump all labels in a dataset to latest | $ ldb pull |
Comparison to related technologies
A fair question when considering a new ML tool is whether it is worth the investment of time to adopt. This section discusses some LDB alternatives.
First and foremost, LDB is focused on Data-driven AI cycles. This means it is most useful when data corpus is dynamic, and where the models are expressive enough to benefit from enhanced data samples and annotations.
Without a tool like LDB, a team facing the problem of progressively training on better data typically attempts to organize their data sources into datasets by one of the common recipes: (1) datasets as file folders, (2) datasets as spreadsheets or database pages, or (3) datasets under control of an end-to-end ML framework. All these solutions have their limits that we discuss in the greater detail here.
A second question is why one should choose LDB over general data versioning services (like DVC or PachyDerm ) since they can also manage the datasets.
The answer is that capabilities of LDB and general versioning systems do not overlap.
For example, DVC actively manages the model repository, and interprets datasets as file folders under the full version control where access to all objects are guaranteed. On the other hand, LDB is an indexing service over existing immutable storage, and treats datasets as collections of entities. This lightweight approach relies on storage immutability to guarantee access, but offers higher speed and better flexibility in return. In addition, LDB understands annotations and can group sparse objects into datasets by queries.
If your data is indexed in storage by LDB while your models are run by DVC, the two tools will happily work together. DVC can recognize LDB datasets as data sources, and LDB can utilize the shared DVC cache.
Installation
pip (PyPi)
pip install ldb
brew (Homebrew/Mac OS)
brew install ldb
Contributing
- boilerplate contribution call to action
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ldb-alpha-0.1.1.tar.gz
.
File metadata
- Download URL: ldb-alpha-0.1.1.tar.gz
- Upload date:
- Size: 44.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 25225630fc509ae0644c2b2d04eded9e4d35994f437ec002ede5657c1bfda311 |
|
MD5 | ece1a8de8031b535e743fbcb9137512c |
|
BLAKE2b-256 | 2aaab2f2a330b6758f71de5c103f7ed51a042823529ba4374910e85f96f331cc |
File details
Details for the file ldb_alpha-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: ldb_alpha-0.1.1-py3-none-any.whl
- Upload date:
- Size: 48.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 796ad7c57f798ce9af20c71af111ec49f662d257153d035a89d59c514f1387ee |
|
MD5 | 19ebab2ede224ee189494de3ba83c2ea |
|
BLAKE2b-256 | 93027230c60b1dc19062000f173c4d508b483fda0aa4ec7ac9f22fd330662385 |