Averaged Perceptron Sequence Tagger
Project description
Apertag: Averaged Perceptron Tagger
Apertag is a sequence tagger based on an averaged perceptron model. In order to avoid making assumptions about what kind of sequence data you are labeling, or the format of your features, the input to the tagger is simply sequences of feature value sets. Each set of values represent an observation to receive a tag. A feature value can be any python type, as long as it can be hashed, but it’s important to note that the the values are used only in a binary fashion, i.e. either they exist in the context of the item being tagged or not; the nature of the value has no impact on the decision.
A simple example illustrating an NP-chunker:
>>> t = Tagger()
>>> t.train([[['POS=DT','WRD=the'],['POS=NN','WRD=dog']]],[['NP-B','NP-I']])
>>> t.tag([['POS=DT','WRD=the'],['POS=NN','WRD=dog']])
['NP-B', 'NP-I']
There is one crucial exception to all this featuratory freedom: Any features wishing to make use of the actual output tags need to signal this by formatting their value as a string with special tags that will be replaced by the corresponding tags from the current context during tagging. The tag format is “<Tn>”, where n is the negative index of the tag relative to the current position. For example, if you are training a POS-tagger and you have a feature that looks at the current word and the previous output tag, and the current word is “dog”, the feature could be encoded as “<T1>:dog”. The tagger will expand this using its predicted label context into something like “DT:dog” (depending on your tag set and feature format, of course).
An example illustrating a POS-tagger with output label features:
>>> t = Tagger()
>>> t.train([[['POS -1:<T-1>','W:the'],['POS -1:<T-1>','W:dog']]],[['DT','NN']])
>>> t.tag([['POS -1:<T-1>','W:the'],['POS -1:<T-1>','W:dog']])
['DT', 'NN']
It is most likely a good idea to use this format for training as well, even though you (hopefully) have the output tags yourself at that point, to ensure the features are identical across training and tagging.
If you don’t require output tags for any of your features, you can slightly increase performance (especially for non-string features) by setting expand_features=False.
Where do I put my columns?
The tagger module can be run as a standalone script, which takes its input as good old files of tab delimited columns, where each row is an observation consisting of feature values, followed by the tag in the last column. For more info run:
$ python apertag.py {train,tag} -h
References and acknowledgments
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file Apertag-1.0.2.linux-x86_64.tar.gz
.
File metadata
- Download URL: Apertag-1.0.2.linux-x86_64.tar.gz
- Upload date:
- Size: 6.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2ae14d6a54edcde67a5782cae0240fb318561c3942a5fcb075700a2cc204a7b0 |
|
MD5 | 509975d42a064ee44e254e55535961b1 |
|
BLAKE2b-256 | 9874cdb9f855e2628c3d89d5bda9d01e57ef445b925408e432ee906f70b35fc3 |