当前位置: 首页 > news >正文

家装企业网站系统下载wordpress4.0伪静态

家装企业网站系统下载,wordpress4.0伪静态,嵊州哪里可以做网站,网站建设课程思政作者简介 杜嘉宝#xff0c;男#xff0c;西安工程大学电子信息学院#xff0c;2024级研究生 研究方向#xff1a;变压器故障预警与检测 电子邮件#xff1a;djb857497378gmail.com 王子谦#xff0c;男#xff0c;西安工程大学电子信息学院#xff0c;2024级研究生男西安工程大学电子信息学院2024级研究生 研究方向变压器故障预警与检测 电子邮件djb857497378gmail.com 王子谦男西安工程大学电子信息学院2024级研究生张宏伟人工智能课题组 研究方向机器视觉与人工智能 电子邮件1523018430qq.com 在这篇文章中我将分享如何使用支持向量机SVM算法对心脏病数据进行分类。整个流程包括数据加载、预处理、SMOTE过采样、PCA降维、超参数调优、灰狼优化算法的使用等。通过这篇文章希望你能够了解如何通过集成不同技术实现更好的分类效果。 1. 安装包的准备 首先你需要安装必要的Python库。以下是一些主要的库 pip install numpy pandas scikit-learn imbalanced-learn matplotlib 这些库提供了SVM、SMOTE过采样、PCA降维以及其他常用的数据处理工具。 2. 数据集介绍 本次我们使用的是UCI心脏病数据集包含多种与心脏病相关的特征如年龄、性别、血压、胆固醇水平等。数据集中的目标变量target有五个不同的类别表示不同程度的心脏病。 通过加载数据我们将其分为特征集X和目标值y并进行清洗将?替换为0。 url https://archive.ics.uci.edu/ml/machine-learning-databases/heart-disease/processed.cleveland.data columns [age, sex, cp, trestbps, chol, fbs, restecg, thalach, exang, oldpeak, slope, ca, thal, target] features, target load_data(url, columns)3. SVM算法介绍 支持向量机SVM是一种强大的分类算法尤其适合处理高维数据。它的目标是寻找一个超平面将不同类别的样本分开并且最大化类别之间的间隔。在这篇文章中我们使用SVC支持向量分类来实现心脏病数据的分类。 from sklearn.svm import SVC svm_clf SVC(kernelrbf, C1.0, gamma0.1) svm_clf.fit(X_train, y_train)4. SMOTE算法介绍 在心脏病数据集中类别不平衡问题较为严重。为了解决这个问题我们使用了SMOTESynthetic Minority Over-sampling Technique算法通过生成合成样本来平衡各个类别。 from imblearn.over_sampling import SMOTE X_resampled, y_resampled smote(X_train, y_train, sampling_strategy{2: 55, 3: 55, 4: 55})5. GridSearch算法 为了寻找SVM模型的最佳超参数我们使用了GridSearchCV进行超参数搜索。通过在不同的C和gamma值之间进行网格搜索找出最优的组合。 from sklearn.model_selection import GridSearchCV gridsearch(X_train, y_train, X_test, y_test)6. PCA算法介绍 主成分分析PCA是降维的常用方法可以在保留数据大部分信息的情况下减少数据的维度。在本次任务中我们使用PCA将数据维度降到95%的信息量。 from sklearn.decomposition import PCA X_train pca.fit_transform(X_train) X_test pca.transform(X_test)7. 灰狼优化算法介绍 灰狼优化算法Grey Wolf Optimizer, GWO是一种模拟灰狼捕猎行为的优化算法。在这里我们使用灰狼优化算法来寻找SVM模型的最佳超参数C和gamma。 def grey_wolf_optimizer(...):# 代码实现见下文return alpha_pos, alpha_score灰狼优化算法通过模拟灰狼群体的领导行为帮助我们在搜索空间中找到最优解。 8. 实现流程 8.1 数据加载与预处理 首先加载数据集并进行数据清洗。然后使用SMOTE算法处理类别不平衡问题。 (X_train, X_test, y_train, y_test) train_test_split(features, target, test_size0.3, random_state1, stratifytarget) X_train, y_train smote(X_train, y_train, sampling_strategy{2: 38, 3: 38, 4: 38})8.2 数据标准化与PCA降维 使用StandardScaler对数据进行标准化处理并使用PCA降维。 X_train, X_test scaler(X_train, X_test) pca PCA(n_components0.95) X_train pca.fit_transform(X_train) X_test pca.transform(X_test)8.3 模型训练与优化 使用SVM进行训练并通过灰狼优化算法调整超参数。 print(grey_wolf_optimizer(0, 100, 10000, 100, 2, X_train, y_train, X_test, y_test))8.4 可视化 使用Matplotlib进行数据可视化展示PCA降维后的数据分布。 fig plt.figure(figsize(8, 6)) ax fig.add_subplot(111, projection3d) ax.scatter(X_train[:, 0], X_train[:, 1], X_train[:, 2], cy_train, cmapviridis, alpha0.7)9. 源代码 Utils.py import numpy as np from sklearn.svm import SVC from sklearn.preprocessing import StandardScaler from sklearn.model_selection import GridSearchCV from sklearn.decomposition import PCAdef scaler(x_train, x_test):standard_transform StandardScaler()return standard_transform.fit_transform(x_train), standard_transform.fit_transform(x_test)def gridsearch(x_train, y_train, x_test, y_test):C np.linspace(0,100,100)gamma np.linspace(0,100,100)param_grid {C : C,gamma:gamma,kernel:[rbf,poly]}svm_clf SVC()grid_search GridSearchCV(estimatorsvm_clf,param_gridparam_grid,n_jobs-1,cv5,scoringaccuracy)grid_search.fit(x_train,y_train)print(网格中最优参数,grid_search.best_params_)print(测试集的准确率,grid_search.score(x_test,y_test))def apply_pca(data, n_components):# 标准化数据使其均值为0方差为1pca_scaler StandardScaler()scaled_data pca_scaler.fit_transform(data)# 进行 PCA 降维pca PCA(n_componentsn_components)reduced_data pca.fit_transform(scaled_data)# 获取解释方差比例explained_variance pca.explained_variance_ratio_return reduced_data, explained_variancedef grey_wolf_optimizer(lb, ub, n_wolves, max_iter, dim, x_train, y_train, x_test, y_test):# 定义目标函数def objective_function(C, gamma):clf SVC(kernelrbf, CC, gammagamma, random_state1)clf.fit(x_train, y_train)return 1 - clf.score(x_test, y_test)# 初始化狼群wolves np.random.uniform(lb, ub, (n_wolves, dim))# 初始化 alpha、beta、delta 位置及适应度值alpha_pos np.zeros(dim)alpha_score float(inf)beta_pos np.zeros(dim)beta_score float(inf)delta_pos np.zeros(dim)delta_score float(inf)# 迭代优化for t in range(max_iter):# 计算当前狼群的适应度for i in range(n_wolves):wolves[i, :] np.clip(wolves[i, :], lb, ub) # 约束搜索范围C max(float(wolves[i, 0]), 1e-3)gamma max(float(wolves[i, 1]),1e-3)fitness objective_function(C, gamma)# 更新 alpha、beta、deltaif fitness alpha_score:delta_score, delta_pos beta_score, beta_pos.copy()beta_score, beta_pos alpha_score, alpha_pos.copy()alpha_score, alpha_pos fitness, wolves[i, :].copy()elif fitness beta_score:delta_score, delta_pos beta_score, beta_pos.copy()beta_score, beta_pos fitness, wolves[i, :].copy()elif fitness delta_score:delta_score, delta_pos fitness, wolves[i, :].copy()# 计算系数 aa 2 - t * (2 / max_iter)# 更新狼群位置for i in range(n_wolves):r1, r2 np.random.rand(dim), np.random.rand(dim)A1 2 * a * r1 - aC1 2 * r2D_alpha abs(C1 * alpha_pos - wolves[i, :])X1 alpha_pos - A1 * D_alphar1, r2 np.random.rand(dim), np.random.rand(dim)A2 2 * a * r1 - aC2 2 * r2D_beta abs(C2 * beta_pos - wolves[i, :])X2 beta_pos - A2 * D_betar1, r2 np.random.rand(dim), np.random.rand(dim)A3 2 * a * r1 - aC3 2 * r2D_delta abs(C3 * delta_pos - wolves[i, :])X3 delta_pos - A3 * D_delta# 计算新位置wolves[i, :] (X1 X2 X3) / 3print(fIteration {t1}: Best C{alpha_pos[0]}, Best gamma{alpha_pos[1]}, Best fitness{1-alpha_score})return alpha_pos, alpha_score load_data.pyimport pandas as pd import numpy as np from imblearn.over_sampling import SMOTEdef load_data(url, columns):# 读取数据df pd.read_csv(url, namescolumns)df_cleaned df.replace(?, 0)X df_cleaned.iloc[:, :-1] # 特征y df_cleaned.iloc[:, -1] # 目标值return X, ydef smote(x, y, sampling_strategy, random_state1, k_neighbors1):smote SMOTE(random_staterandom_state, sampling_strategysampling_strategy, k_neighborsk_neighbors)x_resampled, y_resampled smote.fit_resample(x, y)return x_resampled, y_resampledif __name__ __main__:url https://archive.ics.uci.edu/ml/machine-learning-databases/heart-disease/processed.cleveland.datacolumns [age, sex, cp, trestbps, chol, fbs, restecg, thalach,exang, oldpeak, slope, ca, thal, target]features, target load_data(url, columns)labels, count np.unique(target, return_countsTrue)print(labels, labels, , count:, count)sampling_strategy {2: 55, 3: 55, 4: 55}smote SMOTE(random_state42, sampling_strategysampling_strategy, k_neighbors1)features_resampled, target_resampled smote.fit_resample(features, target)labels, count np.unique(target_resampled, return_countsTrue) print(labels, labels, , count:, count)train.py from sklearn.model_selection import train_test_split from load_data import load_data, smote from utils import scaler, gridsearch,grey_wolf_optimizer import numpy as np import matplotlib.pyplot as plt from sklearn.decomposition import PCAurl https://archive.ics.uci.edu/ml/machine-learning-databases/heart-disease/processed.cleveland.data columns [age, sex, cp, trestbps, chol, fbs, restecg, thalach, exang, oldpeak, slope, ca, thal, target] features, target load_data(url, columns) (X_train,X_test,y_train,y_test) train_test_split(features, target,test_size0.3,random_state1,stratifytarget) labels, count np.unique(y_train, return_countsTrue) print(labels, labels, , count:, count) sampling_strategy {2: 38, 3: 38, 4: 38} X_train, y_train smote(X_train, y_train,sampling_strategy) labels, count np.unique(y_train, return_countsTrue) print(labels, labels, , count:, count) X_train, X_test scaler(X_train,X_test) pca PCA(n_components0.95) X_train pca.fit_transform(X_train) X_test pca.transform(X_test) fig plt.figure(figsize(8, 6)) ax fig.add_subplot(111, projection3d) ax.scatter(X_train[:, 0], X_train[:, 1], X_train[:, 2], cy_train, cmapviridis, alpha0.7)ax.set_xlabel(Principal Component 1) ax.set_ylabel(Principal Component 2) ax.set_zlabel(Principal Component 3) ax.set_title(PCA 3D Scatter Plot) plt.show() print(grey_wolf_optimizer(0,100,10000,100,2,X_train,y_train,X_test,y_test))
http://www.pierceye.com/news/831546/

