> ## Documentation Index
> Fetch the complete documentation index at: https://wb-21fd5541-docs-sandboxes-integrations-placement.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

> W&B Artifacts の概要、仕組み、使い始める方法。

# Artifacts の概要

export const TryProductLink = ({url}) => <a href={url} target="_blank" rel="noopener noreferrer" className="github-source-link">
    <svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round" xmlns="http://www.w3.org/2000/svg">
      <line x1="4" y1="21" x2="4" y2="14"></line>
      <line x1="4" y1="10" x2="4" y2="3"></line>
      <line x1="12" y1="21" x2="12" y2="12"></line>
      <line x1="12" y1="8" x2="12" y2="3"></line>
      <line x1="20" y1="21" x2="20" y2="16"></line>
      <line x1="20" y1="12" x2="20" y2="3"></line>
      <circle cx="4" cy="12" r="2"></circle>
      <circle cx="12" cy="10" r="2"></circle>
      <circle cx="20" cy="14" r="2"></circle>
    </svg>
    W&amp;Bで試す
  </a>;

export const ColabLink = ({url}) => <a href={url} target="_blank" rel="noopener noreferrer" className="colab-link">
    <svg width="20" height="20" viewBox="0 0 24 24" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
      <path d="M14.25.18l.9.2.73.26.59.3.45.32.34.34.25.34.16.33.1.3.04.26.02.2-.01.13V8.5l-.05.63-.13.55-.21.46-.26.38-.3.31-.33.25-.35.19-.35.14-.33.1-.3.07-.26.04-.21.02H8.77l-.69.05-.59.14-.5.22-.41.27-.33.32-.27.35-.2.36-.15.37-.1.35-.07.32-.04.27-.02.21v3.06H3.17l-.21-.03-.28-.07-.32-.12-.35-.18-.36-.26-.36-.36-.35-.46-.32-.59-.28-.73-.21-.88-.14-1.05-.05-1.23.06-1.22.16-1.04.24-.87.32-.71.36-.57.4-.44.42-.33.42-.24.4-.16.36-.1.32-.05.24-.01h.16l.06.01h8.16v-.83H6.18l-.01-2.75-.02-.37.05-.34.11-.31.17-.28.25-.26.31-.23.38-.2.44-.18.51-.15.58-.12.64-.1.71-.06.77-.04.84-.02 1.27.05zm-6.3 1.98l-.23.33-.08.41.08.41.23.34.33.22.41.09.41-.09.33-.22.23-.34.08-.41-.08-.41-.23-.33-.33-.22-.41-.09-.41.09zm13.09 3.95l.28.06.32.12.35.18.36.27.36.35.35.47.32.59.28.73.21.88.14 1.04.05 1.23-.06 1.23-.16 1.04-.24.86-.32.71-.36.57-.4.45-.42.33-.42.24-.4.16-.36.09-.32.05-.24.02-.16-.01h-8.22v.82h5.84l.01 2.76.02.36-.05.34-.11.31-.17.29-.25.25-.31.24-.38.2-.44.17-.51.15-.58.13-.64.09-.71.07-.77.04-.84.01-1.27-.04-1.07-.14-.9-.2-.73-.25-.59-.3-.45-.33-.34-.34-.25-.34-.16-.33-.1-.3-.04-.25-.02-.2.01-.13v-5.34l.05-.64.13-.54.21-.46.26-.38.3-.32.33-.24.35-.2.35-.14.33-.1.3-.06.26-.04.21-.02.13-.01h5.84l.69-.05.59-.14.5-.21.41-.28.33-.32.27-.35.2-.36.15-.36.1-.35.07-.32.04-.28.02-.21V6.07h2.09l.14.01.21.03zm-6.47 14.25l-.23.33-.08.41.08.41.23.33.33.23.41.08.41-.08.33-.23.23-.33.08-.41-.08-.41-.23-.33-.33-.23-.41-.08-.41.08z" />
    </svg>
    Colabで試す
  </a>;

<CardGroup cols={4}>
  <ColabLink url="https://colab.research.google.com/github/wandb/examples/blob/master/colabs/wandb-artifacts/Pipeline_Versioning_with_W&B_Artifacts.ipynb" />

  <TryProductLink url="https://wandb.ai/wandb/arttest/artifacts/model/iv3_trained/5334ab69740f9dda4fed/lineage" />
</CardGroup>

W\&B Artifacts を使用すると、[W\&B Runs](/ja/models/runs) の入力と出力としてデータをトラッキングし、バージョン管理できます。たとえば、モデル トレーニングの run では、入力としてデータセットを受け取り、出力としてトレーニング済みのモデルを生成することがあります。ハイパーパラメーター、メタデータ、メトリクスは run にログできます。また、artifact を使用して、モデルのトレーニングに使用したデータセットを入力としてログ、トラッキング、バージョン管理し、別の artifact を使用して、生成されたモデル チェックポイントを出力としてログできます。

