Skip to main content

CUDA kernel optimization agent powered by OpenEvolve

Project description

EvoKernel

CUDA kernel optimization agent powered by OpenEvolve.

Quick Start

# Install as CLI tool (requires Python 3.10-3.13)
pipx install evokernel
# or with uv
uv tool install evokernel

# Setup Modal (GPU evaluator)
modal setup

# Configure OpenRouter API key
evokernel setup

# Run in any project directory
evokernel

Development Install

git clone https://github.com/haladir-ai/EvoKernel.git
cd EvoKernel
uv tool install .

Usage

Just run evokernel in a directory with CUDA kernels and chat with the agent:

> optimize my_kernel.cu

> check status

> show the best result

> apply changes

Current Features

  • Speedup optimization: Maximizes kernel throughput via evolutionary search
  • EVOLVE markers: Define which code regions to optimize
  • Modal GPU evaluation: Compile and benchmark on cloud A100 (default)
  • Local GPU evaluation: Run benchmarks on your own GPU (for codebases with dependencies)
  • LLM ensemble: Uses Gemini, Claude, GPT via OpenRouter

Evaluator Modes

Mode Use Case
modal (default) Self-contained kernels, no local GPU needed
local Kernels with custom headers/dependencies

Roadmap (Not Yet Implemented)

  • Memory optimization goal: Minimize memory usage instead of speedup
  • Target hardware selection: Optimize for specific GPUs (A100, H100, V100)
  • Energy efficiency goal: Minimize power consumption

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

evokernel-0.3.0.tar.gz (821.1 kB view details)

Uploaded Source

Built Distribution

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

evokernel-0.3.0-py3-none-any.whl (947.3 kB view details)

Uploaded Python 3

File details

Details for the file evokernel-0.3.0.tar.gz.

File metadata

  • Download URL: evokernel-0.3.0.tar.gz
  • Upload date:
  • Size: 821.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for evokernel-0.3.0.tar.gz
Algorithm Hash digest
SHA256 38019eebcfbfb6ed65ed1e85220813c81d15b5ffbbbf8a6e684a88d57b8f1ab0
MD5 1ac6a1425aa95575b93fbc6dd282c776
BLAKE2b-256 6f240156e9c04b53bc34f757fff53fc9f1a0ad121132bbb3c3911aee208faf73

See more details on using hashes here.

Provenance

The following attestation bundles were made for evokernel-0.3.0.tar.gz:

Publisher: publish.yml on haladir-ai/EvoKernel

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file evokernel-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: evokernel-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 947.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for evokernel-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 68ddff240dca5ced1946cb7abe99fb0ef230a3efd7d9b8771e4dbeacf7e87150
MD5 4ca2ef9f8153b71768bec5cfb1ca6096
BLAKE2b-256 057e173ac19f79ce39c30ddfb50cd7ae572eaaf124aa520aca9679d56546557a

See more details on using hashes here.

Provenance

The following attestation bundles were made for evokernel-0.3.0-py3-none-any.whl:

Publisher: publish.yml on haladir-ai/EvoKernel

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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