Skip to main content

BioLM Python client

Project description

https://img.shields.io/pypi/v/biolmai.svg https://api.travis-ci.com/BioLM/py-biolm.svg?branch=production Documentation Status

Python client and SDK for BioLM

Install the package:

pip install biolmai

Basic usage:

from biolmai import biolm

# Encode a single sequence
result = biolm(entity="esm2-8m", action="encode", type="sequence", items="MSILVTRPSPAGEEL")

# Predict a batch of sequences
result = biolm(entity="esmfold", action="predict", type="sequence", items=["SEQ1", "SEQ2"])

# Write results to disk
biolm(entity="esmfold", action="predict", type="sequence", items=["SEQ1", "SEQ2"], output='disk', file_path="results.jsonl")

Asynchronous usage:

from biolmai.core.http import BioLMApiClient
import asyncio

async def main():
    model = BioLMApiClient("esmfold")
    result = await model.predict(items=[{"sequence": "MDNELE"}])
    print(result)

asyncio.run(main())

Overview

The BioLM Python client provides a high-level, user-friendly interface for interacting with the BioLM API. It supports both synchronous and asynchronous usage, automatic batching, flexible error handling, and efficient processing of biological data.

Main features:

  • High-level BioLM constructor for quick requests

  • Sync and async interfaces

  • Automatic or custom rate limiting/throttling

  • Schema-based batch size detection

  • Flexible input formats (single key + list, or list of dicts)

  • Low memory usage via generators

  • Flexible error handling (raise, continue, or stop on error)

  • Universal HTTP client for both sync and async

Features

  • High-level constructor: Instantly run an API call with a single line.

  • Sync and async: Use BioLM for sync, or BioLMApiClient for async.

  • Flexible rate limiting: Use API throttle, disable, or set your own (e.g., ‘1000/second’).

  • Schema-based batching: Automatically queries API for max batch size.

  • Flexible input: Accepts a single key and list, or list of dicts, or list of lists for advanced batching.

  • Low memory: Uses generators for validation and batching.

  • Error handling: Raise HTTPX errors, continue on error, or stop on first error.

  • Disk output: Write results as JSONL to disk.

  • Universal HTTP client: Efficient for both sync and async.

  • Direct access to schema and batching: Use BioLMApi for advanced workflows, including .schema(), .call(), and ._batch_call_autoschema_or_manual().

Example endpoints and actions:

  • esm2-8m/encode: Embedding for protein sequences.

  • esmfold/predict: Structure prediction for protein sequences.

  • progen2-oas/generate: Sequence generation from a context string.

  • dnabert2/predict: Masked prediction for protein sequences.

  • ablang2/encode: Embeddings for paired-chain antibodies.

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

biolmai-0.4.0.tar.gz (2.4 MB view details)

Uploaded Source

Built Distribution

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

biolmai-0.4.0-py2.py3-none-any.whl (114.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file biolmai-0.4.0.tar.gz.

File metadata

  • Download URL: biolmai-0.4.0.tar.gz
  • Upload date:
  • Size: 2.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for biolmai-0.4.0.tar.gz
Algorithm Hash digest
SHA256 7577c9de85e1f8c6df7dc31cbacca63342f49a59ea33fd6cc0936e00eda7b646
MD5 5a9f6fc3839dab4238c66ecb31c66c4a
BLAKE2b-256 98f019788ae5a44535ed12a5d3adb0960d0084e6f5f48a26be25b1aa17724832

See more details on using hashes here.

File details

Details for the file biolmai-0.4.0-py2.py3-none-any.whl.

File metadata

  • Download URL: biolmai-0.4.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 114.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for biolmai-0.4.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f4768080463c278e8984eafc161ddebe2474a8f8fbf424987fadb795b012d06e
MD5 42163deb550019c97fae336a2ceebac0
BLAKE2b-256 d3b7eba172d7381be14b48f43dd5808d96b9f372e8e6efcb0c8d06d0217388ca

See more details on using hashes here.

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