经典多维标度法 mds matlab,多维标度法(MDS)的Python实现

多维标度法(multidimensional scaling,MDS)是一种在低维

多维标度法与主成分分析(Princ

多维标度法的目标 :当n 个对象中各对对象之间的相似性(或距离)给定时,确定这些对象在低维(欧式) 空间中的表示(称为感知图, Perceptual Mapping),并使其尽可能与原先的相似性(或距离)“大体匹配”,使得由降维所引起的任何变形达到最小。

低维(欧式) 空间中排列的每一个点代表一个对象,因此点间的距离与对象间的相似性高度相关。也就是说,两个相似的对象由低维(欧式) 空间中两个距离相近的点表示,而两个不相似的对象则由低维(欧式) 空间两个距离较远的点表示。低维空间通常为二维或三维的欧氏空间,但也可以是非欧氏三维以上空间.

Classical MDS:

• 原始空间下的距离阵和低维空间下的距离阵都采用欧式距离阵

• 距离阵D 为欧式的, 即存在某个正整数p 以及R p 空间的n个点x 1 , . . . , x n , 使得

e36221e7fd47d5943d629fafe50b0227.png

目标在于: 寻找D 的(拟合) 构图x 1 , . . . , x n , 其想法为

– 将平方的欧式距离阵D = (d 2 ij ) 变换为一个非负定矩阵B

– 由B 的特征根和特征向量得到构图X, X 的每一行表示低维空间的点.

• 为此, 记原始的p 维对象(观测点) 为x 1 , . . . , x n (一般是未知的), 两两之间的距离平方为

c181de582e695e9c43c408a7833b3ac3.png

B = −1/2*HDH,H = In − 1/n 11′

eb4ac6a9aa5fdba3073d13e8ccabad85.png

其中, r 的确定: 事先确定r = 1, 2 或3; 或者通过计算前面特征根占全体特征根的比例确定.

importnumpy as np D=np.array([[0,411,213,219,296,397], [411,0,204,203,120,152], [213,204,0,73,136,245], [219,203,73,0,90,191], [296,120,136,90,0,109], [397,152,245,191,109,0]]) N=D.shape[0] T=np.zeros((N,N))#solution 1#ss = 1.0/N**2*np.sum(D**2)#for i in range(N):#for j in range(i,N):#T[i,j] = T[j,i] = -0.5*(D[i,j]**2 -1.0/N*np.dot(D[i,:],D[i,:]) -1.0/N*np.dot(D[:,j],D[:,j])+ss) #solution 2 K =np.dot(D,np.transpose(D)) D2= D**2H= np.eye(N) - 1/N T= -0.5*np.dot(np.dot(H,D2),H) eigVal,eigVec=np.linalg.eig(T) X= np.dot(eigVec[:,:2],np.diag(np.sqrt(eigVal[:2])))print('original','/tnew distance')for i inrange(N):for j in range(i+1,N):print(np.str(D[i,j]),'/t/t',np.str("%.4f"%np.linalg.norm(X[i]-X[j])))

运行结果:

4fd5d7c0535db84a9dd176a9409641c4.png

参考文档:典型相关分析和多维标度法-张伟平的讲义

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值