2.3.2 ピアソン相関によるスコア

集合知プログラミング2章

概要

 閲覧数:1681  投稿日:2015-12-31  更新日:2016-01-02  

P1とP2のピアソン相関係数を返す

リンク先からの変更点
・'Michael Phillips' の 'The Night Listener' 評価を 3.0 から 4.0 へ変更


コード

$critics = array( 
  'Lisa Rose' => array( 
    'Lady in the Water' => 2.5,
    'Snakes on a Plane' => 3.5,
    'Just My Luck' => 3.0,
    'Superman Returns' => 3.5,
    'You, Me and Dupree' => 2.5,
    'The Night Listener' => 3.0,
  ),
  'Gene Seymour' => array( 
    'Lady in the Water' => 3.0,
    'Snakes on a Plane' => 3.5,
    'Just My Luck' => 1.5,
    'Superman Returns' => 5.0,
    'You, Me and Dupree' => 3.5,
    'The Night Listener' => 3.0,
  ),
  'Michael Phillips' => array( 
    'Lady in the Water' => 2.5,
    'Snakes on a Plane' => 3.0,
    'Superman Returns' => 3.5,
    'The Night Listener' => 4.0,
  ),
  'Claudia Puig' => array( 
    'Snakes on a Plane' => 3.5,
    'Just My Luck' => 3.0,
    'Superman Returns' => 4.0,
    'You, Me and Dupree' => 2.5,
    'The Night Listener' => 4.5,
  ),
  'Mick LaSalle' => array( 
    'Lady in the Water' => 3.0,
    'Snakes on a Plane' => 4.0,
    'Just My Luck' => 2.0,
    'Superman Returns' => 3.0,
    'You, Me and Dupree' => 2.0,
    'The Night Listener' => 3.0,
  ),
  'Jack Matthews' => array( 
    'Lady in the Water' => 3.0,
    'Snakes on a Plane' => 4.0,
    'Superman Returns' => 5.0,
    'You, Me and Dupree' => 3.5,
    'The Night Listener' => 3.0,
  ),
  'Toby' => array( 
    'Snakes on a Plane' => 4.5,
    'Superman Returns' => 4.0,
    'You, Me and Dupree' => 1.0,
  ),
);



//P1とP2のピアソン相関係数を返す。
function sim_pearson($prefs,$p1,$p2){

  //両者が互いに評価しているアイテムのリストを取得
  $si = array();
  foreach($prefs["$p1"] as $item => $val){
    if(isset($prefs["$p2"]["$item"])){
      $si["$item"] = 1;
    }
  }

  //要素の数を調べる。
  $n = count($si);

  //すべての嗜好,平方,積を合計する

  //嗜好の合計
  $sum1 = 0;
  $sum2 = 0;

  //平方の合計
  $sum1Sq = 0;
  $sum2Sq = 0;

  //積の合計
  $pSum = 0;

  foreach($si as $item => $val){
    $sum1 += $prefs["$p1"]["$item"];
    $sum2 += $prefs["$p2"]["$item"];
    $sum1Sq += pow($prefs["$p1"]["$item"],2);
    $sum2Sq += pow($prefs["$p2"]["$item"],2);
    $pSum += $prefs["$p1"]["$item"] * $prefs["$p2"]["$item"];
  }

  //ピアソンスコアを計算する
  $num = $pSum - ($sum1 * $sum2 / $n);
  $den = sqrt(($sum1Sq - pow($sum1,2) / $n) * ($sum2Sq - pow($sum2,2) / $n));

  if($den == 0){ return 0;}

  $r = $num / $den;
  return $r;
}


var_dump( sim_pearson($critics,'Lisa Rose','Gene Seymour') ); //float(0.39605901719067)
var_dump( sim_pearson($critics,'Lisa Rose','Lisa Rose') ); //float(1)
var_dump( sim_pearson($critics,'Lisa Rose','Toby') ); //float(0.99124070716193)




結果

float(0.39605901719067)
float(1)
float(0.99124070716193)



タグ


pow 





2.3.1 ユークリッド距離によるスコア

2.3.4 訳者をランキングする 



週間人気ページランキング / 6-17 → 6-23
順位 ページタイトル抜粋 アクセス数
1 PHPコード 23
2 文字列を「複数の区切り文字」で配列へ変換 / preg_split使用案。採用 | 文字列(テキスト処理) 4
3 文字列の改行文字を削除 | 文字列(テキスト処理) 3
3 配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す | 配列(型) 3
3 指定文字が2回目に出現する位置以降の文字列を取得 | 文字列(テキスト処理) 3
3 引数(複数)に指定したデータを、予め指定した文字形式(フォーマット)へ変換 | 文字列(テキスト処理) 3
3 全ての配列要素へ対して順番に処理を実施 | 配列(型) 3
3 配列要素を置換 | 配列(型) 3
3 「指定配列要素が配列内で重複している数」をカウント後、配列要素として追加 | 配列(型) 3
3 指定文字列より前を取得 | 文字列(テキスト処理) 3
3 array_map()第3引数 / 「2つの配列の要素数同士を順番に掛け合わせた配列」を返す | 配列(型) 3
3 配列要素を、文字列連結して表示(元配列を上書) … foreach文+implode | 配列(型) 3
4 Smartyのテンプレートにincludeしたファイルを表示 | Smarty(テンプレートエンジン) 2
4 複数テーブルロック | MySQL 2
4 指定文字列を削除 | 文字列(テキスト処理) 2
4 多次元配列で「二次元目にある指定値のカウント数 +1 」 を返す | 配列(型) 2
4 'xxxx_数字'キーの数だけ、数字毎に分けて二次元配列へ格納(キーのサフィックスは削除する) / array_walk | 配列(型) 2
4 インスタンスオブジェクト経由で、メンバ(プロパティ・メソッド)へアクセス … PHP5 | クラス 2
4 配列キーを置換して返すユーザ定義関数 | 配列(型) 2
4 現在のセッション名を取得、表示 | セッション 2
2026/6/24 5:05 更新