📄 tchkder_.c
字号:
/* driver for chkder example. */#include <stdio.h>#include <math.h>#include <minpack.h>void fcn(int *m, int *n, double *x, double *fvec, double *fjac, int *ldfjac, int *iflag);int main(){ int i, m, n, ldfjac, mode; double x[3], fvec[15], fjac[15*3], xp[3], fvecp[15], err[15]; int one=1, two=2; m = 15; n = 3; /* the following values should be suitable for */ /* checking the jacobian matrix. */ x[1-1] = 9.2e-1; x[2-1] = 1.3e-1; x[3-1] = 5.4e-1; ldfjac = 15; mode = 1; chkder_(&m, &n, x, fvec, fjac, &ldfjac, xp, fvecp, &mode, err); mode = 2; fcn(&m, &n, x, fvec, fjac, &ldfjac, &one); fcn(&m, &n, x, fvec, fjac, &ldfjac, &two); fcn(&m, &n, xp, fvecp, fjac, &ldfjac, &one); chkder_(&m, &n, x, fvec, fjac, &ldfjac, xp, fvecp, &mode, err); for (i=1; i<=m; i++) { fvecp[i-1] = fvecp[i-1] - fvec[i-1]; } printf("\n fvec\n"); for (i=1; i<=m; i++) printf("%s%15.7g",i%3==1?"\n ":"", fvec[i-1]); printf("\n fvecp - fvec\n"); for (i=1; i<=m; i++) printf("%s%15.7g",i%3==1?"\n ":"", fvecp[i-1]); printf("\n err\n"); for (i=1; i<=m; i++) printf("%s%15.7g",i%3==1?"\n ":"", err[i-1]); printf("\n"); return 0;}void fcn(int *m, int *n, double *x, double *fvec, double *fjac, int *ldfjac, int *iflag){ /* subroutine fcn for chkder example. */ int i; double tmp1, tmp2, tmp3, tmp4; double y[15]={1.4e-1, 1.8e-1, 2.2e-1, 2.5e-1, 2.9e-1, 3.2e-1, 3.5e-1, 3.9e-1, 3.7e-1, 5.8e-1, 7.3e-1, 9.6e-1, 1.34, 2.1, 4.39}; if (*iflag != 2) for (i=1; i<=15; i++) { tmp1 = i; tmp2 = 16 - i; tmp3 = tmp1; if (i > 8) tmp3 = tmp2; fvec[i-1] = y[i-1] - (x[1-1] + tmp1/(x[2-1]*tmp2 + x[3-1]*tmp3)); } else { for (i = 1; i <= 15; i++) { tmp1 = i; tmp2 = 16 - i; /* error introduced into next statement for illustration. */ /* corrected statement should read tmp3 = tmp1 . */ tmp3 = tmp2; if (i > 8) tmp3 = tmp2; tmp4 = (x[2-1]*tmp2 + x[3-1]*tmp3); tmp4=tmp4*tmp4; fjac[i-1+ *ldfjac*(1-1)] = -1.; fjac[i-1+ *ldfjac*(2-1)] = tmp1*tmp2/tmp4; fjac[i-1+ *ldfjac*(3-1)] = tmp1*tmp3/tmp4; } } return;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -