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)

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

Pipio
Pipio

Pipio 使每个人都无需麦克风、摄像机、演员或工作室即可制作专业视频。

下载

总结与建议

  • 必做:为梯度更新添加合理学习率(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不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言 数据类型
c语言 数据类型

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

24

2026.02.12

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

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

9

2026.02.12

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

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

98

2026.02.12

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

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

11

2026.02.12

Next.js全栈开发与SSR服务端渲染实战
Next.js全栈开发与SSR服务端渲染实战

本专题系统讲解 Next.js 框架在现代全栈开发中的应用,重点解析 SSR、SSG 与 ISR 渲染模式的原理与差异。内容涵盖路由系统、API Routes、数据获取策略、性能优化以及部署实践。通过完整项目示例,帮助开发者掌握高性能 SEO 友好的 React 全栈开发方案。

11

2026.02.12

Kotlin协程编程与Spring Boot集成实践
Kotlin协程编程与Spring Boot集成实践

本专题围绕 Kotlin 协程机制展开,深入讲解挂起函数、协程作用域、结构化并发与异常处理机制,并结合 Spring Boot 展示协程在后端开发中的实际应用。内容涵盖异步接口设计、数据库调用优化、线程资源管理以及性能调优策略,帮助开发者构建更加简洁高效的 Kotlin 后端服务架构。

90

2026.02.12

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

371

2026.02.11

Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析
Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析

本专题全面整理了Yandex搜索引擎的官方入口信息,涵盖国际版与俄罗斯版官网访问方式、网页版直达入口及免登录使用说明,帮助用户快速、安全地进入Yandex官网,高效使用其搜索与相关服务。

1326

2026.02.11

虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法
虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法

本专题系统整理了虫虫漫画官网及网页版最新入口,涵盖免登录观看、正版漫画全集在线阅读方式,并汇总稳定可用的访问渠道,帮助用户快速找到虫虫漫画官方页面,轻松在线阅读各类热门漫画内容。

105

2026.02.11

热门下载

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

精品课程

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

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