From 500713a073055ac74dc01d9c3657f08b22da5e5b Mon Sep 17 00:00:00 2001 From: Aaron Kutch Date: Sun, 1 Oct 2023 20:52:36 -0500 Subject: [PATCH] start fleshing out `Epoch` --- starlight/src/epoch.rs | 61 ++++++++++++++++++++-------------------- starlight/src/t_dag.rs | 24 ++++++++++------ testcrate/tests/epoch.rs | 30 ++++++++++++++++++++ 3 files changed, 76 insertions(+), 39 deletions(-) create mode 100644 testcrate/tests/epoch.rs diff --git a/starlight/src/epoch.rs b/starlight/src/epoch.rs index 0bfce875..a635ad7f 100644 --- a/starlight/src/epoch.rs +++ b/starlight/src/epoch.rs @@ -1,25 +1,19 @@ /// An epoch management struct used for tests and examples. -use std::{ - cell::RefCell, - mem, - num::{NonZeroU64, NonZeroUsize}, - thread::panicking, -}; +use std::{cell::RefCell, mem, num::NonZeroUsize, thread::panicking}; use awint::{ awint_dag::{ epoch::{EpochCallback, EpochKey}, - triple_arena::Arena, - Location, Op, PNote, PState, + Lineage, Location, Op, PState, }, - dag, + bw, dag, }; -use crate::{PBack, TDag}; +use crate::TDag; #[derive(Debug, Clone)] pub struct Assertions { - pub bits: Vec, + pub bits: Vec, } impl Assertions { @@ -38,8 +32,8 @@ impl Default for Assertions { struct EpochData { key: EpochKey, assertions: Assertions, - /// Backref to a `Referent::State` - states: Arena, + /// All states associated with this epoch + states: Vec, } struct TopEpochData { @@ -74,18 +68,30 @@ pub fn _callback() -> EpochCallback { fn new_pstate(nzbw: NonZeroUsize, op: Op, location: Option) -> PState { EPOCH_DATA_TOP.with(|top| { let mut top = top.borrow_mut(); - let backref = todo!(); //top.tdag.make_state(nzbw, op, location); - top.data.states.insert(backref) + let p_state = top.tdag.make_state(nzbw, op, location); + top.data.states.push(p_state); + p_state }) } fn register_assertion_bit(bit: dag::bool, location: Location) { - todo!() + // need a new bit to attach location data to + let new_bit = new_pstate(bw(1), Op::Copy([bit.state()]), Some(location)); + EPOCH_DATA_TOP.with(|top| { + let mut top = top.borrow_mut(); + top.data.assertions.bits.push(new_bit); + }) } fn get_nzbw(p_state: PState) -> NonZeroUsize { - todo!() + EPOCH_DATA_TOP.with(|top| { + let top = top.borrow(); + top.tdag.states.get(p_state).unwrap().nzbw + }) } fn get_op(p_state: PState) -> Op { - todo!() + EPOCH_DATA_TOP.with(|top| { + let top = top.borrow(); + top.tdag.states.get(p_state).unwrap().op.clone() + }) } EpochCallback { new_pstate, @@ -106,15 +112,14 @@ impl Drop for Epoch { if !panicking() { // unregister callback self.key.pop_off_epoch_stack(); - todo!(); - /*EPOCH_DATA_TOP.with(|top| { + EPOCH_DATA_TOP.with(|top| { let mut top = top.borrow_mut(); // remove all the states associated with this epoch - let mut last_state = top.data.prev_in_epoch; - while let Some(p_state) = last_state { - let state = top.arena.remove(p_state).unwrap(); - last_state = state.prev_in_epoch; + for _p_state in top.data.states.iter() { + // TODO + //top.tdag.states.remove(*p_state).unwrap(); } + top.tdag = TDag::new(); // move the top of the stack to the new top let new_top = EPOCH_DATA_STACK.with(|stack| { let mut stack = stack.borrow_mut(); @@ -125,13 +130,9 @@ impl Drop for Epoch { } else { top.active = false; top.data = EpochData::default(); - // if there is considerable capacity, clear it (else we do not want to incur - // allocations for rapid state epoch creation) - if top.arena.capacity() > 64 { - top.arena.clear_and_shrink(); - } + // TODO capacity clearing? } - });*/ + }); } } } diff --git a/starlight/src/t_dag.rs b/starlight/src/t_dag.rs index 9af8880a..ea94f251 100644 --- a/starlight/src/t_dag.rs +++ b/starlight/src/t_dag.rs @@ -73,9 +73,9 @@ pub enum Referent { /// Represents the state resulting from a mimicking operation #[derive(Debug, Clone)] pub struct State { - pub p_self_bits: SmallVec<[PBack; 4]>, - /// Bitwidth pub nzbw: NonZeroUsize, + /// This either has zero length or has a length equal to `nzbw` + pub p_self_bits: SmallVec<[PBack; 4]>, /// Operation pub op: Op, /// Location where this state is derived from @@ -358,14 +358,20 @@ impl TDag { Ok(()) } - /*pub fn make_state(&mut self, nzbw: NonZeroUsize, op: Op, location: Option) -> PBack { - self.backrefs.insert_with(|p_self_equiv| { - ( - Referent::State(p_state), - Equiv::new(p_self_equiv, V) - ) + pub fn make_state( + &mut self, + nzbw: NonZeroUsize, + op: Op, + location: Option, + ) -> PState { + self.states.insert(State { + nzbw, + p_self_bits: SmallVec::new(), + op, + location, + visit: NonZeroU64::new(2).unwrap(), }) - }*/ + } /// Inserts a `TNode` with `lit` value and returns a `PBack` to it pub fn make_literal(&mut self, lit: Option) -> PBack { diff --git a/testcrate/tests/epoch.rs b/testcrate/tests/epoch.rs new file mode 100644 index 00000000..b1c59c8b --- /dev/null +++ b/testcrate/tests/epoch.rs @@ -0,0 +1,30 @@ +use starlight::{dag::*, Epoch}; + +#[test] +#[should_panic] +fn state_epoch_unregistered0() { + let _x = ExtAwi::zero(bw(1)); +} + +#[test] +#[should_panic] +fn state_epoch_unregistered1() { + let _x: u8 = 7.into(); +} + +#[test] +#[should_panic] +fn state_epoch_unregistered2() { + let epoch0 = Epoch::new(); + drop(epoch0); + let _x: inlawi_ty!(1) = InlAwi::zero(); +} + +#[test] +#[should_panic] +fn state_epoch_fail() { + let epoch0 = Epoch::new(); + let epoch1 = Epoch::new(); + drop(epoch0); + drop(epoch1); +}