NAG(Numerical Algorithms Group, www.nag.com)库是一个无与伦比的算法库,它提供的算法可靠、轻便、严谨,覆盖了数学与统计方方面面。最大的缺点就是:它是一个收费的算法库。

Origin从OriginPro8开始就包含了NAG库的所有函数,通过Origin C可以轻易调用所有这些NAG函数。

Origin C调用NAG库函数的主要说明:

1.头文件

#include <OC_nag.h>  // 这个头文件包括所有通用的NAG头文件

2.NagError结构体,Origin C里的定义如下:

typedef struct {
int code; // Out: Error Code
BOOL print; // In: print? yes/no, not used in Origin C
char message[NAG_ERROR_BUF_LEN]; // InOut: Error message
UINT handler; //Error handling function, not used from OriginC
int errnum; // May hold useful value for some errors
} NagError;

所有的NAG库的函数都接受NagError结构体的指针作为其中的一个参数。通过这个结构体可以测试对应调用的函数是否成功。当调用完函数后,可以通过测试code的值是否为NE_NOERROR#define NE_NOERROR 0)来判断是否成功。

下面演示如何通过调用NAG库的函数来做一个简单的线性回归。用到的NAG库函数为:

void nag_simple_linear_regression (Nag_SumSquare mean,
Integer n, const double x[], const double y[],
const double wt[], double *a, double *b,
double *a_serr, double *b_serr, double *rsq,
double *rss, double *df, NagError *fail)

调用的时候,函数名字除了用nag_simple_linear_regression,也可以用g02cac,后者有点像是代号一样。

参数说明:

1.mean: 类型为Nag_SumSquare,Origin C里这样定义:

#define Nag_SumSquare_start 1362
typedef enum {Nag_AboutMean=Nag_SumSquare_start, Nag_AboutZero} Nag_SumSquare;

这个参数指定是否把直线模型y=a+bx中的a常数项包括入回归当中。如果mean的值为Nag_AboutMean,则回归常项包括进来,否则为Nag_AboutZero就不包括常数项。

2.n:观察值的个数。如果mean == Nag_AboutMeann要大于等于2,如果mean == Nag_AboutZeron要大于等于1

3.x[]:自变量。

4.y[]:因变量。

5.wt[]:权重。如果没有权重,则为NULL

6.a:输出值。如果mean == Nag_AboutMean,输出值为回归常数项,否则为0

7.b:输出值。线性模型的系数。

8.a_serr:输出值。回归常数项的标准差。

9.b_serr:输出值。系数的标准差。

10.rsq:输出值。判定系数。

11.rss:输出值。残差平方和。

12.df:输出值。自由度。

13.fail: NagError结构体,可以用来判断回归是否成功。

函数代码如下:

void Origin_Call_NAG() {  // 定义一个Origin C函数,编译通过可以直接在Origin的Script Window直接运行
Nag_SumSquare mean = Nag_AboutMean; // 回归中包括常数项
int n;
double *x, *y, *wt;
double a, b, a_serr, b_serr, rsq, rss, df;
NagError fail; // 准备数据
n = 8;
x = (double *)malloc(sizeof(double) * n);
y = (double *)malloc(sizeof(double) * n);
wt = (double *)malloc(sizeof(double) * n);
x[0] = 1.0;
x[1] = 0.0;
x[2] = 4.0;
x[3] = 7.5;
x[4] = 2.5;
x[5] = 0.0;
x[6] = 10.0;
x[7] = 5.0;
y[0] = 20.0;
y[1] = 15.5;
y[2] = 28.3;
y[3] = 45.0;
y[4] = 24.5;
y[5] = 10.0;
y[6] = 99.0;
y[7] = 31.2;
wt[0] = 1.0;
wt[1] = 1.0;
wt[2] = 1.0;
wt[3] = 1.0;
wt[4] = 1.0;
wt[5] = 1.0;
wt[6] = 1.0;
wt[7] = 1.0; // 调用NAG函数
nag_simple_linear_regression(mean, n, x, y, wt,
&a, &b, &a_serr, &b_serr,
&rsq, &rss, &df, &fail);
// 或者这样
//g02cac(mean, n, x, y, wt, &a, &b, &a_serr,
//&b_serr, &rsq, &rss, &df, &fail); if (fail.code != NE_NOERROR) { // 回归失败
printf("错误来自于nag_simple_linear_regression(g02cac)。\n%s\n",
fail.message);
} else {
if (mean == Nag_AboutMean) {
printf("\n回归常数项 a = %6.4f\n", a);
printf("回归常数项的标准差 a_serr = %6.4f\n", a_serr);
}
printf("回归系数 b = %6.4f\n", b);
printf("回归系数的标准差 b_serr = %6.4f\n", b_serr);
printf("判别系数R^2 rsq = %6.4f\n", rsq);
printf("残差平方和 rss = %6.4f\n", rss);
printf("自由度 df = %6.4f\n", df);
} free(x);
free(y);
free(wt);
}

