news 2026/6/23 9:23:19

DAY38模型可视化与推理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
DAY38模型可视化与推理
import torch import torch.nn as nn import torch.optim as optim from sklearn.datasets import load_iris from sklearn.model_selection import train_test_split from sklearn.preprocessing import MinMaxScaler import time import matplotlib.pyplot as plt # 设置GPU设备 device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu") print(f"使用设备: {device}") # 加载鸢尾花数据集 iris = load_iris() X = iris.data # 特征数据 y = iris.target # 标签数据 # 划分训练集和测试集 X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42) # 归一化数据 scaler = MinMaxScaler() X_train = scaler.fit_transform(X_train) X_test = scaler.transform(X_test) # 将数据转换为PyTorch张量并移至GPU X_train = torch.FloatTensor(X_train).to(device) y_train = torch.LongTensor(y_train).to(device) X_test = torch.FloatTensor(X_test).to(device) y_test = torch.LongTensor(y_test).to(device) class MLP(nn.Module): def __init__(self): super(MLP, self).__init__() self.fc1 = nn.Linear(4, 10) # 输入层到隐藏层 self.relu = nn.ReLU() self.fc2 = nn.Linear(10, 3) # 隐藏层到输出层 def forward(self, x): out = self.fc1(x) out = self.relu(out) out = self.fc2(out) return out # 实例化模型并移至GPU model = MLP().to(device) # 分类问题使用交叉熵损失函数 criterion = nn.CrossEntropyLoss() # 使用随机梯度下降优化器 optimizer = optim.SGD(model.parameters(), lr=0.01) # 训练模型 num_epochs = 20000 # 训练的轮数 # 用于存储每100个epoch的损失值和对应的epoch数 losses = [] start_time = time.time() # 记录开始时间 for epoch in range(num_epochs): # 前向传播 outputs = model(X_train) # 隐式调用forward函数 loss = criterion(outputs, y_train) # 反向传播和优化 optimizer.zero_grad() #梯度清零,因为PyTorch会累积梯度,所以每次迭代需要清零,梯度累计是那种小的bitchsize模拟大的bitchsize loss.backward() # 反向传播计算梯度 optimizer.step() # 更新参数 # 记录损失值 if (epoch + 1) % 200 == 0: losses.append(loss.item()) # item()方法返回一个Python数值,loss是一个标量张量 print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item():.4f}') # 打印训练信息 if (epoch + 1) % 100 == 0: # range是从0开始,所以epoch+1是从当前epoch开始,每100个epoch打印一次 print(f'Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item():.4f}') time_all = time.time() - start_time # 计算训练时间 print(f'Training time: {time_all:.2f} seconds') # 可视化损失曲线 plt.plot(range(len(losses)), losses) plt.xlabel('Epoch') plt.ylabel('Loss') plt.title('Training Loss over Epochs') plt.show()

@浙大疏锦行

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 23:33:35

重构智慧书-第18条:实力与实干

一、原文呈现实力与实干要得声名显赫,必须兼有实力与实干精神。有了这两者,显赫的声名就会如虎添翼。有实干精神的平庸之辈比无实千精神的高明之辈更有成就。实干创实绩。肯出大力者必得大名。有的人连最简单的事情也不肯下力去干。干与不干,差不多总与一…

作者头像 李华
网站建设 2026/6/23 3:21:12

读捍卫隐私08智能出行

1. 互联网电话 1.1. 和打印机一样,VoIP电话的系统更新也可以被伪造和接受 1.2. 大多数VoIP电话都有一个免提选项,让你可以在你的隔间或办公室中将某人的通话用扬声器播放 1.2.1. 意味着在电话听筒之外不仅有一个扬声器,还有一个麦克风 1.…

作者头像 李华
网站建设 2026/6/23 19:33:05

媒体专访实录:LobeChat创始人谈开源初心

LobeChat 技术架构深度解析:从容器化部署到插件生态的全栈实践 在大模型浪潮席卷全球的今天,AI 对话系统早已不再是实验室里的概念玩具。从客服机器人到个人助手,自然语言交互正成为数字世界的新入口。然而,当 OpenAI 的 ChatGPT …

作者头像 李华
网站建设 2026/6/23 10:00:25

小喵播放器 1.1.2| 一款支持视频超分的播放器,支持网页视频以及B站番剧

小喵播放器是一款基于mpv播放器内核的本地视频播放器,专为动漫观看场景进行优化。它集成了Anime4K实时超分辨率算法,在播放过程中对低分辨率动画进行画质增强。支持常见视频格式、字幕与音轨切换、播放记录、截图等基础播放器功能,并通过GLSL…

作者头像 李华
网站建设 2026/6/23 19:31:02

LobeChat待办事项提取与提醒功能实现

LobeChat待办事项提取与提醒功能实现 在日常使用聊天工具时,我们常常会随口说一句:“记得提醒我明天开会”或者“下周要交报告”。这些话听起来像是对 AI 的一次普通请求,但如果说完就忘,那它不过是一段被淹没在对话流中的信息碎…

作者头像 李华
网站建设 2026/6/20 18:20:28

LobeChat会话管理机制揭秘:让每一次对话都井然有序

LobeChat会话管理机制揭秘:让每一次对话都井然有序 在今天,AI 对话不再是简单的“你问我答”,而是逐渐演变为一种持续、多线程、跨场景的认知协作。无论是开发者调试模型输出,产品经理反复打磨提示词,还是研究人员横向…

作者头像 李华