相关文章:

  • 辽阳专业建设网站公司网站html动态效果代码
  • 微信上可以做网站吗网页设计作业讲解
  • 长春好的做网站公司潍坊 网站
  • 做网站自己装服务器谷歌排名规则
  • 58.搜房等网站怎么做效果才好商贸公司企业简介模板
  • 中国最早做网站是谁卖网站怎样做
  • 张店专业网站优化哪家好书画工作室网站模板网站建设
  • 兰州网站制作怎么样青海哪家做网站的公司最大
  • 云龙湖旅游景区网站建设招标网站升级改版需要几天
  • 高端大气网络设计建设公司网站织梦模板沈阳模板建站哪家好
  • 郑州哪有做网站的高端网站建设与制作
  • 江阴网站网站建设蓝色 宽屏 网站 模板下载
  • 网站建设设计大作业重庆公共信息交易资源网
  • 做公司网站的多少钱公司建网站价格
  • 河间米各庄网站建设制作网站页面模板 建设中
  • wordpress首页添加站点统计小工具住房城乡建设部门门户网站
  • 网站建设在哪块做创业园网站建设
  • 郑州搭建网站公司互联网公司网站建设的目的
  • 响应式视频网站什么是权重高的网站
  • 做教育网站挣钱我的网站域名是什么
  • django 网站开发实例哪里可以检测胎儿性别
  • 刷排名凡搜网站宝微信5000人接推广费用
  • 网站优化外包服务专业网站建设服务商
  • 江西企业网站建设费用wordpress正在执行例行维护_请一分钟后回来.
  • 苏宁推客如何做网站创建一个网站的步骤
  • 优化网站广告优化东莞美食网站建设报价
  • 单页网站的营销定制应用软件有哪些
  • 如何建立一个网站详细步骤品牌建设可以从哪方面入手
  • 杨浦做网站福州网站公司
  • 厦门网站建设工程汽车网站正在建设中模板