p66实验题

news/2025/10/16 21:03:19/文章来源:https://www.cnblogs.com/dfvn/p/19146626

"""
CIFAR-10 图像分类简化版(使用 sklearn)
在安装 TensorFlow 之前可以先运行这个版本
"""

import numpy as np
import matplotlib.pyplot as plt
from sklearn.datasets import fetch_openml
from sklearn.model_selection import train_test_split
from sklearn.ensemble import RandomForestClassifier
from sklearn.metrics import accuracy_score, classification_report, confusion_matrix
import seaborn as sns

class SimpleCIFAR10:
def init(self):
self.class_names = ['airplane', 'automobile', 'bird', 'cat', 'deer',
'dog', 'frog', 'horse', 'ship', 'truck']
self.model = None

def load_and_preprocess_data(self):"""加载和预处理数据(使用 sklearn 的简化版本)"""print("正在加载数据...")# 由于 CIFAR-10 在 sklearn 中没有直接版本,我们使用 MNIST 作为示例# 在实际应用中,你需要安装 TensorFlow 来获取真正的 CIFAR-10 数据from sklearn.datasets import load_digits# 使用 digits 数据集作为示例digits = load_digits()X = digits.images.reshape((len(digits.images), -1))  # 展平图像y = digits.target# 只取前10类(如果有的话)if len(np.unique(y)) > 10:mask = y < 10X, y = X[mask], y[mask]# 分割数据集X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42, stratify=y)# 归一化X_train = X_train / 16.0  # 像素值范围 0-16X_test = X_test / 16.0print(f"训练集形状: {X_train.shape}")print(f"测试集形状: {X_test.shape}")print(f"类别数: {len(np.unique(y))}")return (X_train, y_train), (X_test, y_test)def build_and_train_model(self, X_train, y_train):"""构建和训练模型"""print("\n构建和训练模型...")# 使用随机森林作为示例self.model = RandomForestClassifier(n_estimators=100,max_depth=10,random_state=42)self.model.fit(X_train, y_train)print("模型训练完成!")return self.modeldef evaluate_model(self, X_test, y_test):"""评估模型"""print("\n评估模型...")y_pred = self.model.predict(X_test)accuracy = accuracy_score(y_test, y_pred)print(f"测试准确率: {accuracy:.4f} ({accuracy*100:.2f}%)")# 显示分类报告print("\n分类报告:")print(classification_report(y_test, y_pred))return accuracy, y_preddef visualize_results(self, X_test, y_test, y_pred, num_samples=12):"""可视化结果"""print("\n可视化结果...")# 重塑图像用于显示(如果是 8x8 的 digits 数据)if X_test.shape[1] == 64:  # 8x8 图像images = X_test.reshape(-1, 8, 8)else:print("无法可视化:不支持的图像形状")returnplt.figure(figsize=(15, 10))for i in range(min(num_samples, len(images))):plt.subplot(3, 4, i + 1)plt.imshow(images[i], cmap='gray')color = 'green' if y_pred[i] == y_test[i] else 'red'plt.title(f'预测: {y_pred[i]}\n真实: {y_test[i]}', color=color)plt.axis('off')plt.suptitle('分类结果 (绿色:正确, 红色:错误)', fontsize=16)plt.tight_layout()plt.show()# 绘制混淆矩阵cm = confusion_matrix(y_test, y_pred)plt.figure(figsize=(10, 8))sns.heatmap(cm, annot=True, fmt='d', cmap='Blues')plt.title('混淆矩阵')plt.xlabel('预测标签')plt.ylabel('真实标签')plt.show()

def main():
"""主函数"""
print("简化版图像分类示例")
print("=" * 50)
print("注意: 这是简化版本,使用 digits 数据集作为示例")
print("要运行完整的 CIFAR-10 分类,请先安装 TensorFlow")
print("=" * 50)

classifier = SimpleCIFAR10()try:# 1. 加载数据(X_train, y_train), (X_test, y_test) = classifier.load_and_preprocess_data()# 2. 训练模型classifier.build_and_train_model(X_train, y_train)# 3. 评估模型accuracy, y_pred = classifier.evaluate_model(X_test, y_test)# 4. 可视化结果classifier.visualize_results(X_test, y_test, y_pred)print(f"\n最终准确率: {accuracy:.4f} ({accuracy*100:.2f}%)")except Exception as e:print(f"运行过程中出现错误: {e}")

if name == "main":
main()
IMG_1921

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/938511.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20251016

10.16今天体育课体测,让我发现自己BMI指数居然是25.7,这令我非常不能接受。因此,我要开始为期两个半月的减脂,控制自己,打造健康强壮身体,于是我今天下午直接到操场跑步3公里,我感觉我现在状况非常好。未来我会…

C# - 串口助手

串口通信工具准备 (1)sscom5.13.1.exe: 串口调试工具 (2)VSPD: 是一种虚拟串口驱动程序,用于模拟和创建多个虚拟串口,以便在计算机间进行串口通信 VSPD 串口介绍Sent: 0 Bytes表示从该串口发送出去的数据字节数为…

虚拟线程的pinned问题终于被jdk25完美解决了

虚拟线程是一个非常有用的特征,但是JDK25以前,一直存在pinned问题,一些场景下会导致平台线程被占用无法释放。 比如下面的代码,在JDK 21下运行时,会卡住:import java.time.Duration; import java.util.concurren…

077_尚硅谷_单分支基本使用

077_尚硅谷_单分支基本使用1.单分支基本介绍2.例题判断是否18岁

【比赛记录】2025NOIP 冲刺模拟赛合集I

2025CSP-S模拟赛64A B C D Sum Rank50 0 0 - 50 7/7挂 155pts,挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂挂…

12 继承--instanceof和类型转换

12 继承--instanceof和类型转换多态 父类的引用指向子类的类型 Father f = new Son(); 而能执行的方法只看左边的类型. 父类可以指向子类,但不能调用子类独有的方法 如果非要调用,可以进行强制类型转换.注意事项:多态是…

C0214 拔树游戏 题解

C0214 拔树游戏 题解C0214 拔树游戏 题解 这道题挺有趣的。 不难发现每一次的拔树操作就是对一个根节点的所有子节点(只是下一层)取最小点权的那个节点取代本身。同时发现,因为每次取的节点都是最小的,所以在堆…

CSDN Markdown 编辑器快捷键大全 - 实践

CSDN Markdown 编辑器快捷键大全 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Mo…

P4168 [Violet] 蒲公英题解

P4168 [Violet] 蒲公英题解洛谷题目链接:[Violet] 蒲公英 一道分块好题,调了整整一上午一句话题意:在线求区间众数 考虑到众数没有可加性,所以一般数据结构是不好维护的,这个时候就要用分块了,分块可以维护一些数…

Java了解

Java了解了解Java Java的特性与优势 简单性、面向对象、可移植性、高性能、分布式 动态性(反射机制)、多线程、安全性、健壮性 Java的三大版本与有关工具 Java SE Java ME Java EEJDK:Java Development Kit(包含JRE)…

VGG使用块的网络

VGG使用块的网络 一.手写VGG架构import torch from torch import nn import d2l #1.VGG块 def VGG_block(nums_conv,in_chanels,out_chanels):#卷积层数,输入通道数,输出通道数layers=[]#一个VGG里面的层for i in ra…

使用SpringBoot + Thymeleaf + MyBatisPlus实现一个简单的书籍管理系统

一 系统功能设计 采用SpringBoot + Thymeleaf + MyBatisPlus技术栈实现一个简单的书籍管理系统,包含以下功能:书籍列表展示 书籍添加 书籍编辑 书籍删除 书籍查询(按条件筛选)二 数据库设计 SET NAMES utf8mb4; SE…

创业思路

创业思路ai p图, 人工后期校验, 人工p, 然后把图片给手机壳制作厂, 卖给提供照片的人. diy手机壳. 比如他本人的照片加风景, 比如巴黎铁塔

详细介绍:Java-Spring入门指南(十九)thymeleaf基本概念

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

P2605 [ZJOI2010] 基站选址

题目概述 题目链接:https://www.luogu.com.cn/problem/P2605。 有 \(n\) 个村庄,你需要建立不超过 \(k\) 个基站,每一户人家都有参数 \(d_i,s_i,w_i,c_i\) 分别表示距离第一户人家的距离、在不超过 \(s_i\) 的地方有…

NVIDIA Jetson AGX Xavier刷机教程

NVIDIA Jetson AGX Xavier刷机教程 @目录NVIDIA Jetson AGX Xavier刷机教程1.下载SdkManager2.安装SdkManager3.刷机 1.下载SdkManager 进入SdkManager官网下载SdkManager的deb版本 注意,ubuntu的24.04版本暂时不支持…

洛谷p1462-通往奥格瑞码道路

题目:https://www.luogu.com.cn/problem/P1462 思考过程: 刚拿到这个题,我把消耗的血量和路费当成了负权边去考虑,考虑到我们只需要考虑扣钱的最优,并且在血量扣尽之前达到就好,那我觉得可以用一个数组hp来代表实…

详细介绍:VR 太阳光参数与快速渲染

详细介绍:VR 太阳光参数与快速渲染pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco…

位运算中没用的小技巧

位运算那些没用的小技巧消去最后一位的1 x & (x - 1)交换两个数 a ^= b; b ^= a; a ^= b;检查一个数的奇偶 x & 1求x的绝对值 ~(x >> 31) ? a : ~a + 1取两个数的最大值 x ^ ((x ^ y) & -(x < y…