⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tchkder.c

📁 该程序实现了非线性最小二乘问题和非线性方程组的解法
💻 C
字号:
/*      driver for chkder example. */#include <stdio.h>#include <math.h>#include <cminpack.h>int fcn(int m, int n, const double *x, double *fvec,	 double *fjac, int ldfjac, int iflag);int main(){  int i, m, n, ldfjac;  double x[3], fvec[15], fjac[15*3], xp[3], fvecp[15],     err[15];  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;  chkder(m, n, x, fvec, fjac, ldfjac, xp, fvecp, 1, err);  fcn(m, n, x, fvec, fjac, ldfjac, 1);  fcn(m, n, x, fvec, fjac, ldfjac, 2);  fcn(m, n, xp, fvecp, fjac, ldfjac, 1);  chkder(m, n, x, fvec, fjac, ldfjac, xp, fvecp, 2, 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;}int fcn(int m, int n, const 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 == 0)     {      /*      insert print statements here when nprint is positive. */      return 0;    }  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 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -