0

0

使用单层感知机拟合余弦函数的二次多项式近似——原理、实现与关键修正

碧海醫心

碧海醫心

发布时间:2026-02-13 09:44:52

|

128人浏览过

|

来源于php中文网

原创

使用单层感知机拟合余弦函数的二次多项式近似——原理、实现与关键修正

本文详解如何用带sigmoid激活的单层感知机逼近cos(x)在[0, π/4]上的二次多项式,指出原代码不收敛的根本原因(缺失学习率),并给出数学严谨的梯度更新、激活函数选择建议及更优替代方案。

在函数逼近任务中,将感知机视为“可训练的线性组合器”是一种常见但易被误解的思路。用户试图通过构造输入特征向量 ([x^2, x, 1]) 并用Sigmoid激活的单神经元拟合 (\cos(x)),其直觉合理——即学习映射 (x \mapsto w_0 x^2 + w_1 x + w_2),再经Sigmoid压缩至 ((0,1)) 区间。然而,原始实现中权重更新公式 w += deltaw 隐含了学习率为1,这在梯度下降中极易导致发散:当梯度幅值较大时,参数一步跃出最优邻域,损失震荡甚至爆炸。

核心修正:引入学习率与符号规范化
首先必须显式引入学习率(如 learning_rate = 0.01),确保权重沿负梯度方向稳定更新。更关键的是,应严格遵循梯度下降的数学定义:
[ \mathbf{w} \leftarrow \mathbf{w} - \eta \frac{\partial \mathcal{L}}{\partial \mathbf{w}} ]
其中损失函数取均方误差 (\mathcal{L} = \frac{1}{2} \sum_i (y_i - \sigma(\mathbf{x}_i^\top \mathbf{w}))^2)。经链式法则推导,正确更新应为:

# 正确的梯度下降更新(含学习率与负号)
learning_rate = 0.01
deltaw = -numpy.dot(training_inputs.T, errors * sigmoid_prime(outputs))  # 负梯度
w += learning_rate * deltaw  # 或等价写法:w -= learning_rate * (-deltaw)
✅ 注意:原代码中 deltaw = errors * sigmoid_prime(outputs) 实际计算的是 (\partial \mathcal{L}/\partial z)(对加权和 (z) 的梯度),而 (\partial \mathcal{L}/\partial \mathbf{w} = \mathbf{x}^\top \cdot (\partial \mathcal{L}/\partial z)),故需补全负号与输入转置乘积。

激活函数的适用性边界
Sigmoid输出范围为 ((0,1)),而 (\cos(x)) 在 ([0, \pi/4]) 上取值约为 ([0.707, 1.0]),虽处于其有效区间,但若扩展至 ([0, \pi])((\cos(x) \in [-1,1])),Sigmoid将完全失效。此时应切换为双曲正切函数 tanh(x),其输出范围 ((-1,1)) 与目标函数天然匹配:

def tanh(x):
    return numpy.tanh(x)

def tanh_prime(x):
    return 1 - numpy.tanh(x)**2

相应地,训练输出需改为 tanh(cos(x)),且网络前向传播使用 tanh(numpy.dot(training_inputs, w))。

更优实践:线性回归 vs 感知机
需明确一个本质区别:感知机+非线性激活 ≠ 多项式拟合器。当前架构实际学习的是复合函数 (\sigma(w_0 x^2 + w_1 x + w_2)),其输出并非直接等于多项式值,而是该多项式的Sigmoid变换结果。若目标是获得标准二次多项式 (p(x) = a x^2 + b x + c) 近似 (\cos(x)),最直接、高效且理论保障充分的方法是线性回归

# 无需激活函数,直接求解最小二乘解
X = numpy.column_stack([numpy.array(R)**2, numpy.array(R), numpy.ones(len(R))])
y = numpy.array([math.cos(x) for x in R])
coeffs = numpy.linalg.lstsq(X, y, rcond=None)[0]  # [a, b, c]
print("Linear regression coeffs:", coeffs)

此方法解析求解,无迭代、不收敛、精度高,且系数物理意义清晰——正是所求多项式各项系数。

PopShort.AI
PopShort.AI

PopShort是一个AI短剧生成平台

下载

总结与建议

  • 必做:为梯度更新添加合理学习率(0.01–0.1),并确保符号符合负梯度方向;
  • ⚠️ 慎选:Sigmoid仅适用于目标值域受限于 ((0,1)) 的场景,跨域逼近优先选用 tanh 或线性输出;
  • ? 优选:函数逼近任务中,若特征已手工设计(如多项式基),线性回归远比单层感知机更简洁、鲁棒、可解释;
  • ? 延伸思考:若坚持使用神经网络,应转向无激活(纯线性输出层)或采用ReLU等现代激活,并配合正规化防止过拟合。

感知机的价值在于其作为神经网络基石的教学意义,但在具体数值逼近问题上,选择与问题结构匹配的工具,才是工程实践的专业体现。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

11

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

7

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

8

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

3

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

26

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

9

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

181

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

14

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号