5 unstable releases
0.3.1 | Apr 21, 2021 |
---|---|
0.2.2 | Apr 21, 2021 |
0.2.1 | Apr 21, 2021 |
0.1.2 | Apr 18, 2021 |
0.1.1 | Mar 27, 2021 |
#851 in Text processing
27KB
494 lines
Text Entry Throughput
Text entry throughput introduced by Minguri et al. is a text entry method-independent throughput metric based on Shannon information theory.
This crate is a third-party implementation of TET.
TL;DR
use tet_rs::TextEntryThroughput;
// A preset for English alphabet is provided.
// An explanation for other language texts is wrote on later.
let tet = TextEntryThroughput::alphabet_letter_distribution();
let presented_text = "my watch fell in the waterprevailing wind from the east";
let transcribed_text = "my wacch fell in waterpreviling wind on the east";
let s = std::time::Duration::from_secs(12); // 4 characters per second
let throughput = tet.calc(presented_text, transcribed_text, s).unwrap();
assert!((throughput - 12.954965333409255).abs() < 0.0001);
Usage
Get distribution
First, prepare a distribution of characters to get entropy H(X)
from source.
use tet_rs::{Frequencies, Distribution};
let mut frequency = Frequencies::new();
// get frequency of each character
let source = "large and appropriate text is recommended";
source.chars()
.for_each(|c| {
frequency.record(c.clone());
});
// normalize frequency to get distribution
let distribution = Distribution::new(frequency);
Compute TET
// now you can calculate TET! :+1:
let tet = TextEntryThroughput::new(distribution);
// Of course, you can use also multibyte characters
// ref. https://doc.rust-lang.org/std/primitive.char.html
let (presented, transcribed) = ("うまぴょい", "うまぽい");
let s = std::time::Duration::from_secs(2); // 4 characters per minute
// Text Entry Throughput (bits/second)
let throughput = tet.calc(presented, transcribed, s).unwrap();
Features
serde1
feature allows you to save and load Frequencies
and Distribution
via JSON.
tet_rs = { version = "0.1", features = ["serde1"] }
Dependencies
~175KB