-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathstate_variables.py
199 lines (178 loc) · 8.14 KB
/
state_variables.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
"""
Definition of State Variables, their types, and default values.
By using a dataclass to represent the State Variables:
* We can use types for Python type hints
* Set default values
* Ensure that all State Variables are initialized
"""
import numpy as np
from dataclasses import dataclass
from datetime import datetime
import model.constants as constants
import data.api.beaconchain as beaconchain
import data.api.etherscan as etherscan
import model.system_parameters as system_parameters
from model.system_parameters import validator_environments
from model.types import (
Gwei,
Gwei_per_Gas,
ETH,
USD,
USD_per_ETH,
Percentage,
Stage,
)
from model.utils import default
from data.historical_values import eth_price_mean, eth_price_min, eth_price_max
# Get number of validator environments for initializing Numpy array size
number_of_validator_environments = len(validator_environments)
# Initial state from external live data source, setting a default in case API call fails
number_of_active_validators: int = beaconchain.get_validators_count(default=156_250)
eth_staked: ETH = (
beaconchain.get_total_validator_balance(default=5_000_000e9) / constants.gwei
)
eth_supply: ETH = etherscan.get_eth_supply(default=116_250_000e18) / constants.wei
@dataclass
class StateVariables:
"""State Variables
Each State Variable is defined as:
state variable key: state variable type = default state variable value
"""
# Time state variables
stage: Stage = None
"""
The stage of the network upgrade process.
See "stage" System Parameter in model.system_parameters
& model.types.Stage Enum for further documentation.
"""
timestamp: datetime = None
"""
The timestamp for each timestep as a Python `datetime` object, starting from `date_start` Parameter.
"""
# Ethereum state variables
eth_price: USD_per_ETH = eth_price_mean
"""The ETH spot price"""
eth_supply: ETH = eth_supply
"""The total ETH supply"""
eth_staked: ETH = eth_staked
"""The total ETH staked as part of the Proof of Stake system"""
supply_inflation: Percentage = 0
"""The annualized ETH supply inflation rate"""
network_issuance: ETH = 0
"""The total network issuance in ETH"""
pow_issuance: ETH = 0
"""The total Proof of Work issuance in ETH"""
# Validator state variables
number_of_validators_in_activation_queue: int = 0
"""The number of validators in activation queue"""
average_effective_balance: Gwei = 32 * constants.gwei
"""The validator average effective balance"""
number_of_active_validators: int = number_of_active_validators
"""The total number of active validators"""
number_of_awake_validators: int = min(
system_parameters.parameters["MAX_VALIDATOR_COUNT"][0] or float("inf"),
number_of_active_validators,
)
"""The total number of awake validators"""
validator_uptime: Percentage = 1
"""The combination of validator internet, power, and technical uptime, as a percentage"""
# Reward and penalty state variables
base_reward: Gwei = 0
"""
Validator rewards and penalties are calculated in terms of the base reward.
Under perfect network conditions, each validator should receive 1 base reward per epoch for performing their duties.
"""
validating_rewards: Gwei = 0
"""The total rewards received for PoS validation (attestation, block proposal, sync vote)"""
validating_penalties: Gwei = 0
"""The total penalties received for failing to perform PoS validation duties (attestation, sync vote)"""
source_reward: Gwei = 0
"""The total rewards received for getting a source vote in time and correctly"""
target_reward: Gwei = 0
"""The total rewards received for getting a target vote in time and correctly"""
head_reward: Gwei = 0
"""The total rewards received for getting a head vote in time and correctly"""
block_proposer_reward: Gwei = 0
"""The total rewards received for successfully proposing a block"""
sync_reward: Gwei = 0
"""The total rewards received for attesting as part of a sync committee"""
attestation_penalties: Gwei = 0
"""The total penalties received for failing to perform attestation duties"""
sync_committee_penalties: Gwei = 0
"""The total penalties received for failing to perform sync committee duties"""
# Slashing state variables
amount_slashed: Gwei = 0
"""The total penalties applied for slashable offences"""
whistleblower_rewards: Gwei = 0
"""The total rewards received as a proportion of the effective balance of the slashed validators"""
# EIP-1559 state variables
base_fee_per_gas: Gwei_per_Gas = 1
"""The base fee burned, in Gwei per gas, dynamically updated for each block"""
total_base_fee: Gwei = 0
"""The total base fee burned for all transactions included in blockspace"""
total_priority_fee_to_miners: Gwei = 0
""""The total priority fee to miners pre Proof-of-Stake for all transactions included in blockspace"""
total_priority_fee_to_validators: Gwei = 0
""""The total priority fee to validators post Proof-of-Stake for all transactions included in blockspace"""
# Maximum Extractable Value (MEV) state variables
total_realized_mev_to_miners: ETH = 0
"""The total realized MEV to miners pre Proof-of-Stake"""
total_realized_mev_to_validators: ETH = 0
"""The total realized MEV to validators post Proof-of-Stake"""
# System metric state variables
validator_eth_staked: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=int)
)
"""The ETH staked per validator environment"""
validator_revenue: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=int)
)
"""The total revenue (income received) for performing PoS duties per validator environment"""
validator_profit: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=int)
)
"""The total profit (income received - costs) per validator environment"""
validator_revenue_yields: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=int)
)
"""The total annualized revenue (income received) yields (percentage of investment amount)
per validator environment"""
validator_profit_yields: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=int)
)
"""The total annualized profit (income received - costs) yields (percentage of investment amount)
per validator environment"""
validator_count_distribution: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=int)
)
"""The total number of validators per validator environment"""
validator_hardware_costs: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=USD)
)
"""The total validator hardware operation costs per validator environment"""
validator_cloud_costs: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=USD)
)
"""The total validator cloud operation costs per validator environment"""
validator_third_party_costs: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=USD)
)
"""The total validator third-party fee costs validator environment"""
validator_costs: np.ndarray = default(
np.zeros((number_of_validator_environments, 1), dtype=USD)
)
"""The total validator costs validator environment"""
total_online_validator_rewards: Gwei = 0
"""The total rewards received by online validators"""
total_network_costs: USD = 0
"""The total validator operational costs for securing the network"""
total_revenue: USD = 0
"""The total validator revenue (income received)"""
total_profit: USD = 0
"""The total validator profit (income received - costs)"""
total_revenue_yields: Percentage = 0
"""Annualized revenue (income received) for all validators"""
total_profit_yields: Percentage = 0
"""Annualized profit (income received - costs) for all validators"""
# Initialize State Variables instance with default values
initial_state = StateVariables().__dict__