<div id="use-cases">
  ## 使用例
</div>

ML ワークフロー全体で、[runs](/ja/models/runs) の入力と出力として artifacts を使用できます。処理の入力には、データセット、モデル、さらには他の artifacts も使用できます。

<Frame>
  <img src="https://mintcdn.com/wb-21fd5541-docs-sandboxes-integrations-placement/hS4tNv5jzsGoCezc/images/artifacts/artifacts_landing_page2.png?fit=max&auto=format&n=hS4tNv5jzsGoCezc&q=85&s=3e3684d0ffa412e41b59c06d68d98532" alt="モデル トレーニング、データ処理、モデル評価における入出力を示した Artifacts ワークフロー図" width="1991" height="503" data-path="images/artifacts/artifacts_landing_page2.png" />
</Frame>

| 使用例        | 入力                        | 出力                              |
| ---------- | ------------------------- | ------------------------------- |
| モデル トレーニング | データセット (トレーニング データと検証データ) | トレーニング済みモデル                     |
| データセットの前処理 | データセット (生データ)             | データセット (前処理済みデータ)               |
| モデル評価      | モデル + データセット (テストデータ)     | [W\&B Table](/ja/models/tables) |
| モデル最適化     | モデル                       | 最適化済みモデル                        |

<Note>
  以下のコード スニペットは、順番に実行することを前提としています。
</Note>

<div id="create-an-artifact">
  ## artifact を作成する
</div>

4 行のコードで artifact を作成できます。

1. [W\&B run](/ja/models/runs) を作成します。
2. [`wandb.Artifact`](/ja/models/ref/python/experiments/artifact) を使って artifact オブジェクトを作成します。
3. `wandb.Artifact.add_file()` を使って、モデルファイルやデータセットなど、1 つ以上のファイルを artifact オブジェクトに追加します。
4. `wandb.Run.log_artifact()` を使って、artifact を W\&B にログします。

たとえば、次のコード例は、`dataset.h5` というファイルを `example_artifact` という名前の artifact にログする方法を示しています。

```python theme={null}
import wandb

with wandb.init(project="artifacts-example", job_type="add-dataset") as run:
    artifact = wandb.Artifact(name="example_artifact", type="dataset")
    artifact.add_file(local_path="./dataset.h5", name="training_dataset")
    run.log_artifact(artifact)
```

* artifact の `type` は、W\&B プラットフォームでの表示に影響します。`type` を指定しない場合は、デフォルトで `unspecified` になります。
* ドロップダウンの各ラベルは、それぞれ異なる `type` パラメーター値を表します。上記のコードスニペットでは、artifact の `type` は `dataset` です。

<Note>
  外部のオブジェクトストレージ (Amazon S3 バケットなど) に保存されているファイルやディレクトリーへの参照を追加する方法については、[外部ファイルをトラッキングする](/ja/models/artifacts/track-external-files) ページを参照してください。
</Note>

<div id="download-an-artifact">
  ## artifactをダウンロードする
</div>

run への入力としてマークする artifact は、[`wandb.Run.use_artifact()`](/ja/models/ref/python/experiments/run#use_artifact) method で指定します。

前のコードスニペットに続き、以下のコード例では、先ほど作成した `example_artifact` という artifact の使い方を示します:

```python theme={null}
with wandb.init(project="artifacts-example", job_type="add-dataset") as run:
    artifact = run.use_artifact("training_dataset:latest")  # "my_data" artifactを使用してrunオブジェクトを返す
```

これにより、artifactオブジェクトが返されます。

次に、返されたオブジェクトを使用して、artifactのすべての内容をダウンロードします。

```python theme={null}
datadir = artifact.download()  # `my_data` artifact全体をデフォルトディレクトリにダウンロードします。
```

<Note>
  特定のディレクトリーに artifact をダウンロードするには、`root` [パラメーター](/ja/models/ref/python/experiments/artifact) にカスタムパスを指定できます。Artifacts をダウンロードする別の方法や追加のパラメーターについては、[Artifacts のダウンロードと使用](/ja/models/artifacts/download-and-use-an-artifact) ガイドを参照してください。
</Note>

<div id="next-steps">
  ## 次のステップ
</div>

* Artifacts の [version](/ja/models/artifacts/create-a-new-artifact-version) の作成と [update](/ja/models/artifacts/update-an-artifact) の方法を学びます。
* [automations](/ja/models/automations) を使用して、Artifacts の変更をきっかけにダウンストリームのワークフローをトリガーしたり、Slack チャンネルに通知したりする方法を学びます。
* トレーニング済みモデルを保存するためのスペースである [registry](/ja/models/registry) について学びます。
* [Python SDK](/ja/models/ref/python/experiments/artifact) と [CLI](/ja/models/ref/cli/wandb-artifact) のリファレンスガイドを確認します。
