mosesdecoder/vw/README.md

114 lines
4.2 KiB
Markdown
Raw Normal View History

2015-01-09 17:01:38 +03:00
Vowpal Wabbit for Moses
=======================
This is an attempt to integrate Vowpal Wabbit with Moses as a stateless feature
function.
2015-01-09 17:47:00 +03:00
Compatible with this frozen version of VW:
https://github.com/moses-smt/vowpal_wabbit
2015-01-09 17:54:29 +03:00
To enable VW, you need to provide a path where VW was installed (using `make install`) to bjam:
./bjam --with-vw=<path/to/vw/installation>
2015-01-09 17:47:00 +03:00
2015-01-09 17:01:38 +03:00
Implemented classifier features
-------------------------------
2015-01-09 17:20:22 +03:00
* `VWFeatureSourceBagOfWords`: This creates a feature of form bow^token for every
2015-01-09 17:05:39 +03:00
source sentence token.
* `VWFeatureSourceExternalFeatures column=0`: when used with -inputtype 5 (`TabbedSentence`) this can be used to supply additional feature to VW. The input is a tab-separated file, the first column is the usual input sentence, all other columns can be used for meta-data. Parameter column=0 counts beginning with the first column that is not the input sentence.
2015-01-09 17:20:22 +03:00
* `VWFeatureSourceIndicator`: Ass a feature for the whole source phrase.
* `VWFeatureSourcePhraseInternal`: Adds a separate feature for every word of the source phrase.
2015-01-09 17:21:41 +03:00
* `VWFeatureSourceWindow size=3`: Adds source words in a window of size 3 before and after the source phrase as features. These do not overlap with `VWFeatureSourcePhraseInternal`.
2015-01-09 17:20:22 +03:00
* `VWFeatureTargetIndicator`: Adds a feature for the whole target phrase.
* `VWFeatureTargetPhraseInternal`: Adds a separate feature for every word of the target phrase.
2015-01-09 17:01:38 +03:00
Configuration
-------------
To use the classifier edit your moses.ini
2015-01-09 17:04:10 +03:00
[features]
...
VW path=/home/username/vw/classifier1.vw
VWFeatureSourceBagOfWords
VWFeatureTargetIndicator
2015-01-09 17:05:39 +03:00
VWFeatureSourceIndicator
2015-01-09 17:04:10 +03:00
...
2015-01-09 17:04:10 +03:00
[weights]
...
VW0= 0.2
...
2015-01-09 17:01:38 +03:00
If you change the name of the main VW feature, remember to tell the VW classifier
features which classifier they belong to:
2015-01-09 17:04:10 +03:00
[features]
...
VW name=bart path=/home/username/vw/classifier1.vw
2015-01-09 17:04:10 +03:00
VWFeatureSourceBagOfWords used-by=bart
VWFeatureTargetIndicator used-by=bart
2015-01-09 17:05:39 +03:00
VWFeatureSourceIndicator used-by=bart
2015-01-09 17:04:10 +03:00
...
2015-01-09 17:04:10 +03:00
[weights]
...
bart= 0.2
...
2015-01-09 17:01:38 +03:00
You can also use multiple classifiers:
2015-01-09 17:04:10 +03:00
[features]
...
VW name=bart path=/home/username/vw/classifier1.vw
2015-01-09 17:04:10 +03:00
VW path=/home/username/vw/classifier2.vw
VW path=/home/username/vw/classifier3.vw
VWFeatureSourceBagOfWords used-by=bart,VW0
2015-01-09 17:04:10 +03:00
VWFeatureTargetIndicator used-by=VW1,VW0,bart
VWFeatureSourceIndicator used-by=bart,VW1
...
2015-01-09 17:04:10 +03:00
[weights]
...
bart= 0.2
VW0= 0.2
VW1= 0.2
...
2015-01-09 18:00:36 +03:00
Features can use any combination of factors. Provide a comma-delimited list of factors in the `source-factors` or `target-factors` variables to override the default setting (`0`, i.e. the first factor).
2015-01-09 17:01:38 +03:00
Training the classifier
2015-01-09 17:13:59 +03:00
-----------------------
2015-01-09 17:33:52 +03:00
2015-01-09 18:00:36 +03:00
Training uses `vwtrainer` which is a limited version of the `moses` binary. To train, provide your training data as input in the following format:
source tokens<tab>target tokens<tab>word alignment
Use Moses format for the word alignment (`0-0 1-0` etc.). Set the input type to 5 (`TabbedSentence`, see above):
[inputtype]
5
Configure your features in the `moses.ini` file (see above) and set the `train` flag:
2015-01-09 17:33:52 +03:00
[features]
...
2015-01-09 17:33:52 +03:00
VW name=bart path=/home/username/vw/features.txt train=1
...
The `path` variable points to the file (prefix) where features will be written. Currently, threads write to separate files (maybe subject to change sooner or later): `features.txt.1`, `features.txt.2` etc.
2015-01-09 17:37:20 +03:00
`vwtrainer` creates the translation option collection for each input sentence but does not run decoding. Therefore, you probably want to disable expensive feature functions such as the language model (LM score is not used by VW features at the moment).
2015-01-09 18:02:33 +03:00
Run `vwtrainer`:
vwtrainer -f moses.trainvw.ini < tab-separated-training-data.tsv
2015-01-09 17:33:52 +03:00
Currently, classification is implemented using VW's `csoaa_ldf` scheme with quadratic features which take the product of the source namespace (`s`, contains label-independent features) and the target namespace (`t`, contains label-dependent features).
To train VW in this setting, use the command:
2015-01-12 15:59:20 +03:00
cat features.txt.* | vw --hash all --loss_function logistic --noconstant -b 26 -q st --csoaa_ldf mc -f classifier1.vw