2023-08-29 09:15:41 +00:00
|
|
|
use std::time::Instant;
|
|
|
|
|
2023-08-28 08:16:40 +00:00
|
|
|
use bench_utils::TextAction;
|
|
|
|
use loro_internal::LoroDoc;
|
2022-11-14 10:42:16 +00:00
|
|
|
|
|
|
|
fn main() {
|
2023-08-28 08:16:40 +00:00
|
|
|
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();
|
2023-08-28 08:16:40 +00:00
|
|
|
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-28 08:16:40 +00:00
|
|
|
}
|
|
|
|
|
2023-10-29 06:02:13 +00:00
|
|
|
{
|
|
|
|
// Delta encoding
|
|
|
|
|
|
|
|
// let start = Instant::now();
|
|
|
|
// for _ in 0..10 {
|
|
|
|
// loro.export_from(&Default::default());
|
|
|
|
// }
|
2023-08-29 09:15:41 +00:00
|
|
|
|
2023-10-29 06:02:13 +00:00
|
|
|
// println!("Avg encode {}ms", start.elapsed().as_millis() as f64 / 10.0);
|
2023-08-29 09:15:41 +00:00
|
|
|
|
2023-10-29 06:02:13 +00:00
|
|
|
let data = loro.export_from(&Default::default());
|
|
|
|
let start = Instant::now();
|
|
|
|
for _ in 0..5 {
|
|
|
|
let b = LoroDoc::default();
|
|
|
|
b.import(&data).unwrap();
|
|
|
|
}
|
|
|
|
|
|
|
|
println!("Avg decode {}ms", start.elapsed().as_millis() as f64 / 10.0);
|
|
|
|
println!("size len={}", data.len());
|
|
|
|
let d = miniz_oxide::deflate::compress_to_vec(&data, 10);
|
|
|
|
println!("size after compress len={}", d.len());
|
2023-08-28 08:16:40 +00:00
|
|
|
}
|
2023-08-29 09:15:41 +00:00
|
|
|
|
2023-10-29 06:02:13 +00:00
|
|
|
{
|
|
|
|
// Snapshot encoding
|
|
|
|
// println!("\n=======================\nSnapshot Encoding:");
|
|
|
|
|
|
|
|
// let start = Instant::now();
|
|
|
|
// for _ in 0..10 {
|
|
|
|
// loro.export_snapshot();
|
|
|
|
// }
|
|
|
|
|
|
|
|
// println!("Avg encode {}ms", start.elapsed().as_millis() as f64 / 10.0);
|
|
|
|
|
|
|
|
// let data = loro.export_snapshot();
|
|
|
|
// let start = Instant::now();
|
|
|
|
// let times = 300;
|
|
|
|
// for _ in 0..times {
|
|
|
|
// let b = LoroDoc::default();
|
|
|
|
// b.import(&data).unwrap();
|
|
|
|
// }
|
|
|
|
|
|
|
|
// println!(
|
|
|
|
// "Avg decode {}ms",
|
|
|
|
// start.elapsed().as_millis() as f64 / times as f64
|
|
|
|
// );
|
|
|
|
// println!("size len={}", data.len());
|
|
|
|
// let d = miniz_oxide::deflate::compress_to_vec(&data, 10);
|
|
|
|
// println!("size after compress len={}", d.len());
|
|
|
|
}
|
2022-11-14 10:42:16 +00:00
|
|
|
}
|