Official Python SDK for the Vilvik optimization cloud API.
Project description
vilvik
Official Python SDK for Vilvik, a cloud platform for running and tracking optimization jobs through a REST API, with scoped keys and webhook delivery. Vilvik currently runs Genetic Algorithm (PyGAD) workloads, and this SDK gives your Python code a typed client, a submit-and-wait helper, and a clean error hierarchy to drive them.
Documentation: SDK guide · REST API reference · all docs
pip install vilvik
Quick start
import vilvik
client = vilvik.Client(api_key="vlk_live_…")
submission = client.submissions.create(
fitness_func="""
def fitness_func(ga_instance, solution, idx):
return -sum(s * s for s in solution)
""",
num_genes=5,
num_generations=100,
sol_per_pop=50,
name="quadratic-minimisation",
)
print(submission.id, submission.status) # "abc123…", "queued"
result = client.results.wait_for(submission.id, timeout=300)
print(result.best_fitness, result.best_solution)
The run() one-liner
For scripts and notebook cells, vilvik.run(...) packages create-and-wait
into a context manager that also cancels the run if you exit the block
early:
import vilvik
fn = """
def fitness_func(ga_instance, solution, idx):
return -sum(s * s for s in solution)
"""
with vilvik.run(fitness_func=fn, num_genes=5, num_generations=50) as result:
print(result.best_fitness)
The API key is read from VILVIK_API_KEY if you do not pass it
explicitly.
Listing and pagination
The list endpoints return a Page whose items are typed dataclasses; for
walking everything use iter_all:
page = client.submissions.list(limit=25)
for sub in page:
print(sub.id, sub.status, sub.name)
# All submissions, transparently following the cursor:
for sub in client.submissions.iter_all():
...
Branching a finished run
Results.continue_run branches a fresh run from a finished result. Each
call creates a child submission whose parent_submission is the result
you forked from. Pass any GA parameter you want to override:
parent = client.results.get(result_id)
variant_a = client.results.continue_run(parent.id, mutation_probability=0.10)
variant_b = client.results.continue_run(parent.id, sol_per_pop=100)
The Vilvik dashboard renders the resulting lineage as an interactive tree on the result page.
Errors
Every SDK error inherits from vilvik.VilvikError. Subclasses let you
catch specific failure modes:
try:
client.submissions.get("does-not-exist")
except vilvik.NotFoundError as e:
print("Not found:", e.request_id)
except vilvik.RateLimitError as e:
print("Slow down, retry after", e.retry_after, "seconds")
except vilvik.AuthenticationError:
print("Check your API key and scopes")
except vilvik.VilvikError:
print("Something else went wrong")
Configuration
| Argument | Default | Notes |
|---|---|---|
api_key |
os.environ["VILVIK_API_KEY"] |
Required. Bearer token created in the dashboard. |
base_url |
https://vilvik.com/api/v1 |
Override for staging or self-hosted instances. |
timeout |
60.0 seconds |
Per-HTTP-request timeout. |
max_retries |
2 |
Idempotent (GET / HEAD) retries on network errors. |
Documentation
The full SDK guide lives at https://vilvik.com/docs/sdk/, with a page per feature:
- Installation and configuration
- Submissions,
results, and the
run()helper - Importing a local PyGAD run, code uploads, and webhooks
- Error handling and worked examples
Every SDK page links to the matching REST API reference, so you can drop down to the raw HTTP calls whenever you need to.
Development
pip install -e ".[dev]"
pytest
License
MIT.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file vilvik-0.2.2.tar.gz.
File metadata
- Download URL: vilvik-0.2.2.tar.gz
- Upload date:
- Size: 26.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
69e0190e11b0b8cb7594d90e8b5eb3731d1816794b21c3411970df8cea4db10c
|
|
| MD5 |
a0709f09b6a2a277e44597d138472376
|
|
| BLAKE2b-256 |
e3a8c57616fd7015d75ae8f6895db6e3930668fb0f50c35c9e8411357470d21e
|
File details
Details for the file vilvik-0.2.2-py3-none-any.whl.
File metadata
- Download URL: vilvik-0.2.2-py3-none-any.whl
- Upload date:
- Size: 22.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
25388e6e2214ef7edd5231de89d17744f2cd506ccc0aa3913295167442e0583b
|
|
| MD5 |
66f9530713c43c5515a38fdfe9c91c4a
|
|
| BLAKE2b-256 |
913e1309fe0b320db63abf5a982be0a1cf026626f961235a37808029554acbfa
|