算法设计克林伯格pdf_LSTM算法

算法设计克林伯格pdf_LSTM算法第一部分 levmar的安装与使用 Levenberg-Marquardt算法是求解非线性问题的一个非常好用的算法。该算法属于信赖域算法的一种,关于信赖域算法的解释可以参考这一博主的解释:关于信赖域算法理解,个人感觉很好。    Levenberg-Marquardt算法是一个开源的算法,其文件下载地址如下:http://www.netlib.org/clapack/C

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

第一部分  levmar的安装与使用 

Levenberg-Marquardt算法是求解非线性问题的一个非常好用的算法。该算法属于信赖域算法的一种,关于信赖域算法的解释可以参考这一博主的解释:关于信赖域算法理解,个人感觉很好。

       Levenberg-Marquardt算法是一个开源的算法,其文件下载地址如下:

http://www.netlib.org/clapack/CLAPACK-3.1.1-VisualStudio.zip 下载clapack

http://www.ics.forth.gr/~lourakis/levmar/levmar-2.5.tgz       下载LEVMAR

http://www.cmake.org/files/v2.8/cmake-2.8.0-win32-x86.exe   下载cmake

利用cmake将源码组织成一个工程,其具体安装可参照这篇博客:levmar安装

下面说明下dlevmar_dif()函数的参数内容。

dlevmar_dif()函数共有11个参数:

参数1:void (*func)(double *p, double *hx, int m, int n, void *adata)

就是求解的函数,需要自己构造。以其demo中wood函数为例:

void wood(double *p, double *x, int m, int n, void *data)   /* 非线性目标函数f(x1,x2,x3,x4)  */
{

register int i;
  for(i=0; i<n; i+=6){

    x[i]=10.0*(p[1] – p[0]*p[0]);                  // f(x1,x2,x3,x4) = 10*(x2 – x1*x1);
    x[i+1]=1.0 – p[0];                                  // f(x1,x2,x3,x4) = 1.0 – x1;
    x[i+2]=sqrt(90.0)*(p[3] – p[2]*p[2]);      // f(x1,x2,x3,x4) = sqrt(90.0)*(x4 – x3*x3);
    x[i+3]=1.0 – p[2];                                 //  f(x1,x2,x3,x4) = 1 – x3;  
    x[i+4]=sqrt(10.0)*(p[1]+p[3] – 2.0);      //  f(x1,x2,x3,x4) = sqrt(10.0) *(x2 + x4 – 2); 
    x[i+5]=(p[1] – p[3])/sqrt(10.0);             //  f(x1,x2,x3,x4) = (x2 – x4)/sqrt(10.0)
  }
}

参数2:double *p

输入输出参数,输入初始迭代的参数向量,输出最佳逼近的向量。

参数3:double *x

该参数为期望值向量,即为逼近的目标。

参数4:int m

参数向量P的维数。

参数5:int n

期望向量维数

参数6:int itmax

该参数表示最大迭代次数

参数7:double opts[5]

迭代过程中的一些阈值,包括最初计算阻尼系数时需要的系数、迭代结束需要的系数。如果不知道怎么设可以为NULL,代码有默认配置。

参数8:double info[LM_INFO_SZ]

返回迭代结束的一些信息,如迭代次数、结束原因等。

参数9:double *work

该参数从源码看,并没什么用,可以设为NULL。

参数10:double *covar

该参数为正交矩阵系数(记得不清了,在论文有提到,但我在自己写代码的时候没有用到),该参数可设为NULL。

参数11:void *adata

该参数为是为了当有特殊需求时才传的参数,该参数与(func*)中的void *adata一致,目前没看出怎么用,暂时设为NULL。

第二部分  自己动手编写levmar算法

    可以参考原论文:下载地址

    可以参考K. Madsen等人的《Methods for non-linear least squares problems》写得很不错,推荐看这论文:下载地址


   具体原理我就不多啰嗦,论文解释得还是挺清楚的,自我感觉需要啰嗦一下下的小问题:

1. 雅克比矩阵的求解,可根据导数的定义来近似求解雅克比矩阵,雅克比矩阵:

   jac = f'(x) = [ f(x)-f(x- delta * x) ]/(x- delta * x))

