博客
关于我
梯度下降求函数最小值C++样例
阅读量:686 次
发布时间:2019-03-17

本文共 732 字,大约阅读时间需要 2 分钟。

强力推荐大家阅读《深度学习的数学》一书,日本作家所写(通俗易懂),可当作课外读物阅读

#include
#include
using namespace std;//梯度下降求最小值//以函数z=x^4+y^2,为例子 //算出偏导,梯度向量//x:4x^3 y:2y 梯度向量为 (4x^3,2y) int main(void){ double n=0.001;//步长选0.1 //我们要选一个点,作为起点 double start_x=-5.0,start_y=-5.0; //梯度 double grade_x=4*(start_x*start_x*start_x); double grade_y=2*start_y; //位移向量 double dx=-n*grade_x; double dy=-n*grade_y; while(fabs(dx)>0.00001||fabs(dy)>0.00001){ //更新位置 start_x=start_x+dx; start_y=start_x+dy; //计算位移向量 dx=-n*3*(start_x*start_x); dy=-n*2*start_y; //计算函数值 //std::cout<<"min-value is "<
<
0.01&&fabs(start_y)>0.01)){ cout<<0<<","<<0<
0.01&&fabs(start_y)>0.01)){ cout<<0<<","<<0<

转载地址:http://lfshz.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(43)——MySQL主从复制详细配置
查看>>
Mysql学习总结(44)——Linux下如何实现mysql数据库每天自动备份定时备份
查看>>
Mysql学习总结(45)——Mysql视图和事务
查看>>
Mysql学习总结(46)——8种常被忽视的SQL错误用法
查看>>
Mysql学习总结(48)——MySql的日志与备份还原
查看>>
Mysql学习总结(49)——从开发规范、选型、拆分到减压
查看>>
Mysql学习总结(4)——MySql基础知识、存储引擎与常用数据类型
查看>>
Mysql学习总结(50)——Oracle,mysql和SQL Server的区别
查看>>
Mysql学习总结(51)——Linux主机Mysql数据库自动备份
查看>>
Mysql学习总结(52)——最全面的MySQL 索引详解
查看>>
Mysql学习总结(53)——使用MySql开发的Java开发者规范
查看>>
Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
查看>>
Mysql学习总结(55)——MySQL 语句大全再温习
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>