第十五周作业

本文通过交叉验证比较了高斯朴素贝叶斯、SVM和支持向量机及随机森林三种算法的准确性、F1得分和AUC-ROC得分,并对各算法进行了参数优化。

题目


代码:

from sklearn import datasets
from sklearn import cross_validation
from sklearn.naive_bayes import GaussianNB
from sklearn.svm import SVC
from sklearn.ensemble import RandomForestClassifier
from sklearn import metrics
import numpy as np

def NB(X_train, y_train, X_test):
	clf = GaussianNB()
	clf.fit(X_train, y_train)
	return clf.predict(X_test)

def rbf_svm(X_train, y_train, X_test, C):
	clf = SVC(C=C, kernel='rbf')
	clf.fit(X_train, y_train)
	return clf.predict(X_test)
	
def RFC(n_estimators, X_train, y_train, X_test):
	clf = RandomForestClassifier(n_estimators=10)
	clf.fit(X_train, y_train)
	return clf.predict(X_test)

iris = datasets.load_iris()
dataset = datasets.make_classification(n_samples=1000, n_features=10,
			n_informative=2, n_redundant=2, n_repeated=0, n_classes=2)
			
kf = cross_validation.KFold(len(iris.data), n_folds=10, shuffle=True, random_state=1234)

nb_accuracy = []
nb_f1 = []
nb_auc_roc = []

svm_accuracy = []
svm_f1 = []
svm_auc_roc = []

rfc_accuracy = []
rfc_f1 = []
rfc_auc_roc = []

for train_index, test_index in kf:
	X_train, y_train = dataset[0][train_index], dataset[1][train_index]
	X_test, y_test   = dataset[0][test_index], dataset[1][test_index]
	
	#NB
	pred = NB(X_train, y_train, X_test)
	nb_accuracy.append(metrics.accuracy_score(y_test, pred))
	nb_f1.append(metrics.f1_score(y_test, pred))
	nb_auc_roc.append(metrics.roc_auc_score(y_test, pred))
	
	#rbf_svm	
	nn = len(X_train)
	bestC = None
	Cvalues = [1e-2,1e-1, 1e0, 1e1, 1e2]
	innerscore = []
	for C in Cvalues:
		ikf = cross_validation.KFold(nn, n_folds=5, shuffle=True, random_state=5678)
		innerf1 = []
		for t_index, v_index in ikf:
			X_t, X_v = X_train[t_index], X_train[v_index]
			y_t, y_v = y_train[t_index], y_train[v_index]
			
			ipred = rbf_svm(X_t, y_t, X_v, C)
			innerf1.append(metrics.f1_score(y_v, ipred))
			
		innerscore.append(sum(innerf1)/len(innerf1))
	bestC = Cvalues[np.argmax(innerscore)]
	print('The bestC is {} with the inner f1 score {}'.format(bestC, max(innerscore)))
	pred = rbf_svm(X_train, y_train, X_test, bestC)
	svm_accuracy.append(metrics.accuracy_score(y_test, pred))
	svm_f1.append(metrics.f1_score(y_test, pred))
	svm_auc_roc.append(metrics.roc_auc_score(y_test, pred))

	#RFC
	nn = len(X_train)
	best_nes = None
	nes_values = [10, 100, 1000]
	innerscore = []
	for nes in nes_values:
		ikf = cross_validation.KFold(nn, n_folds=5, shuffle=True, random_state=5678)
		innerf1 = []
		for t_index, v_index in ikf:
			X_t, X_v = X_train[t_index], X_train[v_index]
			y_t, y_v = y_train[t_index], y_train[v_index]
			
			ipred = RFC(nes, X_t, y_t, X_v)
			innerf1.append(metrics.f1_score(y_v, ipred))
			
		innerscore.append(sum(innerf1)/len(innerf1))
	best_nes = nes_values[np.argmax(innerscore)]
	print('The best n_estimators value is {} with the inner f1 score {}'.format(best_nes, max(innerscore)))
	pred = RFC(nes, X_train, y_train, X_test)
	rfc_accuracy.append(metrics.accuracy_score(y_test, pred))
	rfc_f1.append(metrics.f1_score(y_test, pred))
	rfc_auc_roc.append(metrics.roc_auc_score(y_test, pred))

