您的位置:首页 > 新闻 > 资讯 > 网上机械加工厂_重庆好玩还是成都好玩_百度推广关键词技巧定价_浙江seo外包

网上机械加工厂_重庆好玩还是成都好玩_百度推广关键词技巧定价_浙江seo外包

2025/5/8 19:52:44 来源:https://blog.csdn.net/Mooczx/article/details/144288401  浏览:    关键词:网上机械加工厂_重庆好玩还是成都好玩_百度推广关键词技巧定价_浙江seo外包
网上机械加工厂_重庆好玩还是成都好玩_百度推广关键词技巧定价_浙江seo外包

数据:

# 线性回归
import torch
import numpy as np
import matplotlib.pyplot as plt# 随机种子,确保每次运行结果一致
torch.manual_seed(42)# 生成训练数据
X = torch.randn(100, 3)  # 100 个样本,每个样本 3 个特征
true_w = torch.tensor([2.0, 3.0, 4.5] )  # 假设真实权重
true_b = 4.0  # 偏置项
Y = X @ true_w + true_b + torch.randn(100) * 0.2  # 加入一些噪声# 打印部分数据
print(X[:5])
print(Y[:5])

模型:

import torch.nn as nn# 定义线性回归模型
class LinearRegressionModel(nn.Module):def __init__(self):super(LinearRegressionModel, self).__init__()# 定义一个线性层,输入为2个特征,输出为1个预测值self.linear = nn.Linear(3, 1)  # 输入维度2,输出维度1def forward(self, x):return self.linear(x)  # 前向传播,返回预测结果# 创建模型实例
model = LinearRegressionModel()# 损失函数(均方误差)
criterion = nn.MSELoss()# 优化器(使用 SGD 或 Adam)
optimizer = torch.optim.SGD(model.parameters(), lr=0.01)  # 学习率设置为0.01

训练:

# 训练模型
num_epochs = 1000  # 训练 1000 轮
for epoch in range(num_epochs):model.train()  # 设置模型为训练模式# 前向传播predictions = model(X)  # 模型输出预测值loss = criterion(predictions.squeeze(), Y)  # 计算损失(注意预测值需要压缩为1D)# 反向传播optimizer.zero_grad()  # 清空之前的梯度loss.backward()  # 计算梯度optimizer.step()  # 更新模型参数# 打印损失if (epoch + 1) % 100 == 0:print(f'Epoch [{epoch + 1}/1000], Loss: {loss.item():.4f}')# 查看训练后的权重和偏置
print(f'Predicted weight: {model.linear.weight.data.numpy()}')
print(f'Predicted bias: {model.linear.bias.data.numpy()}')# 在新数据上做预测
with torch.no_grad():  # 评估时不需要计算梯度predictions = model(X)# 可视化预测与实际值
plt.scatter(X[:, 0], Y, color='blue', label='True values')
plt.scatter(X[:, 0], predictions, color='red', label='Predictions')
plt.legend()
plt.show()

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com