Skip to main content

morphological analyzer (word segmentor + PoS Tagger) for Chinese and Japanese

Project description

Rakuten MA Python

travis-ci.org coveralls.io pyversion latest version Code Health license

Rakuten MA Python (morphological analyzer) is a Python version of Rakuten MA (word segmentor + PoS Tagger) for Chinese and Japanese.

For details about Rakuten MA, See https://github.com/rakuten-nlp/rakutenma

See also http://qiita.com/yukinoi/items/925bc238185aa2fad8a7 (In Japanese)

Contributions are welcome!

Installation

pip install rakutenma

Example

from rakutenma import RakutenMA

# Initialize a RakutenMA instance with an empty model
# the default ja feature set is set already
rma = RakutenMA()

# Let's analyze a sample sentence (from http://tatoeba.org/jpn/sentences/show/103809)
# With a disastrous result, since the model is empty!
print(rma.tokenize("彼は新しい仕事できっと成功するだろう。"))

# Feed the model with ten sample sentences from tatoeba.com
# "tatoeba.json" is available at https://github.com/rakuten-nlp/rakutenma
import json
tatoeba = json.load(open("tatoeba.json"))
for i in tatoeba:
    rma.train_one(i)

# Now what does the result look like?
print(rma.tokenize("彼は新しい仕事できっと成功するだろう。"))

# Initialize a RakutenMA instance with a pre-trained model
rma = RakutenMA(phi=1024, c=0.007812)  # Specify hyperparameter for SCW (for demonstration purpose)
rma.load("model_ja.json")

# Set the feature hash function (15bit)
rma.hash_func = rma.create_hash_func(15)

# Tokenize one sample sentence
print(rma.tokenize("うらにわにはにわにわとりがいる"));

# Re-train the model feeding the right answer (pairs of [token, PoS tag])
res = rma.train_one(
       [["うらにわ","N-nc"],
        ["に","P-k"],
        ["は","P-rj"],
        ["にわ","N-n"],
        ["にわとり","N-nc"],
        ["が","P-k"],
        ["いる","V-c"]])
# The result of train_one contains:
#   sys: the system output (using the current model)
#   ans: answer fed by the user
#   update: whether the model was updated
print(res)

# Now what does the result look like?
print(rma.tokenize("うらにわにはにわにわとりがいる"))

NOTE

Added API

As compared to original RakutenMA, following methods are added:

  • RakutenMA::load(model_path) - Load model from JSON file

  • RakutenMA::save(model_path) - Save model to path

misc

As initial setting, following values are set:

  • rma.featset = CTYPE_JA_PATTERNS # RakutenMA.default_featset_ja

  • rma.hash_func = rma.create_hash_func(15)

  • rma.tag_scheme = “SBIEO” # if using Chinese, set “IOB2”

LICENSE

Apache License version 2.0

CHANGES

0.3.3 (2017-05-22)

  • Bug fix about training

0.3.2 (2017-02-01)

  • Use ujson when possible

  • Enable POS to MeCab style

  • Support Python 3.5 and 3.6

0.3 (2016-04-10)

  • Add CUI ($ rakutenma)

0.2.2 (2016-04-09)

  • Bundle model files (model_ja.json, model_ja_min.json)

  • Support Windows

0.2 (2015-01-10)

  • Support Python 2.6 and 2.7

0.1.1 (2015-01-08)

  • Slightly improve performance

0.1 (2015-01-01)

  • First release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rakutenma-0.3.3.tar.gz (25.0 MB view details)

Uploaded Source

File details

Details for the file rakutenma-0.3.3.tar.gz.

File metadata

  • Download URL: rakutenma-0.3.3.tar.gz
  • Upload date:
  • Size: 25.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for rakutenma-0.3.3.tar.gz
Algorithm Hash digest
SHA256 2ee2ffe6cf93d7dae805f7e0e1971ef6a40f724a72e92d4de4f498097f776773
MD5 1cc18f28ae60e334211a2bc707129b20
BLAKE2b-256 b753e2c622a87a70a8f271b8bf8d62147366f619cad41e3ecbb21e4c6acdc540

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page