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

网站建设万户wordpress不显示中文图片不显示

网站建设万户,wordpress不显示中文图片不显示,山东省建设教育集团网站,百度网页制作网站建设目录 1.1深度学习介绍 1.2神经网络NN 1、概念#xff1a; 2、神经元 3、#xff08;单层#xff09;神经网络 4、感知机#xff08;两层#xff09; 5、多层神经网络 6、激活函数 #xff08;1#xff09;饱和与非饱和激活函数 #xff08;2#xff09;饱和激活…目录 1.1深度学习介绍 1.2神经网络NN 1、概念 2、神经元 3、单层神经网络 4、感知机两层 5、多层神经网络 6、激活函数 1饱和与非饱和激活函数 2饱和激活函数 ① Sigmoid激活函数 ② tanh激活函数 3非饱和激活函数 ① ⚠️ReLU激活函数 ② Leaky Relu激活函数 ③ ELU激活函数 1.3pytorch安装入门 1、pytorch安装 2、Tensor张量 3、张量的创建方法 4、张量的方法和属性 5、tensor的数据类型 6、tensor的其他操作 1tensor 和 tensor相加。 2tensor和数字操作 3CUDA中的tensor 1.4梯度下降和反向传播 1、梯度 2、梯度下降 3、常见的导数的计算 4、反向传播 5、使用Pytorch完成线性回归 6、手动实现线性回归。 7、nn.Module  1.1深度学习介绍 1、深度学习 机器学习的分支。人工神经网络为基础对数据的特征进行学习的方法。 2、机器学习和深度学习的区别 【特征抽取】 机器学习人工的特征抽取。深度学习自动的进行特征抽取。 【数据量】 机器学习数据少效果不是很好深度学习数据多效果更好 3、深度学习应用场景 图像识别物体识别、场景识别、人脸检测跟踪、人脸身份认证。自然语言处理技术机器翻译、文本识别、聊天对话。语音技术语音识别 4、深度学习框架pytorch 目前企业常见的深度学习框架有很多TensorFlow、Caffe2、Theano、Pytorch、Chainer、DyNet、MXNet等。 1.2神经网络NN 1、概念 又称为人工神经网络ANNArtificial Netural Network。简称神经网络NN或类神经网络。模拟生物的神经系统对函数进行估计或近似。 2、神经元 概念神经网络中的基础单元相互连接组成神经网络。 其中 ①a1、a2... an为各个输入的分量。 ②w1、w2...wn为各个输入分量对应的权重参数。 ③b为偏置 ④f为激活函数。常见的激活函数有tanh、sigmoid、relu ⑤t为神经元的输出。 使用数学公式表示      其中   表示W的转置 对公式的理解输出 激活函数( 权重*输入求和  偏置) 可见一个神经元的功能是求得输入向量与权向量的内积后经一个非线性传递函数得到一个标量结果。 3、单层神经网络 最简单的神经网络的形式。 4、感知机两层 两层的神经网络。简单的二分类的模型给定阈值判断数据属于哪一部分。 5、多层神经网络 输入层、输出层、隐藏层可以有多层每一层的神经元的个数可以不确定。 全连接层当前层和前一层每个神经元相互连接我们称当前这一层为全连接层。 即第N层和第N-1层中的神经元两两之间都有连接。 进行的是 y Wx b 6、激活函数 作用 增加模型的非线性分割能力。提高模型稳健性缓解梯度消失问题加速模型收敛等。 1饱和与非饱和激活函数 相对于饱和激活函数使用非饱和激活函数的优势在于 非饱和激活函数能解决深度神经网络层数非常多带来的梯度消失问题。使用非饱和激活函数能加快收敛速度。 2饱和激活函数 ① Sigmoid激活函数 数学表达式为 求导 结果输出值范围为0,1之间的实数。 ② tanh激活函数 数学表达式为 实际上Tanh函数是 sigmoid 的变形 tanh是“零为中心”的。 结果输出值范围为-1,1之间的实数。 3非饱和激活函数 ① ⚠️ReLU激活函数 数学表达式为 使用场景 ReLU解决了梯度消失的问题当输入值为正时神经元不会饱和由于ReLU线性、非饱和的性质在SGD中能够快速收敛计算复杂度低不需要进行指数运算 缺点 与Sigmoid一样其输出不是以0为中心的 ② Leaky Relu激活函数 数学表达式为 什么情况下适合使用Leaky ReLU 解决了ReLU输入值为负时神经元出现的死亡的问题Leaky ReLU线性、非饱和的性质在SGD中能够快速收敛计算复杂度低不需要进行指数运算 ③ ELU激活函数 数学表达式为 1.3pytorch安装入门 1、pytorch安装 2、Tensor张量 各种数值数据称为张量。 0阶张量常数 scaler 1阶张量向量vector 2阶张量矩阵matrix 3阶张量... 3、张量的创建方法 打开jupyter使用命令jupyter notebook 1使用python中的列表或者序列创建tensor 2使用numpy中的数组创建tensor 3使用torcch的api创建tensor ①torch.empty(3,4) 创建3行4列的空的tensor会用无用数据进行填充。 ②torch.ones(3,4) 创建3行4列的全为1 的tensor ③torch.zeros(3,4) 创建3行4列的全为0的tensor ④torch.rand(3,4) 创建3行4列的随机值的tensor随机值的区间是[0,1) ⑤torch.randint( low 0,high 10, size [3,4]) 创建3行4列的随机整数的tensor随机值的区间是[ low,high) ⑥torch.randn([3,4]) 创建3行4列的随机数的tensor ,随机值的分布均值为0方差为1 (这里的randn n表示normal) 4、张量的方法和属性 1获取tensor中的数据当tensor中只有一个元素可用tensor.item( ) 2转化为numpy数组 3获取形状tensor.size() tensor.size(0)  获取第一个维度的形状 4形状改变tensor.view((3,4)) 。类似numpy中的reshape是一种浅拷贝仅仅是形状发生改变。 5获取维数tensor.dim() 6获取最大值tensor.max() 7转置tensor.t()   二维 高维tensor.transpose(1,2)  将第一维度和第二维度交换、tensor.permute(0,2,1) 8获取tensor[1,3] 获取tensor中第一行第三列的值。行和列的索引都是从0开始 9tensor[1,3] 对tensor中第一行第散列的位置进行赋值。 10tensor切片 图片所示取了第一列。 5、tensor的数据类型 1获取tensor 的数据类型tensor.dtype 2创建数据的时候指定类型 3类型的修改 6、tensor的其他操作 1tensor 和 tensor相加。 x.add(y)  不会直接修改x的值。 x.add_(y) 会直接修改x的值。⚠️ 2tensor和数字操作 3CUDA中的tensor 通过.to 方法能够把一个tensor转移到另外一个设备比如从CPU转到GPU # 实例化device device torch.device(cuda if torch.cuda.is_available() else cpu)# 把tensor转化为CUDA支持的tensor或者cpu支持的tensor tensor.to(device) 1.4梯度下降和反向传播 1、梯度 概念梯度是一个向量导数变化最快的方向学习的前进方向 回顾下机器学习 ① 收集数据x构建机器学习模型f得到f(xw) Ypredict ②判断模型好坏的方法 loss (Ypredict - Ytrue)^2 回归损失 loss Ytrue · log(Yredict) (分类损失) ③目标通过调整学习参数w尽可能的降低loss。 2、梯度下降 算出梯度、 3、常见的导数的计算 链式法则、求偏导数、 4、反向传播 1前向传播将训练集数据输入到ANN的输入层经过隐藏层最后到达输出层并输出结果。【输入层—隐藏层–输出层】 2反向传播由于ANN的输入结果与输出结果有误差则计算估计值与实际值之间的误差并将该误差从输出层向隐藏层反向传播直至传播到输入层。【输出层–隐藏层–输入层】 3权重更新在反向传播的过程中根据误差调整各种参数的值不断迭代上述过程直至收敛。 5、使用Pytorch完成线性回归 1tensor(data, requires_grad True) ① 该tensor后续会被计算梯度、tensor所有的操作都会被记录在grade_in  ② 当requires_grad True时tensor.data 和 tensor不相同。否则得到是相同的结果。 2with torch.no_grad() 其中的操作不会被跟踪 3反向传播output.backward() 4获取某个参数的梯度x.grad   累加梯度每次反向传播之前需要先把梯度置为0之后。 6、手动实现线性回归。 假设基础模型ywxb 其中w和b均为参数我们使用y 3x0.8 来构造数据xy所以最后通过模型应该能够得出w和b应该分别接近3和0.8。 1准备数据2计算预测值 3计算损失把参数的梯度置为0进行反向传播4更新参数 import torch import matplotlib.pyplot as plt learning_rate 0.01 # 定义一个学习率# 1、准备数据y wx b y 3x 0.8x torch.rand([100, 1]) y_true x*3 0.8# 2、通过模型计算 y_project w torch.rand([1, 1], requires_gradTrue) b torch.tensor(0, requires_gradTrue, dtypetorch.float32)# 4、通过循环反向传播更新参数 for i in range(500):# 3、计算lossy_predict torch.matmul(x, w) bloss (y_true - y_predict).pow(2).mean() # 平方再均值if w.grad is not None: # 将梯度置为0w.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.gradprint(fw:{w.item()},b:{b.item()},loss:{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().reshape(-1), cr) plt.show()7、nn.Module  nn.Module 是torch.nn提供的一个类是pytorch 中我们自定义网络的一个基类在这个类中定义了很多有用的方法让我们在继承这个类定义网络的时候非常简单。
http://www.tj-hxxt.cn/news/138723.html

