fdjac2.c

来自「InsightToolkit-1.4.0(有大量的优化算法程序)」· C语言 代码 · 共 115 行

C
115
字号
#include "f2c.h"
#include "netlib.h"
extern double sqrt(double); /* #include <math.h> */

/* Table of constant values */
static integer c__1 = 1;

/* Subroutine */ void fdjac2_(fcn, m, n, x, fvec, fjac, ldfjac, iflag, epsfcn, wa)
/* Subroutine */ void (*fcn) (integer*,integer*,doublereal*,doublereal*,integer*);
integer *m, *n;
doublereal *x, *fvec, *fjac;
integer *ldfjac, *iflag;
doublereal *epsfcn, *wa;
{
    /* Initialized data */
    static doublereal zero = 0.;

    /* Local variables */
    static doublereal temp, h;
    static integer i, j;
    static doublereal epsmch;
    static doublereal eps;

/*     ********** */

/*     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.                               */

/*     argonne national laboratory. minpack project. march 1980. */
/*     burton s. garbow, kenneth e. hillstrom, jorge j. more */

/*     ********** */

/*     epsmch is the machine precision. */

    epsmch = dpmpar_(&c__1);

    eps = sqrt((max(*epsfcn,epsmch)));
    for (j = 0; j < *n; ++j) {
        temp = x[j];
        h = eps * abs(temp);
        if (h == zero) {
            h = eps;
        }
        x[j] = temp + h;
        (*fcn)(m, n, x, wa, iflag);
        if (*iflag < 0) {
            break;
        }
        x[j] = temp;
        for (i = 0; i < *m; ++i) {
            fjac[i + j * *ldfjac] = (wa[i] - fvec[i]) / h;
        }
    }
    return;
} /* fdjac2_ */

⌨️ 快捷键说明

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