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

📄 fdjac2_.c

📁 这是在张正友摄像机标定的基础上对其算法进行改进
💻 C
字号:
/* fdjac2.f -- translated by f2c (version 20020621).   You must link the resulting object file with the libraries:	-lf2c -lm   (in that order)*/#include <math.h>#include "minpack.h"#define max(a,b) ((a) >= (b) ? (a) : (b))/* Subroutine */ void fdjac2_(void (*fcn)(const int *m, const int *n, const double *x, double *fvec,			 int *iflag ), const int *m, const int *n, double *x, 	const double *fvec, double *fjac, const int *ldfjac, int *iflag, 	const double *epsfcn, double *wa){    /* Table of constant values */    const int c__1 = 1;    /* System generated locals */    int fjac_dim1, fjac_offset, i__1, i__2;    /* Local variables */    double h__;    int i__, j;    double eps, temp, epsmch;/*     ********** *//*     subroutine fdjac2 *//*     this subroutine computes a forward-difference approximation *//*     to the m by n jacobian matrix associated with a specified *//*     problem of m functions in n variables. *//*     the subroutine statement is *//*       subroutine fdjac2(fcn,m,n,x,fvec,fjac,ldfjac,iflag,epsfcn,wa) *//*     where *//*       fcn is the name of the user-supplied subroutine which *//*         calculates the functions. fcn must be declared *//*         in an external statement in the user calling *//*         program, and should be written as follows. *//*         subroutine fcn(m,n,x,fvec,iflag) *//*         integer m,n,iflag *//*         double precision x(n),fvec(m) *//*         ---------- *//*         calculate the functions at x and *//*         return this vector in fvec. *//*         ---------- *//*         return *//*         end *//*         the value of iflag should not be changed by fcn unless *//*         the user wants to terminate execution of fdjac2. *//*         in this case set iflag to a negative integer. *//*       m is a positive integer input variable set to the number *//*         of functions. *//*       n is a positive integer input variable set to the number *//*         of variables. n must not exceed m. *//*       x is an input array of length n. *//*       fvec is an input array of length m which must contain the *//*         functions evaluated at x. *//*       fjac is an output m by n array which contains the *//*         approximation to the jacobian matrix evaluated at x. *//*       ldfjac is a positive integer input variable not less than m *//*         which specifies the leading dimension of the array fjac. *//*       iflag is an integer variable which can be used to terminate *//*         the execution of fdjac2. see description of fcn. *//*       epsfcn is an input variable used in determining a suitable *//*         step length for the forward-difference approximation. this *//*         approximation assumes that the relative errors in the *//*         functions are of the order of epsfcn. if epsfcn is less *//*         than the machine precision, it is assumed that the relative *//*         errors in the functions are of the order of the machine *//*         precision. *//*       wa is a work array of length m. *//*     subprograms called *//*       user-supplied ...... fcn *//*       minpack-supplied ... dpmpar *//*       fortran-supplied ... dabs,dmax1,dsqrt *//*     argonne national laboratory. minpack project. march 1980. *//*     burton s. garbow, kenneth e. hillstrom, jorge j. more *//*     ********** */    /* Parameter adjustments */    --wa;    --fvec;    --x;    fjac_dim1 = *ldfjac;    fjac_offset = 1 + fjac_dim1 * 1;    fjac -= fjac_offset;    /* Function Body *//*     epsmch is the machine precision. */    epsmch = dpmpar_(&c__1);    *iflag = 1;    eps = sqrt((max(*epsfcn,epsmch)));    i__1 = *n;    for (j = 1; j <= i__1; ++j) {	temp = x[j];	h__ = eps * fabs(temp);	if (h__ == 0.) {	    h__ = eps;	}	x[j] = temp + h__;	(*fcn)(m, n, &x[1], &wa[1], iflag);	if (*iflag < 0) {	    /* goto L30; */            return;	}	x[j] = temp;	i__2 = *m;	for (i__ = 1; i__ <= i__2; ++i__) {	    fjac[i__ + j * fjac_dim1] = (wa[i__] - fvec[i__]) / h__;/* L10: */	}/* L20: */    }/* L30: */    return;/*     last card of subroutine fdjac2. */} /* fdjac2_ */

⌨️ 快捷键说明

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