Python實現(xiàn)的計算馬氏距離算法示例-創(chuàng)新互聯(lián)

本文實例講述了Python實現(xiàn)的計算馬氏距離算法。分享給大家供大家參考,具體如下:

成都創(chuàng)新互聯(lián)擁有一支富有激情的企業(yè)網(wǎng)站制作團隊,在互聯(lián)網(wǎng)網(wǎng)站建設行業(yè)深耕10余年,專業(yè)且經(jīng)驗豐富。10余年網(wǎng)站優(yōu)化營銷經(jīng)驗,我們已為上1000家中小企業(yè)提供了成都做網(wǎng)站、網(wǎng)站建設解決方案,定制設計,設計滿意,售后服務無憂。所有客戶皆提供一年免費網(wǎng)站維護!

Python實現(xiàn)的計算馬氏距離算法示例

我給寫成函數(shù)調(diào)用了

python實現(xiàn)馬氏距離源代碼:

# encoding: utf-8
from __future__ import division
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
import numpy as np
def mashi_distance(x,y):
  print x
  print y
  #馬氏距離要求樣本數(shù)要大于維數(shù),否則無法求協(xié)方差矩陣
  #此處進行轉(zhuǎn)置,表示10個樣本,每個樣本2維
  X=np.vstack([x,y])
  print X
  XT=X.T
  print XT
  #方法一:根據(jù)公式求解
  S=np.cov(X)  #兩個維度之間協(xié)方差矩陣
  SI = np.linalg.inv(S) #協(xié)方差矩陣的逆矩陣
  #馬氏距離計算兩個樣本之間的距離,此處共有4個樣本,兩兩組合,共有6個距離。
  n=XT.shape[0]
  d1=[]
  for i in range(0,n):
    for j in range(i+1,n):
      delta=XT[i]-XT[j]
      d=np.sqrt(np.dot(np.dot(delta,SI),delta.T))
      print d
      d1.append(d)
if __name__ == '__main__':
  # 第一列
  x = [3, 5, 2, 8]
  # 第二列
  y = [4, 6, 2, 4]
  mashi_distance(x,y)

網(wǎng)站欄目:Python實現(xiàn)的計算馬氏距離算法示例-創(chuàng)新互聯(lián)
網(wǎng)頁路徑:http://bm7419.com/article40/igceo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、網(wǎng)站內(nèi)鏈、App開發(fā)、微信公眾號關(guān)鍵詞優(yōu)化、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司