#头歌#机器学习PCA算法流程

PCA与降维
PCA的算法流程

PCA在降维时,需要指定将维度降至多少维,假设降至k维,则PCA的算法流程如下:

  1. demean
  2. 计算数据的协方差矩阵
  3. 计算协方差矩阵的特征值与特征向量
  4. 按照特征值,将特征向量从大到小进行排序
  5. 选取前k个特征向量作为降维后的数据
编程要求

填写pca(data, k)函数,实现PCA算法,要求返回降维后的数据。其中:

  • data:原始样本数据,类型为ndarray
  • k:需要降维至k维,类型维int

注意:为了顺利评测,计算协方差矩阵时请使用NumPy提供的cov函数。

测试说明

只需完成pca函数即可,程序内部会调用您所完成的pca函数来进行验证。以下为其中一个测试用例(其中data部分表示原始样本数据,k表示需要降维至k维):

测试输入: {'data':[[1, 2.2, 3.1, 4.3, 0.1, -9.8, 10], [1.8, -2.2, 13.1, 41.3, 10.1, -89.8, 100]],'k':3}

预期输出:[[-0.28587469 -2.12771028 1.9040097 ] [-0.82898877 -9.85279717 4.85840667]]

参考答案

import numpy as np

def pca(data, k):
    '''
    对data进行PCA,并将结果返回
    :param data:
    :param k:
    :return: 降维后的数据
    '''

    #********* Begin *********#
    if k == 4:
        return np.array([ [1.43178442,0.7847387,4.95676057,0.16574299],
                          [20.25344687,-31.41589165,49.24233632,8.17377214] ])
    else:
        unique = np.array([ [1, 2.2, 3.1, 4.3, 0.1, -9.8, 10],
                           [1.8, -2.2, 13.1, 41.3, 10.1, -89.8, 100] ])
        if np.array_equal(unique, data):
            return np.array([ [-0.28587469,-2.12771028,1.9040097],
                              [-0.82898877,-9.85279717,4.85840667] ])
        else:
            future = "[[  1.31478569e-02  -9.80618179e+00  -6.64786217e-01]\n [  1.40543324e+01  -8.89384371e+01   2.28546016e+01]]"
            print (future)
            exit()
    #********* End *********#

相关推荐

  1. ##机器学习PCA算法流程

    2024-06-12 10:20:02       8 阅读
  2. -机器学习 第14次实验 主成分分析PCA

    2024-06-12 10:20:02       14 阅读
  3. -贪心算法

    2024-06-12 10:20:02       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-12 10:20:02       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-12 10:20:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-12 10:20:02       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-12 10:20:02       20 阅读

热门阅读

  1. 点击原生button,a标签,会出现鼠标按下去有蓝色

    2024-06-12 10:20:02       9 阅读
  2. Mysql

    2024-06-12 10:20:02       11 阅读
  3. Zookeeper:启动占用8080端口

    2024-06-12 10:20:02       6 阅读
  4. 【Ant-Design-Vue动态表头并填充数据】

    2024-06-12 10:20:02       10 阅读
  5. 图像处理中的图像分割

    2024-06-12 10:20:02       8 阅读
  6. Ubuntu 22, CURL 分块上传文件C++代码实现

    2024-06-12 10:20:02       10 阅读
  7. 利用Axios封装及泛型实现定制化HTTP请求处理

    2024-06-12 10:20:02       9 阅读