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

校园网站建设先进企业网站建设费用账务处理

校园网站建设先进,企业网站建设费用账务处理,上海企业建站提供商,网络营销课程总结与心得体会假设我们的基础模型就是y wx b,其中w和b均为参数#xff0c;我们使用y 3x0.8来构造数据x、y#xff0c;所以最后通过模型应该能够得出w和b应该分别接近3和0.8。 步骤如下#xff1a; 准备数据计算预测值计算损失#xff0c;把参数的梯度置为0#xff0c;进行反向传播…假设我们的基础模型就是y wx b,其中w和b均为参数我们使用y 3x0.8来构造数据x、y所以最后通过模型应该能够得出w和b应该分别接近3和0.8。 步骤如下 准备数据计算预测值计算损失把参数的梯度置为0进行反向传播更新参数 方式一 该方式没有用pytorch的模型api手动实现 import torch,numpy import matplotlib.pyplot as plt# 1、准备数据 learning_rate 0.01 #y3x 0.8 x torch.rand([500,1]) y_true x*3 0.8# 2、通过模型计算y_predict w torch.rand([1,1],requires_gradTrue) b torch.tensor(0,requires_gradTrue,dtypetorch.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%500: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),cr) plt.show() 循环500次的效果 循环2000次的结果 方式二 方式一的方式虽然已经购简便了但是还是有些许繁琐所以我们可以采用pytorch的api来实现。 nn.Module是torch.nn提供的一个类,是pytorch中我们自定义网络的一个基类在这个类中定义了很多有用的方法让我们在继承这个类定义网络的时候非常简单。 当我们自定义网络的时候有两个方法需要特别注意: 1.__init__需要调用super方法继承父类的属性和方法 2. forward方法必须实现用来定义我们的网络的向前计算的过程用前面的y wxb的模型举例如下: #定义模型 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(),lr1e-3) #优化器#3、训练模型 for i in range(3000):out model(x)# 获取预测值loss criterion(y,out) #计算损失optimizer.zero_grad() #梯度归零loss.backward() #计算梯度optimizer.step() #更新梯度if(i1) % 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(),cr) plt.plot(x.data.numpy(),predict) plt.show() 注意 model.eval()表示设置模型为评估模式即预测模式 model.train(modeTrue) 表示设置模型为训练模式 在当前的线性回归中上述并无区别 但是在其他的一些模型中训练的参数和预测的参数会不相同到时候就需要具体告诉程序我们是在进行训练还是预测比如模型中存在DropoutBatchNorm的时候 循环2000次的结果 循环30000次的结果
http://www.dnsts.com.cn/news/56049.html

相关文章:

  • 全球最大购物网站建筑工程类人才招聘
  • 学雷锋 做美德少年网站上海旅游景点
  • 返利网站建设哪个公司好绿蜻蜓建设管理有限公司网站
  • 海洋cms做电影网站好做吗用.net做网站中含有论坛
  • 上海建设工程信息网站网站添加邮件发送怎么做
  • 网站首页栏目怎么做萧山网页设计
  • 服务器主机管理系统建好后如何用它搭建网站刚做的网站怎么
  • 现在做个网站要多少钱网站开发 c
  • 深圳坪山住房和建设局网站机械加工信息
  • 价格划算的常州做网站电脑全自动挂机赚钱
  • 网站建站建设公司平面设计师务所
  • 网站短期就业培训班网站的二级菜单怎么做
  • 重庆网站制作合作商做淘客网站 名字
  • 网站开发需要什么上海网站seo设计
  • 展开网站建设西安网站推广招聘网
  • 自助外贸网站建设网站建设企业需要准备资料
  • 网站宣传片的创意基层建设 官方网站
  • 做网站找哪家好要钱吗企业年金如何查询
  • 长春网站建设平台自己制作的网站如何发布
  • 移动端网站建设的好处电器工程东莞网站建设
  • 营口建设工程质量监督站网站有网站公司源码可以重建网站吗
  • 如何做网站推广下拉刘贺稳14国外优秀的网站设计
  • 建设银行网站查询密码是什么c网站制作
  • 第一免费营销型网站用自己的名字设计头像
  • 别人是怎么建设网站的十大技能培训机构排名
  • 闽侯县住房和城乡建设局官方网站住房和城乡建设部政务服务门户
  • 票据理财网站建设长春火车站有几个
  • 网站建设陆金手指谷哥7导航网站前端模板下载
  • 快刷网站怎么自己免费创建网站
  • 网站服务器租赁需要什么手续编程代码