Tools for development with the Rendered.AI Ana Platform.
Project description
AnaTools
Project Description
Anatools is a python package with modules for developing with the Ana Platform from Rendered.AI. With AnaTools you can generate and access synthetic datasets, and much more!
>>> import anatools
>>> ana = anatools.AnaClient()
'Enter your credentials for Ana.'
'email:' example@rendered.ai
'password:' ***************
>>> ana.get_channels()
['mychannel1', 'mychannel2']
>>> graphs = ana.get_graphs()
>>> datasets = ana.get_datasets()
Install the AnaTools Package
(Optional) Create a new Conda Environment
- Install conda for your operating system: https://www.anaconda.com/products/individual.
- Create a new conda environment and activate it.
- Install anatools from the Python Package Index.
$ conda create -n renderedai python=3.7
$ conda activate renderedai
Install AnaTools to the Python Environment
- Install AnaTools from the Python Package Index.
$ pip install anatools
Dependencies
The anatools package requires python 3.6 or higher and has dependencies on the following packages:
Package | Description |
---|---|
pyrebase | A python wrapper for Google Firebase API. |
jwt | A python library for encoding and decoding JSON web tokens. |
keyring | A python library for storing and accessing passwords securely. |
docker | A python library for the Docker Engine API. |
sphinx | A python documentation generator. |
pytest | A python testing framework. |
pyyaml | A python YAML parser and emitter. |
If you have any questions or comments, contact Rendered.AI at info@rendered.ai.
Quickstart Guide
What is Ana?
Ana is a synthetic dataset generation tool where graphs describe what and how synthetic datasets are generated.
Terms | Definitions |
---|---|
workspace | A workspace is a collection of data used for a particular use-case, for example workspaces can be used to organize data for different projects. |
dataset | A dataset is a collection of data, for many use-cases these are images with text-based annotation files. |
graph | A graph is defined by nodes and links, it describes the what and the how a dataset is generated. |
node | A node can be described as an executable block of code, it has inputs and runs some algorithm to generate outputs. |
link | A link is used to transfer data from the output of one node, to the input of other nodes. |
channel | A channel is a collection of nodes, it is used to limit the scope of what is possible to generate in a dataset (like content from a tv channel). |
How do you use Ana?
Ana creates synthetic datasets by processing a graph, so we will need to create our Ana client, create a graph, then create a dataset.
- Execute the python command line, create a client and login to Ana. In this example we are instantiating a client with no workspace or environment variables, so it is setting our default workspace. To access the tool, you will need to use your email and password for https://deckard.rendered.ai.
>>> import anatools
>>> ana = anatools.AnaClient()
'Enter your credentials for Ana.'
'email:' example@rendered.ai
'password:' ***************
- Create a graph file called 'graph.yml' with the code below. We are defining a simplistic graph for this example with multiple cubes dropped into a container. Graphs are usually stored in json or yaml format, but read into a python dictionary to be passed to the API.
nodes:
Cube:
class: CubeGenerator
ObjectPlacement:
class: RandomPlacement
inputs:
object_generator: {$link: [Cube, object_generator]}
object_number: '5'
Container:
class: ContainerGenerator
DropObjects:
class: DropObjectsNode
inputs:
objects: {$link: [ObjectPlacement, objects]}
container_generator: {$link: [Container, object_generator]}
Render:
class: RenderNode
inputs:
frame_number: 150
target_object: {$link: [DropObjects, target_object]}
annotated_objects: {$link: [DropObjects, annotated_objects]}
- Create a graph using the client. To create a new graph, we load the graph defined above into a python dictionary using the yaml python package. Then we create a graph using the client, this graph is being named 'testgraph' and is using the 'example' channel. The client will return a graphid so we can reference this graph later.
>>> import yaml
>>> with open('graph.yml') as graphfile:
>>> graph = yaml.safe_load(graphfile)
>>> graphid = ana.create_graph(name='testgraph',channel='example',graph=graph)
>>> graphid
'e175a44e-23a5-11eb-adc1-0242ac120002'
- Create a dataset using the client. Using the graphid, we can create a new job to generate a dataset.
The client will return a datasetid that can be used for reference later.
>>> datasetid = ana.create_dataset(name='testdataset',graphid=graphid,interpretations='10',priority='1',seed='1',description='A simple dataset with cubes in a container.')
>>> datasetid
'ce66e81c-23a6-11eb-adc1-0242ac120002 '
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 anatools-1.0.4.tar.gz
.
File metadata
- Download URL: anatools-1.0.4.tar.gz
- Upload date:
- Size: 17.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | afe9ad267efc4d6f0c192566f7337097e29d6249c02abae8c7616492b8d75157 |
|
MD5 | 3949a2a4fd9fd4479332551b889da131 |
|
BLAKE2b-256 | 3f93da1859d4ac55ec05a768166905020c78377b20b69af06cfebfaf2fe3f3dc |
File details
Details for the file anatools-1.0.4-py3-none-any.whl
.
File metadata
- Download URL: anatools-1.0.4-py3-none-any.whl
- Upload date:
- Size: 16.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 915d281b9dc57bee62ce4f0e9bdcf91c2218c9ad9628bf783151f9277e83bfb5 |
|
MD5 | 2f5766d5035bced0d0e33f8feac197fa |
|
BLAKE2b-256 | 47984ecb8329eb41eb75905a2731e350e49f45210befebfc948d995ce3befa9a |