热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

梯度下降法,一阶曲线拟合

程序文件study2.mfunctionstudy2()??count7;??n1;??%X[123454.2678]‘;??%Y[5,4,5,4.5,5,6,643]‘;

    程序文件 study2.m

function study2()
    count=7;
    n=1;
    %X=[1 2 3 4 5 4.2 6 7 8]‘;
    %Y=[5,4,5,4.5,5,6,6 4 3]‘;
    X=1:10;
 Y=rand(1,10)*100;
 sita=rand(n,1);
 overvalue=-1;
 count=0;
 b=(max(Y)+min(Y))/2;  %%假设函数为 h(x)=sita*x+b
    while 8<(J=calJ())&&(abs(J-overvalue)>0.0001) 
      study();
  overvalue=J;
  count=count+1;
      draw();
  sleep(0.01)
    endwhile
 count
    draw();
    
    function ans=calJ()
      ans=sum((X*sita+b-Y).^2)/2;
    endfunction
    
    function study()
      sita=sita-0.003*sum((X*sita+b-Y).*X);
    endfunction 
   
    function draw()
        hold off
        plot(X,Y,‘*‘);
        hold on
        tempx=linspace(0,max(X)*5/4,3);
        tempy=tempx*sita+b;
        plot(tempx,tempy);
    endfunction
endfunction

    执行过程如下所示

     技术分享

   一个简单的学习算法,其中学习速度选取很关键,就是子函数study中0.003代表的意思,如果选取过大会发现曲线震荡发散不收敛,选取过小学习时间太长。决定了整个系统学习的效率。

    上图演示的时候我将sita=zeros(n,1)了,因为要有一个好的动画效果 -_-! ,开头代码中所用的随机数实际效果更好。



梯度下降法,一阶曲线拟合


推荐阅读
  • 探索OpenWrt中的LuCI框架
    本文深入探讨了OpenWrt系统中轻量级HTTP服务器uhttpd的工作原理及其配置,重点介绍了LuCI界面的实现机制。 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 本文概述了在GNU/Linux系统中,动态库在链接和运行阶段的搜索路径及其指定方法,包括通过编译时参数、环境变量及系统配置文件等方式来控制动态库的查找路径。 ... [详细]
  • 使用REM和媒体查询实现响应式布局
    本文介绍如何利用REM单位和媒体查询(Media Queries)来创建适应不同屏幕尺寸的网页布局。通过具体示例,展示在不同屏幕宽度下如何调整页面元素的样式。 ... [详细]
  • 本文详细介绍了如何使用Rufus工具制作一个兼容UEFI启动模式的Windows Server 2008 R2安装U盘,包括必要的软件和步骤。 ... [详细]
  • 本文介绍如何使用 Python 计算两个时间戳之间的时间差,并将其转换为毫秒。示例代码展示了如何通过 `time` 和 `datetime` 模块实现这一功能。 ... [详细]
  • 使用 ModelAttribute 实现页面数据自动填充
    本文介绍了如何利用 Spring MVC 中的 ModelAttribute 注解,在页面跳转后自动填充表单数据。主要探讨了两种实现方法及其背后的原理。 ... [详细]
  • 本文详细对比了HashMap和HashTable在多线程环境下的安全性、对null值的支持、性能表现以及方法同步等方面的特点,帮助开发者根据具体需求选择合适的数据结构。 ... [详细]
  • 神策数据分析基础
    本文介绍了基于用户行为的数据分析方法,包括业务问题的提出与定义、具体行为的识别及统计分析流程。同时,详细阐述了如何利用事件模型(Event Model)来描述用户行为,以及在实际应用中的案例分析。 ... [详细]
  • Docker基础入门与环境配置指南
    本文介绍了Docker——一款用Go语言编写的开源应用程序容器引擎。通过Docker,用户能够将应用及其依赖打包进容器内,实现高效、轻量级的虚拟化。容器之间采用沙箱机制,确保彼此隔离且资源消耗低。 ... [详细]
  • 本文列举了构建和运行 Struts2 应用程序所需的核心 JAR 文件,包括文件上传、日志记录、模板引擎等关键组件。 ... [详细]
  • selenium通过JS语法操作页面元素
    做过web测试的小伙伴们都知道,web元素现在很多是JS写的,那么既然是JS写的,可以通过JS语言去操作页面,来帮助我们操作一些selenium不能覆盖的功能。问题来了我们能否通过 ... [详细]
  • 本文介绍了一个来自AIZU ONLINE JUDGE平台的问题,即清洁机器人2.0。该问题来源于某次编程竞赛,涉及复杂的算法逻辑与实现技巧。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 本文介绍了用户界面(User Interface, UI)的基本概念,以及在iOS应用程序中UIView及其子类的重要性和使用方式。文章详细探讨了UIView如何作为用户交互的核心组件,以及它与其他UI控件和业务逻辑的关系。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有