Skip to main content

Library and command line interface for darwin.v7labs.com

Project description

V7 Darwin Python SDK

Downloads Downloads GitHub Repo stars Twitter Follow OpenSSF Scorecard

⚡️ Official library to annotate, manage datasets, and models on V7's Darwin Training Data Platform. ⚡️

Darwin-py can both be used from the command line and as a python library.


Main functions are (but not limited to):

  • Client authentication
  • Listing local and remote datasets
  • Create/remove datasets
  • Upload/download data to/from remote datasets
  • Direct integration with PyTorch dataloaders
  • Extracting video artifacts

Support tested for python 3.10 - 3.13

🏁 Installation

pip install darwin-py

You can now type darwin in your terminal and access the command line interface.

If you wish to use the PyTorch bindings, then you can use the ml flag to install all the additional requirements

pip install darwin-py[ml]

If you wish to use video frame extraction, then you can use the ocv flag to install all the additional requirements

pip install darwin-py[ocv]

If you wish to use video artifacts extraction, then you need to install FFmpeg

To run test, first install the test extra package

pip install darwin-py[test]

Configuration

Retry Configuration

The SDK includes a retry mechanism for handling API rate limits (429) and server errors (500, 502, 503, 504). You can configure the retry behavior using the following environment variables:

  • DARWIN_RETRY_INITIAL_WAIT: Initial wait time in seconds between retries (default: 60)
  • DARWIN_RETRY_MAX_WAIT: Maximum wait time in seconds between retries (default: 300)
  • DARWIN_RETRY_MAX_ATTEMPTS: Maximum number of retry attempts (default: 10)

Example configuration:

# Configure shorter retry intervals and fewer attempts
export DARWIN_RETRY_INITIAL_WAIT=30
export DARWIN_RETRY_MAX_WAIT=120
export DARWIN_RETRY_MAX_ATTEMPTS=5

The retry mechanism will automatically handle:

  • Rate limiting (HTTP 429)
  • Server errors (HTTP 500, 502, 503, 504)

For each retry attempt, you'll see a message indicating the type of error and the wait time before the next attempt.

Development

See our development and QA environment installation recommendations here


Usage as a Command Line Interface (CLI)

Here you can find V7 labs doc on the CLI usage

Once installed, darwin is accessible as a command line tool. A useful way to navigate the CLI usage is through the help command -h/--help which will provide additional information for each command available.

Client Authentication

To perform remote operations on Darwin you first need to authenticate. This requires a team-specific API-key. If you do not already have a Darwin account, you can contact us and we can set one up for you.

To start the authentication process:

$ darwin authenticate
API key:
Make example-team the default team? [y/N] y
Datasets directory [~/.darwin/datasets]:
Authentication succeeded.

You will be then prompted to enter your API-key, whether you want to set the corresponding team as default and finally the desired location on the local file system for the datasets of that team. This process will create a configuration file at ~/.darwin/config.yaml. This file will be updated with future authentications for different teams.

Listing local and remote datasets

Lists a summary of local existing datasets

$ darwin dataset local
NAME            IMAGES     SYNC_DATE         SIZE
mydataset       112025     yesterday     159.2 GB

Lists a summary of remote datasets accessible by the current user.

$ darwin dataset remote
NAME                       IMAGES     PROGRESS
example-team/mydataset     112025        73.0%

Create/remove a dataset

To create an empty dataset remotely:

$ darwin dataset create test
Dataset 'test' (example-team/test) has been created.
Access at https://darwin.v7labs.com/datasets/579

The dataset will be created in the team you're authenticated for.

To delete the project on the server:

$ darwin dataset remove test
About to delete example-team/test on darwin.
Do you want to continue? [y/N] y

Upload/download data to/from a remote dataset

Uploads data to an existing remote project. It takes the dataset name and a single image (or directory) with images/videos to upload as parameters.

The -e/--exclude argument allows to indicate file extension/s to be ignored from the data_dir. e.g.: -e .jpg

For videos, the frame rate extraction rate can be specified by adding --fps <frame_rate>

Supported extensions:

  • Video files: [.mp4, .bpm, .mov, .avi, .mkv, .hevc, .pdf, .dcm, .nii, .nii.gz, .ndpi, .rvg formats].
  • Image files [.jpg, .jpeg, .png, .jfif, .tif, .tiff, .qtiff, .bmp, .svs, .webp, .JPEG, .JPG, .BMP formats].
$ darwin dataset push test /path/to/folder/with/images
100%|████████████████████████| 2/2 [00:01<00:00,  1.27it/s]

Before a dataset can be downloaded, a release needs to be generated:

$ darwin dataset export test 0.1
Dataset test successfully exported to example-team/test:0.1

This version is immutable, if new images / annotations have been added you will have to create a new release to included them.

To list all available releases

$ darwin dataset releases test
NAME                           IMAGES     CLASSES                   EXPORT_DATE
example-team/test:0.1               4           0     2019-12-07 11:37:35+00:00

And to finally download a release.

$ darwin dataset pull test:0.1
Dataset example-team/test:0.1 downloaded at /directory/choosen/at/authentication/time .

Usage as a Python library

Here you can find V7 labs doc on the usage as Python library

The framework is designed to be usable as a standalone python library. Usage can be inferred from looking at the operations performed in darwin/cli_functions.py. A minimal example to download a dataset is provided below and a more extensive one can be found in

./darwin_demo.py.

from darwin.client import Client

client = Client.local() # use the configuration in ~/.darwin/config.yaml
dataset = client.get_remote_dataset("example-team/test")
dataset.pull() # downloads annotations and images for the latest exported version

Follow this guide for how to integrate darwin datasets directly in PyTorch.

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

darwin_py-3.5.2.tar.gz (256.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

darwin_py-3.5.2-py3-none-any.whl (352.4 kB view details)

Uploaded Python 3

File details

Details for the file darwin_py-3.5.2.tar.gz.

File metadata

  • Download URL: darwin_py-3.5.2.tar.gz
  • Upload date:
  • Size: 256.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for darwin_py-3.5.2.tar.gz
Algorithm Hash digest
SHA256 09771280eaef76aaa57655457199e61116bf366f7bcac9022e33ea5182217090
MD5 3c70de871b29788a9a4912c30ef5b054
BLAKE2b-256 31468368abd19a36ac03efe343d3372a0f1df03258d70d8d25ba06ade621b4d3

See more details on using hashes here.

Provenance

The following attestation bundles were made for darwin_py-3.5.2.tar.gz:

Publisher: EVENT_release.yml on v7labs/darwin-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file darwin_py-3.5.2-py3-none-any.whl.

File metadata

  • Download URL: darwin_py-3.5.2-py3-none-any.whl
  • Upload date:
  • Size: 352.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for darwin_py-3.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ec8502238188014caf2c19261e5c2f2d4981ce2f001173a119f55efe62be18c3
MD5 b7ab698090a8c5531c58bed4498562ec
BLAKE2b-256 54dcb3727d7c18a7265203afe005f172bdff9a1edfe34f652d4e52e7f66da5df

See more details on using hashes here.

Provenance

The following attestation bundles were made for darwin_py-3.5.2-py3-none-any.whl:

Publisher: EVENT_release.yml on v7labs/darwin-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page