# k 最近鄰
> 原文: [https://pythonbasics.org/k-nearest-neighbors/](https://pythonbasics.org/k-nearest-neighbors/)
認識 K 最近鄰,這是最簡單的機器學習算法之一。
該算法用于**分類**和**回歸**。 在這兩種使用中,輸入均包含特征空間中 k 個最接近的訓練示例。 另一方面,輸出取決于大小寫。
* 在“K 最近鄰分類”中,輸出是類成員。
* 在“K 最近鄰回歸”中,輸出是對象的屬性值。
K 最近鄰易于實現,并且能夠執行復雜的分類任務。
## KNN
### k 最近鄰
由于它沒有專門的訓練階段,因此被稱為**惰性**學習算法。
它是一種非參數學習算法,因此不會對基礎數據做任何假設。 由于大多數數據都沒有遵循理論上的假設,因此是一項有用的功能。
k 最近鄰的最大優勢在于,該算法無需進行訓練即可進行預測,從而可以添加新數據。
最大的缺點是該算法難以計算高維數據的距離。
### 應用
K 最近鄰有很多應用程序。
一些示例可以是:
* 收集財務特征以將具有相似財務特征的人與數據庫進行比較,以進行信用評級。
* 將可能成為潛在選民的人分類為一個政黨或另一黨,以預測政治。
* 模式識別可檢測手寫,圖像識別和視頻識別。
### k 最近鄰算法
**K 最近鄰(knn)**具有您應了解的理論。
* 首先,K 最近鄰僅計算新數據點到所有其他訓練數據點的距離。 它可以是任何類型的距離。
* 其次,選擇 K 個最近的數據點,其中 K 可以是任何整數。
* 第三,它將數據點分配給大多數 K 個數據點所屬的類。
理解實際的算法是一個更好的例子。 假設我們要使用的數據集有兩個變量。
任務是將帶有“X”的新數據點分類為“紅色”類或“藍色”類。

數據點的坐標值為`x = 45`和`y = 50`。
現在我們假設 K 的值為 2(兩個簇)。
K 最近鄰算法開始計算點 X 與所有點的距離。
它找到到點 X(黑點)的距離最近的點。
最后一步是為三個最近的點中的大多數都屬于的類分配新點。
## 示例
### Scikit-Learn k 最近鄰
為了實現 K 最近鄰,我們需要一種編程語言和一個庫。
我們建議使用 Python 和 Scikit-Learn。
步驟很簡單,程序員必須
> 導入庫。
> 導入數據集。
> 進行預處理。
> (可選)拆分訓練/測試數據。
> 做出預測。
> (可選)評估算法。
現在,我們可以使用 K 最近鄰算法。
```py
from sklearn.neighbors import NearestNeighbors
import numpy as np
X = np.array([[-1, -1], [-2, -1], [-3, -2], [1, 1], [2, 1], [3, 2]])
K = 2
nbrs = NearestNeighbors(n_neighbors=K, algorithm='ball_tree').fit(X)
distances, indices = nbrs.kneighbors(X)
print(distances)
```
### k 最近鄰分類器
我們用`x`和`y`值創建一個二維空間。 目標包含可能的輸出類(通常稱為標簽)。
knn 可用作分類器。 使用 scikit-learn `KNeighborsClassifier`,其中參數`n_neighbors`為`K`。
然后可以對新值進行預測。
```py
from sklearn import datasets
from sklearn import metrics
from sklearn.neighbors import KNeighborsClassifier
import numpy as np
# dataset
X = np.array([[-1, -1], [-2, -1], [-3, -2], [1, 1], [2, 1], [3, 2]])
target = [0, 0, 0, 1, 1, 1]
# fit a k-nearest neighbor model to the data
K = 3
model = KNeighborsClassifier(n_neighbors = K)
model.fit(X, target)
print(model)
# make predictions
print( '(-2,-2) is class'),
print( model.predict([[-2,-2]]) )
print( '(1,3) is class'),
print( model.predict([[1,3]]) )
```
### k 最近鄰回歸
knn 可用于回歸問題。 在下面的示例中,每月租金價格基于平方米(m^2)進行預測。
它使用 sklearn 的`KNeighborsRegressor`實現。 由于數據集很小,因此將 K 設置為 2 個最近的鄰居。
```py
from sklearn.neighbors import KNeighborsRegressor
# dataset (X=m^2, y=rental price)
X = [[40], [45], [60], [70]]
y = [1000, 1200, 2000, 2500]
# fit
neigh = KNeighborsRegressor(n_neighbors=2)
neigh.fit(X, y)
# predict
print('Monthly Rental Price for 65m^2 in $'),
print(neigh.predict([[65]]))
```
[下載示例和練習](https://gum.co/MnRYU)
- 介紹
- 學習 python 的 7 個理由
- 為什么 Python 很棒
- 學習 Python
- 入門
- 執行 Python 腳本
- 變量
- 字符串
- 字符串替換
- 字符串連接
- 字符串查找
- 分割
- 隨機數
- 鍵盤輸入
- 控制結構
- if語句
- for循環
- while循環
- 數據與操作
- 函數
- 列表
- 列表操作
- 排序列表
- range函數
- 字典
- 讀取文件
- 寫入文件
- 嵌套循環
- 切片
- 多個返回值
- 作用域
- 時間和日期
- try except
- 如何使用pip和 pypi
- 面向對象
- 類
- 構造函數
- 獲取器和設置器
- 模塊
- 繼承
- 靜態方法
- 可迭代對象
- Python 類方法
- 多重繼承
- 高級
- 虛擬環境
- 枚舉
- Pickle
- 正則表達式
- JSON 和 python
- python 讀取 json 文件
- 裝飾器
- 網絡服務器
- 音頻
- 用 Python 播放聲音
- python 文字轉語音
- 將 MP3 轉換為 WAV
- 轉錄音頻
- Tkinter
- Tkinter
- Tkinter 按鈕
- Tkinter 菜單
- Tkinter 標簽
- Tkinter 圖片
- Tkinter 畫布
- Tkinter 復選框
- Tkinter 輸入框
- Tkinter 文件對話框
- Tkinter 框架
- Tkinter 列表框
- Tkinter 消息框
- Tkinter 單選按鈕
- Tkinter 刻度
- 繪圖
- Matplotlib 條形圖
- Matplotlib 折線圖
- Seaborn 分布圖
- Seaborn 繪圖
- Seaborn 箱形圖
- Seaborn 熱力圖
- Seaborn 直線圖
- Seaborn 成對圖
- Seaborn 調色板
- Seaborn Pandas
- Seaborn 散點圖
- Plotly
- PyQt
- PyQt
- 安裝 PyQt
- PyQt Hello World
- PyQt 按鈕
- PyQt QMessageBox
- PyQt 網格
- QLineEdit
- PyQT QPixmap
- PyQt 組合框
- QCheckBox
- QSlider
- 進度條
- PyQt 表格
- QVBoxLayout
- PyQt 樣式
- 編譯 PyQt 到 EXE
- QDial
- QCheckBox
- PyQt 單選按鈕
- PyQt 分組框
- PyQt 工具提示
- PyQt 工具箱
- PyQt 工具欄
- PyQt 菜單欄
- PyQt 標簽小部件
- PyQt 自動補全
- PyQt 列表框
- PyQt 輸入對話框
- Qt Designer Python
- 機器學習
- 數據科學
- 如何從機器學習和 AI 認真地起步
- 為什么要使用 Python 進行機器學習?
- 機器學習庫
- 什么是機器學習?
- 區分機器學習,深度學習和 AI?
- 機器學習
- 機器學習算法比較
- 為什么要使用 Scikit-Learn?
- 如何在 Python 中加載機器學習數據
- 機器學習分類器
- 機器學習回歸
- Python 中的多項式回歸
- 決策樹
- k 最近鄰
- 訓練測試拆分
- 人臉檢測
- 如何為 scikit-learn 機器學習準備數據
- Selenium
- Selenium 瀏覽器
- Selenium Cookie
- Selenium 執行 JavaScript
- Selenium 按 ID 查找元素
- Selenium 無頭 Firefox
- Selenium Firefox
- Selenium 獲取 HTML
- Selenium 鍵盤
- Selenium 最大化
- Selenium 截圖
- Selenium 向下滾動
- Selenium 切換到窗口
- Selenium 等待頁面加載
- Flask 教程
- Flask 教程:Hello World
- Flask 教程:模板
- Flask 教程:路由