

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

# データとデータ品質に関するインサイトを取得する
<a name="data-wrangler-data-insights"></a>

**データ品質とインサイトレポート**を使用して、Data Wrangler にインポートしたデータを分析します。データセットをインポートした後にレポートを作成することをお勧めします。このレポートはデータのクリーニングと処理に役立ちます。欠損値の数や外れ値の数などの情報が提供されます。ターゲット漏洩や不均衡など、データに問題がある場合は、インサイトレポートでそれらの問題に注意を向けることができます。

以下の手順を使用して、データ品質とインサイトレポートを作成します。Data Wrangler フローにデータセットをインポート済みであることを前提としています。

**データ品質とインサイトレポートを作成するには**

1. Data Wrangler フロー内のノードの横にある **[\$1]** を選択します。

1. **[データインサイトを取得する]** を選択します。

1. **[分析名]** に、インサイトレポートの名前を指定します。

1. (オプション) **[ターゲット列]** に、ターゲット列を指定します。

1. **[問題のタイプ]** に、**[回帰]** または **[分類]** を指定します。

1. **[データサイズ]** に、次のいずれかを指定します。
   + **[50 K]** — インポートしたデータセットの最初の 50,000 行を使用してレポートを作成します。
   + **[データセット全体]** — インポートしたデータセット全体を使用してレポートを作成します。
**注記**  
データセット全体に関するデータ品質とインサイトレポートを作成するには、Amazon SageMaker 処理ジョブを使用します。SageMaker 処理ジョブは、すべてのデータのインサイトを取得するために必要な追加のコンピューティングリソースをプロビジョンします。SageMaker の処理ジョブの詳細については、「[SageMaker Processing によるデータ変換ワークロード](processing-job.md)」を参照してください。

1. **[作成]** を選択します。

以下のトピックはレポートの各セクションを示しています。

