mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-12 18:26:30 +03:00
Update command docstrings and docs
This commit is contained in:
parent
0ab483037c
commit
c96535e338
|
@ -53,10 +53,13 @@ def convert_cli(
|
||||||
# fmt: on
|
# fmt: on
|
||||||
):
|
):
|
||||||
"""
|
"""
|
||||||
Convert files into json or DocBin format for use with train command and other
|
Convert files into json or DocBin format for training. The resulting .spacy
|
||||||
experiment management functions. If no output_dir is specified, the data
|
file can be used with the train command and other experiment management
|
||||||
|
functions.
|
||||||
|
|
||||||
|
If no output_dir is specified and the output format is JSON, the data
|
||||||
is written to stdout, so you can pipe them forward to a JSON file:
|
is written to stdout, so you can pipe them forward to a JSON file:
|
||||||
$ spacy convert some_file.conllu > some_file.json
|
$ spacy convert some_file.conllu --file-type json > some_file.json
|
||||||
"""
|
"""
|
||||||
if isinstance(file_type, FileTypes):
|
if isinstance(file_type, FileTypes):
|
||||||
# We get an instance of the FileTypes from the CLI so we need its string value
|
# We get an instance of the FileTypes from the CLI so we need its string value
|
||||||
|
|
|
@ -46,9 +46,8 @@ def init_model_cli(
|
||||||
# fmt: on
|
# fmt: on
|
||||||
):
|
):
|
||||||
"""
|
"""
|
||||||
Create a new model from raw data, like word frequencies, Brown clusters
|
Create a new model from raw data. If vectors are provided in Word2Vec format,
|
||||||
and word vectors. If vectors are provided in Word2Vec format, they can
|
they can be either a .txt or zipped as a .zip or .tar.gz.
|
||||||
be either a .txt or zipped as a .zip or .tar.gz.
|
|
||||||
"""
|
"""
|
||||||
init_model(
|
init_model(
|
||||||
lang,
|
lang,
|
||||||
|
|
|
@ -23,11 +23,13 @@ def package_cli(
|
||||||
# fmt: on
|
# fmt: on
|
||||||
):
|
):
|
||||||
"""
|
"""
|
||||||
Generate Python package for model data, including meta and required
|
Generate an installable Python package for a model. Includes model data,
|
||||||
installation files. A new directory will be created in the specified
|
meta and required installation files. A new directory will be created in the
|
||||||
output directory, and model data will be copied over. If --create-meta is
|
specified output directory, and model data will be copied over. If
|
||||||
set and a meta.json already exists in the output directory, the existing
|
--create-meta is set and a meta.json already exists in the output directory,
|
||||||
values will be used as the defaults in the command-line prompt.
|
the existing values will be used as the defaults in the command-line prompt.
|
||||||
|
After packaging, "python setup.py sdist" is run in the package directory,
|
||||||
|
which will create a .tar.gz archive that can be installed via "pip install".
|
||||||
"""
|
"""
|
||||||
package(
|
package(
|
||||||
input_dir,
|
input_dir,
|
||||||
|
|
|
@ -7,7 +7,7 @@ menu:
|
||||||
- ['Info', 'info']
|
- ['Info', 'info']
|
||||||
- ['Validate', 'validate']
|
- ['Validate', 'validate']
|
||||||
- ['Convert', 'convert']
|
- ['Convert', 'convert']
|
||||||
- ['Debug data', 'debug-data']
|
- ['Debug', 'debug']
|
||||||
- ['Train', 'train']
|
- ['Train', 'train']
|
||||||
- ['Pretrain', 'pretrain']
|
- ['Pretrain', 'pretrain']
|
||||||
- ['Init Model', 'init-model']
|
- ['Init Model', 'init-model']
|
||||||
|
@ -133,30 +133,82 @@ $ python -m spacy convert [input_file] [output_dir] [--converter]
|
||||||
| `ner` | NER with IOB/IOB2 tags, one token per line with columns separated by whitespace. The first column is the token and the final column is the IOB tag. Sentences are separated by blank lines and documents are separated by the line `-DOCSTART- -X- O O`. Supports CoNLL 2003 NER format. See [sample data](https://github.com/explosion/spaCy/tree/master/examples/training/ner_example_data). |
|
| `ner` | NER with IOB/IOB2 tags, one token per line with columns separated by whitespace. The first column is the token and the final column is the IOB tag. Sentences are separated by blank lines and documents are separated by the line `-DOCSTART- -X- O O`. Supports CoNLL 2003 NER format. See [sample data](https://github.com/explosion/spaCy/tree/master/examples/training/ner_example_data). |
|
||||||
| `iob` | NER with IOB/IOB2 tags, one sentence per line with tokens separated by whitespace and annotation separated by `|`, either `word|B-ENT` or `word|POS|B-ENT`. See [sample data](https://github.com/explosion/spaCy/tree/master/examples/training/ner_example_data). |
|
| `iob` | NER with IOB/IOB2 tags, one sentence per line with tokens separated by whitespace and annotation separated by `|`, either `word|B-ENT` or `word|POS|B-ENT`. See [sample data](https://github.com/explosion/spaCy/tree/master/examples/training/ner_example_data). |
|
||||||
|
|
||||||
## Debug data {#debug-data new="2.2"}
|
## Debug {#debug new="3"}
|
||||||
|
|
||||||
|
The `spacy debug` CLI includes helpful commands for debugging and profiling your
|
||||||
|
configs, data and implementations.
|
||||||
|
|
||||||
|
### debug config {#debug-config}
|
||||||
|
|
||||||
|
Debug a [`config.cfg` file](/usage/training#config) and show validation errors.
|
||||||
|
The command will create all objects in the tree and validate them. Note that
|
||||||
|
some config validation errors are blocking and will prevent the rest of the
|
||||||
|
config from being resolved. This means that you may not see all validation
|
||||||
|
errors at once and some issues are only shown once previous errors have been
|
||||||
|
fixed.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ python -m spacy debug config [config_path] [--code] [overrides]
|
||||||
|
```
|
||||||
|
|
||||||
|
> #### Example
|
||||||
|
>
|
||||||
|
> ```bash
|
||||||
|
> $ python -m spacy debug config ./config.cfg
|
||||||
|
> ```
|
||||||
|
|
||||||
|
<Accordion title="Example output" spaced>
|
||||||
|
|
||||||
|
```
|
||||||
|
✘ Config validation error
|
||||||
|
|
||||||
|
training -> use_gpu field required
|
||||||
|
training -> omit_extra_lookups field required
|
||||||
|
training -> batch_by field required
|
||||||
|
training -> raw_text field required
|
||||||
|
training -> tag_map field required
|
||||||
|
training -> evaluation_batch_size extra fields not permitted
|
||||||
|
training -> vectors extra fields not permitted
|
||||||
|
training -> width extra fields not permitted
|
||||||
|
|
||||||
|
{'gold_preproc': False, 'max_length': 3000, 'limit': 0, 'orth_variant_level': 0.0, 'dropout': 0.1, 'patience': 6000, 'max_epochs': 0, 'max_steps': 100000, 'eval_frequency': 400, 'seed': 0, 'accumulate_gradient': 4, 'width': 768, 'use_pytorch_for_gpu_memory': True, 'scores': ['speed', 'tags_acc', 'uas', 'las', 'ents_f'], 'score_weights': {'las': 0.4, 'ents_f': 0.4, 'tags_acc': 0.2}, 'init_tok2vec': None, 'vectors': None, 'discard_oversize': True, 'evaluation_batch_size': 16, 'batch_size': {'@schedules': 'compounding.v1', 'start': 800, 'stop': 800, 'compound': 1.001}, 'optimizer': {'@optimizers': 'Adam.v1', 'beta1': 0.9, 'beta2': 0.999, 'L2_is_weight_decay': True, 'L2': 0.01, 'grad_clip': 1.0, 'use_averages': False, 'eps': 1e-08, 'learn_rate': {'@schedules': 'warmup_linear.v1', 'warmup_steps': 250, 'total_steps': 20000, 'initial_rate': 5e-05}}}
|
||||||
|
```
|
||||||
|
|
||||||
|
</Accordion>
|
||||||
|
|
||||||
|
| Argument | Type | Description |
|
||||||
|
| -------------- | ---------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
|
| `config_path` | positional | Path to [training config](/api/data-formats#config) file containing all settings and hyperparameters. |
|
||||||
|
| `--code`, `-c` | option | Path to Python file with additional code to be imported. Allows [registering custom functions](/usage/training#custom-models) for new architectures. |
|
||||||
|
| `--help`, `-h` | flag | Show help message and available arguments. |
|
||||||
|
| overrides | | Config parameters to override. Should be options starting with `--` that correspond to the config section and value to override, e.g. `--training.use_gpu 1`. |
|
||||||
|
|
||||||
|
### debug data {#debug-data}
|
||||||
|
|
||||||
Analyze, debug, and validate your training and development data. Get useful
|
Analyze, debug, and validate your training and development data. Get useful
|
||||||
stats, and find problems like invalid entity annotations, cyclic dependencies,
|
stats, and find problems like invalid entity annotations, cyclic dependencies,
|
||||||
low data labels and more.
|
low data labels and more.
|
||||||
|
|
||||||
|
<Infobox title="New in v3.0" variant="warning">
|
||||||
|
|
||||||
|
The `debug-data` command is now available as a subcommand of `spacy debug`. It
|
||||||
|
takes the same arguments as `train` and reads settings off the
|
||||||
|
[`config.cfg` file](/usage/training#config).
|
||||||
|
|
||||||
|
</Infobox>
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ python -m spacy debug-data [lang] [train_path] [dev_path] [--base-model]
|
$ python -m spacy debug data [train_path] [dev_path] [config_path] [--code]
|
||||||
[--pipeline] [--tag-map-path] [--ignore-warnings] [--verbose] [--no-format]
|
[--ignore-warnings] [--verbose] [--no-format] [overrides]
|
||||||
```
|
```
|
||||||
|
|
||||||
| Argument | Type | Description |
|
> #### Example
|
||||||
| ------------------------------------------------------ | ---------- | ------------------------------------------------------------------------------------------------------------------------- |
|
>
|
||||||
| `lang` | positional | Model language. |
|
> ```bash
|
||||||
| `train_path` | positional | Location of [binary training data](/usage/training#data-format). Can be a file or a directory of files. |
|
> $ python -m spacy debug data ./train.spacy ./dev.spacy ./config.cfg
|
||||||
| `dev_path` | positional | Location of [binary development data](/usage/training#data-format) for evaluation. Can be a file or a directory of files. |
|
> ```
|
||||||
| `--tag-map-path`, `-tm` <Tag variant="new">2.2.4</Tag> | option | Location of JSON-formatted tag map. |
|
|
||||||
| `--base-model`, `-b` | option | Optional name of base model to update. Can be any loadable spaCy model. |
|
|
||||||
| `--pipeline`, `-p` | option | Comma-separated names of pipeline components to train. Defaults to `'tagger,parser,ner'`. |
|
|
||||||
| `--ignore-warnings`, `-IW` | flag | Ignore warnings, only show stats and errors. |
|
|
||||||
| `--verbose`, `-V` | flag | Print additional information and explanations. |
|
|
||||||
| `--no-format`, `-NF` | flag | Don't pretty-print the results. Use this if you want to write to a file. |
|
|
||||||
|
|
||||||
<Accordion title="Example output">
|
<Accordion title="Example output" spaced>
|
||||||
|
|
||||||
```
|
```
|
||||||
=========================== Data format validation ===========================
|
=========================== Data format validation ===========================
|
||||||
|
@ -295,6 +347,20 @@ will not be available.
|
||||||
|
|
||||||
</Accordion>
|
</Accordion>
|
||||||
|
|
||||||
|
| Argument | Type | Description |
|
||||||
|
| -------------------------- | ---------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
|
| `train_path` | positional | Location of [binary training data](/usage/training#data-format). Can be a file or a directory of files. |
|
||||||
|
| `dev_path` | positional | Location of [binary development data](/usage/training#data-format) for evaluation. Can be a file or a directory of files. |
|
||||||
|
| `config_path` | positional | Path to [training config](/api/data-formats#config) file containing all settings and hyperparameters. |
|
||||||
|
| `--code`, `-c` | option | Path to Python file with additional code to be imported. Allows [registering custom functions](/usage/training#custom-models) for new architectures. |
|
||||||
|
| `--ignore-warnings`, `-IW` | flag | Ignore warnings, only show stats and errors. |
|
||||||
|
| `--verbose`, `-V` | flag | Print additional information and explanations. |
|
||||||
|
| `--no-format`, `-NF` | flag | Don't pretty-print the results. Use this if you want to write to a file. |
|
||||||
|
| `--help`, `-h` | flag | Show help message and available arguments. |
|
||||||
|
| overrides | | Config parameters to override. Should be options starting with `--` that correspond to the config section and value to override, e.g. `--training.use_gpu 1`. |
|
||||||
|
|
||||||
|
<!-- TODO: document debug profile and debug model? -->
|
||||||
|
|
||||||
## Train {#train}
|
## Train {#train}
|
||||||
|
|
||||||
Train a model. Expects data in spaCy's
|
Train a model. Expects data in spaCy's
|
||||||
|
@ -310,10 +376,9 @@ you need to manage complex multi-step training workflows, check out the new
|
||||||
|
|
||||||
<Infobox title="New in v3.0" variant="warning">
|
<Infobox title="New in v3.0" variant="warning">
|
||||||
|
|
||||||
As of spaCy v3.0, the `train` command doesn't take a long list of command-line
|
The `train` command doesn't take a long list of command-line arguments anymore
|
||||||
arguments anymore and instead expects a single
|
and instead expects a single [`config.cfg` file](/usage/training#config)
|
||||||
[`config.cfg` file](/usage/training#config) containing all settings for the
|
containing all settings for the pipeline, training process and hyperparameters.
|
||||||
pipeline, training process and hyperparameters.
|
|
||||||
|
|
||||||
</Infobox>
|
</Infobox>
|
||||||
|
|
||||||
|
@ -343,46 +408,35 @@ an approximate language-modeling objective. Specifically, we load pretrained
|
||||||
vectors, and train a component like a CNN, BiLSTM, etc to predict vectors which
|
vectors, and train a component like a CNN, BiLSTM, etc to predict vectors which
|
||||||
match the pretrained ones. The weights are saved to a directory after each
|
match the pretrained ones. The weights are saved to a directory after each
|
||||||
epoch. You can then pass a path to one of these pretrained weights files to the
|
epoch. You can then pass a path to one of these pretrained weights files to the
|
||||||
`spacy train` command.
|
`spacy train` command. This technique may be especially helpful if you have
|
||||||
|
little labelled data.
|
||||||
|
|
||||||
This technique may be especially helpful if you have little labelled data.
|
<Infobox title="Changed in v3.0" variant="warning">
|
||||||
However, it's still quite experimental, so your mileage may vary. To load the
|
|
||||||
weights back in during `spacy train`, you need to ensure all settings are the
|
As of spaCy v3.0, the `pretrain` command takes the same
|
||||||
same between pretraining and training. The API and errors around this need some
|
[config file](/usage/training#config) as the `train` command. This ensures that
|
||||||
improvement.
|
settings are consistent between pretraining and training. Settings for
|
||||||
|
pretraining can be defined in the `[pretraining]` block of the config file. See
|
||||||
|
the [data format](/api/data-formats#config) for details.
|
||||||
|
|
||||||
|
</Infobox>
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ python -m spacy pretrain [texts_loc] [vectors_model] [output_dir]
|
$ python -m spacy pretrain [texts_loc] [output_dir] [config_path]
|
||||||
[--width] [--conv-depth] [--cnn-window] [--cnn-pieces] [--use-chars] [--sa-depth]
|
[--code] [--resume-path] [--epoch-resume] [overrides]
|
||||||
[--embed-rows] [--loss_func] [--dropout] [--batch-size] [--max-length]
|
|
||||||
[--min-length] [--seed] [--n-iter] [--use-vectors] [--n-save-every]
|
|
||||||
[--init-tok2vec] [--epoch-start]
|
|
||||||
```
|
```
|
||||||
|
|
||||||
| Argument | Type | Description |
|
| Argument | Type | Description |
|
||||||
| ----------------------------------------------------- | ---------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------- | ---------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `texts_loc` | positional | Path to JSONL file with raw texts to learn from, with text provided as the key `"text"` or tokens as the key `"tokens"`. [See here](#pretrain-jsonl) for details. |
|
| `texts_loc` | positional | Path to JSONL file with raw texts to learn from, with text provided as the key `"text"` or tokens as the key `"tokens"`. [See here](#pretrain-jsonl) for details. |
|
||||||
| `vectors_model` | positional | Name or path to spaCy model with vectors to learn from. |
|
| `output_dir` | positional | Directory to write models to on each epoch. |
|
||||||
| `output_dir` | positional | Directory to write models to on each epoch. |
|
| `config_path` | positional | Path to [training config](/api/data-formats#config) file containing all settings and hyperparameters. |
|
||||||
| `--width`, `-cw` | option | Width of CNN layers. |
|
| `--code`, `-c` | option | Path to Python file with additional code to be imported. Allows [registering custom functions](/usage/training#custom-models) for new architectures. |
|
||||||
| `--conv-depth`, `-cd` | option | Depth of CNN layers. |
|
| `--resume-path`, `-r` | option | TODO: |
|
||||||
| `--cnn-window`, `-cW` <Tag variant="new">2.2.2</Tag> | option | Window size for CNN layers. |
|
| `--epoch-resume`, `-er` | option | TODO: |
|
||||||
| `--cnn-pieces`, `-cP` <Tag variant="new">2.2.2</Tag> | option | Maxout size for CNN layers. `1` for [Mish](https://github.com/digantamisra98/Mish). |
|
| `--help`, `-h` | flag | Show help message and available arguments. |
|
||||||
| `--use-chars`, `-chr` <Tag variant="new">2.2.2</Tag> | flag | Whether to use character-based embedding. |
|
| overrides | | Config parameters to override. Should be options starting with `--` that correspond to the config section and value to override, e.g. `--training.use_gpu 1`. |
|
||||||
| `--sa-depth`, `-sa` <Tag variant="new">2.2.2</Tag> | option | Depth of self-attention layers. |
|
| **CREATES** | weights | The pretrained weights that can be used to initialize `spacy train`. |
|
||||||
| `--embed-rows`, `-er` | option | Number of embedding rows. |
|
|
||||||
| `--loss-func`, `-L` | option | Loss function to use for the objective. Either `"L2"` or `"cosine"`. |
|
|
||||||
| `--dropout`, `-d` | option | Dropout rate. |
|
|
||||||
| `--batch-size`, `-bs` | option | Number of words per training batch. |
|
|
||||||
| `--max-length`, `-xw` | option | Maximum words per example. Longer examples are discarded. |
|
|
||||||
| `--min-length`, `-nw` | option | Minimum words per example. Shorter examples are discarded. |
|
|
||||||
| `--seed`, `-s` | option | Seed for random number generators. |
|
|
||||||
| `--n-iter`, `-i` | option | Number of iterations to pretrain. |
|
|
||||||
| `--use-vectors`, `-uv` | flag | Whether to use the static vectors as input features. |
|
|
||||||
| `--n-save-every`, `-se` | option | Save model every X batches. |
|
|
||||||
| `--init-tok2vec`, `-t2v` <Tag variant="new">2.1</Tag> | option | Path to pretrained weights for the token-to-vector parts of the models. See `spacy pretrain`. Experimental. |
|
|
||||||
| `--epoch-start`, `-es` <Tag variant="new">2.1.5</Tag> | option | The epoch to start counting at. Only relevant when using `--init-tok2vec` and the given weight file has been renamed. Prevents unintended overwriting of existing weight files. |
|
|
||||||
| **CREATES** | weights | The pretrained weights that can be used to initialize `spacy train`. |
|
|
||||||
|
|
||||||
### JSONL format for raw text {#pretrain-jsonl}
|
### JSONL format for raw text {#pretrain-jsonl}
|
||||||
|
|
||||||
|
|
|
@ -5,8 +5,11 @@ import classNames from 'classnames'
|
||||||
import Link from './link'
|
import Link from './link'
|
||||||
import classes from '../styles/accordion.module.sass'
|
import classes from '../styles/accordion.module.sass'
|
||||||
|
|
||||||
const Accordion = ({ title, id, expanded, children }) => {
|
const Accordion = ({ title, id, expanded, spaced, children }) => {
|
||||||
const [isExpanded, setIsExpanded] = useState(true)
|
const [isExpanded, setIsExpanded] = useState(true)
|
||||||
|
const rootClassNames = classNames(classes.root, {
|
||||||
|
[classes.spaced]: !!spaced,
|
||||||
|
})
|
||||||
const contentClassNames = classNames(classes.content, {
|
const contentClassNames = classNames(classes.content, {
|
||||||
[classes.hidden]: !isExpanded,
|
[classes.hidden]: !isExpanded,
|
||||||
})
|
})
|
||||||
|
@ -17,7 +20,7 @@ const Accordion = ({ title, id, expanded, children }) => {
|
||||||
useEffect(() => setIsExpanded(expanded), [])
|
useEffect(() => setIsExpanded(expanded), [])
|
||||||
return (
|
return (
|
||||||
<section className="accordion" id={id}>
|
<section className="accordion" id={id}>
|
||||||
<div className={classes.root}>
|
<div className={rootClassNames}>
|
||||||
<h4>
|
<h4>
|
||||||
<button
|
<button
|
||||||
className={classes.button}
|
className={classes.button}
|
||||||
|
|
|
@ -4,6 +4,9 @@
|
||||||
margin-bottom: var(--spacing-xs)
|
margin-bottom: var(--spacing-xs)
|
||||||
border-radius: var(--border-radius)
|
border-radius: var(--border-radius)
|
||||||
|
|
||||||
|
.spaced
|
||||||
|
margin-bottom: var(--spacing-md)
|
||||||
|
|
||||||
.button
|
.button
|
||||||
font: bold var(--font-size-lg)/var(--line-height-md) var(--font-primary)
|
font: bold var(--font-size-lg)/var(--line-height-md) var(--font-primary)
|
||||||
color: var(--color-theme-dark)
|
color: var(--color-theme-dark)
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
.juniper-input pre,
|
.juniper-input pre,
|
||||||
.juniper-output
|
.juniper-output
|
||||||
font: var(--font-size-code)/var(--line-height-code) var(--font-code) !important
|
font: var(--font-size-code)/var(--line-height-code) var(--font-code) !important
|
||||||
|
font-variant-ligatures: none !important
|
||||||
-webkit-font-smoothing: subpixel-antialiased
|
-webkit-font-smoothing: subpixel-antialiased
|
||||||
-moz-osx-font-smoothing: auto
|
-moz-osx-font-smoothing: auto
|
||||||
|
|
||||||
|
@ -44,6 +45,7 @@
|
||||||
box-decoration-break: clone
|
box-decoration-break: clone
|
||||||
white-space: nowrap
|
white-space: nowrap
|
||||||
text-shadow: none
|
text-shadow: none
|
||||||
|
font-variant-ligatures: none
|
||||||
-webkit-font-smoothing: subpixel-antialiased
|
-webkit-font-smoothing: subpixel-antialiased
|
||||||
-moz-osx-font-smoothing: auto
|
-moz-osx-font-smoothing: auto
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user