The super.AI Python library provides access to the super.AI API via Python and our command line interface (CLI). Full details on our API are listed in our API reference. For data programmers, we also offer the Data Program Builder.
In this README, you will find the following sections:
In your terminal, run:
pip install superai
Note: If you want to create a data program yourself follow these installation instructions
- Python 3.9 or later
- Dependencies in this package rely on the Clang build tools on MacOS. If you have recently updated or installed XCode, you may have to run
sudo xcodebuild -license
prior to installation. - A super.AI account
Installing the API client provides access to the superai
command from within your terminal.
superai [command]
# Run `--help` for detailed information about CLI commands, including required and optional flags
superai [command] --help
In order to use the CLI, you need to pass us your API key. Use the following command to do this:
superai login --username {username}
Replace {username}
with your super.AI account username.
When prompted, enter your password and press enter. You should see a confirmation like this:
Api key {api-key} was set
If you created your account through Google Sign-In you will need to manually set your API key:
- Find your API key in the super.AI dashboard by hovering over the profile icon in the lower left of the screen, then heading to API keys. You can copy the key by clicking on the copy button.
- Provide your API key to the client using the following command (replacing
{api-key}
with your actual API key):superai config --api-key {api-key}
You can log out and thereby remove your API key by running the following command:
superai logout
login
create_jobs
list_jobs
fetch_job
get_job_responses
cancel_job
download_jobs
fetch_batch_job
fetch_batches_job
create_ground_truth
list_ground_truth_data
get_ground_truth_data
update_ground_truth
delete_ground_truth_data
If you're new to using a CLI, our Getting started with the CLI page can show you the ropes.
This client allows you to run Python scripts on your machine to automate your work processes. For example, you can use a script like this to submit data points for processing to a project that takes image inputs, replacing any {variables}
where necessary:
import superai as ai
client = ai.Client("{api-key}")
client.create_jobs(
app_id="{project-id}",
inputs=[{"image_url":"https://cdn.super.ai/cool-bulldog.jpg"},{"image_url":"https://cdn.super.ai/hot-dog-01.jpeg"}]
)
The super.AI Data Program Builder is a Python SDK that lets you create your own Data Programs. Take a look at our full documentation.
- A super.AI data programmer account. Please contact us to create an account.
- Python >=
3.6
and <3.9
. Python >3.9
is not yet supported. - Java JRE installed. To verify if you have Java installed, run
java --version
. If you don't have it installed, follow the relevant installation instructions: - Note If you are a Windows user, you will need to install Windows Subsystem for Linux(WSL)
- For AI components, Source-to-Image package is required. Check the installation instructions
- Create and activate a virtual environment (we recommend using pyenv-virtualenv or Anaconda)
- If you're using Anaconda, run
conda install -c conda-forge pycryptodome
before moving on
- If you're using Anaconda, run
- Run
pip install --upgrade pip==20.1.1
- Run
pip install "awscli"
- Run
pip install --upgrade "superai>=0.1.0.alpha1"
- Run
superai env set -e sandbox
- Run
superai login -u <user_email>
- Verify that the pip was configured correctly by running
pip config get global.index-url
If the response is empty then runsuperai login --show-pip -u <user_email>
and copy/paste thepip config set...
command as indicated - Install superai in dataprogramming mode
pip install --upgrade "superai[dp]>=0.1.0.beta2"
- For AI components install
pip install --upgrade superai[ai]>=0.1.0.beta2
- Install everything by
pip install --upgrade superai[complete]>=0.1.0.beta2
Creating a basic super AI is a easy as:
- Create a data program name
- Define the input, output and paremeter schemas
- Instantiate a Project class
- Optional: Label some data yourself
import uuid
import superai_schema.universal_schema.data_types as dt
from superai.data_program import Project, WorkerType
# 1) First we need to create the interface of our data program. We do this using schemas that define
# the input, output and parameter types. In this data program we are specifying that its input has
# to be a dictionary that with `key`:mnist_image_url and its value is an image url e.g.
# {"mnist_image_url": "https://superai-public.s3.amazonaws.com/example_imgs/digits/0zero.png"}.
# An an example of the parameters that validate against the parameters schema is:
# params={
# "instructions": "My simple instruction",
# "choices": ["0","1"]
# }
#
# Finally as output this data program is going to generate an object of type exclusive choice that
# looks like: {
# "mnist_class": {
# "choices": [
# {
# "tag": "0",
# "value": "0"
# },
# {
# "tag": "1",
# "value": "1"
# }
# ],
# "selection": {
# "tag": "0",
# "value": "0"
# }
# }
# }
dp_definition = {
"input_schema": dt.bundle(mnist_image_url=dt.IMAGE),
"parameter_schema": dt.bundle(instructions=dt.TEXT, choices=dt.array_to_schema(dt.TEXT, 0)),
"output_schema": dt.bundle(mnist_class=dt.EXCLUSIVE_CHOICE),
}
# 2) Create a data program name (it has to be unique across super.ai)
# Using uuid.getnode() to get a unique name for your first
DP_NAME = "MyFirstDataProgram" + str(uuid.getnode())
# 3) Create a Project project by defining the data pogram parameter values
superAI = Project(
dp_name=DP_NAME,
dp_definition=dp_definition,
params={
"instructions": "My simple instruction",
"choices": [f"{i}" for i in range(10)],
},
)
# 4) Now we are ready to test our Project, so let's submit some jobs for processing. One you run the
# following lines a new browser window will open (because we are passing `open_browser=True` as an
# argument to the process function, and a couple of seconds afterwards you should be able to annotate
# the images yourself
mnist_urls = [
"https://superai-public.s3.amazonaws.com/example_imgs/digits/0zero.png",
"https://superai-public.s3.amazonaws.com/example_imgs/digits/1one.png",
"https://superai-public.s3.amazonaws.com/example_imgs/digits/2two.png",
"https://superai-public.s3.amazonaws.com/example_imgs/digits/3three.png",
]
inputs = [{"mnist_image_url": url} for url in mnist_urls]
labels = superAI.process(inputs=inputs, worker=WorkerType.me, open_browser=True)
You can find more examples in docs/examples
For better logging when using Pycharm, please change your run configuration to have the following switch enabled. It's easier to do it once for the Python runner template for the project.
- Emulate terminal in output console
To build the automation release image, which contains the superai-sdk installed in a virtual environment inside the docker container, run the following command:
Ensure that you have the AWS credentials present in your local environment. We recommend using aws-sso plugin.
earthly -P \
--build-arg AWS_ACCESS_KEY_ID \
--build-arg AWS_SECRET_ACCESS_KEY \
--build-arg AWS_SESSION_TOKEN \
--secret-file aws="$HOME/.aws/credentials" \
+ai-requirements
The SDK allows defining and deploying AI models which integrate with the Super.AI platform. Check out the AI Quickstart Notebook for a first glance. For more information on AI model development check the AI Readme.
The earthly file creates a base image used in the Jenkins pipeline used for AI automation. The definition of the Jenkinsfile is here https://github.com/mysuperai/ai-automation.