源码可于github下载:https://github.com/gkimeeq/OriginAdvancedApplication

Origin C调用NAG库的更多相关文章

  1. Java调用动态库方法说明-最详细

    Java不能直接调用由c或者c++写得dll(TF_ID.dll),所以只能采用jni得方法,一步一步生成符合规范得dll文件(假设叫FANGJIAN.dll),在FANGJIAN.dll这个文件里来 ...

  2. C#:控制台程序调用中间库创建窗体

    1.类库项目引用System.Windows.Forms并添加引用后,才可创建窗体. 2.控制台应用程序调用中间库(DLL)中的方法创建窗体:中间类库使用反射下的Assembly加载包含窗体的类库及创 ...

  3. Android JNI如何调用第三方库

    http://www.2cto.com/kf/201504/388764.html Android JNI找不到第三方库的解决方案 cannot load library 最近做一个jni项目,拿到的 ...

  4. C++调用C#库简单例程

    有些时候,为了使用别人已经写好的C#库文件,我们需要使用C++调用C#库文件: 以下做了一简单的调用工程,步骤如下: 1.准备C#库 (dll文件)   1)创建C#库:     2)编写C#类:   ...

  5. iOS开发:在Swift中调用oc库

    先列举这个工程中用到的oc源码库: MBProgressHUD:半透明提示器,Loading动画等 SDWebImage:图片下载和缓存的库 MJRefresh: 下拉刷新,上拉加载 Alamofir ...

  6. Qt中调用PolarSSL库(一)

    最近一直在学习SSL相关的知识,也是先了解理论相关的知识,主要是SSL相关的基本概念和连接建立过程,主要是基于PolarSSL开源库进行学习.学习完了之后就希望能给有所运用,就想用Qt写一个简单的程序 ...

  7. [置顶] android利用jni调用第三方库——第三篇——编写库android程序整合第三方库libhello.so到自己的库libhelloword.so

    0:前言: 在第二篇中,我们主要介绍了丙方android公司利用乙方C++公司给的动态库,直接调用库中的方法,但是这样方式受限于: 乙方C++公司开发的动态库是否符合jni的规范,如果不规范,则不能直 ...

  8. [置顶] android利用jni调用第三方库——第二篇——编写库android程序直接调用第三方库libhello.so

    0:前言 1:本文主要作为丙方android公司的身份来写 2:作者有不对的地方,请指出,谢谢 [第一篇:android利用jni调用第三方库——编写库libhello.so] [第二篇:androi ...

  9. windows下Qt Creator5.1.0编写程序以及调用OpenCV库

    系统说明 最近使用opencv编写程序,程序编的差不多就学习使用QT加个界面,首先声明下本人的系统和使用的软件版本, 系统: windows xp QT IDE:QT Creator5.1.0 Ope ...

随机推荐

  1. Android: 帮助找出内存泄漏的工具

    1. Intellij Idea的Memory Monitor 通过Memory Monitor,我们可以知道哪个页面哪些操作会占用比较多的内存.如果需要更详细的信息,可以导出heap,通过MAT来分 ...

  2. sizeof小览

    一.文章来由-一道面试题迁出的探究 我发现我已经形成一种习惯写来由了,以后看博客的时候能够让我回顾起为什么出现这个问题,我用什么方法解决的,既然形成习惯就让这个习惯保持下去吧.今天实验室师姐在看书,一 ...

  3. Android应用程序无法读写USB设备的解决方法

    假设android系统中的API或者apk无法读写usb设备.可能是没有加入读写usb的权限,须要依照例如以下方法进行设置: 1. 在android.hardware.usb.host.xml文件里加 ...

  4. word设置

    word文档编号

  5. Java遍历一个文件夹下的全部文件

    Java工具中为我们提供了一个用于管理文件系统的类,这个类就是File类,File类与其它流类不同的是,流类关心的是文件的内容.而File类关心的是磁盘上文件的存储. 一,File类有多个构造器,经常 ...

  6. BestCoder Round #59 (div.2) B. Reorder the Books 想法题

    Reorder the Books 问题描述 dxy家收藏了一套书,这套书叫<SDOI故事集>,<SDOI故事集>有n(n\leq 19)n(n≤19)本,每本书有一个编号,从 ...

  7. 【转载】java学习线路

    http://www.cnblogs.com/Leo_wl/p/5437059.html java基础(java编程思想) =>web开发(html/css/js  servlet/jsp 数据 ...

  8. 【POJ 1958】 Strange Towers of Hanoi

    [题目链接] http://poj.org/problem?id=1958 [算法] 先考虑三个塔的情况,g[i]表示在三塔情况下的移动步数,则g[i] = g[i-1] * 2 + 1 再考虑四个塔 ...

  9. 【WIP】Ruby CSV文件操作

    创建: 2017/09/30                                                                                       ...

  10. 过河 2005年NOIP全国联赛提高组(离散化+dp)

    1105 过河 2005年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description 在河上有一 ...