1. Learn
  2. /
  3. คอร์ส
  4. /
  5. Rで学ぶ caret を使った Machine Learning

Connected

แบบฝึกหัด

中央値による欠損値補完を適用する

この章では、Wisconsin Breast Cancer データセットのバージョンを使用します。これは二値分類の典型的な問題で、サンプルの 50% は良性、50% は悪性です。どちらがどちらかを見分けることが課題です。

このデータセットの特徴は、多くの予測変数に欠損値が含まれており、ほとんどの行に少なくとも 1 つの欠損があることです。ほとんどの Machine Learning アルゴリズムはそのままでは欠損値を扱えないため、これはモデリング上の課題になります。たとえば、最初の発想としてロジスティック回帰モデルを当てはめたくなるかもしれませんが、その前に NA をどのように処理するかの方針が必要です。

幸い、caret の train() 関数には preProcess という引数があり、中央値補完を使って欠損値を埋めるよう指定できます。前の章では、y ~ . のような式を使って train() でモデルを作成しました。別の方法として、train() に x と y の引数を指定することもできます。ここで、x は行にサンプル、列に特徴量を持つオブジェクト、y は目的変数を含む数値または因子ベクトルです。言い換えると、x は、たとえば lm() の data 引数に渡す全データ(ただし目的変数の列は除く)を含む行列またはデータフレームで、y は目的変数の列だけを含むベクトルです。

この演習では、train() の引数 x は breast_cancer_x、y は breast_cancer_y としてワークスペースに読み込まれています。

คำแนะนำ

100 XP
  • train() 関数を使って、乳がんデータセットに glm モデルを当てはめ、median_model というオブジェクトに保存してください。欠損値処理には preProcess = "medianImpute" を指定します。
  • median_model をコンソールに出力してください。