Levmar配置

原文有些错误,在我的博客里已经改好了:http://blog.sina.com.cn/s/blog_45b747f70101he1t.html

如果6或者7自由度机器人的运动学逆解无法找到解析解,我们就要用数值解法来处理。这属于非线性超越方程的数值解法问题。LM算法,也成为阻尼最小二乘法。

本人编程能力太弱,只好借助于库函数。看到网上教程有用Levmar(FAQ)来做LM算法的。Levmar可用于C++, Matlab,Perl, Python, Haskell and Tcl。本人在VS2010下编程,所以下面只谈谈如何在VS2010下配置。

经过测试,win7与win8 64位系统下的VS2010/VS2013用下面的方法配置可以成功。

准备工具:

1. cmake-2.8.12.1-win32-x86.zip (选择Binarydistributions栏下的第二个)。

2. clapack-3.2.1-CMAKE.tgz(页面做的稍乱,找到同名的那个压缩包下载)。

3. levmar-2.6

步骤:

1.  先将上面下载的三个压缩包都解压。解压后的cmake-2.8.12.1-win32-x86是编译工具,建议放在常用的工具文件夹下(英文目录,不要有中文)。解压后的clapack-3.2.1-CMAKE和levmar-2.6等会要用到,而且编程的时候也用到其做包含目录,因此不建议放在桌面。

2.  针对clapack-3.2.1-CMAKE的操作。双击打开cmake-gui.exe(该文件在cmake-2.8.12.1-win32-x86文件夹里的bin文件夹下)首先要对clapack-3.2.1-CMAKE进行编译。如图:

对于箭头1,点击右边的BrowseSource...将文件夹定位到第一步解压出的clapack3.2.1-CMAKE,对于箭头2,Browse Build..则是你要编译到的位置,为了方便我选择C:\CLAPACK。选择完之后,我们点击左下角的configure按钮,弹出的框里我们选择Visual Studio 10 Win64,点Finish等几秒钟,Configure结束后画面中间会出来一些红色的条框,不管它,我们再点Configure右边的Generate按钮,根据下面提示Generate
done后,可以先关掉这个窗口了。现在我们到C:\CLAPACK下,找到CLAPACK.sln这个文件,并双击,这时候会在VS2010里出来一个工程,等待加载完成后,我们选择生成解决方案。这里需要花点时间,等程序跑完之后会提示成功了33个项目(这一步是为了生成4个lib文件)。下面我们可以先关掉VS2010。然后再次到C:\CLAPACK文件夹下,我们要寻找4个.lib文件(为了在levmar中要链接他们),这4个文件分别是:

l C:\Clapack\BLAS\SRC\Debug:       blas.lib

l C:\Clapack\F2CLIBS\libf2c\Debug:    libf2c.lib

l C:\Clapack\SRC\Debug:              lapack.lib

l C:\Clapack\Testing\MATGEN\Debug:     tmglib.lib

为了便于我们在后面链接他们,我们先在C:\CLAPACK下新建一个LIB文件夹,然后复制上面四个lib文件到这个文件夹下。到这里第二步基本完成了。

注意:复制libf2c.lib的时候我们将文件名改为f2c.lib(因为后面链接的默认名是f2c.lib)

3.   针对LEVMAR2.6部分接下去我们再次打开cmake-gui.exe,Browse Source...选择第一步解压出来的levmar-2.6,Browse Build..选择要编译到的位置,这里我选的是C:\lm26。然后点击Configure,选择Visual Studio 10 Win64,之后弹出如下所示:

将LAPACKBLAS_DIR 后面的usr/lib文件夹路径改成第二步中我们自己建的那个文件夹路径 C:\CLAPACK\LIB。然后再次点击左下角的Configure,红色变白色,之后再点击Generate。下面我们到 C:\lm26文件夹下找到LEVMAR.sln文件,运行它,点生成解决方案,全部成功后关掉。这一步是为里生成C:\lm26\Debug\levmar.lib文件。到这里配置部分基本完成了,下面讲如何在我们自己的程序里用。

4.  新建一个VS2010的c++工程lm_test,点顶部菜单栏的项目,再点属性,点左侧的配置属性,再点右侧的配置管理器,点活动平台解决方案的下拉菜单,点新建,然后把Itanium换成x64点确定,如图

这样,我们就将我们的工程配置成了64位的。

然后右键点击左侧解决方案资源管理器中lm_test,选择属性,弹出的窗口左侧点击配置属性下的VC++目录,然后在右侧的包含目录中添加我们在第一步中解压出的levmar2.6的文件夹,如图

确定后,我们再在库目录下再添加两个文件夹,一个是我们在第二步中自己新建的那个C:\CLAPACK\LIB,另一个是C:\lm26\Debug,为的就是这两个文件夹里面的lib文件,如图:

