Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Can you programmatically detect pluralizations of English words, and derive the singular form?

Given some (English) word that we shall assume is a plural, is it possible to derive the singular form? I'd like to avoid lookup/dictionary tables if possible.

Some examples:

Examples  -> Example    a simple 's' suffix
Glitch    -> Glitches   'es' suffix, as opposed to above
Countries -> Country    'ies' suffix.
Sheep     -> Sheep      no change: possible fallback for indeterminate values

Or, this seems to be a fairly exhaustive list.

Suggestions of libraries in language x are fine, as long as they are open-source (ie, so that someone can examine them to determine how to do it in language y)

like image 275
Matthew Scharley Avatar asked Sep 04 '09 03:09

Matthew Scharley


3 Answers

It really depends on what you mean by 'programmatically'. Part of English works on easy to understand rules, and part doesn't. It has to do mainly with frequency. For a brief overview, you can read Pinker's "Words and Rules", but do yourself a favor and don't take the whole generative theory of linguistics entirely to heart. There's a lot more empiricism there than that school of thought really lends to the pursuit.

A lot of English can be statistically lemmatized. By the way, stemming or lemmatization is the term you're looking for. One of the most effective lemmatizers which work off of statistical rules bootstrapped with frequency-based exceptions is the Morpha Lemmatizer. You can give this a shot if you have a project that requires this type of simplification of strings which represent specific terms in English.

There are even more naive approaches that accomplish much with respect to normalizing related terms. Take a look at the Porter Stemmer, which is effective enough to cluster together most terms in English.

like image 114
Robert Elwell Avatar answered Sep 24 '22 07:09

Robert Elwell


Going from singular to plural, English plural form is actually pretty regular compared to some other European languages I have a passing familiarity with. In German for example, working out the plural form is really complicated (eg Land -> Länder). I think there are roughly 20-30 exceptions and the rest follow a fairly simple ruleset:

  • -y -> -ies (family -> families)
  • -us -> -i (cactus -> cacti)
  • -s -> -ses (loss -> losses)
  • otherwise add -s

That being said, plural to singular form becomes that much harder because the reverse cases have ambiguities. For example:

  • pies: is it py or pie?
  • ski: is it singular or plural for 'skus'?
  • molasses: is it singular or plural for 'molasse' or 'molass'?

So it can be done but you're going to have a much larger list of exceptions and you're going to have to store a lot of false positives (ie things that appear plural but aren't).

like image 44
cletus Avatar answered Sep 20 '22 07:09

cletus


Is "axes" the plural of "ax" or of "axis"? Even a human cannot tell without context.

like image 33
Robert L Avatar answered Sep 22 '22 07:09

Robert L