Spaces:
Running
on
Zero
Running
on
Zero
## Zero-Shot Approximation of Language Embeddings | |
This directory contains all scripts that are needed to reproduce the meta learning for zero-shot part of our system. These scripts allow you to predict representations of languages purely based on distances between them, as measured by a variety of linguistically informed metrics, or even better, a learned combination thereof. | |
### Applying zero-shot approximation to a trained model | |
Use `run_zero_shot_lang_emb_injection.py` to update the language embeddings of a trained model for all languages that were *not* seen during training (by default, `supervised_languages.json` is used to determine which languages *were* seen). | |
See the script for arguments that can be passed (e.g. to use a custom model path). Here is an example: | |
``` | |
cd IMS-Toucan/ | |
python run_zero_shot_lang_emb_injection.py -m <model_path> -d <distance_type> -k <number_of_nearest_neighbors> | |
``` | |
By default, the updated model is saved with a modified filename in the same directory. | |
### Cached distance lookups | |
In order to apply any zero-shot approximation, cache files for distance lookups are required. | |
The ASP lookup file (`asp_dict.pkl`) needs to be downloaded from the release page. All other cache files are automatically generated as required when running `run_zero_shot_lang_emb_injection.py`. | |
**Note:** While the map, tree, and inverse ASP distances are model independent, **the learned distance lookup is only applicable for the model it was trained on**, i.e., different Toucan models require different learned-distance lookups. If you want to apply zero-shot approximation to a new model, make sure that you are not using an outdated, pre-existing learned distance lookup, but instead train a new learned distance metric. | |