x-evolution
Project description
x-evolution
Implementation of various evolutionary algorithms, starting with evolutionary strategies
Install
$ pip install x-evolution
Usage
import torch
from x_evolution import EvoStrategy
# model
from torch import nn
model = torch.nn.Sequential(
nn.Linear(8, 16),
nn.ReLU(),
nn.Linear(16, 4)
)
# evolution wrapper
evo_strat = EvoStrategy(
model,
environment = lambda model: torch.randint(0, 100, ()), # environment is just a function that takes in the individual model (with unique noise) and outputs the fitness - you can select for whatever you want here (rewards, model complexity, etc etc), does not have to be differentiable.
noise_population_size = 30,
num_generations = 100,
learning_rate = 1e-3,
noise_scale = 1e-3,
params_to_optimize = None # defaults to all parameters, but can be [str {param name}] or [Parameter]
)
# do evolution with your desired fitness function for so many generations
evo_strat()
# model will be saved under checkpoints/ folder
# can also specify checkpoint_every at init and select the one with your favored fitness score for continued policy gradient learning etc
Distributed
Using the CLI from 🤗
$ accelerate config
Then
$ accelerate launch train.py
Citations
@article{Qiu2025EvolutionSA,
title = {Evolution Strategies at Scale: LLM Fine-Tuning Beyond Reinforcement Learning},
author = {Xin Qiu and Yulu Gan and Conor F. Hayes and Qiyao Liang and Elliot Meyerson and Babak Hodjat and Risto Miikkulainen},
journal = {ArXiv},
year = {2025},
volume = {abs/2509.24372},
url = {https://api.semanticscholar.org/CorpusID:281674745}
}
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
x_evolution-0.0.16.tar.gz
(8.3 kB
view details)
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 x_evolution-0.0.16.tar.gz.
File metadata
- Download URL: x_evolution-0.0.16.tar.gz
- Upload date:
- Size: 8.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4226a9729d743e1ff9fc3c3ce38dcc506faad113b1087e7093705ff75c21c220
|
|
| MD5 |
dc4bf901058412f2bd5061c3ed0d9c66
|
|
| BLAKE2b-256 |
0ba22816a572c7f554545a6e8ca39c5233dd007ee4aa0e3f33a7525228a7d669
|
File details
Details for the file x_evolution-0.0.16-py3-none-any.whl.
File metadata
- Download URL: x_evolution-0.0.16-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
aaae6f9ab72d450431a27bcbf1aeb94275d565e8d51ef660e02211c1ff9ed278
|
|
| MD5 |
37f3c23b888749f5a04dbe3f470e829b
|
|
| BLAKE2b-256 |
e9c99b81528be1a1d279ec95a2ca0d678c525c1dfbf7426d96d0c3fced26b067
|