SVM算法识别政治家面部识别

实验名称: SVM算法识别政治家面部识别

一、问题描述

国际政治家面部识别。在此数据集上,采用SVM算法实现:
给定以张图片,预测图片中的任务是否是这位政治家。

在这里插入图片描述
在这里插入图片描述

二、实验目的

学习SVM算法的算法。

三、实验内容

数据导入


from sklearn.datasets import fetch_lfw_people

数据预处理

lfw_people = fetch_lfw_people(min_faces_per_person=70, resize=0.4)
X = lfw_people.data
y = 2 * (lfw_people.target==3).astype(np.int32).reshape(-1,1) - 1

算法描述

当线性不可分时,即不存在分离平面,软间隔SVM算法仍然能给出一个近似的分类平面。

在这里插入图片描述
在这里插入图片描述

class SoftSVM(SVM):
    def __init__(self, C = 1000):
        self.C = C
    
    def get_H(self, Lambda, i,j, y):
        C = self.C
        if y[i]==y[j]:
            return min(C, Lambda[i] + Lambda[j])
        else:
            return min(C, C + Lambda[j] - Lambda[i]) 
    
    def get_L(self, Lambda, i, j, y):
        if y[i]==y[j]:
            return max(0, Lambda[i] + Lambda[j] - self.C)
        else:
            return max(0, Lambda[j] - Lambda[i])

主要代码

import numpy as np
from sklearn.datasets import fetch_lfw_people
from sklearn.model_selection import train_test_split
import matplotlib.pyplot as plt
from sklearn.svm import SVC
from sklearn.metrics import accuracy_score

faces = fetch_lfw_people(min_faces_per_person=70, resize=0.4)
print(faces.target_names)
print(faces.images.shape)


lfw_people = fetch_lfw_people(min_faces_per_person=70, resize=0.4)
X = lfw_people.data
y = 2 * (lfw_people.target==3).astype(np.int32).reshape(-1,1) - 1
# print(lfw_people.target)
m, h, w = lfw_people.images.shape
print(h,w)
# plt.imshow(X[1].reshape(h, w))
plt.imshow(X[3].reshape(h, w))
plt.show()

X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=0)
model = SVC(kernel='rbf', C=1, gamma=1)
model.fit(X_train, y_train)
y_pred = model.predict(X_test)
accuracy = accuracy_score(y_test, y_pred)
print("accuracy = {}".format(accuracy))

四、实验结果及分析

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

五、遇到的问题和解决方法

六、获得资源

https://download.csdn.net/download/m0_61504367/85320352
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汪程序猿

就当请我吃顿饭

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值