Learn how to interact with this route using the Ouro SDK or REST API.
API access requires an API key. Create one in Settings → API Keys, then set OURO_API_KEY in your environment.
Request format
Parameters and request body schema for this route.
Parameters
ouro-route-id
in header
ouro-route-org-id
in header
ouro-route-team-id
in header
ouro-action-id
in header
Request body
composition
stringRequired
Chemical composition (e.g., 'PbTe' or 'Bi2Se3')
space_group
Space group symbol (e.g., 'Fd3m', 'P4_2/n', etc.)
temperature
numberDefaults to 0.8
Range: 0.1 to 10
Sampling temperature. 1.0 = no change, < 1.0 = less random, > 1.0 = more random
max_new_tokens
integerDefaults to 3000
Range: 1 to 10000
Number of tokens generated in each sample
Retrieve route
Get route metadata including name, visibility, description, and endpoint details. You can retrieve by route ID or identifier.
import osfrom ouro import Ouro# Set OURO_API_KEY in your environment or replace os.environ.get("OURO_API_KEY")ouro = Ouro(api_key=os.environ.get("OURO_API_KEY"))# Option 1: Retrieve by route IDroute_id = "2443b425-a2bf-4a6f-8202-3ba8b36c921f"route = ouro.routes.retrieve(route_id)# Option 2: Retrieve by route identifier (username/route-name)route_identifier = "mmoderwell/post-generate"route = ouro.routes.retrieve(route_identifier)print(route.name, route.visibility)print(route.metadata)
Use route
Execute the route endpoint with request body, query parameters, or path parameters.
# Retrieve the routeroute = ouro.routes.retrieve("mmoderwell/post-generate")# Use the route with a request bodyresponse = route.use( body={ 'composition': 'example_string', 'temperature': 0.8, 'max_new_tokens': 3000 })print(response)
Read actions
Get the request and response history for this route. Actions are especially useful for long-running routes where you can poll the status and retrieve the response when ready.
# Retrieve the routeroute = ouro.routes.retrieve("mmoderwell/post-generate")# Read all actions (request/response history) for this routeactions = route.read_actions()print(actions)# Actions are especially useful for long-running routes# You can poll the status and retrieve the response when readyfor action in actions: print(f"Action ID: {action['id']}") print(f"Status: {action['status']}") print(f"Response: {action.get('response_data')}")
That's the mission here. The process is pretty simple. Generate magnet candidate -> find out if it's a good candidate -> rinse and repeat.
Anyone can contribute. It's a numbers game, so the more peopl