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

加深理解神经元的工作原理:感知机预测的实现

怎么去理解一个神经元的工作原理 加权求和,激活函数. 这些概念反反复复的就是记不住,怎么理解监督学习,权重更新规则,这些理论模模糊糊总是理解不到. 下面用一个简单的例子.加深上面这些内容的理解使用Python和NumPy(不使用深度学习框架),实现一个感知机,用于对一个简单的逻辑门(AND;OR)进行分类数据集:AND逻辑门的数据:输入:[0, 0], 标签 0输入:[0, 1], 标签 0输入:[1, 0],标签 0输入:[1, 1],标签 1要求:1.创建一个Perceptron类2.类中应包含weights和偏置bias3.实现predict方法,遍历数据集,如果预测错误,则根据感知机学习规则更新权重和偏置:w_new w_old learning_rate * (label - prediction) * xb_new b_old learning_rate * (label -prediction)训练你的感知机,并验证它能正确预测AND逻辑门的所有输入#定义一个预测机class Perceptron: #learning_rate 学习率:控制步长 #input_size (int):输入特征的数量(对于AND门是2) 比如与房价相关的特征[面积,地点,学 #区...] 有8个特征 这里的input_size 就是8 def __init__(self, input_size, learning_rate0.1): #初始化特征对应的每一个权重 self.weights np.random.rand(input_size) * 2 - 1 #初始化偏置,随机初始化一个值 self.bias np.random.rand(1) *2 -1 #保存学习率 self.lr learning_rate #bias[0] 这是一个只有一个元素的NumPy数组,[0]用来获取这个元素的值 #:.4f 这是格式说明,表明开始格式化, .4表示保留4位小数, f表示浮点数(float)形式显示 print(f初始化权重:{self.weight},初始化偏置:{self.bias[0]:.4f}) def activation_function(self, x): return 1 if x 0 else 0 def predict(self, inputs): weighted_sum np.dot(self.weights, inputs) self.bias return self.activation_function(weighted_sum) #开始训练 #trainning_inputs (list of lists):训练数据集的输入 #epochs (int):训练的轮数,即将整个数据集重复学习的次数 #labels (list):训练数据集的标签,也就是每个输入对应的正确输出 def train(self, training_inputs, labels, epochs10): for epoch in range(epochs): total_error 0 for inputs, label in zip(trainning_inputs, labels): #将输入转换为numpy数组 inputs np.array(inputs) #1.进行预测 prediction self.predict(inputs) #计算误差 error label - prediction #如果有误差,就更新权重 if error ! 0: total_error 1 update self.lr * error self.weights update * inputs self.bias update print(f第{epochs1}轮;错误数 {total_error}, 当前权重 {self.weights}, 当前偏置 {self.bias[0]:.4f}) #如果一轮下来没有任何错误,说明已经收敛,可以结束训练 if total_error 0: print(训练完成,模型已收敛) break print(----训练结束-----) if __name__ __main__: training_inputs [ [0, 0], [0, 1], [1, 0], [0, 1] ] labels [0, 0, 0, 1] #常见一个感知实例, 输入特征是2个 (x1, x2) perceptron Perceptron(input_size2) #训练感知机 其实就是不断的更新权重和偏置 perceptron.train(traning_inputs, labels) #测试训练好的感知机, AND门:因为数据集太小,我们通常用traning_inpus本身来测 #试 即test_cases [[0, 0], [0, 1], [1, 0],[1, 1]] test_cases [ [0, 0], [0, 1], [1, 0], [1, 1] ] for test_input in test_cases: prediction perceptron.predict(np.array(test_input)) print(f输入:{test_input}, 预测输出:{prediction})讲一下np的语法np 是NumPy库的常用别名,NumPy是Python进行科学计算的核心库,特别擅长处理多维数据(矩阵)np.random.rand(input_size)会创建一个形状为(input_size)的NumPy数组,其中每个元素都是[0.0, 1.0]区间内的随机浮点数例如 如果input_size 是3,它可能会生成[0.12, 0.85, 0.34]*2-1 (向量化操作), 这是NumPy的一个强大功能,叫做向量化, 这个操作会对数组中的每一个元素执行*2-1的计算. 而不需要写for循环[0.0, 1.0]区间的随机数经过*2变成[0.0, 2.0],再-1就变成了[-1.0 , 1.0]区间在机器学习中,将权重初始化在-1到1之间的对称区间通常比0到1更好,有助于模型更快,更稳定地收敛讲一下zip的语法zip函数把多个可迭代的对象压缩在一起,然后返回一个迭代器,这个迭代器每次会生成一个元祖(tuple),元祖中的元素分别来自于你传入的每个可迭代对象的对应位置假设你有两个列表 一个记录学生姓名,一个记录考试成绩students [小明, 小红, 小刚] scores [ 90, 95, 82 ] 使用zip将他们配置 paired_data zip(students, scores) 为了看清zip的结果 我们转换成list print(list(paired_data))

