《PHP實例:PHP數據分析引擎計算余弦相似度算法示例》要點:
本文介紹了PHP實例:PHP數據分析引擎計算余弦相似度算法示例,希望對您有用。如果有疑問,可以聯系我們。
PHP編程本文實例講述了PHP數據分析引擎計算余弦相似度算法.分享給大家供大家參考,具體如下:
PHP編程關于余弦相似度的相關介紹可參考百度百科:余弦相似度
PHP編程
<?php
/**
* 數據分析引擎
* 分析向量的元素 必須和基準向量的元素一致,取最大個數,分析向量不足元素以0填補.
* 求出分析向量與基準向量的余弦值
* @author yu.guo@okhqb.com
*/
/**
* 獲得向量的模
* @param unknown_type $array 傳入分析數據的基準點的N維向量.|eg:array(1,1,1,1,1);
*/
function getMarkMod($arrParam){
$strModDouble = 0;
foreach($arrParam as $val){
$strModDouble += $val * $val;
}
$strMod = sqrt($strModDouble);
//是否需要保留小數點后幾位
return $strMod;
}
/**
* 獲取標桿的元素個數
* @param unknown_type $arrParam
* @return number
*/
function getMarkLenth($arrParam){
$intLenth = count($arrParam);
return $intLenth;
}
/**
* 對傳入數組進行索引分配,基準點的索引必須為k,求夾角的向量索引必須為 'j'.
* @param unknown_type $arrParam
* @param unknown_type $index
* @ruturn $arrBack
*/
function handIndex($arrParam, $index = 'k'){
foreach($arrParam as $key => $val){
$in = $index.$key;
$arrBack[$in] = $val;
}
return $arrBack;
}
/**
*
* @param unknown_type $arrMark標桿向量數組(索引被處理過)
* @param unknown_type $arrAnaly 分析向量數組 (索引被處理過) |array('j0'=>1,'j1'=>2....)
* @param unknown_type $strMarkMod標桿向量的模
* @param unknown_type $intLenth 向量的長度
*/
function getCosine($arrMark, $arrAnaly, $strMarkMod ,$intLenth){
$strVector = 0;
$strCosine = 0;
for($i = 0; $i < $intLenth; $i++){
$strMarkVal = $arrMark['k'.$i];
$strAnalyVal = $arrAnaly['j'.$i];
$strVector += $strMarkVal * $strAnalyVal;
}
$arrAnalyMod = getMarkMod($arrAnaly); //求分析向量的模
$strFenzi = $strVector;
$strFenMu = $arrAnalyMod * $strMarkMod;
$strCosine = $strFenzi / $strFenMu;
if(0 !== (int)$strFenMu){
$strCosine = $strFenzi / $strFenMu;
}
return $strCosine;
}
?>
PHP編程更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《php程序設計算法總結》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》及《PHP數組(Array)操作技巧大全》
PHP編程希望本文所述對大家PHP程序設計有所幫助.
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/355.html