print('*****the cross-validated performance*****')
print('GaussianNB:')
print('Accuracy score:\n{}'.format(nb_accuracy))
print('average: {}'.format(sum(nb_accuracy)/len(nb_accuracy)))
print('F1-score:\n{}'.format(nb_f1))
print('average: {}'.format(sum(nb_f1)/len(nb_f1)))
print('AUC ROC score:\n{}'.format(nb_auc_roc))
print('average: {}'.format(sum(nb_auc_roc)/len(nb_auc_roc)))
print('*****')
print('SVC:')
print('Accuracy score:\n{}'.format(svm_accuracy))
print('average: {}'.format(sum(svm_accuracy)/len(svm_accuracy)))
print('F1-score:\n{}'.format(svm_f1))
print('average: {}'.format(sum(svm_f1)/len(svm_f1)))
print('AUC ROC score:\n{}'.format(svm_auc_roc))
print('average: {}'.format(sum(svm_auc_roc)/len(svm_auc_roc)))
print('*****')
print('RandomForestClassifier:')
print('Accuracy score:\n{}'.format(rfc_accuracy))
print('average: {}'.format(sum(rfc_accuracy)/len(rfc_accuracy)))
print('F1-score:\n{}'.format(rfc_f1))
print('average: {}'.format(sum(rfc_f1)/len(rfc_f1)))
print('AUC ROC score:\n{}'.format(rfc_auc_roc))
print('average: {}'.format(sum(rfc_auc_roc)/len(rfc_auc_roc)))
print('*****')
结果:
The bestC is 1.0 with the inner f1 score 0.8678749455945998
The best n_estimators value is 1000 with the inner f1 score 0.8962557909926332
The bestC is 1.0 with the inner f1 score 0.8445989304812833
The best n_estimators value is 10 with the inner f1 score 0.8725475181926795
The bestC is 1.0 with the inner f1 score 0.8518346271059742
The best n_estimators value is 10 with the inner f1 score 0.8443333333333332
The bestC is 1.0 with the inner f1 score 0.8619444444444445
The best n_estimators value is 100 with the inner f1 score 0.8623759305210917
The bestC is 1.0 with the inner f1 score 0.8324285083631727
The best n_estimators value is 10 with the inner f1 score 0.8402929245034508
The bestC is 1.0 with the inner f1 score 0.8563861266068397
The best n_estimators value is 10 with the inner f1 score 0.8607061772077251
The bestC is 1.0 with the inner f1 score 0.8197329552168261
The best n_estimators value is 1000 with the inner f1 score 0.8546247083225303
The bestC is 1.0 with the inner f1 score 0.8367141397501928
The best n_estimators value is 100 with the inner f1 score 0.8504655299721714
The bestC is 1.0 with the inner f1 score 0.8334529785192293
The best n_estimators value is 1000 with the inner f1 score 0.8514978242888482
The bestC is 1.0 with the inner f1 score 0.8269505800095344
The best n_estimators value is 100 with the inner f1 score 0.8705391012398799
*****the cross-validated performance*****
GaussianNB:
Accuracy score:
[0.8666666666666667, 0.7333333333333333, 0.8, 0.8, 0.7333333333333333, 0.8, 0.93
33333333333333, 0.7333333333333333, 0.9333333333333333, 0.8666666666666667]
average: 0.8200000000000001
F1-score:
[0.8571428571428571, 0.75, 0.8571428571428572, 0.7692307692307693, 0.75, 0.79999
99999999999, 0.9333333333333333, 0.7777777777777778, 0.9523809523809523, 0.88888
88888888888]
average: 0.8335897435897437
AUC ROC score:
[0.8888888888888888, 0.7321428571428571, 0.75, 0.8125, 0.75, 0.8035714285714286,
 0.9375, 0.7222222222222223, 0.9, 0.8611111111111112]
