Skip to main content

A framework for easily producing custom agens for your Encord Workflows.

Project description

Documentation | Try it Now | Blog | Join our Community

Encord logo

Easily build agents for the Encord echo system. With just few lines of code, you can take automation to the next level.

Key features:

  1. Easy: Multiple template agents to be adapted and hosted via GCP, own infra, or cloud.
  2. Convenient: The library conveniently loads data via the Encord SDK upon request.
  3. 👨‍💻 Focus: With essential resources readily available, you can focus on what matters. Create agents with pre-existing (or custom) dependencies for loading labels and data.
  4. 🤏 Slim: the library is slim at it's core and should not conflict with the dependencies of most projects.

💡 For the full documentation and end-to-end examples, please see here.

Here are some use-cases:

Decision tree for which agent to use

Here's how to build an Agent:

from uuid import UUID
from encord.objects.ontology_labels_impl import LabelRowV2
from encord_agents.tasks import Runner

runner = Runner(project_hash="<your_project_hash>")


@runner.stage(UUID("<your_agent_stage_uuid>"))
def by_file_name(lr: LabelRowV2) -> UUID | None:
    # Assuming the data_title is of the format "%d.jpg"
    # and in the range [0; 100]
    priority = int(lr.data_title.split(".")[0]) / 100
    lr.set_priority(priority=priority)
    return UUID("<your_pathway_uuid>")


if __name__ == "__main__":
    runner.run()

You can also inject dependencies:

from typing_extensions import Annotated

from encord.objects import LabelRowV2
from encord_agents.tasks import Runner, Depends

runner = Runner(project_hash="<your_project_hash>")

def my_custom_dependency(label_row: LabelRowV2) -> dict:
    # e.g., look up additional data in own db
    return db.query("whatever")

@runner.stage(stage="<my_stage_name>")
def by_custom_data(
    custom_data: Annotated[dict, Depends(my_custom_dependency)]
) -> str:
    # `custom_data` automatically injected here.
    # ... do your thing
    # then, return name of task pathway.


if __name__ == "__main__":
    runner.run()

Please visit our 📖 Documentation for a complete reference to how to use the agents library.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

encord_agents-0.1.0.tar.gz (23.1 kB view details)

Uploaded Source

Built Distribution

encord_agents-0.1.0-py3-none-any.whl (30.0 kB view details)

Uploaded Python 3

File details

Details for the file encord_agents-0.1.0.tar.gz.

File metadata

  • Download URL: encord_agents-0.1.0.tar.gz
  • Upload date:
  • Size: 23.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.6 Linux/6.5.0-1025-azure

File hashes

Hashes for encord_agents-0.1.0.tar.gz
Algorithm Hash digest
SHA256 6d0834878f22775dd4725b7981eeb84b72326a8b3cc0b9c6a73c4f18e43f4081
MD5 6f16338d45861c63bad11ec55e7d1e22
BLAKE2b-256 8970c30fbc17e2b4a3115d745e49dbda466055df6f8311f879251f822bd16193

See more details on using hashes here.

File details

Details for the file encord_agents-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: encord_agents-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 30.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.6 Linux/6.5.0-1025-azure

File hashes

Hashes for encord_agents-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7c33cb407214dd37fe831508dbe224a3b4dbe11f94ebf293c8a3e4074c7c0476
MD5 a3a81586b09cb64270ae274c39efa138
BLAKE2b-256 cf33c4642f85f49d948e9e5a0b9bce78c513e976fe2d3b7de6c05dc8bbd23143

See more details on using hashes here.

Supported by

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