推荐系统之K近邻(KNN)算法

推荐系统之K近邻(KNN)算法

1.引入库


import numpy as np
import pandas as pd

#这里直接引入sklearn 里的数据集  iris 燕尾花
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split    
#切分数据集为训练集和测试集
from sklearn.metrics import accuracy_score
#计算分类预测的准确率

2.数据加载与预处理

iris=load_iris()

df=pd.DataFrame(data=iris.data,columns=iris.feature_names)
df['class']=iris.target

df['class']=df['class'].map({0:iris.target_names[0],1:iris.target_names[1],2:iris.target_names[2]})
df

在这里插入图片描述

x=iris.data
y=iris.target.reshape(-1,1)
print(x.shape,y.shape)

#划分训练集和测试集
x_train,x_test,y_train,y_test=train_test_split(x,y,test_size=0.3,random_state=35,stratify=y)

print(x_train.shape,y_train.shape)
print(x_test.shape,y_test.shape)

#x_test[0].reshape(1,-1).shape
#print(np.abs(x_train-x_test[0].reshape(1,-1)))
#np.sum(np.abs(x_train-x_test[0].reshape(1,-1)),axis=1)

3.核心算法实现

#距离函数定义
def l1_distance(a,b):
    #a可以是矩阵,b只能是向量
    return np.sum(np.abs(a-b),axis=1)
def l2_distance(a,b):
    return np.sqrt(np.sum((a-b)**2,axis=1))

#分类器的写法
class kNN(object):
    #定义一个初始化方法,__init__是类的构造方法
    def __init__(self,n_neighbors=1,dist_func = l1_distance):
        self.n_neighbors=n_neighbors
        self.dist_func=dist_func
    
    #训练模型的方法
    def fit(self,x,y):
        self.x_train=x
        self.y_train=y
        
    #模型预测方法
    def predict(self,x):
        #初始化预测分类数组
        y_pred= np.zeros((x.shape[0],1),dtype=self.y_train.dtype)
        
        #遍历输入的x数据点,取出每个数据点的序号i和数据x_test
        for i,x_test in enumerate(x):
            #x_test跟所有训练数据计算距离(一个是矩阵,一个是向量)distance是一个一维向量
            distance=self.dist_func(self.x_train,x_test)
            
            #得到的距离按照由近到远排序
            nn_index=np.argsort(distance)
            
            #选取最近的k个点,保存他们对应的分类类别
            nn_y=self.y_train[nn_index[:self.n_neighbors]].ravel()
            
            #统计类别中出现频率最高的那个,赋给y_pred[i]
            y_pred[i]=np.argmax(np.bincount(nn_y))
        
        return y_pred

4.测试

#定义一个kNN实例
knn=kNN(n_neighbors=3)
#训练模型
knn.fit(x_train,y_train)

#传入测试数据,做预测
y_pred=knn.predict(x_test)

#求出预测准确率
accuracy=accuracy_score(y_test,y_pred)

print("预测准确率为:",accuracy)

5.拓展,不同参数的准确率比较

#定义一个KNN实例
knn=kNN()
#训练模型
knn.fit(x_train,y_train)

#保存不同的结果
result_list=[]

#针对不同的参数进行选取,做预测
for p in [1,2]:
    knn.dist_func= l1_distance if p==1 else l2_distance
    
    #考虑不同的k取值,步长为2
    for k in range(1,10,2):
        knn.n_neighbors=k
        #传入测试数据  做预测
        y_pred=knn.predict(x_test)
        #做出准确值的预测
        accuracy=accuracy_score(y_pred,y_test)
        result_list.append([k,'l1_distance' if p==1 else 'l2_distance',accuracy])
df=pd.DataFrame(result_list,columns=['k','距离函数','预测准确率'])
df

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值