相关文章:

加深理解神经元的工作原理:感知机预测的实现

怎么去理解一个神经元的工作原理? 加权求和,激活函数. 这些概念反反复复的就是记不住,怎么理解监督学习,权重更新规则,这些理论模模糊糊总是理解不到. 下面用一个简单的例子.加深上面这些内容的理解 使用Python和NumPy(不使用深度学习框架),实现一个感知机,用于对一…...

Flowise效果展示:不同Embedding模型(BGE/bge-m3)在中文场景表现

Flowise效果展示:不同Embedding模型(BGE/bge-m3)在中文场景表现 1. 引言:当可视化拖拽遇到中文Embedding 想象一下这样的场景:你手里有一堆中文文档,想要快速搭建一个智能问答系统,但又不愿意…...

【工具推荐】EVCapture 电脑录屏软件,无水印超省心

【工具推荐】EVCapture - 免费好用的电脑录屏软件 一、工具简介 EVCapture 是一款免费无水印的电脑屏幕录制软件,支持Windows系统。它可以录制电脑屏幕、摄像头、声音,是一款实用的录屏工具。 官方信息项目信息软件名称EVCapture版本v5.4.5类型屏幕录制软…...

用Python模拟Barra CNE5风险模型:手把手教你构建A股量化策略(附完整代码)

用Python构建A股多因子风险模型:从理论到实战的完整指南 在量化投资领域,风险模型是构建稳健策略的核心基础设施。对于A股市场而言,由于交易机制、投资者结构和政策环境的特殊性,直接套用海外成熟市场的风险模型往往效果不佳。本文…...

My first article

12345...

重新理解基础数据结构(动态数组,链表)

1 最近在准备面试,发现 ArrayList 扩容机制总是死记硬背,过段时间就忘。索性花几小时彻底啃一遍源码,争取一次拿下、终身不忘。2 ArrayList 底层是动态数组。Java 原生数组一旦定义长度就不可变,使用场景受限。ArrayList 就是对数…...

【Azure App Service】PHP页面上传文件413错误的解决方案

问题描述 在使用 Azure App Service(Linux PHP) 部署 Web 应用时,如果上传文件大于1MB,就会遇到 HTTP 413(Request Entity Too Large) 错误。 错误截图 问题解答 一、HTTP 413 错误的本质含义 413 Req…...

如何备份备库Data Guard_在Standby端执行RMAN备份减轻主库压力

不能直接在备库连RMAN TARGET /备份,因DG备库控制文件为只读的standby控制文件,RMAN默认不信任其作为备份源,需先配置DB_UNIQUE_NAME、挂载standby控制文件并编目数据文件。为什么不能直接在备库连 RMAN TARGET / 就开干因为默认情况下&#…...

VideoSrt:终极视频字幕自动生成解决方案,让字幕制作变得简单快速

VideoSrt:终极视频字幕自动生成解决方案,让字幕制作变得简单快速 【免费下载链接】video-srt-windows 这是一个可以识别视频语音自动生成字幕SRT文件的开源 Windows-GUI 软件工具。 项目地址: https://gitcode.com/gh_mirrors/vi/video-srt-windows …...

私有化AI视频助手搭建实录:当Ollama遇上OpenClaw

AI视频生成的热度仍在攀升,从HappyHorse-1.0匿名屠榜到各家模型竞相开源,创作者似乎迎来了最好的时代。但一个现实问题始终悬而未决:云端服务固然方便,可谁愿意把未公开的脚本、商业素材甚至客户数据,毫无保留地交给一…...

