mirror of
https://github.com/Akkudoktor-EOS/EOS.git
synced 2025-11-21 04:46:31 +00:00
406 lines
16 KiB
Markdown
406 lines
16 KiB
Markdown
|
|
## Base configuration for devices simulation settings
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
:::{table} devices
|
||
|
|
:widths: 10 20 10 5 5 30
|
||
|
|
:align: left
|
||
|
|
|
||
|
|
| Name | Environment Variable | Type | Read-Only | Default | Description |
|
||
|
|
| ---- | -------------------- | ---- | --------- | ------- | ----------- |
|
||
|
|
| batteries | `EOS_DEVICES__BATTERIES` | `Optional[list[akkudoktoreos.devices.devices.BatteriesCommonSettings]]` | `rw` | `None` | List of battery devices |
|
||
|
|
| electric_vehicles | `EOS_DEVICES__ELECTRIC_VEHICLES` | `Optional[list[akkudoktoreos.devices.devices.BatteriesCommonSettings]]` | `rw` | `None` | List of electric vehicle devices |
|
||
|
|
| home_appliances | `EOS_DEVICES__HOME_APPLIANCES` | `Optional[list[akkudoktoreos.devices.devices.HomeApplianceCommonSettings]]` | `rw` | `None` | List of home appliances |
|
||
|
|
| inverters | `EOS_DEVICES__INVERTERS` | `Optional[list[akkudoktoreos.devices.devices.InverterCommonSettings]]` | `rw` | `None` | List of inverters |
|
||
|
|
| max_batteries | `EOS_DEVICES__MAX_BATTERIES` | `Optional[int]` | `rw` | `None` | Maximum number of batteries that can be set |
|
||
|
|
| max_electric_vehicles | `EOS_DEVICES__MAX_ELECTRIC_VEHICLES` | `Optional[int]` | `rw` | `None` | Maximum number of electric vehicles that can be set |
|
||
|
|
| max_home_appliances | `EOS_DEVICES__MAX_HOME_APPLIANCES` | `Optional[int]` | `rw` | `None` | Maximum number of home_appliances that can be set |
|
||
|
|
| max_inverters | `EOS_DEVICES__MAX_INVERTERS` | `Optional[int]` | `rw` | `None` | Maximum number of inverters that can be set |
|
||
|
|
| measurement_keys | | `Optional[list[str]]` | `ro` | `N/A` | None |
|
||
|
|
:::
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Input**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"batteries": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"capacity_wh": 8000,
|
||
|
|
"charging_efficiency": 0.88,
|
||
|
|
"discharging_efficiency": 0.88,
|
||
|
|
"levelized_cost_of_storage_kwh": 0.0,
|
||
|
|
"max_charge_power_w": 5000,
|
||
|
|
"min_charge_power_w": 50,
|
||
|
|
"charge_rates": "[0. 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1. ]",
|
||
|
|
"min_soc_percentage": 0,
|
||
|
|
"max_soc_percentage": 100,
|
||
|
|
"measurement_key_soc_factor": "battery1-soc-factor",
|
||
|
|
"measurement_key_power_l1_w": "battery1-power-l1-w",
|
||
|
|
"measurement_key_power_l2_w": "battery1-power-l2-w",
|
||
|
|
"measurement_key_power_l3_w": "battery1-power-l3-w",
|
||
|
|
"measurement_key_power_3_phase_sym_w": "battery1-power-3-phase-sym-w",
|
||
|
|
"measurement_keys": [
|
||
|
|
"battery1-soc-factor",
|
||
|
|
"battery1-power-l1-w",
|
||
|
|
"battery1-power-l2-w",
|
||
|
|
"battery1-power-l3-w",
|
||
|
|
"battery1-power-3-phase-sym-w"
|
||
|
|
]
|
||
|
|
}
|
||
|
|
],
|
||
|
|
"max_batteries": 1,
|
||
|
|
"electric_vehicles": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"capacity_wh": 8000,
|
||
|
|
"charging_efficiency": 0.88,
|
||
|
|
"discharging_efficiency": 0.88,
|
||
|
|
"levelized_cost_of_storage_kwh": 0.0,
|
||
|
|
"max_charge_power_w": 5000,
|
||
|
|
"min_charge_power_w": 50,
|
||
|
|
"charge_rates": "[0. 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1. ]",
|
||
|
|
"min_soc_percentage": 0,
|
||
|
|
"max_soc_percentage": 100,
|
||
|
|
"measurement_key_soc_factor": "battery1-soc-factor",
|
||
|
|
"measurement_key_power_l1_w": "battery1-power-l1-w",
|
||
|
|
"measurement_key_power_l2_w": "battery1-power-l2-w",
|
||
|
|
"measurement_key_power_l3_w": "battery1-power-l3-w",
|
||
|
|
"measurement_key_power_3_phase_sym_w": "battery1-power-3-phase-sym-w",
|
||
|
|
"measurement_keys": [
|
||
|
|
"battery1-soc-factor",
|
||
|
|
"battery1-power-l1-w",
|
||
|
|
"battery1-power-l2-w",
|
||
|
|
"battery1-power-l3-w",
|
||
|
|
"battery1-power-3-phase-sym-w"
|
||
|
|
]
|
||
|
|
}
|
||
|
|
],
|
||
|
|
"max_electric_vehicles": 1,
|
||
|
|
"inverters": [],
|
||
|
|
"max_inverters": 1,
|
||
|
|
"home_appliances": [],
|
||
|
|
"max_home_appliances": 1
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Output**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"batteries": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"capacity_wh": 8000,
|
||
|
|
"charging_efficiency": 0.88,
|
||
|
|
"discharging_efficiency": 0.88,
|
||
|
|
"levelized_cost_of_storage_kwh": 0.0,
|
||
|
|
"max_charge_power_w": 5000,
|
||
|
|
"min_charge_power_w": 50,
|
||
|
|
"charge_rates": "[0. 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1. ]",
|
||
|
|
"min_soc_percentage": 0,
|
||
|
|
"max_soc_percentage": 100,
|
||
|
|
"measurement_key_soc_factor": "battery1-soc-factor",
|
||
|
|
"measurement_key_power_l1_w": "battery1-power-l1-w",
|
||
|
|
"measurement_key_power_l2_w": "battery1-power-l2-w",
|
||
|
|
"measurement_key_power_l3_w": "battery1-power-l3-w",
|
||
|
|
"measurement_key_power_3_phase_sym_w": "battery1-power-3-phase-sym-w",
|
||
|
|
"measurement_keys": [
|
||
|
|
"battery1-soc-factor",
|
||
|
|
"battery1-power-l1-w",
|
||
|
|
"battery1-power-l2-w",
|
||
|
|
"battery1-power-l3-w",
|
||
|
|
"battery1-power-3-phase-sym-w"
|
||
|
|
]
|
||
|
|
}
|
||
|
|
],
|
||
|
|
"max_batteries": 1,
|
||
|
|
"electric_vehicles": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"capacity_wh": 8000,
|
||
|
|
"charging_efficiency": 0.88,
|
||
|
|
"discharging_efficiency": 0.88,
|
||
|
|
"levelized_cost_of_storage_kwh": 0.0,
|
||
|
|
"max_charge_power_w": 5000,
|
||
|
|
"min_charge_power_w": 50,
|
||
|
|
"charge_rates": "[0. 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1. ]",
|
||
|
|
"min_soc_percentage": 0,
|
||
|
|
"max_soc_percentage": 100,
|
||
|
|
"measurement_key_soc_factor": "battery1-soc-factor",
|
||
|
|
"measurement_key_power_l1_w": "battery1-power-l1-w",
|
||
|
|
"measurement_key_power_l2_w": "battery1-power-l2-w",
|
||
|
|
"measurement_key_power_l3_w": "battery1-power-l3-w",
|
||
|
|
"measurement_key_power_3_phase_sym_w": "battery1-power-3-phase-sym-w",
|
||
|
|
"measurement_keys": [
|
||
|
|
"battery1-soc-factor",
|
||
|
|
"battery1-power-l1-w",
|
||
|
|
"battery1-power-l2-w",
|
||
|
|
"battery1-power-l3-w",
|
||
|
|
"battery1-power-3-phase-sym-w"
|
||
|
|
]
|
||
|
|
}
|
||
|
|
],
|
||
|
|
"max_electric_vehicles": 1,
|
||
|
|
"inverters": [],
|
||
|
|
"max_inverters": 1,
|
||
|
|
"home_appliances": [],
|
||
|
|
"max_home_appliances": 1,
|
||
|
|
"measurement_keys": [
|
||
|
|
"battery1-soc-factor",
|
||
|
|
"battery1-power-l1-w",
|
||
|
|
"battery1-power-l2-w",
|
||
|
|
"battery1-power-l3-w",
|
||
|
|
"battery1-power-3-phase-sym-w",
|
||
|
|
"battery1-soc-factor",
|
||
|
|
"battery1-power-l1-w",
|
||
|
|
"battery1-power-l2-w",
|
||
|
|
"battery1-power-l3-w",
|
||
|
|
"battery1-power-3-phase-sym-w"
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
### Inverter devices base settings
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
:::{table} devices::inverters::list
|
||
|
|
:widths: 10 10 5 5 30
|
||
|
|
:align: left
|
||
|
|
|
||
|
|
| Name | Type | Read-Only | Default | Description |
|
||
|
|
| ---- | ---- | --------- | ------- | ----------- |
|
||
|
|
| battery_id | `Optional[str]` | `rw` | `None` | ID of battery controlled by this inverter. |
|
||
|
|
| device_id | `str` | `rw` | `<unknown>` | ID of device |
|
||
|
|
| max_power_w | `Optional[float]` | `rw` | `None` | Maximum power [W]. |
|
||
|
|
| measurement_keys | `Optional[list[str]]` | `ro` | `N/A` | None |
|
||
|
|
:::
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Input**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"inverters": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"max_power_w": 10000.0,
|
||
|
|
"battery_id": null
|
||
|
|
}
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Output**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"inverters": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"max_power_w": 10000.0,
|
||
|
|
"battery_id": null,
|
||
|
|
"measurement_keys": []
|
||
|
|
}
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
### Home Appliance devices base settings
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
:::{table} devices::home_appliances::list
|
||
|
|
:widths: 10 10 5 5 30
|
||
|
|
:align: left
|
||
|
|
|
||
|
|
| Name | Type | Read-Only | Default | Description |
|
||
|
|
| ---- | ---- | --------- | ------- | ----------- |
|
||
|
|
| consumption_wh | `int` | `rw` | `required` | Energy consumption [Wh]. |
|
||
|
|
| device_id | `str` | `rw` | `<unknown>` | ID of device |
|
||
|
|
| duration_h | `int` | `rw` | `required` | Usage duration in hours [0 ... 24]. |
|
||
|
|
| measurement_keys | `Optional[list[str]]` | `ro` | `N/A` | None |
|
||
|
|
| time_windows | `Optional[akkudoktoreos.utils.datetimeutil.TimeWindowSequence]` | `rw` | `None` | Sequence of allowed time windows. Defaults to optimization general time window. |
|
||
|
|
:::
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Input**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"home_appliances": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"consumption_wh": 2000,
|
||
|
|
"duration_h": 1,
|
||
|
|
"time_windows": {
|
||
|
|
"windows": [
|
||
|
|
{
|
||
|
|
"start_time": "10:00:00.000000 Europe/Berlin",
|
||
|
|
"duration": "2 hours",
|
||
|
|
"day_of_week": null,
|
||
|
|
"date": null,
|
||
|
|
"locale": null
|
||
|
|
}
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Output**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"home_appliances": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"consumption_wh": 2000,
|
||
|
|
"duration_h": 1,
|
||
|
|
"time_windows": {
|
||
|
|
"windows": [
|
||
|
|
{
|
||
|
|
"start_time": "10:00:00.000000 Europe/Berlin",
|
||
|
|
"duration": "2 hours",
|
||
|
|
"day_of_week": null,
|
||
|
|
"date": null,
|
||
|
|
"locale": null
|
||
|
|
}
|
||
|
|
]
|
||
|
|
},
|
||
|
|
"measurement_keys": []
|
||
|
|
}
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
### Battery devices base settings
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
:::{table} devices::batteries::list
|
||
|
|
:widths: 10 10 5 5 30
|
||
|
|
:align: left
|
||
|
|
|
||
|
|
| Name | Type | Read-Only | Default | Description |
|
||
|
|
| ---- | ---- | --------- | ------- | ----------- |
|
||
|
|
| capacity_wh | `int` | `rw` | `8000` | Capacity [Wh]. |
|
||
|
|
| charge_rates | `Optional[numpydantic.vendor.npbase_meta_classes.NDArray]` | `rw` | `[0. 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1. ]` | Charge rates as factor of maximum charging power [0.00 ... 1.00]. None triggers fallback to default charge-rates. |
|
||
|
|
| charging_efficiency | `float` | `rw` | `0.88` | Charging efficiency [0.01 ... 1.00]. |
|
||
|
|
| device_id | `str` | `rw` | `<unknown>` | ID of device |
|
||
|
|
| discharging_efficiency | `float` | `rw` | `0.88` | Discharge efficiency [0.01 ... 1.00]. |
|
||
|
|
| levelized_cost_of_storage_kwh | `float` | `rw` | `0.0` | Levelized cost of storage (LCOS), the average lifetime cost of delivering one kWh [€/kWh]. |
|
||
|
|
| max_charge_power_w | `Optional[float]` | `rw` | `5000` | Maximum charging power [W]. |
|
||
|
|
| max_soc_percentage | `int` | `rw` | `100` | Maximum state of charge (SOC) as percentage of capacity [%]. |
|
||
|
|
| measurement_key_power_3_phase_sym_w | `str` | `ro` | `N/A` | None |
|
||
|
|
| measurement_key_power_l1_w | `str` | `ro` | `N/A` | None |
|
||
|
|
| measurement_key_power_l2_w | `str` | `ro` | `N/A` | None |
|
||
|
|
| measurement_key_power_l3_w | `str` | `ro` | `N/A` | None |
|
||
|
|
| measurement_key_soc_factor | `str` | `ro` | `N/A` | None |
|
||
|
|
| measurement_keys | `Optional[list[str]]` | `ro` | `N/A` | None |
|
||
|
|
| min_charge_power_w | `Optional[float]` | `rw` | `50` | Minimum charging power [W]. |
|
||
|
|
| min_soc_percentage | `int` | `rw` | `0` | Minimum state of charge (SOC) as percentage of capacity [%]. This is the target SoC for charging |
|
||
|
|
:::
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Input**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"batteries": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"capacity_wh": 8000,
|
||
|
|
"charging_efficiency": 0.88,
|
||
|
|
"discharging_efficiency": 0.88,
|
||
|
|
"levelized_cost_of_storage_kwh": 0.12,
|
||
|
|
"max_charge_power_w": 5000.0,
|
||
|
|
"min_charge_power_w": 50.0,
|
||
|
|
"charge_rates": "[0. 0.25 0.5 0.75 1. ]",
|
||
|
|
"min_soc_percentage": 10,
|
||
|
|
"max_soc_percentage": 100
|
||
|
|
}
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|
||
|
|
|
||
|
|
<!-- pyml disable no-emphasis-as-heading -->
|
||
|
|
**Example Output**
|
||
|
|
<!-- pyml enable no-emphasis-as-heading -->
|
||
|
|
|
||
|
|
<!-- pyml disable line-length -->
|
||
|
|
```json
|
||
|
|
{
|
||
|
|
"devices": {
|
||
|
|
"batteries": [
|
||
|
|
{
|
||
|
|
"device_id": "battery1",
|
||
|
|
"capacity_wh": 8000,
|
||
|
|
"charging_efficiency": 0.88,
|
||
|
|
"discharging_efficiency": 0.88,
|
||
|
|
"levelized_cost_of_storage_kwh": 0.12,
|
||
|
|
"max_charge_power_w": 5000.0,
|
||
|
|
"min_charge_power_w": 50.0,
|
||
|
|
"charge_rates": "[0. 0.25 0.5 0.75 1. ]",
|
||
|
|
"min_soc_percentage": 10,
|
||
|
|
"max_soc_percentage": 100,
|
||
|
|
"measurement_key_soc_factor": "battery1-soc-factor",
|
||
|
|
"measurement_key_power_l1_w": "battery1-power-l1-w",
|
||
|
|
"measurement_key_power_l2_w": "battery1-power-l2-w",
|
||
|
|
"measurement_key_power_l3_w": "battery1-power-l3-w",
|
||
|
|
"measurement_key_power_3_phase_sym_w": "battery1-power-3-phase-sym-w",
|
||
|
|
"measurement_keys": [
|
||
|
|
"battery1-soc-factor",
|
||
|
|
"battery1-power-l1-w",
|
||
|
|
"battery1-power-l2-w",
|
||
|
|
"battery1-power-l3-w",
|
||
|
|
"battery1-power-3-phase-sym-w"
|
||
|
|
]
|
||
|
|
}
|
||
|
|
]
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
<!-- pyml enable line-length -->
|