mirror of
https://github.com/salsa-rs/salsa.git
synced 2025-01-15 01:39:25 +00:00
Remove LRU distribution tests
They are ignored and in the git history anyway.
This commit is contained in:
parent
b460db700a
commit
35a420d0c0
2 changed files with 0 additions and 129 deletions
|
@ -5,8 +5,6 @@ use std::sync::atomic::AtomicUsize;
|
|||
use std::sync::atomic::Ordering;
|
||||
use std::sync::Arc;
|
||||
|
||||
mod test;
|
||||
|
||||
/// A simple and approximate concurrent lru list.
|
||||
///
|
||||
/// We assume but do not verify that each node is only used with one
|
||||
|
|
127
src/lru/test.rs
127
src/lru/test.rs
|
@ -1,127 +0,0 @@
|
|||
#![cfg(test)]
|
||||
|
||||
use super::*;
|
||||
use linked_hash_map::LinkedHashMap;
|
||||
use rand_distr::{Distribution, Normal};
|
||||
|
||||
#[derive(Debug)]
|
||||
struct TestNode {
|
||||
id: usize,
|
||||
index: LruIndex,
|
||||
}
|
||||
|
||||
impl TestNode {
|
||||
fn new(id: usize) -> Arc<Self> {
|
||||
Arc::new(TestNode {
|
||||
id,
|
||||
index: Default::default(),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
impl LruNode for TestNode {
|
||||
fn lru_index(&self) -> &LruIndex {
|
||||
&self.index
|
||||
}
|
||||
}
|
||||
|
||||
const PICK_SEED: &str = "Wippity WIP";
|
||||
|
||||
/// Randomly requests nodes and compares the performance of a
|
||||
/// *perfect* LRU vs our more approximate version. Since all the
|
||||
/// random number generators use fixed seeds, these results are
|
||||
/// reproducible. Returns (oracle_hits, lru_hits) -- i.e., the number
|
||||
/// of times that the oracle had something in cache vs the number of
|
||||
/// times that our LRU did.
|
||||
fn compare(
|
||||
standard_deviation: usize,
|
||||
num_nodes: usize,
|
||||
capacity: usize,
|
||||
requests: usize,
|
||||
) -> (usize, usize) {
|
||||
// Remember the clock each time we access a given element.
|
||||
let mut last_access: Vec<usize> = (0..num_nodes).map(|_| 0).collect();
|
||||
|
||||
// Use a linked hash map as our *oracle* -- we track each node we
|
||||
// requested and (as the value) the clock in which we requested
|
||||
// it. When the capacity is exceed, we can pop the oldest.
|
||||
let mut oracle = LinkedHashMap::new();
|
||||
|
||||
let lru = Lru::with_seed(super::LRU_SEED);
|
||||
lru.set_lru_capacity(capacity);
|
||||
|
||||
let nodes: Vec<_> = (0..num_nodes).map(|i| TestNode::new(i)).collect();
|
||||
|
||||
let mut oracle_hits = 0;
|
||||
let mut lru_hits = 0;
|
||||
|
||||
let mut pick_rng = super::rng_with_seed(PICK_SEED);
|
||||
let normal = Normal::new((num_nodes / 2) as f64, standard_deviation as f64).unwrap();
|
||||
for clock in (0..requests).map(|n| n + 1) {
|
||||
let request_id = (normal.sample(&mut pick_rng) as usize).min(num_nodes - 1);
|
||||
assert!(request_id < num_nodes);
|
||||
|
||||
last_access[request_id] = clock;
|
||||
|
||||
if oracle.contains_key(&request_id) {
|
||||
oracle_hits += 1;
|
||||
}
|
||||
|
||||
if nodes[request_id].index.is_in_lru() {
|
||||
lru_hits += 1;
|
||||
}
|
||||
|
||||
// maintain the oracle LRU
|
||||
oracle.insert(request_id, ());
|
||||
if oracle.len() > capacity {
|
||||
oracle.pop_front().unwrap();
|
||||
}
|
||||
|
||||
// maintain our own version
|
||||
if let Some(lru_evicted) = lru.record_use(&nodes[request_id]) {
|
||||
assert!(!lru_evicted.index.is_in_lru());
|
||||
}
|
||||
}
|
||||
|
||||
println!("oracle_hits = {}", oracle_hits);
|
||||
println!("lru_hits = {}", lru_hits);
|
||||
(oracle_hits, lru_hits)
|
||||
}
|
||||
|
||||
// Compare performance of approximate LRU vs the perfect oracle in
|
||||
// various scenarios -- different standard deviations and total size.
|
||||
// Note that the `lru_hits` variable is just recording the current
|
||||
// state and would be expected to change if you tweak the
|
||||
// implementation (`oracle_hits` ought not to change).
|
||||
|
||||
#[test]
|
||||
#[ignore] // these results seem to vary between CI and local machines, not sure why, maybe version of rand?
|
||||
fn scenario_20_of_1000() {
|
||||
let (oracle_hits, lru_hits) = compare(20, 1000, 100, 10000);
|
||||
assert_eq!(oracle_hits, 9662);
|
||||
assert_eq!(lru_hits, 9428);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[ignore] // these results seem to vary between CI and local machines, not sure why, maybe version of rand?
|
||||
fn scenario_200_of_1000() {
|
||||
let (oracle_hits, lru_hits) = compare(200, 1000, 100, 10000);
|
||||
assert_eq!(oracle_hits, 1496);
|
||||
assert_eq!(lru_hits, 1488);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[ignore] // these results seem to vary between CI and local machines, not sure why, maybe version of rand?
|
||||
fn scenario_500_of_1000() {
|
||||
let (oracle_hits, lru_hits) = compare(500, 1000, 100, 10000);
|
||||
assert_eq!(oracle_hits, 3835);
|
||||
assert_eq!(lru_hits, 3839);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[ignore] // these results seem to vary between CI and local machines, not sure why, maybe version of rand?
|
||||
fn scenario_2000_of_10000() {
|
||||
let (oracle_hits, lru_hits) = compare(2000, 10000, 100, 10000);
|
||||
assert_eq!(oracle_hits, 256);
|
||||
assert_eq!(lru_hits, 229);
|
||||
}
|
Loading…
Reference in a new issue