深入解析AMD Ryzen处理器硬件调试:5大核心功能实战指南

深入解析AMD Ryzen处理器硬件调试:5大核心功能实战指南 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://g…...

Spring Boot @Value 绑定 Set 失败?

Spring Boot Value 绑定 Set 失败&#xff1f;一、问题背景在同事项目开发过程中&#xff0c;遇到了一个看起来很简单但实际很容易踩坑的问题&#xff1a;同事希望在 application.properties 中配置一个字符串集合&#xff0c;然后在代码中直接注入为 Set<String>。配置如…...

【含最新安装包】5 分钟完成 OpenClaw 2.6.2 Windows 部署

Windows 一键部署 OpenClaw 教程&#xff5c;5 分钟搞定本地 AI 智能体&#xff0c;告别复杂配置 核心亮点&#xff1a;零代码门槛&#xff5c;全程可视化&#xff5c;无需手动配环境&#xff5c;内置所有依赖&#xff5c;28 万 Tokens 额度 下载地址&#xff1a;【点击下载o…...

AI生成内容版权:法律与职业风险

——软件测试从业者的专业视角与风险防控一、AI版权争议的法律核心&#xff1a;独创性认定《著作权法》第三条明确规定&#xff0c;作品需满足独创性智力成果双重要件。近年司法实践通过典型案例确立以下原则&#xff1a;关键司法判例解析案例案号核心结论对测试工作的启示AI图…...

GPU vs CPU 基本概念学习笔记

GPU vs CPU 名词解释名词通俗解释Die&#xff08;芯片裸片&#xff09;封装壳里那块薄薄的硅片&#xff0c;是芯片的"本体"&#xff0c;上面刻着几十亿个晶体管电路Core&#xff08;核心&#xff09;芯片里能独立执行计算任务的"大脑单元"&#xff0c;就像…...

SpringBoot2项目信创改造:东方通TongWeb嵌入式版集成实战

1. 为什么选择东方通TongWeb嵌入式版 最近几年&#xff0c;国产化信创改造成为很多企业技术升级的重点方向。作为技术负责人&#xff0c;我在实际项目中遇到了从Tomcat迁移到国产应用服务器的需求。经过多方对比&#xff0c;最终选择了东方通TongWeb嵌入式版&#xff0c;这里分…...

计及风光不确定性的基于IGDT信息间隙决策的综合能源系统优化调度 摘要:代码构建了含光热电站、...

计及风光不确定性的基于IGDT信息间隙决策的综合能源系统优化调度 摘要&#xff1a;代码构建了含光热电站、储气、储碳、碳捕集装置的综合能源系统优化调度模型&#xff0c;并考虑P2G装置与碳捕集装置联合运行&#xff0c;从而实现碳经济的最大化&#xff0c;与此同时&#xff0…...

办公室里的“神秘”同事:那位深藏不露的调试高手

在软件测试团队中&#xff0c;总有一些同事看似低调平凡&#xff0c;却能在关键时刻力挽狂澜。他们不是聚光灯下的主角&#xff0c;而是隐藏在角落的“调试高手”。今天&#xff0c;我们就来聚焦这样一位神秘人物——李明。他从不张扬&#xff0c;却在每一次产品迭代中成为质量…...

2026年AI编程实战指南:三大工具深度对比与选型建议

2026年&#xff0c;AI编程助手已经成为开发者标配。但面对GitHub Copilot、Claude Code、DeepSeek-Coder三大主流工具&#xff0c;如何选择&#xff1f;本文通过实际代码示例和对比测试&#xff0c;帮你找到最适合自己的AI编程伙伴。 一、环境准备与安装配置 1.1 GitHub Copil…...

Ubuntu2024编译CMake时OpenSSL缺失问题全解析

1. 问题现象与背景解析 最近在Ubuntu 2024系统上手动编译CMake时&#xff0c;很多开发者都遇到了一个典型错误&#xff1a;Could not find OpenSSL。这个报错通常出现在执行./bootstrap阶段&#xff0c;系统提示需要安装OpenSSL开发包。我上周在给团队搭建新开发环境时&#xf…...

基于ADS的微带线等效电感设计与仿真验证