确定后我们点击左侧的链接器、输入,附加依赖项添加第二步生成4个lib文件和第三步生成的1个lib文件: lapack.lib, blas.lib, f2c.lib,tmglib.lib.levmar.lib。

现在把下面的程序拷贝进去运行看看吧。(可以对比 levmar-2.6 里面的 expfit.c  )

// testlevmar.cpp : Defines the entry pointfor the console application.

//

////////////////////////////////////////////////////////////////////////////////////

// Example program that shows how to use levmar in order to fit the three-

// parameter exponential model x_i = p[0]*exp(-p[1]*i) + p[2] to a set of

// data measurements; example is based on a similar one from GSL.

//

// Copyright (C) 2008-11  ManolisLourakis (lourakis at ics forth gr)

// Institute of Computer Science, Foundation for Research & Technology- Hellas

// Heraklion, Crete, Greece.

//

// This program is free software; you can redistribute it and/or modify

// it under the terms of the GNU General Public License as published by

// the Free Software Foundation; either version 2 of the License, or

// (at your option) any later version.

//

// This program is distributed in the hope that it will be useful,

// but WITHOUT ANY WARRANTY; without even the implied warranty of

// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the

// GNU General Public License for more details.

//

////////////////////////////////////////////////////////////////////////////////////

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <math.h>

#include "levmar.h"

#ifdef _cplusplus

extern "C"{

#include "f2c.h"

#include "clapack.h"

}

#endif

#ifndef LM_DBL_PREC

#error Example program assumes that levmarhas been compiled with double precision, see LM_DBL_PREC!

#endif

#define M_PI 3.14

#undef REPEATABLE_RANDOM

#define DBL_RAND_MAX (double)(RAND_MAX)

#ifdef _MSC_VER // MSVC

#include <process.h>

#define GETPID  _getpid

#elif defined(__GNUC__) // GCC

#include <sys/types.h>

#include <unistd.h>

#define GETPID  getpid

#else

#warning Do not know the name of thefunction returning the process id for your OS / compiler combination

#define GETPID  0

#endif

#ifdef REPEATABLE_RANDOM

#define INIT_RANDOM(seed) srandom(seed)

#else

#define INIT_RANDOM(seed)srandom((int)GETPID()) // seed unused

#endif

double gNoise(double m, double s)

{

doubler1, r2, val;

r1= ((double)rand()) / DBL_RAND_MAX;

r2= ((double)rand()) / DBL_RAND_MAX;

val= sqrt(-2.0*log(r1))*cos(2.0*M_PI*r2);

val= s*val + m;

returnval;

}

struct xtradata{

charmsg[128];

};

void expfunc(double *p, double *x, int m,int n, void *data)

{

registerint i;

structxtradata *dat;

dat= (struct xtradata *)data;

for(i = 0; i<n; ++i)

{

x[i]= p[0] * exp(-p[1] * i) + p[2];

}

}

/* Jacobian of expfunc() */

void jacexpfunc(double *p, double *jac, intm, int n, void *data)

{

registerint i, j;

structxtradata *dat;

dat= (struct xtradata *)data;

/*fill Jacobian row by row */

for(i = j = 0; i<n; ++i)

{

jac[j++]= exp(-p[1] * i);

jac[j++]= -p[0] * i*exp(-p[1] * i);

jac[j++] = 1.0;

}

}

int main()

{

constint n = 40, m = 3; // 40 measurements, 3 parameters

doublep[m], x[n], opts[LM_OPTS_SZ], info[LM_INFO_SZ];

registerint i;

intret;

structxtradata data;

/*generate some measurement using the exponential model with

*parameters (5.0, 0.1, 1.0), corrupted with zero-mean

*Gaussian noise of s=0.1

*/

//INIT_RANDOM(0);//这个地方源程序是没注释掉的

for(i = 0; i<n; ++i)

x[i]= (5.0*exp(-0.1*i) + 1.0) + gNoise(0.0, 0.1);

/*initial parameters estimate: (1.0, 0.0, 0.0) */

p[0]= 1.0; p[1] = 0.0; p[2] = 0.0;

/*optimization control parameters; passing to levmar NULL instead of opts revertsto defaults */

opts[0]= LM_INIT_MU; opts[1] = 1E-15; opts[2] = 1E-15; opts[3] = 1E-20;

opts[4]= LM_DIFF_DELTA; // relevant only if the finite difference Jacobian version isused

strcpy_s(data.msg,"Hello there!");

/*invoke the optimization function */

ret= dlevmar_der(expfunc, jacexpfunc, p, x, m, n, 1000, opts, info, NULL, NULL,(void *)&data); // with analytic Jacobian

//ret=dlevmar_dif(expfunc,p, x, m, n, 1000, opts, info, NULL, NULL, (void *)&data); // withoutJacobian

printf("Levenberg-Marquardtreturned in %g iter, reason %g, sumsq %g [%g]\n", info[5], info[6],info[1], info[0]);

printf("Bestfit parameters: %.7g %.7g %.7g\n", p[0], p[1], p[2]);

system("pause");

exit(0);

}