相关文章:

  • 大美南京网站软件开发服务税率
  • 网站建设建设报价网站建设 流程
  • 做大型网站费用深圳做网站的公司哪个好
  • php旅游网站开发小结珠海网站专业制作
  • 网站登录模板下载建网站 外贸
  • 第一ppt网站苏州网站营销公司
  • 二级域名网站可以做关键词优化吗网站制作公司网站建设
  • 建筑网站上海设计制造有限公司
  • linux ctlscript.sh wordpress广州全面优化各项防控措施
  • 做响应式网站字体需要响应么站长论坛 激活网站
  • 吉林做网站优化深圳建站费用
  • 网站设计展示优化关键词排名
  • 北京创意网站设计城乡住房和城乡建设部网站
  • 网站设计制作从哪wordpress 缓存 收录
  • 免费公司网站互联网公司名称
  • 东莞东城做网站公司潍坊网站建设服务商
  • 网站诊断案例wordpress 存储插件
  • 手机网站建设免费空间蒙文网站开发
  • 网站建设品牌排行榜在线头像制作免费软件
  • 网站经营性质wordpress seo免费主题
  • 响应式视频网站模板oneinstack wordpress
  • 网站建设毕业设计中期进度报告微信推送用哪个网站做
  • 中国大型网站免费设计室内装修app软件
  • 建立新网站要多少钱网站建设销售求职
  • 佛山响应式网站宁波seo网络推广软件系统
  • 中小企业网站seo网站开发 app
  • 做网站的创始人免费建自己域名的网站吗
  • 河南城市建设招标类网站网页设计
  • 百度云在线登录苏州百度关键词优化
  • 各省网站备案时长成都房建设部网站