[python] 深度学习基础------人工神经网络实现鸢尾花分类(二)

简介: [python] 深度学习基础------人工神经网络实现鸢尾花分类(二)

具体实现过程:



定义特征和标签


image.png


我们看一下具体的实现过程,用神经网络实现鸢尾花的分类,输入数据是1行4列的数据,通过一个神经网络,输出是每一个种类的可能性大小,这个神经网络里的每一个具有计算功能的粉色小球,就是一个神经元


介绍MP模型


image.png

1943年,英国 物理学家麦卡洛克 和 数学家皮茨 这两个人就给出了神经元的计算模型,称之为MP模型,MP模型是每一个输入特征乘以线上的权重,求和,再通过一个非线性函数输出。


为了求解简单我们暂时去掉非线性函数,把MP模型简化为这个样子,就是所有的输入x乘以各自线上的权重w,求和,加上偏置项b,输入y。


image.png


可以写成这样一个式子,y = x*w+b


输出y是一行三列的                                x是输入特征  一行四列的  


w是权重 是四行三列的                           b是3个偏置项(可以自定义参数的)


针对我们鸢尾花的例子,x是输入特征,w是权重,b是三个偏置项,y就是三种鸢尾花各自的可能性大小。


用神经网络实现鸢尾花分类:搭建网络


image.png


输入是四个特征,所以这里是四个输入节点,输出是三种鸢尾花各自可能性大小,所以这里是三个输出节点


中间连线有4行3列,一共12个线上的权重w,每个神经元还有一个偏置项b,于是我们就搭建出了这样一个神经网络结构


左右都有连接关系我们称之为全连接网络


有了网络结构,线上的权重w和偏置b会被随机初始化为一些随机数,


用神经网络实现鸢尾花分类:喂入数据


image.png


喂入一组数据  5.8 4.0 1.2 0.2和他们对应的标签    标签: 0狗尾草鸢尾  


用神经网络实现鸢尾花分类:前向传播


image.png


神经网络执行前向传播,x*w+b代入数据,计算出y,这个过程就叫做前向传播


用神经网络实现鸢尾花分类:损失函数


我们通过输出y可以看出,数据最大的也就是可能性最高的是1 , 而不是标签0 (喂入数据特征对应的是标签0)


这是因为最初的参数W和B都是随机产生的,现在输出的结果就是蒙的,


我们用损失函数定义预测值 y 和标准答案也就是标签 y' 的差距,损失函数可以定量的判断当前这组参数W和B的优劣,


从而让我们得到最优的W和B的值,因为损失函数表达的是预测值与标准答案之间的差距,


当损失函数最小值,参数W和B就会出现最优值。


损失函数的定义有很多种方法,均方误差就是一种常用的损失函数,它计算每个前向传播输出y和标准答案 y' 的差,求平方,在求和,再除以n取平均值。


image.png


表征了网络前向传播推理(结果)和标准答案之间的差距


用神经网络实现鸢尾花分类:梯度下降


我们的目的是要寻找一组参数W和B使得损失函数最小


损失函数的梯度:表示损失函数对各参数求偏导后的向量,损失函数梯度下降方向是函数减小方向


梯度下降就是沿着损失函数梯度下降的方向,寻找损失函数的最小值,得到最优参数的方法


学习率(learning rate,lr):当学习率设置的过小时,收敛过程将变得十  分缓慢。而当学习率设置的过大时,梯度可能会在最小值附近来回震荡,  甚至可能无法收敛。


image.png


这个公式给出了梯度下降法更新参数的计算,其中 lr 是学习率,是梯度下降的速度,是一个超参数,如果学习率设置过小,参数更新会很慢,如果学习率设置过大,参数更新会跳过最小值,这个公式很重要  需要记住


用神经网络实现鸢尾花分类:反向传播


反向传播:从后向前,逐层求损失函数对每层神经元参数  的偏导数,迭代更新所有参数。


image.png


image.png


我们用这个公式体会一下反向传播参数更新的过程,假设损失函数是 W+1 的平方,损失函数对参数w的偏导是 2W+2 , 参数w在初始化的时候被随机初始化为 5 , 学习率是个超参数  我们设置为 0.2 ;


我们画出损失函数 W+1 的平方图像,优化参数W就是要找到某个w,使损失函数的梯度减少,从图上我们可以直观的看到,损失函数最小点应该在这个位置,也就是-1 , 损失函数loss的值最小,


我们优化参数的目的就是为了找到损失函数loss值最小

