PCA

PCA的想法其实很简单。

目的:投影后的坐标点方差最大(分得最开)

目标问题:


(这里对X要求零均值,不然方差不是这样求

方法:对于目标问题通过拉格朗日乘子法展开,变成求解特征值和特征向量的问题


def PCA(x, n=1):
    x = np.asarray(x, np.float32)
    mean_data = np.mean(x, axis=0)
    x -= mean_data
    mat = x.T.dot(x)
    eigVects, eigVal, _ = np.linalg.svd(mat)
    idx = np.argsort(eigVal)[::-1]
    eigVects = eigVects[:, idx]
    result = x.dot(eigVects[:, 0:n])
    return np.reshape(result, len(x)), mean_data


看下效果

降维前


降维后



搞定,收工~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值