**Topics**
+ [概要](#data-wrangler-data-insights-summary)
+ [ターゲット列](#data-wrangler-data-insights-target-column)
+ [クイックモデル](#data-wrangler-data-insights-quick-model)
+ [特徴の概要](#data-wrangler-data-insights-feature-summary)
+ [サンプル](#data-wrangler-data-insights-samples)
+ [定義](#data-wrangler-data-insights-definitions)

レポートはダウンロードすることも、オンラインで表示することもできます。レポートをダウンロードするには、画面右上にあるダウンロードボタンを選択します。次の図は、ボタンを示しています。

![\[ダウンロードボタンの例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-download.png)


## 概要
<a name="data-wrangler-data-insights-summary"></a>

インサイトレポートには、欠損値、無効な値、特徴型、外れ値の数などの一般的な情報を含むデータの簡単な概要が表示されます。また、データに問題がある可能性を示す、重要度の高い警告を含めることもできます。警告を調査することをお勧めします。

レポートの要約の例を次に示します。

![\[レポートの概要例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-report-summary.png)


## ターゲット列
<a name="data-wrangler-data-insights-target-column"></a>

データ品質とインサイトレポートを作成すると、Data Wrangler ではターゲット列を選択するオプションが表示されます。ターゲット列とは、予測しようとしている列のことです。ターゲット列を選択すると、Data Wrangler はターゲット列分析を自動的に作成します。また、予測能力の順に特徴をランク付けします。ターゲット列を選択するときは、解決しようとしているのが回帰問題なのか分類問題なのかを指定する必要があります。

分類の場合、Data Wrangler は最も一般的なクラスの表とヒストグラムを表示します。クラスはカテゴリです。また、ターゲット値が欠落しているか無効である観測値または行も表示されます。

次の図は、分類問題のターゲット列分析の例を示しています。

![\[ターゲット列分析の例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-target-column-classification.png)


回帰の場合、Data Wrangler はターゲット列のすべての値のヒストグラムを表示します。また、ターゲット値が欠落している、無効である、または外れ値になっている観測値または行も表示されます。

次の図は、回帰問題のターゲット列分析の例を示しています。

![\[ターゲット列分析の例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-target-column-regression.png)


## クイックモデル
<a name="data-wrangler-data-insights-quick-model"></a>

**クイックモデル**では、データを使ってトレーニングしたモデルの想定される予測品質を推定できます。

Data Wrangler はデータをトレーニングフォールドと検証フォールドに分割します。サンプルの 80% をトレーニングに、値の 20% を検証に使用します。分類の場合、サンプルは層化分割されます。層化分割では、各データパーティションのラベルの比率は同じです。分類問題では、トレーニングフォールドと分類フォールドのラベルの比率を同じにすることが重要です。Data Wrangler は、デフォルトのハイパーパラメータを使用して XGBoost モデルをトレーニングします。検証データに早期停止を適用し、特徴の前処理は最小限に抑えます。

分類モデルの場合、Data Wrangler はモデルの要約と混同行列の両方を返します。

以下は、分類モデルの要約の例です。返される情報の詳細については、「[定義](#data-wrangler-data-insights-definitions)」を参照してください。

![\[分類モデルサマリーの例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-quick-model-classification-summary.png)


以下に、クイックモデルが返す混同行列の例を示します。

![\[混同行列の例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-quick-model-classification-confusion-matrix.png)


混同行列には、次の情報が表示されます。
+ 予測されたラベルが実際のラベルと一致する回数。
+ 予測されたラベルが実際のラベルと一致しない回数。

実際のラベルは、データ内の実際の観測値を表します。例えば、モデルを使用して不正取引を検出する場合、実際のラベルは実際に不正または不正でない取引を表します。予測されたラベルは、モデルがデータに割り当てるラベルを表します。

混同行列を使用すると、モデルが条件の有無をどの程度正確に予測できるかを確認できます。不正取引を予測する場合は、混同行列を使用してモデルの感度と特異性の両方を把握できます。感度とは、モデルが不正取引を検出する能力を指します。特異性とは、不正ではない取引を不正な取引として検出することを回避するモデルの能力を指します。

回帰問題のクイックモデル出力の例を次に示します。

![\[リグレッション問題のクイックモデル出力の例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-quick-model-regression-summary.png)


## 特徴の概要
<a name="data-wrangler-data-insights-feature-summary"></a>

ターゲット列を指定すると、Data Wrangler は特徴を予測能力の順に並べます。予測能力は、データを 80% のトレーニングフォールドと 20% の検証フォールドに分割した後で測定されます。Data Wrangler は、各特徴のモデルをトレーニングフォールドで別々にあてはめます。最小限の特徴の前処理を適用し、検証データの予測パフォーマンスを測定します。

スコアは [0,1] の範囲に正規化されます。予測スコアが高いほど、その列がターゲットを単独で予測するのに有用であることを示します。スコアが低いほど、列がターゲット列を予測できないことを示します。

単独で予測できない列を他の列と組み合わせて使用することで予測可能になることはまれです。予測スコアを使用して、データセット内の特徴が予測可能かどうかを確信をもって判断できます。

通常、スコアが低い場合は、特徴が冗長であることを示します。スコア 1 は完璧な予測能力を示し、多くの場合はターゲット漏洩を意味します。ターゲット漏洩は通常、予測時に使用できない列がデータセットに含まれている場合に発生します。例えば、ターゲット列と重複している場合があります。

各特徴の予測値を示す表とヒストグラムの例を以下に示します。

![\[各特徴量の予測値を示す概要テーブルの例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-feature-summary-table.png)


![\[各特徴量の予測値を示すヒストグラムの例\]](http://docs.aws.amazon.com/ja_jp/sagemaker/latest/dg/images/studio/mohave/data-insights/data-insights-feature-summary-histogram.png)


## サンプル
<a name="data-wrangler-data-insights-samples"></a>

Data Wrangler は、サンプルが異常かどうか、またはデータセットに重複があるかどうかに関する情報を提供します。

Data Wrangler は、アイソレーションフォレストアルゴリズムを使用して異常サンプルを検出します。**アイソレーションフォレストは、データセットの各サンプル (行) に異常スコアを関連付けます。異常スコアが低い場合は、サンプルに異常があることを示します。スコアが高いほど、サンプルに異常がないことを示します。通常、異常スコアが負のサンプルは異常と見なされ、異常スコアが正のサンプルは異常ではないと見なされます。

異常の可能性があるサンプルを調べる場合は、異常な値に注意することをお勧めします。例えば、データの収集と処理におけるエラーによって異常な値になる場合があります。異常なサンプルを調査する際は、ドメインのナレッジとビジネスロジックを使用することをお勧めします。

Data Wrangler は重複行を検出し、データ内の重複行の比率を計算します。データソースによっては、有効な重複データが含まれている場合があります。他のデータソースには重複があり、データ収集に問題がある可能性があります。問題のあるデータ収集によって発生した重複サンプルは、データを独立したトレーニングフォールドと検証フォールドに分割することに依存する機械学習プロセスに支障をきたす可能性があります。

サンプルが重複すると影響を受ける可能性があるインサイトレポートの要素は次のとおりです。
+ クイックモデル
+ 予測力の推定
+ ハイパーパラメータの自動調整

**[行を管理]** の **[重複データの削除]** トランスフォームを使用して、データセットから重複サンプルを削除できます。Data Wrangler は、重複が最も多い行を表示します。

## 定義
<a name="data-wrangler-data-insights-definitions"></a>

データインサイトレポートで使用される技術用語の定義は次のとおりです。

------
#### [ Feature types ]

各特徴型の定義は次のとおりです。
+ **数値** — 数値は浮動小数点数でも、年齢や収入などの整数でもかまいません。機械学習モデルは、数値が順序付けられ、その上で距離が定義されていることを前提としています。例えば、3 は 10 よりも 4 に近く、3 < 4 < 10 です。
+ カテゴリ — 列のエントリは一意の値のセットに属します。通常、この値は列のエントリ数よりもかなり小さくなります。例えば、長さ 100 の列には一意の値 `Dog`、`Cat`、`Mouse` が含まれる場合があります。値は、数値、テキスト、または両方の組み合わせです。`Horse`、`House`、`8`、`Love`、`3.1` はすべて有効な値で、同じカテゴリ列にあります。機械学習モデルでは、すべての値が数値であっても、数値特徴とは対照的に、カテゴリ別特徴の値の順序や距離を想定していません。
+ **バイナリ** — バイナリ特徴は、一意の値における集合の高基数が 2 である特殊なカテゴリ別特徴型です。
+ **テキスト** — テキスト列には、数値以外の一意の値が多数含まれています。極端なケースでは、列のすべての要素が一意です。極端なケースでは、2 つとして同じエントリはありません。
+ **Datetime** — datetime 列には日付または時刻に関する情報が含まれます。日付と時刻の両方に関する情報を含めることができます。

------
#### [ Feature statistics ]

各特徴統計の定義は次のとおりです。
+ **予測能力** — 予測能力は、その列がターゲットの予測にどの程度役立つかを測定します。
+ **外れ値** (数値列) — Data Wrangler は、外れ値に対して堅牢な中央値とロバスト標準偏差 (RSTD) という 2 つの統計を使用して外れ値を検出します。RSTD は、特徴値を [5 パーセンタイル、95 パーセンタイル] の範囲にクリップし、クリップされたベクトルの標準偏差を計算することによって算出されます。中央値 \$1 5 \$1 RSTD より大きい値、または中央値 - 5 \$1 RSTD より小さい値はすべて外れ値と見なされます。
+ **スキュー** (数値列) — スキューは分布の対称性を測定し、分布の 3 番目のモーメントを標準偏差の 3 乗で割った値として定義されます。正規分布やその他の対称分布の歪みはゼロです。正の値は、分布の右裾が左裾よりも長いことを意味します。負の値は、分布の左裾が右裾よりも長いことを意味します。経験則として、スキューの絶対値が 3 より大きい場合、分布は歪んでいると見なされます。
+ **尖度** (数値列) — ピアソンの尖度は、分布の裾の重さを測定します。分布の 4 番目のモーメントを 2 番目のモーメントの 2 乗で割ったものとして定義されます。正規分布の尖度は 3 です。尖度値が 3 より小さいということは、分布が平均の周りに集中していて、裾が正規分布の裾よりも軽いことを意味します。尖度値が 3 より大きい場合は、裾が重いか、外れ値が大きいことを意味します。
+ **欠損値** — NULL のようなオブジェクト、空の文字列、空白のみで構成された文字列は欠落しているとみなされます。
+ **数値特徴または回帰ターゲットの有効な値** — 有限浮動小数点数にキャストできる値はすべて有効です。欠損値は無効です。
+ **カテゴリ、バイナリ、テキスト特徴、または分類ターゲットの有効な値** — 欠落していない値はすべて有効です。
+ **Datetime 特徴** — datetime オブジェクトにキャストできる値はすべて有効です。欠損値は無効です。
+ **無効な値** — 欠落しているか、正しくキャストできない値。例えば、数値列では、文字列 `"six"` や null 値をキャストすることはできません。

------
#### [ Quick model metrics for regression ]

クイックモデルメトリクスの定義は次のとおりです。
+ R2 または決定係数 — R2 は、モデルによって予測されるターゲットの変動の割合です。R2 は [-infty, 1] の範囲内にあります。1 はターゲットを完全に予測するモデルのスコア、0 はターゲットの平均を常に予測するトリビアルモデルのスコアです。
+ MSE または平均二乗誤差 — MSE は [0, infty] の範囲にあります。0 は、ターゲットを完全に予測するモデルのスコアです。
+ MAE または平均絶対誤差 — MAE は [0, infty] の範囲にあります。0 はターゲットを完全に予測するモデルのスコアです。
+ RMSE または二乗平均平方根誤差 — RMSE は [0, infty] の範囲にあります。0 はターゲットを完全に予測するモデルのスコアです。
+ 最大誤差 — データセット全体の誤差の最大絶対値。最大誤差は [0, infty] の範囲です。0 はターゲットを完全に予測するモデルのスコアです。
+ 絶対誤差の中央値 — 絶対誤差の中央値は [0, infty] の範囲です。0 は、ターゲットを完全に予測するモデルのスコアです。

------
#### [ Quick model metrics for classification ]

クイックモデルメトリクスの定義は次のとおりです。
+ **精度** — 精度は、正確に予測されたサンプルの比率です。精度は [0, 1] の範囲です。0 はすべてのサンプルを誤って予測したモデルのスコア、1 は完全なモデルのスコアです。
+ **バランス精度** — バランス精度とは、データのバランスが取れるようにクラスの重みを調整したときに正確に予測されるサンプルの比率です。頻度に関係なく、すべてのクラスに同じ重要度が与えられます。バランス精度は [0, 1] の範囲です。0 はすべてのサンプルが間違っていると予測したモデルのスコアです。1 は完全なモデルのスコアです。
+ **AUC (二項分類)** — 受信者操作特性曲線の下面積です。AUC は [0, 1] の範囲にあり、ランダムモデルでは 0.5、完全なモデルでは 1 のスコアが返されます。
+ **AUC (OVR)** — 多クラス分類では、受信者操作特性曲線の下面積を、ラベルごとに 1 と残りのラベルで個別に計算したものです。Data Wrangler はエリアの平均をレポートします。AUC は [0, 1] の範囲にあり、ランダムモデルでは 0.5 のスコアが返され、完全モデルでは 1 のスコアが返されます。
+ **精度** — 精度は特定のクラスに対して定義されます。精度は、モデルがそのクラスとして分類したすべてのインスタンスのうち、真陽性の割合です。精度は [0, 1] の範囲です。1 は、そのクラスで偽陽性がなかったモデルのスコアです。二項分類では、Data Wrangler は陽性クラスの精度をレポートします。
+ **リコール** — リコールは特定のクラスに対して定義されます。リコールは、関連するクラスインスタンスが、正常に取得された割合です。リコールは [0, 1] の範囲です。1 はクラスのすべてのインスタンスを正しく分類したモデルのスコアです。二項分類の場合、Data Wrangler は陽性クラスのリコールをレポートします。
+ **F1** — F1 は特定のクラスに対して定義されます。正確性とリコールを組み合わせた手法です。F1 は [0, 1] の範囲です。1 は完全なモデルのスコアです。二項分類では、Data Wrangler は正の値を持つクラスの F1 をレポートします。

------
#### [ Textual patterns ]

**パターン**は、文字列のテキスト形式を読みやすい形式で記述します。テキストパターンの例を以下に示します。
+ 「\$1digits:4-7\$1」は、長さが 4 から 7 までの一連の数字を表します。
+ 「\$1alnum:5\$1」は、長さがちょうど 5 の英数字文字列を表します。

Data Wrangler は、データから空でない文字列のサンプルを調べてパターンを推測します。よく使われるパターンの多くを記述できます。パーセンテージで表される**信頼度**は、どの程度のデータがパターンに一致すると推定されるかを示します。テキストパターンを使用すると、データのどの行を修正または削除する必要があるかがわかります。

Data Wrangler が認識できるパターンを次に示します。


| パターン | テキスト形式 | 
| --- | --- | 
|  \$1alnum\$1  |  英数字の文字列  | 
|  \$1any\$1  |  任意の単語文字列  | 
|  \$1digits\$1  |  一連の数字  | 
|  \$1lower\$1  |  小文字の単語  | 
|  \$1mixed\$1  |  大文字と小文字が混在する単語  | 
|  \$1name\$1  |  大文字で始まる単語  | 
|  \$1upper\$1  |  大文字の単語  | 
|  \$1whitespace\$1  |  空白文字  | 

単語文字は、どの言語の単語にも使用できるアンダースコアまたは文字です。例えば、「Hello\$1word」と「écoute」という文字列はどちらも単語文字で構成されています。「H」と「é」はどちらも単語文字の例です。

------