2. 海森矩阵的求解,海森矩阵的计算近似等于:雅克比矩阵的转置乘以雅克比矩阵 ==>  Hessen = jacT * jac

3. 线性系统求解“步进”,求解参数向量的“步进”Dp,这是一个求解线性系统问题;求解线性系统问题有许多方法和工具,这里我为了简单就使用了opencv中的 cvSlove()函数求解。


   根据其提供伪代码配合理论就可以很快编写出自己的levmar函数了。

   啰嗦下因为采用的求解线性系统的方法不一样,所以在迭代次数和结果上与原版levmar算有一点点差异,迭代次数可能相差几次,及结果会相差一点(一般相差不会超过0.01)。


   levmar伪代码如下:

算法设计克林伯格pdf_LSTM算法


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/187205.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java手机编程软件_手机java编程软件下载[通俗易懂]

    java手机编程软件_手机java编程软件下载[通俗易懂]手机java编程软件安卓版是一款专为java开发人员服务的编辑客户端应用,利用手机java编程软件手机安卓版实时进行相关编辑还能进行简单的编译,运行单个小程序等,提供您的效率。功能介绍手机java编程软件安卓版是一款将openjdk中关于编译java工程的代码移植到了安卓平台。手机java编程软件手机安卓版支持添加jar格式的lib文件,并且将编译后的程序dex化,以便在安卓设备上运行。在编译和运…

    2022年7月21日
    16
  • 高斯同余理论_高斯模糊算法

    高斯同余理论_高斯模糊算法针对鲸鱼优化算法在处理高维问题时存在收敛速度慢、容易陷入局部最优和收敛精度低等问题,提出一种基于对数惯性权重和高斯差分变异的鲸群优化算法。通过高斯差分变异对鲸鱼位置更新方程进行变异,增加了种群多样性,提高了鲸群算法的全局搜索能力,防止早熟现象发生;将对数惯性权重引入搜寻猎物阶段,平衡全局搜索和局部开发能力,提高了算法寻优精度。通过测试函数优化实验对算法进行测试,实验结果表明,改进算法具有更高的寻优精度和更快的收敛速度。

    2022年10月5日
    3
  • Pycharm最简单安装Python里面的各种包

    Pycharm最简单安装Python里面的各种包大家在用Pycharm安装各种Python里面的包时,可能会出错,安装不成功。下面我介绍一种最可靠,最稳定,最便利的安装。第一步:打开Pycharm,点击右上角的File,找到setting第二步:在setting里面搜索interpreter,找到ProjectInterpreter点击右侧的+号第三步:点击最下面的ManageRespositories删除默认的配置…

    2022年8月29日
    2
  • 机器学习框架及评估指标详解

    机器学习框架及评估指标详解目录机器学习的步骤train_test_split函数的详解机器学习评估指标分类模型评估指标混淆矩阵ROC曲线利用ROC的其他评估标准Python绘制ROC曲线求解AUC模板代码错误率精度查准率、查全率P-R曲线Python绘制P-R曲线模板代码平衡点(BEP)F1度量Python求解F1_score代码回归模型评估指标均方误差MAE(平均绝对误差)MAPE(平均绝对百分比误差)RMSE(均方根误差)RSquare(

    2022年6月16日
    28
  • commons-beanutils_Bean @session

    commons-beanutils_Bean @sessionBeanUtils介绍       所谓BeanUtils为何要开发呢,每个工程师或许在写JavaBean的时候,都会乖乖地去写getters和setters,就是getXXX()及setXXX()methods,但是当你的object是动态产生的,也许是用档案,也许是其它原因,那你该如何去存取数据呢!!几个例子你可能会用到BeanUtils,当…

    2025年9月6日
    6
  • int和int32的区别_int是多少位的

    int和int32的区别_int是多少位的大家有没有写了很久代码,还不知道这个Int8,Int16,Int32,Int64有什么区别呢?或者是为什么后面的数字不一样呢?初步了解了一下,才清楚这个东西。先来扫盲一下计算机存储单元,  在计算机内部,信息都是釆用二进制的形式进行存储、运算、处理和传输的。信息存储单位有位、字节和字等几种。各种存储设备存储容量单位有KB、MB、GB和TB等几种计算机的基本的存储单元有:…

    2022年8月15日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号