A client for the MARA conversational agent for cheminformatics.
Project description
mara client module
This package provides a Python interface for the MARA conversational agent for cheminformatics.
Installation
pip install mara-client
Usage
To use the MARA client, you need to have an API key. You can create one at https://mara.nanome.ai/settings/api-keys.
MARA chats are created using the new_chat
method, or retrieved with the get_chat
method of the client. You can then interact with the chat using the prompt
method. The prompt
method returns a ChatResult
object, which contains the response from MARA, intermediate messages such as tool runs, and any files that were generated during the conversation. You can download these files using the download_file
method of the chat. Chat will be visible as conversations in the MARA web interface, and can be deleted using the delete
method.
import mara_client
API_KEY = "..."
URL = "https://mara.example.com" # optional
client = mara.Client(API_KEY, URL)
chat = client.new_chat()
# or, chat = client.get_chat("chat_id")
result = chat.prompt('Download SDF of aspirin')
print(result.response)
# The SDF file for the compound aspirin has been downloaded successfully. You can access it [here](CHEMBL25.sdf).
print(result.files)
# [ChatFile(id='...', name='CHEMBL25.sdf', size=1203, date=...)]
chat.files.download('CHEMBL25.sdf', 'aspirin.sdf')
# downloaded as aspirin.sdf in current working directory
result = chat.prompt('Calculate chem props')
print(result.response)
# The chemical properties of the compound with ChEMBL ID CHEMBL25 (aspirin) are as follows:
#
# | Property | Value |
# | --- | --- |
# | Molecular Weight (MW) | 180.159 |
# | LogP | 1.310 |
# | Total Polar Surface Area (TPSA) | 63.600 |
# | Hydrogen Bond Acceptors (HBA) | 3 |
# | Hydrogen Bond Donors (HBD) | 1 |
# | Rotatable Bonds (RB) | 2 |
chat.delete()
# remove chat from history, delete associated files and data
Data Tables
The chat object contains a datatables
attribute for working with DataTables.
# Create a data table from already uploaded file
csv_file = './example.csv'
datatable: DataTable = chat.datatables.create(csv_file)
# List all data tables
table_list = chat.datatables.list()
# Generate a new DataTable based on Chat context
chat.datatables.generate()
# Run prompt to update/query a datatable
dt_id = datatable.id
chat.datatables.prompt(dt_id, prompt)
# Retrieve a datatable
chat.datatables.get(dt_id)
# View datatable as a pandas Dataframe
df = datatable.dataframe
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 mara_client-0.14.2.tar.gz
.
File metadata
- Download URL: mara_client-0.14.2.tar.gz
- Upload date:
- Size: 5.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 079a92ad5bf4a20feceec21006859013a9831ca859e809a1532263a8a071b56b |
|
MD5 | c9c2464c7921d6353db316847723f9eb |
|
BLAKE2b-256 | b7371db7d43aa09adf62d13df57c316b4bc3c764415674adda62eb588f82d6c1 |
File details
Details for the file mara_client-0.14.2-py3-none-any.whl
.
File metadata
- Download URL: mara_client-0.14.2-py3-none-any.whl
- Upload date:
- Size: 6.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 871d6df1608964de09a0010a85fab0a45fb67631e761b2200ea3c75067000b44 |
|
MD5 | 88a5c607691bac3f50f16a6d132dd107 |
|
BLAKE2b-256 | 55267311c3de9e3edbc90fdfb9b27df2e86e16115c090b1c45dc1f19a80ae5b1 |