average: 0.8157936507936508
*****
SVC:
Accuracy score:
[0.8, 0.7333333333333333, 0.8, 0.8666666666666667, 0.7333333333333333, 0.8, 0.93
33333333333333, 0.8, 0.8666666666666667, 0.8666666666666667]
average: 0.8200000000000001
F1-score:
[0.8, 0.75, 0.8695652173913044, 0.8571428571428571, 0.7777777777777778, 0.823529
411764706, 0.9333333333333333, 0.8421052631578948, 0.9090909090909091, 0.8888888
888888888]
average: 0.8451433658547671
AUC ROC score:
[0.8333333333333334, 0.7321428571428571, 0.7, 0.875, 0.7222222222222223, 0.79464
28571428572, 0.9375, 0.7777777777777778, 0.8, 0.8611111111111112]
average: 0.8033730158730158
*****
RandomForestClassifier:
Accuracy score:
[0.8, 0.7333333333333333, 0.8, 0.8666666666666667, 0.8, 0.8, 1.0, 0.8, 0.9333333
333333333, 0.8]
average: 0.8333333333333334
F1-score:
[0.7692307692307692, 0.75, 0.8695652173913044, 0.8571428571428571, 0.8, 0.823529
411764706, 1.0, 0.8421052631578948, 0.9523809523809523, 0.823529411764706]
average: 0.8487483882833191
AUC ROC score:
[0.8055555555555556, 0.7321428571428571, 0.7, 0.875, 0.8333333333333333, 0.79464
28571428572, 1.0, 0.7777777777777778, 0.9, 0.8055555555555555]
average: 0.8224007936507937
*****

分析:在选择参数的过程中使用了使分数最大的参数,共10次样例。机器学习的这些函数使用在课件上都有给出,而且过程也比较清晰,只要在10次样例中分别进行性能评估即可。
内容概要:本文详细介绍了一个基于Java和Vue的联邦学习隐私保护推荐系统的设计与实现。系统采用联邦学习架构,使用户数据在本地完成模型训练,仅上传加密后的模型参数或梯度,通过中心服务器进行联邦平均聚合,从而实现数据隐私保护与协同建模的双重目标。项目涵盖完整的系统架构设计,包括本地模型训练、中心参数聚合、安全通信、前后端解耦、推荐算法插件化等模块,并结合差分隐私与同态加密等技术强化安全性。同时,系统通过Vue前端实现用户行为采集与个性化推荐展示,Java后端支撑高并发服务与日志处理,形成“本地训练—参数上传—全局聚合—模型下发—个性化微调”的完整闭环。文中还提供了关键模块的代码示例,如特征提取、模型聚合、加密上传等,增强了项目的可实施性与工程参考价值。 适合人群:具备一定Java和Vue开发基础,熟悉Spring Boot、RESTful API、分布式系统或机器学习相关技术,从事推荐系统、隐私计算或全栈开发方向的研发人员。 使用场景及目标:①学习联邦学习在推荐系统中的工程落地方法;②掌握隐私保护机制(如加密传输、差分隐私)与模型聚合技术的集成;③构建高安全、可扩展的分布式推荐系统原型;④实现前后端协同的个性化推荐闭环系统。 阅读建议:建议结合代码示例深入理解联邦学习流程,重点关注本地训练与全局聚合的协同逻辑,同时可基于项目架构进行算法替换与功能扩展,适用于科研验证与工业级系统原型开发。
源码来自:https://pan.quark.cn/s/a4b39357ea24 遗传算法 - 简书 遗传算法的理论是根据达尔文进化论而设计出来的算法: 人类是朝着好的方向(最优解)进化,进化过程中,会自动选择优良基因,淘汰劣等基因。 遗传算法(英语:genetic algorithm (GA) )是计算数学中用于解决最佳化的搜索算法,是进化算法的一种。 进化算法最初是借鉴了进化生物学中的一些现象而发展起来的,这些现象包括遗传、突变、自然选择、杂交等。 搜索算法的共同特征为: 首先组成一组候选解 依据某些适应性条件测算这些候选解的适应度 根据适应度保留某些候选解,放弃其他候选解 对保留的候选解进行某些操作,生成新的候选解 遗传算法流程 遗传算法的一般步骤 my_fitness函数 评估每条染色体所对应个体的适应度 升序排列适应度评估值,选出 前 parent_number 个 个体作为 待选 parent 种群(适应度函数的值越小越好) 从 待选 parent 种群 中随机选择 2 个个体作为父方和母方。 抽取父母双方的染色体,进行交叉,产生 2 个子代。 (交叉概率) 对子代(parent + 生成的 child)的染色体进行变异。 (变异概率) 重复3,4,5步骤,直到新种群(parentnumber + childnumber)的产生。 循环以上步骤直至找到满意的解。 名词解释 交叉概率:两个个体进行交配的概率。 例如,交配概率为0.8,则80%的“夫妻”会生育后代。 变异概率:所有的基因中发生变异的占总体的比例。 GA函数 适应度函数 适应度函数由解决的问题决定。 举一个平方和的例子。 简单的平方和问题 求函数的最小值,其中每个变量的取值区间都是 [-1, ...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值