Helper library for interacting with Landing AI LandingLens
Project description
LandingLens Python SDK
The LandingLens Python SDK contains the LandingLens development library and examples that show how to integrate your app with LandingLens in a variety of scenarios. The examples cover different model types, image acquisition sources, and post-procesing techniques.
We've provided some examples in Jupyter Notebooks to focus on ease of use, and some examples in Python apps to provide a more robust and complete experience.
Example | Description | Type |
---|---|---|
Poker Card Suit Identification | This notebook shows how to use an object detection model from LandingLens to detect suits on playing cards. A webcam is used to take photos of playing cards. | Jupyter Notebook |
Door Monitoring for Home Automation | This notebook shows how to use an object detection model from LandingLens to detect whether a door is open or closed. An RTSP camera is used to acquire images. | Jupyter Notebook |
Streaming Video | This application shows how to continuously run inference on images extracted from a streaming RTSP video camera feed. | Python application |
Satellite Images and Post-Processing | This notebook shows how to use a Visual Prompting model from LandingLens to identify different objects in satellite images. The notebook includes post-processing scripts that calculate the percentage of ground cover that each object takes up. | Jupyter Notebook |
Install the Library
pip install landingai
Quick Start
Prerequisites
This library needs to communicate with the LandingLens platform to perform certain functions. (For example, the Predictor
API calls the HTTP endpoint of your deployed model). To enable communication with LandingLens, you will need the following information:
- The Endpoint ID of your deployed model in LandingLens. You can find this on the Deploy page in LandingLens.
- The API Key and API Secret for the LandingLens organization that has the model you want to deploy. To learn how to generate these credentials, go here.
Run Inference
Run inference using the endpoint you created in LandingLens:
- Install the Python library.
- Create a
Predictor
fucntion with your Endpoint ID, API Key, and API Secret. - Call the
predict()
function with an image (using the NumPy array format).
from landingai.predict import Predictor
# Find your API key and secrets
endpoint_id = "FILL_YOUR_INFERENCE_ENDPOINT_ID"
api_key = "FILL_YOUR_API_KEY"
api_secret = "FILL_YOUR_API_SECRET"
# Load your image
image = ...
# Run inference
predictor = Predictor(endpoint_id, api_key, api_secret)
predictions = predictor.predict(image)
See a working example in here.
Visualize and Save Predictions
Visualize your inference results by overlaying the predictions on the input image and saving the updated image:
from landingai.visualize import overlay_predictions
# continue the above example
predictions = predictor.predict(image)
image_with_preds = overlay_predictions(predictions, image)
image_with_preds.save("image.jpg")
Putting together a vision pipeline
All the modules shown above and others can be chained together using the vision_pipeline
abstraction. At its core, a pipeline is a sequence of chained calls that operate on a FrameSet
.
cloud_sky_model = Predictor("FILL_YOUR_INFERENCE_ENDPOINT_ID"
, "FILL_YOUR_API_KEY"
, "FILL_YOUR_API_SECRET")
Camera = NetworkedCamera(stream_url)
for frame in Camera:
(
frame.downsize(width=1024)
.run_predict(predictor=cloud_sky_model)
.overlay_predictions()
.show_image()
.save_image(filename_prefix="./capture")
)
Run Examples Locally
All the examples in this repo can be run locally.
To give you some guidance, here's how you can run the rtsp-capture
example locally in a shell environment:
- Clone the repo to local:
git clone https://github.com/landing-ai/landingai-python.git
- Install the library:
poetry install --with examples
(Note: See Developer Guide for how to installpoetry
) - Activate the virtual environment:
poetry shell
- Run:
python landingai-python/examples/capture-service/run.py
Documentation
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 landingai-0.0.40.tar.gz
.
File metadata
- Download URL: landingai-0.0.40.tar.gz
- Upload date:
- Size: 24.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.10.11 Linux/5.15.0-1038-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 27d75c948c09ecfcb0ae8147cf7cfc13593a4f6e18552dfba8aff41c4f1c7645 |
|
MD5 | deab22aac9d35ea83f38b8710a4fedb1 |
|
BLAKE2b-256 | f5b9bd91b076dda3a3494374df1e8dc93d5608bbe3e322e41410e08c7daab25f |
File details
Details for the file landingai-0.0.40-py3-none-any.whl
.
File metadata
- Download URL: landingai-0.0.40-py3-none-any.whl
- Upload date:
- Size: 26.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.10.11 Linux/5.15.0-1038-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ce4caf411f708a42ea9bc95da3d956cbf2611e4353f5129862fc4d62b9f3c269 |
|
MD5 | cee5eda62911586709208f2fdd8e9541 |
|
BLAKE2b-256 | ce0e90ff136202a45655c9e3e9087ba6462852e3371702fb745ae0e4c57db2a5 |