Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

guide: DVC Experiments Overview #2909

Merged
merged 50 commits into from
Dec 13, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
5e43591
guide: add DVC Experiments page and links +
jorgeorpinel Oct 9, 2021
6b7300a
guide: remove checkpoint related changes
jorgeorpinel Oct 10, 2021
6027e15
guide: remove `dvc experiments` long cmd autolinks
jorgeorpinel Oct 10, 2021
7704a4d
Merge branch 'master' into exp/dvc-exps-page
jorgeorpinel Oct 11, 2021
8f04899
guide: move run-cache section back to Exp Mgmt index bottom
jorgeorpinel Oct 11, 2021
3bfd2a9
Merge branch 'master' into exp/dvc-exps-page
jorgeorpinel Nov 1, 2021
0c2bcf5
guide: Exp Mgmt/ DVC Exps -> Exps Overview
jorgeorpinel Nov 1, 2021
27afdc1
guide: clear separation between Exp Mgmt index and Overview page
jorgeorpinel Nov 2, 2021
30db819
guide: single guide for Persisting Exps content and
jorgeorpinel Nov 2, 2021
aa3c5d0
guide: begin extracting Exp details from Running to Overview
jorgeorpinel Nov 2, 2021
7710433
guide: make ToC entry for Run Cache section
jorgeorpinel Nov 2, 2021
a133f70
Update content/docs/user-guide/experiment-management/index.md
jorgeorpinel Nov 4, 2021
32a269f
Merge branch 'master' into exp/dvc-exps-page
jorgeorpinel Nov 4, 2021
af94248
Merge branch 'master' into exp/dvc-exps-page +
jorgeorpinel Nov 17, 2021
dacaf85
[NESTED] guide: Exp implementation details, naming into Overview (#3006)
jorgeorpinel Nov 17, 2021
cab14da
Merge branch 'master' into exp/dvc-exps-page +
jorgeorpinel Nov 29, 2021
9a1e142
Merge branch 'exp/dvc-exps-page' of github.com:iterative/dvc.org into…
jorgeorpinel Nov 30, 2021
b40f340
Merge branch 'master' into exp/dvc-exps-page
jorgeorpinel Nov 30, 2021
73175a9
guide: emphasize dvc exps are not part of Git tree in overview
jorgeorpinel Nov 30, 2021
112ad87
guide: ID->name in dvc exps overview
jorgeorpinel Nov 30, 2021
9c2a55c
guide: ID->name in other exp guides
jorgeorpinel Nov 30, 2021
9b2902a
guide: Visualize->Review in exp/overview/basic-workflow
jorgeorpinel Nov 30, 2021
7b9384f
guide: don't say "cleans the slate" in exp/overview/basic-workflow
jorgeorpinel Nov 30, 2021
c9493f4
giude: soften params description in exps index
jorgeorpinel Nov 30, 2021
42454f0
guide: generalize dvc exps basic workflow
jorgeorpinel Nov 30, 2021
bd95136
guide: Properties section in DVC Exps overview page
jorgeorpinel Nov 30, 2021
6162f5a
guide: exp init section in Exp Overview page
jorgeorpinel Nov 30, 2021
63a9864
Merge branch 'master' into exp/dvc-exps-page
jorgeorpinel Dec 1, 2021
5043e64
guide: clarify dvc exp implementation
jorgeorpinel Dec 1, 2021
27f01e6
guide: expand on Exp Overview motivation
jorgeorpinel Dec 1, 2021
a799743
guide: direct language in Exp Overview/ workflow intro
jorgeorpinel Dec 1, 2021
59505f6
guide: mention metrics in exp init intro (Exp Overview)
jorgeorpinel Dec 1, 2021
3d0bede
guide: intro exp init before giving specific examples of what it does
jorgeorpinel Dec 1, 2021
db2d610
guide: hint forach stages for hybrid exp org pattern
jorgeorpinel Dec 1, 2021
f6eef79
guide: exp mgmt index copy edits
jorgeorpinel Dec 1, 2021
c68fc78
guide: mention label-based exp organization
jorgeorpinel Dec 1, 2021
3384af0
Merge branch 'master' into exp/dvc-exps-page
jorgeorpinel Dec 7, 2021
9fd3b3a
guide: hide exp naming section in overview page and
jorgeorpinel Dec 7, 2021
f241901
guide: mention `exp init -i` in Overview
jorgeorpinel Dec 7, 2021
e122b0a
guide: typo fix
jorgeorpinel Dec 7, 2021
659dd82
Merge branch 'master' into exp/dvc-exps-page +
jorgeorpinel Dec 7, 2021
73d510d
ref: exp apply copy edits
jorgeorpinel Dec 7, 2021
9d43ca6
ref: mention init before exp init
jorgeorpinel Dec 7, 2021
24c967d
guide: correct info aboug exp init in Exp Overview
jorgeorpinel Dec 7, 2021
439050e
ref: link from exp init to corresponding guide
jorgeorpinel Dec 7, 2021
3af2f9a
guide: make exp intro more concrete
jorgeorpinel Dec 8, 2021
12f8797
guide: rewrite exp init section of Exps Overview page
jorgeorpinel Dec 8, 2021
ad652a6
Merge branch 'master' into exp/dvc-exps-page
jorgeorpinel Dec 10, 2021
8aed622
ref: roll back unrelated ref changes (moved to ref/exp-misc)
jorgeorpinel Dec 10, 2021
c088a06
guide: roll back unrelated changes (moved to #3080)
jorgeorpinel Dec 10, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions content/docs/command-reference/exp/init.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@
Codify project using [DVC metafiles](/doc/user-guide/project-structure) to run
[experiments](/doc/user-guide/experiment-management).

> Requires a <abbr>DVC repository</abbr>, created with `git init` and
> `dvc init`.

## Synopsis

```usage
Expand Down Expand Up @@ -32,6 +35,11 @@ training of machine learning models.
This command is intended to be a quick way to start running experiments. To
create more complex stages and pipelines, use `dvc stage add`.

> 📖 More context in [Experiments Overview].

[experiments overview]:
/doc/user-guide/experiment-management/experiments-overview

### The `command` argument

The `command` argument is optional, if you are using `--interactive` mode. The
Expand Down
1 change: 1 addition & 0 deletions content/docs/sidebar.json
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,7 @@
"slug": "experiment-management",
"source": "experiment-management/index.md",
"children": [
"experiments-overview",
"running-experiments",
"comparing-experiments",
"sharing-experiments",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@

Although DVC uses minimal resources to keep track of the experiments, they may
clutter tables and the workspace. DVC allows to remove specific experiments from
the workspace or delete all not-yet-persisted experiments at once.
the workspace or delete all not-yet-[persisted] experiments at once.

[persisted]: /doc/user-guide/experiment-management/persisting-experiments

## Removing specific experiments

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
# DVC Experiments Overview
Copy link
Member

@shcheklein shcheklein Nov 2, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it can be a good page (still not clear if need a separate one for this though, considering that we have index)

should we do a diagram here with the basic workflow?

should we include cleaning here?

Copy link
Contributor Author

@jorgeorpinel jorgeorpinel Nov 4, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good ideas. Not sure about Cleaning Exps in here (you need to know how to make them first?) but a diagram for the workflow would be nice.

I also recently thought about possibly putting experiment naming information (IDs vs names) here. Added check box to the PR description. Thought that may be more appropriate for the Running or Comparing Exps guides, not sure.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

a diagram for the workflow would be nice

Since finalizing that properly may involve including alternative paths (a sort of flow chart) and design work, I vote to make it a follow-up issue (tied to the Exp Versioning release cc @dberenbaum) so we can merge this, if the content is approved in general.


DVC Experiments are captured automatically by DVC when [run]. Each experiment
creates and tracks a variation of your data science project based on the changes
in your <abbr>workspace</abbr>.

Experiments preserve a connection to the latest commit in the current branch
(Git `HEAD`) as their parent or _baseline_, but do not form part of the regular
Git tree (unless you make them [persistent]). This prevents bloating your repo
with temporary commits and branches.

[run]: /doc/user-guide/experiment-management/running-experiments

<details>

### ⚙️ How does DVC track experiments?

Experiments are custom [Git references](/blog/experiment-refs) (found in
`.git/refs/exps`) with one or more commits based on `HEAD`. These commits are
hidden and not checked out by DVC. Note that these are not pushed to Git remotes
by default either (see `dvc exp push`).

Note that DVC Experiments require a unique name to identify them. DVC will
usually auto-generate one by default, such as `exp-bfe64` (based on the
experiment's hash). A custom name can be set instead, using the `--name`/`-n`
option of `dvc exp run`. These names can be used to reference experiments in
other `dvc exp` subcommands.

</details>

## Basic workflow

`dvc exp` commands let you automatically track a variation of a project version
(the baseline). You can create independent groups of experiments this way, as
well as review, compare, and restore them later. The basic workflow goes like
this:

- Modify hyperparameters or other dependencies (input data, source code,
commands to execute, etc.). Leave these changes un-committed in Git.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It might help to discuss why we have this workflow and want to leave changes un-committed. In other experiment tracking tools, the workflow looks like:

  1. Run the experiment.
  2. Log the commit hash of the current HEAD, even though it doesn't include your dirty changes.
  3. If everything is successful, save changes in a new commit.

This creates a confusing state where the experiment should really be associated with the second commit instead of the first.

It might be too much detail or inappropriate for the page, but maybe it can be summarized, or it might spark other ideas. This is probably a good point for the blog post but not sure if there's a place for it...

Copy link
Contributor Author

@jorgeorpinel jorgeorpinel Dec 1, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Related to the discussions in https://www.notion.so/iterative/Experiment-Workflows-3873c4f3cc2e49c6a7871a831bc8302b

Yeah this needs more work. I'm hoping for now it's mergeable but I'll improve is as much as possible ⌛

This comment was marked as off-topic.

This comment was marked as off-topic.

- [Run experiments][run] with `dvc exp run` (instead of `repro`). The results
are reflected in your <abbr>workspace</abbr>, and tracked automatically.
- Review and [compare] experiments with `dvc exp show` or `dvc exp diff`, using
[metrics](/doc/command-reference/metrics) to identify the best one(s). Repeat
🔄
- Make certain experiments [persistent] by committing their results to Git. This
lets you repeat the process from that point.

[compare]: /doc/user-guide/experiment-management/comparing-experiments
[persistent]: /doc/user-guide/experiment-management/persisting-experiments

## Initialize DVC Experiments on any project

To use DVC Experiments you need a <abbr>DVC project</abbr> with a minimal
structure and configuration. To avoid having to bootstrap DVC manually, the
`dvc exp init` command lets you quickly onboard an existing project to the DVC
Experiments workflow.

It will create a simple `dvc.yaml` metafile, which codifies your planned
experiments. This includes the locations for expected <abbr>dependencies</abbr>
(data, parameters, source code) and <abbr>outputs</abbr> (ML models,
<abbr>metrics</abbr>, etc.). These assume [sane defaults] but can be customized
with the options of `dvc exp init`.

💡 We recommend adding the `-i` flag to use its `--interactive` mode. This will
ask you how to run the experiments, and guide you through customizing the
aforementioned locations (optional).

You can review the resulting changes to your repo (and commit them to Git) to
begin using DVC Experiments. Now you can move on to [running experiments][run]
(next).

[sane defaults]: /doc/command-reference/exp/init#description
137 changes: 57 additions & 80 deletions content/docs/user-guide/experiment-management/index.md
Original file line number Diff line number Diff line change
@@ -1,113 +1,90 @@
# Experiment Management

_New in DVC 2.0 (see `dvc version`)_

Data science and ML are iterative processes that require a large number of
attempts to reach a certain level of a metric. Experimentation is part of the
development of data features, hyperspace exploration, deep learning
optimization, etc. DVC helps you codify and manage all of your
<abbr>experiments</abbr>, supporting these main approaches:

1. Create [experiments](#experiments) that derive from your latest project
version without having to track them manually. DVC does that automatically,
letting you list and compare them. The best ones can be made persistent, and
the rest archived.
2. Place in-code [checkpoints](#checkpoints-in-source-code) that mark a series
of variations, forming a deep experiment. DVC helps you capture them at
runtime, and manage them in batches.
3. Make experiments or checkpoints [persistent](#persistent-experiments) by
committing them to your <abbr>repository</abbr>. Or create these versions
from scratch like typical project changes.

At this point you may also want to consider the different
[ways to organize](#organization-patterns) experiments in your project (as
Git branches, as folders, etc.).

DVC also provides specialized features to codify and analyze experiments.
[Parameters](/doc/command-reference/params) are simple values you can tweak in a
human-readable text file, which cause different behaviors in your code and
models. On the other end, [metrics](/doc/command-reference/metrics) (and
Data science and machine learning are iterative processes that require a large
number of attempts to reach a certain level of a metric. Experimentation is part
of the development of data features, hyperspace exploration, deep learning
optimization, etc.

Some of DVC's base features already help you codify and analyze experiments.
[Parameters](/doc/command-reference/params) are simple values in a formatted
text file which you can tweak and use in your code. On the other end,
[metrics](/doc/command-reference/metrics) (and
[plots](/doc/command-reference/plots)) let you define, visualize, and compare
meaningful measures for the experimental results.

> 👨‍💻 See [Get Started: Experiments](/doc/start/experiments) for a hands-on
> introduction to DVC experiments.
quantitative measures of your results.

## Experiments
## Experimentation in DVC

`dvc exp` commands let you automatically track a variation to an established
[data pipeline](/doc/command-reference/dag). You can create multiple isolated
experiments this way, as well as review, compare, and restore them later, or
roll back to the baseline. The basic workflow goes like this:

- Modify stage <abbr>parameters</abbr> or other dependencies (e.g. input data,
source code) of committed stages.
- Use `dvc exp run` (instead of `repro`) to execute the pipeline. The results
are reflected in your <abbr>workspace</abbr>, and tracked automatically.
- Use [metrics](/doc/command-reference/metrics) to identify the best
experiment(s).
- Visualize, compare experiments with `dvc exp show` or `dvc exp diff`. Repeat
🔄
- Use `dvc exp apply` to roll back to the best one.
- Make the selected experiment persistent by committing its results to Git. This
cleans the slate so you can repeat the process.

## Checkpoints in source code
_New in DVC 2.0 (see `dvc version`)_

To track successive steps in a longer experiment, you can register checkpoints
from your code at runtime. This allows you, for example, to track the progress
in deep learning techniques such as evolving neural networks.
DVC experiment management features build on top of base DVC features to form a
comprehensive framework to organize, execute, manage, and share ML experiments.
They support support these main approaches:

This kind of experiments track a series of variations (the checkpoints) and its
execution can be stopped and resumed as needed. You interact with them using
`dvc exp run` and its `--rev`, `--reset` options (see also the `checkpoint`
field in `dvc.yaml` `outs`).
- Compare parameters and metrics of existing project versions (for example
different Git branches) against each other or against new, uncommitted results
in your workspace. One tool to do so is `dvc exp diff`.

> 📖 To learn more, see the dedicated
> [Checkpoints](/doc/user-guide/experiment-management/checkpoints) guide.
- [Run and capture] multiple experiments (derived from any project version as
baseline) without polluting your Git history. DVC tracks them for you, letting
you compare and share them. 📖 More info in the [Experiments
Overview][experiments].

## Persistent experiments
- Generate [checkpoints] at runtime to keep track of the internal progress of
deeper experiments. DVC captures [live metrics](/doc/dvclive), which you can
manage in batches.

When your experiments are good enough to save or share, you may want to store
them persistently as Git commits in your <abbr>repository</abbr>.
[run and capture]: /doc/user-guide/experiment-management/running-experiments
[experiments]: /doc/user-guide/experiment-management/experiments-overview
[checkpoints]: /doc/user-guide/experiment-management/checkpoints

Whether the results were produced with `dvc repro` directly, or after a
`dvc exp` workflow (refer to previous sections), the `dvc.yaml` and `dvc.lock`
pair in the <abbr>workspace</abbr> will codify the experiment as a new project
version. The right <abbr>outputs</abbr> (including
[metrics](/doc/command-reference/metrics)) should also be present, or available
via `dvc checkout`.
> 👨‍💻 See [Get Started: Experiments](/doc/start/experiments) for a hands-on
> introduction to DVC experiments.

### Organization patterns

DVC takes care of arranging `dvc exp` experiments and the data
<abbr>cache</abbr> under the hood. But when it comes to full-blown persistent
experiments, it's up to you to decide how to organize them in your project.
These are the main alternatives:
It's up to you to decide how to organize completed experiments. These are the
main alternatives:

- **Git tags and branches** - use the repo's "time dimension" to distribute your
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think dvc exp commands work towards this organization pattern, not separate directories. IMO we can modify this section to describe the organization pattern DVC leads. We don't have much facility to use "space dimension" for experiments.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This index tries to cover the traditional experiments as well. It's not exclusively about dvc exp until you get to the sub-pages. That's one of the reasons for creating a separate DVC Experiments overview page in this PR.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When I look into the text, I think DVC helps to organize the experiments in "space dimension" as well. What DVC does is better IMO, but mentioning these organization patterns seems to remind the reader a feature DVC lacks.

Copy link
Contributor Author

@jorgeorpinel jorgeorpinel Dec 1, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would be great to improve on this indeed so it's clear that we're separating manual exp tracking you can do on DVC projects vs. the DVC Experiments workflow.
UPDATE: Wait I was confusing this discussion with #2909 (review)...

Copy link
Contributor Author

@jorgeorpinel jorgeorpinel Dec 1, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When I look into the text, I think DVC helps to organize the experiments in "space dimension" as well.

It can @iesahin, for example multiple via dvc.yaml files (copy/pasted + small changes) or via init --subrepo (monorepo structure). Both supported by DVC

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

p.s. this makes me thing about another route: using foreach stages to quickly define multiple experiments based on a params file and running them all (in parallel). I guess it's a pre-exp way to manage experiments with DVC, but in which you can see all the results at once in your workspace (may be messy unless you create a bunch of subdirectories so perhaps it's the same as the "space dimension")...

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

p.p.s I added a section about custom labels as well (for org pattern) based on this table. See c68fc78

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It can @iesahin, for example multiple via dvc.yaml files (copy/pasted + small changes) or via init --subrepo (monorepo structure). Both supported by DVC

The dvc exp workflow is orthogonal to these features, they are not alternatives to each other. One can use multiple dvc.yaml files with dvc exp as well.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

They are conceptual alternatives which you can combine, which is already stated in the text.

experiments. This makes the most sense for experiments that build on each
other. Helpful if the Git [revisions](https://git-scm.com/docs/revisions) can
be easily visualized, for example with tools
[like GitHub](https://docs.github.com/en/github/visualizing-repository-data-with-graphs/viewing-a-repositorys-network).

- **Directories** - the project's "space dimension" can be structured with
directories (folders) to organize experiments. Useful when you want to see all
your experiments at the same time (without switching versions) by just
exploring the file system.

- **Hybrid** - combining an intuitive directory structure with a good repo
branching strategy tends to be the best option for complex projects.
Completely independent experiments live in separate directories, while their
progress can be found in different branches.
Completely independent experiments live in separate directories (and can be
generated with [`foreach` stages], for example), while their progress can be
found in different branches.

- **Labels** - in general, you can record experiments in a separate system and
structure them using custom labeling. This is typical in dedicated experiment
tracking tools. A possible problem with this approach is that it's easy to
lose the connection between your project history and the experiments logged.

DVC takes care of arranging `dvc exp` experiments and the data
<abbr>cache</abbr> under the hood so there's no need to decide on the above
until your experiments are made [persistent].

[`foreach` stages]:
/doc/user-guide/project-structure/pipelines-files#foreach-stages
[persistent]: /doc/user-guide/experiment-management/persisting-experiments

## Automatic log of stage runs (run-cache)
## Run Cache: Automatic Log of Stage Runs

Every time you `dvc repro` pipelines or `dvc exp run` experiments, DVC logs the
unique signature of each stage run (to `.dvc/cache/runs` by default). If it
never happened before, the stage command(s) are executed normally. Every
Every time you [reproduce](/doc/command-reference/repro) a pipeline with DVC, it
logs the unique signature of each stage run (in `.dvc/cache/runs` by default).
If it never happened before, the stage command(s) are executed normally. Every
subsequent time a [stage](/doc/command-reference/run) runs under the same
conditions, the previous results can be restored instantly, without wasting time
or computing resources.

✅ This built-in feature is called <abbr>run-cache</abbr> and it can
dramatically improve performance. It's enabled out-of-the-box (but can be
disabled with the `--no-run-cache` command option).
dramatically improve performance. It's enabled out-of-the-box (can be disabled),
which means DVC is already saving all of your tests and experiments behind the
scene. But there's no easy way to explore it.
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
# Persisting Experiments

DVC runs experiments outside of the Git stage/commit cycle for quick iteration.
When your experiments are good enough to save or share, you may want to store
them persistently as Git commits in your repository.

In this section, we describe how to bring them to the standard Git workflow with
`dvc exp branch` and `dvc exp apply`.
DVC Experiments run outside of the regular Git workflow for faster iteration and
shcheklein marked this conversation as resolved.
Show resolved Hide resolved
to avoid polluting your <abbr>repository</abbr>'s history. Once experiments are
good enough to keep or distribute, you may want to store them persistently as
Git commits.

## Create a Git branch from an experiment

Expand Down Expand Up @@ -73,7 +71,7 @@ $ dvc exp show --include-params=my_param

The results found in the workspace are shown in the respective row. When you
want to bring another experiment to the workspace, you can reference it using
it's name or ID, e.g.:
it's name, e.g.:

```dvc
$ dvc exp apply exp-e6c97
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
# Running Experiments

We explain how DVC codifies and executes experiments, setting their parameters,
using multiple jobs to run them in parallel, and running them in queues, among
other details.
We explain how to execute DVC Experiments, setting their parameters, using
multiple jobs to run them in parallel, and running them in queues, among other
details.

> 📖 If this is the first time you are introduced into data science
> experimentation, you may want to check the basics in
Expand Down Expand Up @@ -231,7 +231,7 @@ Note that Git-ignored files/dirs are explicitly excluded from queued/temp runs
to avoid committing unwanted files into Git (e.g. once successful experiments
are [persisted]).

[persisted]: /doc/user-guide/experiment-management#persistent-experiments
[persisted]: /doc/user-guide/experiment-management/persisting-experiments

> 💡 To include untracked files, stage them with `git add` first (before
> `dvc exp run`) and `git reset` them afterwards.
Expand Down