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

医院网站备案流程网站常用字体

医院网站备案流程,网站常用字体,简单的做图网站,绍兴网站建设哪家好假设我们的基础模型就是y wx b,其中w和b均为参数,我们使用y 3x0.8来构造数据x、y,所以最后通过模型应该能够得出w和b应该分别接近3和0.8。 步骤如下: 准备数据计算预测值计算损失,把参数的梯度置为0,进行反向传播…

假设我们的基础模型就是y = wx + b,其中w和b均为参数,我们使用y = 3x+0.8来构造数据x、y,所以最后通过模型应该能够得出w和b应该分别接近3和0.8。

步骤如下:

  1. 准备数据
  2. 计算预测值
  3. 计算损失,把参数的梯度置为0,进行反向传播
  4. 更新参数

方式一

该方式没有用pytorch的模型api,手动实现

import torch,numpy
import matplotlib.pyplot as plt# 1、准备数据
learning_rate = 0.01
#y=3x + 0.8
x = torch.rand([500,1])
y_true= x*3 + 0.8# 2、通过模型计算y_predict
w = torch.rand([1,1],requires_grad=True)
b = torch.tensor(0,requires_grad=True,dtype=torch.float32)# 3、通过循环,反向传播,更新参数
for i in range(500):# 4、计算lossy_predict = torch.matmul(x,w) + bloss = (y_true-y_predict).pow(2).mean()# 每次循环判断是否存在梯度,防止累加if w.grad is not None:w.grad.data.zero_()if b.grad is not None:b.grad.data.zero_()# 反向传播loss.backward()w.data = w.data - learning_rate*w.gradb.data = b.data - learning_rate*b.grad# 每50次输出一下结果if i%50==0:print("w,b,loss",w.item(),b.item(),loss.item())#可视化显示
plt.figure(figsize=(20,8))
plt.scatter(x.numpy().reshape(-1),y_true.numpy().reshape(-1))
y_predict = torch.matmul(x,w) + b
plt.plot(x.numpy().reshape(-1),y_predict.detach().numpy().reshape(-1),c="r")
plt.show()

循环500次的效果
在这里插入图片描述
循环2000次的结果
在这里插入图片描述

方式二

方式一的方式虽然已经购简便了,但是还是有些许繁琐,所以我们可以采用pytorchapi来实现。
nn.Moduletorch.nn提供的一个类,是pytorch中我们自定义网络的一个基类,在这个类中定义了很多有用的方法,让我们在继承这个类定义网络的时候非常简单。
当我们自定义网络的时候,有两个方法需要特别注意:
1.__init__需要调用super方法,继承父类的属性和方法
2. forward方法必须实现,用来定义我们的网络的向前计算的过程用前面的y = wx+b的模型举例如下:

#定义模型
from torch import nn
class Lr(nn.Module): #继承nn.Moduledef __init__(self):super(Lr, self).__init__()self.linear = nn.Linear(1,1)def forward(self,x):out = self.linear(x)return out

全部代码如下:

#!/usr/bin/env python 
# -*- coding:utf-8 -*-
import torch
from torch import nn
from torch import optim
import numpy as np
from matplotlib import pyplot as plt#1、定义数据
x = torch.rand([50,1])
y = x*3 + 0.8#定义模型
class Lr(nn.Module): #继承nn.Moduledef __init__(self):super(Lr, self).__init__()self.linear = nn.Linear(1,1)def forward(self,x):out = self.linear(x)return out
#2、实例化模型、loss函数以及优化器
model = Lr()
criterion = nn.MSELoss()   #损失函数
optimizer = optim.SGD(model.parameters(),lr=1e-3) #优化器#3、训练模型
for i in range(3000):out = model(x)# 获取预测值loss = criterion(y,out) #计算损失optimizer.zero_grad() #梯度归零loss.backward() #计算梯度optimizer.step() #更新梯度if(i+1) % 20 ==0:print('Epoch[{}/{}],loss:{:.6f}'.format(i,500,loss.data))#4、模型评估
model.eval() #设置模型为评估模式,即预测模式
predict = model(x)
predict = predict.data.numpy()
plt.scatter(x.data.numpy(),y.data.numpy(),c="r")
plt.plot(x.data.numpy(),predict)
plt.show()

注意:

model.eval()表示设置模型为评估模式,即预测模式

model.train(mode=True) 表示设置模型为训练模式

在当前的线性回归中,上述并无区别

但是在其他的一些模型中,训练的参数和预测的参数会不相同,到时候就需要具体告诉程序我们是在进行训练还是预测,比如模型中存在DropoutBatchNorm的时候

循环2000次的结果:
在这里插入图片描述
循环30000次的结果:
在这里插入图片描述

http://www.yayakq.cn/news/810863/

相关文章:

  • 南京安居建设集团网站阿里wordpress怎么安装教程
  • 如何自己做网站挣钱城阳网站建设
  • 怎样看网站做的好不好南京公司网站建立
  • 代做财务报表分析网站百度优化推广
  • 贵州省建设厅审图网站logo制作方法
  • 四川建设网站官网免费无代码开发平台排行榜
  • 企业网站分析报告平面设计就业方向有哪些
  • 杭州市建设监理协会网站展厅施工公司
  • 网站建设及运营 经营范围除了WordPress等
  • 网络营销怎么做网站wordpress里的站点标题是什么意思
  • 如何让自己的网站被搜索引擎收录wordpress文章列表显示摘要
  • 合肥外贸网站建设全国文明城市创建标准
  • 合肥建网站公司旅游网站建设的相关报价
  • 东莞设计兼职网站建设廊坊建设银行网站
  • 学vue可以做pc网站企业网上登记注册平台
  • wordpress个人建站教程wordpress数据清除缓存
  • 网站做301根目录在哪里怎么验证网站
  • php网站开发招招聘net开发网页小程序
  • 网站首页被k 做跳转做影视网站需要的软件
  • 专业的培训行业网站制作沧州网站建设运营公司
  • 网站开发的需求分析论文网站制作五个界面
  • 达建网站防止爬虫的办法交互网站 百度
  • 游戏发卡中心网站源码深圳网站建设信科网络
  • 新手做哪类网站湖南省交通建设质量监督站网站
  • 如何介绍设计的网站模板下载地址网站数据库建设方案
  • 长沙正规网站制作公司php网页游戏源码
  • 怎么下载Wordpressseo网站诊断分析报告
  • 大数据 做网站流量统计电器网站建设流程
  • 网站更新后 为什么不显示专业的开发网站建设价格
  • net网站开发wordpress邮箱登录