loro/crates/loro-internal/examples/encoding.rs

38 lines
1.1 KiB
Rust
Raw Normal View History

2023-08-29 09:15:41 +00:00
use std::time::Instant;
use bench_utils::TextAction;
use loro_internal::LoroDoc;
fn main() {
let actions = bench_utils::get_automerge_actions();
let loro = LoroDoc::default();
let text = loro.get_text("text");
for TextAction { pos, ins, del } in actions.iter() {
2023-08-29 09:15:41 +00:00
let mut txn = loro.txn().unwrap();
text.delete(&mut txn, *pos, *del).unwrap();
text.insert(&mut txn, *pos, ins).unwrap();
2023-08-29 09:15:41 +00:00
txn.commit().unwrap();
}
2023-08-29 09:15:41 +00:00
let start = Instant::now();
for _ in 0..10 {
loro.export_from(&Default::default());
}
2023-08-29 09:15:41 +00:00
println!("Avg encode {}ms", start.elapsed().as_millis() as f64 / 10.0);
let data = loro.export_from(&Default::default());
2023-08-29 09:15:41 +00:00
let start = Instant::now();
for _ in 0..100 {
let mut b = LoroDoc::default();
b.detach();
b.import(&data).unwrap();
}
2023-08-29 09:15:41 +00:00
println!("Avg decode {}ms", start.elapsed().as_millis() as f64 / 10.0);
2023-08-29 09:15:41 +00:00
println!("size len={}", data.len());
let d = miniz_oxide::deflate::compress_to_vec(&data, 10);
println!("size after compress len={}", d.len());
}