目录
打赏
0
0
0
0
17
分享
相关文章
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
262 5
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
PyTorch生态系统中的连续深度学习:使用Torchdyn实现连续时间神经网络
神经常微分方程(Neural ODEs)是深度学习领域的创新模型,将神经网络的离散变换扩展为连续时间动力系统。本文基于Torchdyn库介绍Neural ODE的实现与训练方法,涵盖数据集构建、模型构建、基于PyTorch Lightning的训练及实验结果可视化等内容。Torchdyn支持多种数值求解算法和高级特性,适用于生成模型、时间序列分析等领域。
209 77
PyTorch生态系统中的连续深度学习:使用Torchdyn实现连续时间神经网络
基于MobileNet深度学习网络的MQAM调制类型识别matlab仿真
本项目基于Matlab2022a实现MQAM调制类型识别,使用MobileNet深度学习网络。完整程序运行效果无水印,核心代码含详细中文注释和操作视频。MQAM调制在无线通信中至关重要,MobileNet以其轻量化、高效性适合资源受限环境。通过数据预处理、网络训练与优化,确保高识别准确率并降低计算复杂度,为频谱监测、信号解调等提供支持。
基于Python深度学习的【害虫识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
害虫识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了12种常见的害虫种类数据集【"蚂蚁(ants)", "蜜蜂(bees)", "甲虫(beetle)", "毛虫(catterpillar)", "蚯蚓(earthworms)", "蜚蠊(earwig)", "蚱蜢(grasshopper)", "飞蛾(moth)", "鼻涕虫(slug)", "蜗牛(snail)", "黄蜂(wasp)", "象鼻虫(weevil)"】 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Djan
84 1
基于Python深度学习的【害虫识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
基于MobileNet深度学习网络的活体人脸识别检测算法matlab仿真
本内容主要介绍一种基于MobileNet深度学习网络的活体人脸识别检测技术及MQAM调制类型识别方法。完整程序运行效果无水印,需使用Matlab2022a版本。核心代码包含详细中文注释与操作视频。理论概述中提到,传统人脸识别易受非活体攻击影响,而MobileNet通过轻量化的深度可分离卷积结构,在保证准确性的同时提升检测效率。活体人脸与非活体在纹理和光照上存在显著差异,MobileNet可有效提取人脸高级特征,为无线通信领域提供先进的调制类型识别方案。
基于Python深度学习的【蘑菇识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
蘑菇识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了9种常见的蘑菇种类数据集【"香菇(Agaricus)", "毒鹅膏菌(Amanita)", "牛肝菌(Boletus)", "网状菌(Cortinarius)", "毒镰孢(Entoloma)", "湿孢菌(Hygrocybe)", "乳菇(Lactarius)", "红菇(Russula)", "松茸(Suillus)"】 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,
124 11
基于Python深度学习的【蘑菇识别】系统~卷积神经网络+TensorFlow+图像识别+人工智能
Python 高级编程与实战:深入理解网络编程与异步IO
在前几篇文章中,我们探讨了 Python 的基础语法、面向对象编程、函数式编程、元编程、性能优化、调试技巧、数据科学、机器学习、Web 开发和 API 设计。本文将深入探讨 Python 在网络编程和异步IO中的应用,并通过实战项目帮助你掌握这些技术。
利用Python脚本自动备份网络设备配置
通过本文的介绍,我们了解了如何利用Python脚本自动备份网络设备配置。该脚本使用 `paramiko`库通过SSH连接到设备,获取并保存配置文件。通过定时任务调度,可以实现定期自动备份,确保网络设备配置的安全和可用。希望这些内容能够帮助你在实际工作中实现网络设备的自动化备份。
88 14
基于yolov4深度学习网络的排队人数统计系统matlab仿真,带GUI界面
本项目基于YOLOv4深度学习网络,利用MATLAB 2022a实现排队人数统计的算法仿真。通过先进的计算机视觉技术,系统能自动、准确地检测和统计监控画面中的人数,适用于银行、车站等场景,优化资源分配和服务管理。核心程序包含多个回调函数,用于处理用户输入及界面交互,确保系统的高效运行。仿真结果无水印,操作步骤详见配套视频。
96 18
基于Python深度学习果蔬识别系统实现
本项目基于Python和TensorFlow,使用ResNet卷积神经网络模型,对12种常见果蔬(如土豆、苹果等)的图像数据集进行训练,构建了一个高精度的果蔬识别系统。系统通过Django框架搭建Web端可视化界面,用户可上传图片并自动识别果蔬种类。该项目旨在提高农业生产效率,广泛应用于食品安全、智能农业等领域。CNN凭借其强大的特征提取能力,在图像分类任务中表现出色,为实现高效的自动化果蔬识别提供了技术支持。
100 0
基于Python深度学习果蔬识别系统实现

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等