## General Optimization Configuration :::{table} optimization :widths: 10 20 10 5 5 30 :align: left | Name | Environment Variable | Type | Read-Only | Default | Description | | ---- | -------------------- | ---- | --------- | ------- | ----------- | | algorithm | `EOS_OPTIMIZATION__ALGORITHM` | `str` | `rw` | `GENETIC` | The optimization algorithm. Defaults to GENETIC | | genetic | `EOS_OPTIMIZATION__GENETIC` | `GeneticCommonSettings` | `rw` | `required` | Genetic optimization algorithm configuration. | | horizon | | `int` | `ro` | `N/A` | Number of optimization steps. | | horizon_hours | `EOS_OPTIMIZATION__HORIZON_HOURS` | `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` | `int` | `rw` | `3600` | The optimization interval [sec]. Defaults to 3600 seconds (1 hour) | | keys | | `list[str]` | `ro` | `N/A` | The keys of the solution. | ::: **Example Input** ```json { "optimization": { "horizon_hours": 24, "interval": 3600, "algorithm": "GENETIC", "genetic": { "individuals": 400, "generations": 400, "seed": null, "penalties": { "ev_soc_miss": 10 } } } } ``` **Example Output** ```json { "optimization": { "horizon_hours": 24, "interval": 3600, "algorithm": "GENETIC", "genetic": { "individuals": 400, "generations": 400, "seed": null, "penalties": { "ev_soc_miss": 10 } }, "keys": [], "horizon": 24 } } ``` ### General Genetic Optimization Algorithm Configuration :::{table} optimization::genetic :widths: 10 10 5 5 30 :align: left | Name | Type | Read-Only | Default | Description | | ---- | ---- | --------- | ------- | ----------- | | generations | `Optional[int]` | `rw` | `400` | Number of generations to evolve [>= 10]. Defaults to 400. | | individuals | `Optional[int]` | `rw` | `300` | Number of individuals (solutions) in the population [>= 10]. Defaults to 300. | | penalties | `dict[str, Union[float, int, str]]` | `rw` | `required` | Penalty parameters used in fitness evaluation. | | seed | `Optional[int]` | `rw` | `None` | Random seed for reproducibility. None = random. | ::: **Example Input/Output** ```json { "optimization": { "genetic": { "individuals": 300, "generations": 400, "seed": null, "penalties": { "ev_soc_miss": 10 } } } } ```