欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

(手寫)PCA原理及其Python實現(xiàn)圖文詳解

 更新時間:2021年08月17日 09:16:33   作者:Raymond_桐  
這篇文章主要介紹了Python來PCA算法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望能給你帶來幫助

1、背景

為什么需要降維呢?

因為數(shù)據(jù)個數(shù) N 和每個數(shù)據(jù)的維度 p 不滿足 N >> p,造成了模型結(jié)果的“過擬合”。有兩種方法解決上述問題:

增加N;減小p。

這里我們講解的 PCA 屬于方法2。

2、樣本均值和樣本方差矩陣

在這里插入圖片描述

在這里插入圖片描述

3、PCA

在這里插入圖片描述
在這里插入圖片描述

3.1 最大投影方差

在這里插入圖片描述

3.2 最小重構(gòu)距離

在這里插入圖片描述

4、Python實現(xiàn)

"""
    -*- coding: utf-8 -*-
    @ Time     : 2021/8/15  22:19
    @ Author   : Raymond
    @ Email    : wanght2316@163.com
    @ Editor   : Pycharm
"""
from sklearn.datasets import load_digits
from sklearn.decomposition import PCA
import pandas as pd
import matplotlib.pyplot as plt

digits = load_digits()
print(digits.keys())
print("數(shù)據(jù)的形狀為: {}".format(digits['data'].shape))
# 構(gòu)建模型 - 降到10 d
pca = PCA(n_components=10)
pca.fit(digits.data)
projected=pca.fit_transform(digits.data)
print('降維后主成分的方差值為:',pca.explained_variance_)
print('降維后主成分的方差值占總方差的比例為:',pca.explained_variance_ratio_)
print('降維后最大方差的成分為:',pca.components_)
print('降維后主成分的個數(shù)為:',pca.n_components_)
print('original shape:',digits.data.shape)
print('transformed shape:',projected.shape)
s = pca.explained_variance_
c_s = pd.DataFrame({'b': s,'b_sum': s.cumsum() / s.sum()})
c_s['b_sum'].plot(style= '--ko',figsize= (10, 4))
plt.rcParams['font.sans-serif'] = ['SimHei']  # 指定默認字體
plt.rcParams['axes.unicode_minus'] = False  # 解決保存圖像是負號'-'顯示為方塊的問題
plt.axhline(0.85,  color= 'r',linestyle= '--')
plt.text(6, c_s['b_sum'].iloc[6]-0.08, '第7個成分累計貢獻率超過85%', color='b')
plt.title('PCA 各成分累計占比')
plt.grid()
plt.savefig('./PCA.jpg')
plt.show()

結(jié)果展示:

在這里插入圖片描述

總結(jié)

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • Python實現(xiàn)對圖像加噪(高斯噪聲 椒鹽噪聲)

    Python實現(xiàn)對圖像加噪(高斯噪聲 椒鹽噪聲)

    這篇文章主要介紹了展示通過Python給圖像疊加不同等級的椒鹽噪聲和高斯噪聲的代碼,相應的疊加噪聲的已編為對應的類,可實例化使用。感興趣的同學可以看看
    2021-11-11
  • python函數(shù)的重新定義及練習

    python函數(shù)的重新定義及練習

    這篇文章主要為大家詳細介紹了python的函數(shù),使用python,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • python 還原梯度下降算法實現(xiàn)一維線性回歸

    python 還原梯度下降算法實現(xiàn)一維線性回歸

    這篇文章主要介紹了python 還原梯度下降算法實現(xiàn)一維線性回歸,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10
  • 用Python自動下載網(wǎng)站所有文件

    用Python自動下載網(wǎng)站所有文件

    這篇文章主要介紹了如何用Python自動下載網(wǎng)站所有文件,幫助大家更好的理解和學習使用python,感興趣的朋友可以了解下
    2021-03-03
  • python中的三種注釋方法

    python中的三種注釋方法

    這篇文章主要介紹了python中的三種注釋方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • python串口讀取數(shù)據(jù)的實例

    python串口讀取數(shù)據(jù)的實例

    這篇文章主要介紹了python串口讀取數(shù)據(jù)的實例,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • python獲取命令行參數(shù)實例方法講解

    python獲取命令行參數(shù)實例方法講解

    在本篇文章里小編給大家整理的是一篇關(guān)于python獲取命令行參數(shù)實例方法講解內(nèi)容,有興趣的朋友們可以學習下。
    2020-11-11
  • 詳解python之協(xié)程gevent模塊

    詳解python之協(xié)程gevent模塊

    這篇文章主要介紹了詳解python之協(xié)程gevent模塊,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • Python中移除List重復項的五種方法

    Python中移除List重復項的五種方法

    本文列些處幾種去除在Python 列表中(list)可能存在的重復項,這在很多應用程序中都會遇到的需求,本文介紹幾種方法,感興趣的可以了解一下
    2021-05-05
  • Python實現(xiàn)獲取郵箱內(nèi)容并解析的方法示例

    Python實現(xiàn)獲取郵箱內(nèi)容并解析的方法示例

    這篇文章主要介紹了Python實現(xiàn)獲取郵箱內(nèi)容并解析的方法,結(jié)合完整實例形式分析了Python登陸pop3服務器并解析獲取郵箱內(nèi)容相關(guān)操作技巧,需要的朋友可以參考下
    2018-06-06

最新評論