Levmar 配置的更多相关文章

  1. NDK配置debug环境时:Error:FAILURE: Build failed with an exception

    Error:FAILURE: Build failed with an exception. * What went wrong: Execution failed for task ':app:ex ...

  2. levmar ndk 编译

         levmar是一个强大的和高效率的C/C++库,采用Levenberg - 马奎德(LM)优化算法, 主要是为了解决非线性最小二乘问题.官网是:http://users.ics.forth. ...

  3. Levmar:Levenberg-Marquardt非线性最小二乘算法

    Levmar:Levenberg-Marquardt非线性最小二乘算法 eryar@163.com Abstract. Levmar is GPL native ANSI C implementati ...

  4. 配置android sdk 环境

    1:下载adnroid sdk安装包 官方下载地址无法打开,没有vpn,使用下面这个地址下载,地址:http://www.android-studio.org/

  5. Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记

    以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...

  6. react-router 组件式配置与对象式配置小区别

    1. react-router 对象式配置 和 组件式配置    组件式配置(Redirect) ----对应---- 对象式配置(onEnter钩子) IndexRedirect -----对应-- ...

  7. 总结:Mac前端开发环境的搭建(配置)

    新年新气象,在2016年的第一天,我入手了人生中第一台自己的电脑(大一时好友赠送的电脑在一次无意中烧坏了主板,此后便不断借用别人的或者网站的).macbook air,身上已无分文...接下来半年的房 ...

  8. Android Studio 多个编译环境配置 多渠道打包 APK输出配置

    看完这篇你学到什么: 熟悉gradle的构建配置 熟悉代码构建环境的目录结构,你知道的不仅仅是只有src/main 开发.生成环境等等环境可以任意切换打包 多渠道打包 APK输出文件配置 需求 一般我 ...

  9. Virtual Box配置CentOS7网络(图文教程)

    之前很多次安装CentOS7虚拟机,每次配置网络在网上找教程,今天总结一下,全图文配置,方便以后查看. Virtual Box可选的网络接入方式包括: NAT 网络地址转换模式(NAT,Network ...

随机推荐

  1. Ouroboros Snake POJ - 1392(数位哈密顿回路)

    看hdu 2894的题意  两个题一样 旋转鼓的表面分成m块扇形,如图所示(m=8).图中阴影区表示用导电材料制成,空白区用绝缘材料制成,终端a.b和c是3(k=3)处接地或不是接地分别用二进制信号0 ...

  2. Picture POJ - 1177(扫描线求面积并)

    题意:求矩形并的面积.. 解析: 扫描线第一道题....自下而上扫描的... 如果不懂什么是扫描线戳我 #include <iostream> #include <cstdio> ...

  3. day8 笔记

    文件操作的最简单步骤open():打开文件,将句柄赋值给一个变量 read()write()等:操作文件 close():关闭文件,一定要关闭文件 ps:python会帮助你保存数据关闭文件,但是要在 ...

  4. BZOJ3730 震波 | 动态点分治

    #include <cstdio> #include <cstring> #include <cmath> #include <algorithm> # ...

  5. 洛谷 P2672 推销员 解题报告

    P2672 推销员 题目描述 阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户.螺丝街一共有N家住户,第i家住户到入口的距离为 ...

  6. Java -- JDBC 学习--批量处理

    批量处理JDBC语句提高处理速度 当需要成批插入或者更新记录时.可以采用Java的批量更新机制,这一机制允许多条语句一次性提交给数据库批量处理.通常情况下比单独提交处理更有效率JDBC的批量处理语句包 ...

  7. A1035. Password

    To prepare for PAT, the judge sometimes has to generate random passwords for the users. The problem ...

  8. redis访问安全加固

    目录 redis漏洞 入侵特征 安全隐患 redis安全规范 禁止root用户启动 限制redis文件目录访问权限 开启密码认证,设置复杂密码 禁用或重命名危险命令 设置允许监听地址,不要使用0.0. ...

  9. 【已解决】ERR_BLOCKED_BY_XSS_AUDITOR:Chrome 在此网页上检测到了异常代码:解决办法

    工作中,用Selenium自动化填表并获取结果时,程序一直安静的读取数据库,网页填表,获取结果,存库,但跑着跑着突然报错了. 排查后,原来不是Selenium的问题,是数据比较特殊,带了个双引号,如下 ...

  10. es6小记

    let, const, class, extends, super, arrow functions, template string, destructuring, default, rest ar ...