2025-11-13 22:53:46 +01:00
## General Optimization Configuration
<!-- pyml disable line - length -->
:::{table} optimization
:widths: 10 20 10 5 5 30
:align: left
| Name | Environment Variable | Type | Read-Only | Default | Description |
| ---- | -------------------- | ---- | --------- | ------- | ----------- |
2026-02-28 11:31:51 +01:00
| algorithm | `EOS_OPTIMIZATION__ALGORITHM` | `Optional[str]` | `rw` | `GENETIC` | The optimization algorithm. |
| genetic | `EOS_OPTIMIZATION__GENETIC` | `Optional[akkudoktoreos.optimization.optimization.GeneticCommonSettings]` | `rw` | `None` | Genetic optimization algorithm configuration. |
| horizon_hours | `EOS_OPTIMIZATION__HORIZON_HOURS` | `Optional[int]` | `rw` | `24` | The general time window within which the energy optimization goal shall be achieved [h]. Defaults to 24 hours. |
| interval | `EOS_OPTIMIZATION__INTERVAL` | `Optional[int]` | `rw` | `3600` | The optimization interval [sec]. |
2025-12-30 22:08:21 +01:00
| keys | | `list[str]` | `ro` | `N/A` | The keys of the solution. |
2025-11-13 22:53:46 +01:00
:::
<!-- pyml enable line - length -->
<!-- pyml disable no - emphasis - as - heading -->
2025-12-30 22:08:21 +01:00
**Example Input**
2025-11-13 22:53:46 +01:00
<!-- pyml enable no - emphasis - as - heading -->
<!-- pyml disable line - length -->
```json
{
"optimization": {
"horizon_hours": 24,
"interval": 3600,
"algorithm": "GENETIC",
"genetic": {
"individuals": 400,
"generations": 400,
"seed": null,
"penalties": {
"ev_soc_miss": 10
}
}
}
}
```
<!-- pyml enable line - length -->
2025-12-30 22:08:21 +01:00
<!-- pyml disable no - emphasis - as - heading -->
**Example Output**
<!-- pyml enable no - emphasis - as - heading -->
<!-- pyml disable line - length -->
```json
{
"optimization": {
"horizon_hours": 24,
"interval": 3600,
"algorithm": "GENETIC",
"genetic": {
"individuals": 400,
"generations": 400,
"seed": null,
"penalties": {
"ev_soc_miss": 10
}
},
"keys": []
}
}
```
<!-- pyml enable line - length -->
2025-11-13 22:53:46 +01:00
### General Genetic Optimization Algorithm Configuration
<!-- pyml disable line - length -->
:::{table} optimization::genetic
:widths: 10 10 5 5 30
:align: left
| Name | Type | Read-Only | Default | Description |
| ---- | ---- | --------- | ------- | ----------- |
2026-02-28 11:31:51 +01:00
| generations | `Optional[int]` | `rw` | `400` | Number of generations to evaluate the optimal solution [>= 10]. Defaults to 400. |
| individuals | `Optional[int]` | `rw` | `300` | Number of individuals (solutions) to generate for the (initial) generation [>= 10]. Defaults to 300. |
| penalties | `Optional[dict[str, Union[float, int, str]]]` | `rw` | `None` | A dictionary of penalty function parameters consisting of a penalty function parameter name and the associated value. |
| seed | `Optional[int]` | `rw` | `None` | Fixed seed for genetic algorithm. Defaults to 'None' which means random seed. |
2025-11-13 22:53:46 +01:00
:::
<!-- pyml enable line - length -->
<!-- pyml disable no - emphasis - as - heading -->
**Example Input/Output**
<!-- pyml enable no - emphasis - as - heading -->
<!-- pyml disable line - length -->
```json
{
"optimization": {
"genetic": {
"individuals": 300,
"generations": 400,
"seed": null,
"penalties": {
"ev_soc_miss": 10
}
}
}
}
```
<!-- pyml enable line - length -->