#nlp #syllable #language #language-model #text

syllarust

A simple crate for quickly counting syllables

3 unstable releases

0.2.0 Jan 6, 2025
0.1.1 May 7, 2024
0.1.0 Mar 12, 2024

#1509 in Text processing

Download history 11/week @ 2024-09-25 10/week @ 2024-10-02 2/week @ 2024-12-04 3/week @ 2024-12-11 132/week @ 2025-01-01 23/week @ 2025-01-08

155 downloads per month

Apache-2.0

19KB
322 lines

syllarust

A simple syllable counter implemented natively in Rust. This is based on the work of the python-syllables team, which implents the same functionality in Python.

My goal was to bring the same ease/simplicity to Rust - and use Rust's fearless concurrency model to help improve the speed/quality at which syllable counts can be generated. This means if you're trying to generate syllable counts for large NLP/LLM applications where speed matters, this may be the crate you're looking for!

Parallelism snippet using Rayon

use syllarust::estimate_syllables;
use rayon::prelude::*;

fn main() {
    let test_strs: Vec<&str> = vec![
        "Apple",
        "Tart",
        "plate",
        "Pontificate",
        "Hello"
    ];
    
    let start = Instant::now();
    let results: Vec<usize> = test_strs.par_iter()
        .map(|s| estimate_syllables(s))
        .collect();

    let stop = Instant::now();
    println!("{:?}", stop - start);
    println!("{:?}", results);
}

Contributions/Issues

This is currently a work-in-progress repo. If you have any feature requests/spot a bug, leave me an issue and I'll try and tackle it when I can. I'm also open to sensible PRs.

If you're a more experienced Rust dev and you spy any inefficiencies, I'd be grateful for your feedback. I'm a relatively new Rustacean 🦀 who works full-time as a Python-native ML Engineer, and therefore I might do dumb things sometimes.

Dependencies

~6–8MB
~148K SLoC