1. 微带线等效电感设计基础 微带线作为PCB上最常见的传输线结构之一&#xff0c;在高频电路中经常被用来替代传统的集总参数电感。这种设计方法不仅节省空间&#xff0c;还能避免分立元件带来的寄生效应。我第一次用微带线做电感是在设计一个2.4GHz的滤波器时&#xff0c;当时发…...

解决 Bookmarklet 中 %0A 换行符导致的跨环境执行失败问题

本文详解如何在 JavaScript Bookmarklet 与浏览器控制台中统一处理换行符 %0A&#xff0c;避免因 URL 编码解析差异引发的语法错误或截断异常&#xff0c;并提供健壮、可复用的 encodifyText 实现方案。 本文详解如何在 javascript bookmarklet 与浏览器控制台中统一处理换…...

毕业设计智能化革新:8款AI工具提升论文与代码效率

文章总结表格&#xff08;工具排名对比&#xff09; 工具名称 核心优势 aibiye 精准降AIGC率检测&#xff0c;适配知网/维普等平台 aicheck 专注文本AI痕迹识别&#xff0c;优化人类表达风格 askpaper 快速降AI痕迹&#xff0c;保留学术规范 秒篇 高效处理混AIGC内容&…...

XUnity AutoTranslator 终极指南:轻松为Unity游戏添加多语言实时翻译

XUnity AutoTranslator 终极指南&#xff1a;轻松为Unity游戏添加多语言实时翻译 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 想要玩日文游戏却看不懂剧情&#xff1f;英文界面让你头疼&#xff1f;XU…...

如何突破Windows屏幕限制?开源虚拟显示器驱动让你免费扩展10个虚拟屏幕

如何突破Windows屏幕限制&#xff1f;开源虚拟显示器驱动让你免费扩展10个虚拟屏幕 【免费下载链接】virtual-display-rs A Windows virtual display driver to add multiple virtual monitors to your PC! For Win10. Works with VR, obs, streaming software, etc 项目地址…...

SSL_read vs recv:从TCP到TLS的数据读取差异详解(附Wireshark抓包分析)

SSL_read与recv的深度对比&#xff1a;从TCP流到TLS记录层的读取机制解析 当开发者从传统TCP套接字编程转向加密通信时&#xff0c;往往会遇到一个看似简单却令人困惑的问题&#xff1a;为什么SSL_read的行为与recv如此不同&#xff1f;本文将通过协议栈原理、内核行为差异和实…...

如何实现SQL动态字段选择查询_利用反射或动态拼接字符串

SQL动态字段选择不能用参数化查询&#xff0c;因为?占位符仅支持值而非标识符&#xff08;如字段名、表名&#xff09;&#xff0c;必须通过白名单校验后字符串拼接实现安全动态列。SQL动态字段选择为什么不能直接用参数化查询因为字段名不是数据值&#xff0c;PreparedStatem…...

多线程:生产者消费者

本文展示了一个基于C的多线程生产者-消费者模型实现。核心组件ThreadSafeQueue是一个线程安全的队列模板类&#xff0c;使用互斥锁和条件变量实现同步机制&#xff0c;支持阻塞式push/pop操作。系统包含3个生产者线程&#xff08;各生产10个产品&#xff09;和2个消费者线程&am…...

实测:穗光谈链上买冷钱包靠谱吗?销售商底细起底

【导语】在区块链技术快速普及的当下&#xff0c;冷钱包作为链上资产安全防护的核心载体&#xff0c;其销售渠道的正规性愈发关键。不少CSDN用户后台留言咨询&#xff0c;核心疑问集中在“穗光谈链上买冷钱包靠谱吗”“其背后的销售商菏泽穗达商贸是正规公司吗”。作为专注区块…...

Unity中Dotween动画的精准控制:暂停、继续、终止与正反向播放实战

1. Dotween动画控制的核心场景 在游戏开发中&#xff0c;UI动画的精细控制直接影响用户体验。想象一个任务完成的弹窗&#xff1a;当玩家点击暂停按钮时&#xff0c;庆祝动画需要立即冻结&#xff1b;继续游戏时&#xff0c;动画应该从暂停的位置无缝衔接&#xff1b;如果玩家快…...