#nlp #information-retrieval #stemming #language #retrieval

rust-stemmers

A rust implementation of some popular snowball stemming algorithms

6 releases (stable)

Uses old Rust 2015

1.2.0 Nov 17, 2019
1.1.0 Jan 24, 2019
1.0.2 Dec 30, 2017
1.0.1 Aug 22, 2017
0.1.0 Feb 7, 2017

#98 in Algorithms

Download history 76177/week @ 2024-10-17 75865/week @ 2024-10-24 72292/week @ 2024-10-31 76680/week @ 2024-11-07 83649/week @ 2024-11-14 72801/week @ 2024-11-21 74188/week @ 2024-11-28 78683/week @ 2024-12-05 69753/week @ 2024-12-12 49629/week @ 2024-12-19 31833/week @ 2024-12-26 67585/week @ 2025-01-02 105898/week @ 2025-01-09 81633/week @ 2025-01-16 86741/week @ 2025-01-23 81515/week @ 2025-01-30

371,131 downloads per month
Used in 283 crates (32 directly)

MIT/BSD-3-Clause

2.5MB
19K SLoC

Rust Stemmers

This crate implements some stemmer algorithms found in the snowball project which are compiled to rust using the rust-backend of the snowball compiler.

Supported Algorithms

  • Arabic
  • Danish
  • Dutch
  • English
  • French
  • German
  • Greek
  • Hungarian
  • Italian
  • Norwegian
  • Portuguese
  • Romanian
  • Russian
  • Spanish
  • Swedish
  • Tamil
  • Turkish

Usage

extern crate rust_stemmers;
use rust_stemmers::{Algorithm, Stemmer};

// Create a stemmer for the english language
let en_stemmer = Stemmer::create(Algorithm::English);

// Stemm the word "fruitlessly"
// Please be aware that all algorithms expect their input to only contain lowercase characters.
assert_eq!(en_stemmer.stem("fruitlessly"), "fruitless");

Related Projects

  • The stemmer crate provides bindings to the C Snowball implementation.

lib.rs:

This library provides rust implementations for some stemmer algorithms written in the snowball language.

All algorithms expect the input to already be lowercased.

Usage

[dependencies]
rust-stemmers = "^1.0"
extern crate rust_stemmers;

use rust_stemmers::{Algorithm, Stemmer};

fn main() {
   let en_stemmer = Stemmer::create(Algorithm::English);
   assert_eq!(en_stemmer.stem("fruitlessly"), "fruitless");
}

Dependencies