mirror of
https://github.com/bitcoinresearchkit/brk.git
synced 2026-07-01 14:29:01 -07:00
82 lines
2.3 KiB
Rust
82 lines
2.3 KiB
Rust
use brk_error::Result;
|
|
use brk_traversable::Traversable;
|
|
use brk_types::{BasisPointsSigned32, Height, Indexes, Sats, SatsSigned, Version};
|
|
use vecdb::{AnyStoredVec, AnyVec, Exit, Rw, StorageMode, WritableVec};
|
|
|
|
use crate::{
|
|
distribution::state::{CohortState, CostBasisOps, RealizedOps},
|
|
prices,
|
|
};
|
|
|
|
use crate::internal::{AmountPerBlock, LazyRollingDeltasFromHeight};
|
|
|
|
use crate::distribution::metrics::ImportConfig;
|
|
|
|
/// Base supply metrics: total supply only (2 stored vecs).
|
|
#[derive(Traversable)]
|
|
pub struct SupplyBase<M: StorageMode = Rw> {
|
|
pub total: AmountPerBlock<M>,
|
|
pub delta: LazyRollingDeltasFromHeight<Sats, SatsSigned, BasisPointsSigned32>,
|
|
}
|
|
|
|
impl SupplyBase {
|
|
pub(crate) fn forced_import(cfg: &ImportConfig) -> Result<Self> {
|
|
let supply: AmountPerBlock = cfg.import("supply", Version::ZERO)?;
|
|
|
|
let delta = LazyRollingDeltasFromHeight::new(
|
|
&cfg.name("supply_delta"),
|
|
cfg.version + Version::ONE,
|
|
&supply.sats.height,
|
|
cfg.cached_starts,
|
|
cfg.indexes,
|
|
);
|
|
|
|
Ok(Self {
|
|
total: supply,
|
|
delta,
|
|
})
|
|
}
|
|
|
|
pub(crate) fn min_len(&self) -> usize {
|
|
self.total.sats.height.len()
|
|
}
|
|
|
|
#[inline(always)]
|
|
pub(crate) fn push_state(&mut self, state: &CohortState<impl RealizedOps, impl CostBasisOps>) {
|
|
self.total.sats.height.push(state.supply.value);
|
|
}
|
|
|
|
pub(crate) fn collect_vecs_mut(&mut self) -> Vec<&mut dyn AnyStoredVec> {
|
|
vec![
|
|
&mut self.total.sats.height as &mut dyn AnyStoredVec,
|
|
&mut self.total.cents.height as &mut dyn AnyStoredVec,
|
|
]
|
|
}
|
|
|
|
pub(crate) fn compute(
|
|
&mut self,
|
|
prices: &prices::Vecs,
|
|
max_from: Height,
|
|
exit: &Exit,
|
|
) -> Result<()> {
|
|
self.total.compute(prices, max_from, exit)
|
|
}
|
|
|
|
pub(crate) fn compute_from_stateful(
|
|
&mut self,
|
|
starting_indexes: &Indexes,
|
|
others: &[&Self],
|
|
exit: &Exit,
|
|
) -> Result<()> {
|
|
self.total.sats.height.compute_sum_of_others(
|
|
starting_indexes.height,
|
|
&others
|
|
.iter()
|
|
.map(|v| &v.total.sats.height)
|
|
.collect::<Vec<_>>(),
|
|
exit,
|
|
)?;
|
|
Ok(())
|
|
}
|
|
}
|