* Introduce automatic ABI maintenance mechanism (2/2; rollout) * Fix stable clippy * Change to symlink * Freeze abi of Tower * fmt... * Improve dev-experience! * Update BankSlotDelta $ diff -u /tmp/abi8/*7dg6BreYxTuxiVz6aLvk3p2Z7GQk2cJqfGvC9h4FAoSj* /tmp/abi8/*9chBcbXVJ4fK7uGgydQzam5aHipaAKFw6V4LDFpjbE4w* --- /tmp/abi8/bank__BankSlotDelta_frozen_abi__test_abi_digest_7dg6BreYxTuxiVz6aLvk3p2Z7GQk2cJqfGvC9h4FAoSj 2020-06-18 18:01:22.831228087 +0900 +++ /tmp/abi8/bank__BankSlotDelta_frozen_abi__test_abi_digest_9chBcbXVJ4fK7uGgydQzam5aHipaAKFw6V4LDFpjbE4w 2020-07-03 15:59:58.430695244 +0900 @@ -140,7 +140,7 @@ field u8 primitive u8 field solana_sdk::instruction::InstructionError - enum InstructionError (variants = 34) + enum InstructionError (variants = 35) variant(0) GenericError (unit) variant(1) InvalidArgument (unit) variant(2) InvalidInstructionData (unit) @@ -176,6 +176,7 @@ variant(31) CallDepth (unit) variant(32) MissingAccount (unit) variant(33) ReentrancyNotAllowed (unit) + variant(34) MaxSeedLengthExceeded (unit) variant(9) CallChainTooDeep (unit) variant(10) MissingSignatureForFee (unit) variant(11) InvalidAccountIndex (unit) * Fix some merge conflicts...
111 lines
2.9 KiB
Rust
111 lines
2.9 KiB
Rust
//! configuration for network inflation
|
|
|
|
#[derive(Serialize, Deserialize, PartialEq, Clone, Debug, Copy, AbiExample)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct Inflation {
|
|
/// Initial inflation percentage, from time=0
|
|
pub initial: f64,
|
|
|
|
/// Terminal inflation percentage, to time=INF
|
|
pub terminal: f64,
|
|
|
|
/// Rate per year, at which inflation is lowered until reaching terminal
|
|
/// i.e. inflation(year) == MAX(terminal, initial*((1-taper)^year))
|
|
pub taper: f64,
|
|
|
|
/// Percentage of total inflation allocated to the foundation
|
|
pub foundation: f64,
|
|
/// Duration of foundation pool inflation, in years
|
|
pub foundation_term: f64,
|
|
|
|
/// DEPRECATED, this field is currently unused
|
|
pub storage: f64,
|
|
}
|
|
|
|
const DEFAULT_INITIAL: f64 = 0.15;
|
|
const DEFAULT_TERMINAL: f64 = 0.015;
|
|
const DEFAULT_TAPER: f64 = 0.15;
|
|
const DEFAULT_FOUNDATION: f64 = 0.05;
|
|
const DEFAULT_FOUNDATION_TERM: f64 = 7.0;
|
|
const DEFAULT_STORAGE: f64 = 0.0;
|
|
|
|
impl Default for Inflation {
|
|
fn default() -> Self {
|
|
Self {
|
|
initial: DEFAULT_INITIAL,
|
|
terminal: DEFAULT_TERMINAL,
|
|
taper: DEFAULT_TAPER,
|
|
foundation: DEFAULT_FOUNDATION,
|
|
foundation_term: DEFAULT_FOUNDATION_TERM,
|
|
storage: DEFAULT_STORAGE,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Inflation {
|
|
pub fn new_disabled() -> Self {
|
|
Self {
|
|
initial: 0.0,
|
|
terminal: 0.0,
|
|
taper: 0.0,
|
|
foundation: 0.0,
|
|
foundation_term: 0.0,
|
|
storage: 0.0,
|
|
}
|
|
}
|
|
/// inflation rate at year
|
|
pub fn total(&self, year: f64) -> f64 {
|
|
let tapered = self.initial * ((1.0 - self.taper).powf(year));
|
|
|
|
if tapered > self.terminal {
|
|
tapered
|
|
} else {
|
|
self.terminal
|
|
}
|
|
}
|
|
|
|
/// portion of total that goes to validators
|
|
pub fn validator(&self, year: f64) -> f64 {
|
|
self.total(year) - self.storage(year) - self.foundation(year)
|
|
}
|
|
|
|
/// DEPRECATED
|
|
fn storage(&self, year: f64) -> f64 {
|
|
self.total(year) * self.storage
|
|
}
|
|
|
|
/// portion of total that goes to foundation
|
|
pub fn foundation(&self, year: f64) -> f64 {
|
|
if year < self.foundation_term {
|
|
self.total(year) * self.foundation
|
|
} else {
|
|
0.0
|
|
}
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::*;
|
|
|
|
#[test]
|
|
#[allow(clippy::float_cmp)]
|
|
fn test_inflation_basic() {
|
|
let inflation = Inflation::default();
|
|
|
|
let mut last = inflation.total(0.0);
|
|
|
|
for year in &[0.1, 0.5, 1.0, DEFAULT_FOUNDATION_TERM, 100.0] {
|
|
let total = inflation.total(*year);
|
|
assert_eq!(
|
|
total,
|
|
inflation.validator(*year) + inflation.storage(*year) + inflation.foundation(*year)
|
|
);
|
|
assert!(total < last);
|
|
assert!(total >= inflation.terminal);
|
|
last = total;
|
|
}
|
|
assert_eq!(last, inflation.terminal);
|
|
}
|
|
}
|