https://github.com/cran/nleqslv
Raw File
Tip revision: 841972b2cdbfaddf568c3813f28ee733b4382d77 authored by Berend Hasselman on 26 November 2023, 23:30:14 UTC
version 3.3.5
Tip revision: 841972b
nwout.c

#include <stdio.h>
#include <string.h>
#include <math.h>

#include <R.h>

static  int jacsng = -1;
static  int jacupd = -1;
static  double jacond = 0.0;

/*
 * output for a single incorrect jacobian entry
 */

void F77_SUB(nwckot)(int *i, int *j, double *aij, double *wi)
{
    Rprintf("Chkjac  possible error in jacobian[%d,%d] = %20.13e\n"
            "                         Estimated[%d,%d] = %20.13e\n", *i, *j, *aij, *i, *j, *wi);
}

#if 0
/* for debugging */
void F77_SUB(prmunjac)(double *mu)
{
    Rprintf("nwnjac mu=%g\n",*mu);
}
void F77_SUB(prmubjac)(double *mu)
{
    Rprintf("nwbjac mu=%g\n",*mu);
}
void F77_SUB(praifal1)(double *aifnrm, double *al1nrm)
{
    Rprintf("aifnrm=%g al1nrm=%g\n",*aifnrm,*al1nrm);
}
#endif

void F77_SUB(nwsnot)(int *jtype, int *ierr, double *rcond)
{
    /*
     * save for later printing
     */

    jacsng = *ierr;
    jacupd = *jtype;
    jacond = *rcond;
}

double getjacond(void) { return(jacond); }

/*
 * output a compact description of the type of the jacobian used
 *    Newton/Broyden followed by lowercase letter for ill-conditioned/singular
 *    estimated inverse condition number
 *
 * sprintf on Windows seems to use 3 digits for the exponent by default (msvcrt.dll?)
 * and doesn't obey the %7.1e format (uses 8.1)
 * that messes up a nice layout
 */

static void  nwrowhdr(int *iter)
{
    char jmethod;

    Rprintf( "  %4d ", *iter);
    if( jacupd < 0) {
        /* output padding */
        Rprintf("%11s","");
    }
    else {
        jmethod = (jacupd == 0) ? 'N' : 'B';

        /*
         * meaning jacsng
         *   0   jacobian is ok (not singular or ill-conditioned)
         *   1   jacobian is ill-conditioned
         *   2   jacobian is singular
         *
         * Indicate this after output of <jmethod>
         */

        if( jacsng == 0 )
            Rprintf(" %c(%7.1e)", jmethod, jacond);
        else if( jacsng == 1 )
            Rprintf("%ci(%7.1e)", jmethod, jacond);
        else
            Rprintf("%cs%9s", jmethod,"");

        /*
         * avoid output of redundant information on next time called
         */

        jacupd = -1;
    }
}

void F77_SUB(nwjerr)(int *iter)
{
    nwrowhdr(iter);
    Rprintf("\n");
}

/*
 * output trust region size within width 8
 * (sometimes it is too large for %8.4f)
 */

static void dnumout(double x)
{
    if(x >= 1000.0)
        Rprintf(" %8.*e", x >= 1e100? 1 : 2, x);
    else
        Rprintf(" %8.4f",x);
}

static void enumout(double x)
{
    Rprintf(" %13.*e", fabs(x) >= 1e100? 5 : 6, x);
}

static void znumout(int retcd, double x)
{
    char marker;

    marker = (retcd == 3) ? '*' : ' ';
    Rprintf("%c%13.*e", marker, fabs(x) >= 1e100? 5 : 6, x);
}

#if 0
/* for debugging */
void F77_SUB(xclshpar)(int *gcnt, double *slope, double *a, double *b, double *disc, double *dbp2, double *t, double *t1,double *t2)
{
    Rprintf("Clsh: gcnt=%d, slope=%g, a=%g, b=%g, disc=%g, disc-b^2= %d, t=%g t1=%g t2=%g\n",*gcnt, *slope, *a, *b, *disc, *dbp2>0, *t,*t1,*t2);
}
#endif
void F77_SUB(nwprot)(int *iter, int *lstep, double *oarg)
{
    /*
     * None global method output
     */

    double v;

    if( *lstep <= 0 ) {
        if( *lstep == -1)
            Rprintf("  %4s %11s %8s  %13s %13s\n",
                        "Iter","Jac","Lambda","Fnorm","Largest |f|");

        Rprintf("  %4d%22s %13.6e %13.6e\n" , *iter, "", oarg[0],oarg[1]);
    }
    else {
        nwrowhdr(iter);
        v = *oarg;
        if( fabs(v) > 0.0001 )
            Rprintf( " %8.4f ",v);
        else
            Rprintf( " %8.1e ",v);

        enumout(oarg[1]);
        enumout(oarg[2]);
        Rprintf("\n");
    }
}

void F77_SUB(nwlsot)(int *iter, int *lstep, double *oarg)
{
    /*
     * Linesearch output
     */

    double v;

    if( *lstep <= 0 ) {
        if( *lstep == -1)
            Rprintf("  %4s %11s %8s  %13s %13s %13s\n",
                        "Iter","Jac","Lambda","Ftarg","Fnorm","Largest |f|");

        Rprintf("  %4d%36s %13.6e %13.6e\n" , *iter, "", oarg[0],oarg[1]);
    }
    else {
        nwrowhdr(iter);
        v = *oarg;
        if( fabs(v) > 0.0001 )
            Rprintf( " %8.4f ",v);
        else
            Rprintf( " %8.1e ",v);

        enumout(oarg[1]);
        enumout(oarg[2]);
        enumout(oarg[3]);
        Rprintf("\n");
    }
}

void F77_SUB(dgdbg)(double *gamma, double *numerator, double *denominator) {
    Rprintf("gamma=%g numerator=%g denominator=%g\n", *gamma, *numerator, *denominator);
}

void F77_SUB(nwdgot)(int *iter, int *lstep, int *retcd, double *oarg)
{
    /*
     * Double dogleg output
     */

    char step;

    /*
     *  C gradient (cauchy) step
     *  N newton step
     *  P partial newton step
     *  W convex combination of P and C
     */

    if( *lstep <= 0 ) {
        if( *lstep == -1)
            Rprintf("  %4s %11s   %8s %8s %8s %8s %13s %13s\n",
                       "Iter","Jac","Lambda", "Eta", "Dlt0", "Dltn", "Fnorm","Largest |f|");

        Rprintf("  %4d%50s" , *iter, "");
        enumout(oarg[0]);
        enumout(oarg[1]);
        Rprintf("\n");
    }
    else {
        nwrowhdr(iter);
        step = "CWPN"[*lstep-1];
        Rprintf( " %c ", step);

        if( *lstep == 2 )
            Rprintf( "%8.4f", oarg[0]);
        else
            Rprintf( "%8s", "");

        Rprintf(" %8.4f", oarg[3]);
        dnumout(oarg[1]);
        dnumout(oarg[2]);
        znumout(*retcd, oarg[4]);
        enumout(oarg[5]);
        Rprintf("\n");
    }
}

void F77_SUB(nwpwot)(int *iter, int *lstep, int *retcd, double *oarg)
{
    /*
     * Single dogleg output
     */

    char step;

    /*
     *  C gradient (cauchy) step
     *  N newton step
     *  W convex combination of P and C
     */

    if( *lstep <= 0 ) {
        if( *lstep == -1)
            Rprintf("  %4s %11s   %8s %8s %8s %13s %13s\n",
                        "Iter","Jac","Lambda", "Dlt0", "Dltn", "Fnorm","Largest |f|");

        Rprintf("  %4d%41s", *iter, "");
        enumout(oarg[0]);
        enumout(oarg[1]);
        Rprintf("\n");
    }
    else {
        nwrowhdr(iter);
        step = "CWN"[*lstep-1];
        Rprintf( " %c ", step);

        if( *lstep == 2 )
            Rprintf( "%8.4f",oarg[0]);
        else
            Rprintf( "%8s", "");

        dnumout(oarg[1]);
        dnumout(oarg[2]);
        znumout(*retcd, oarg[3]);
        enumout(oarg[4]);
        Rprintf("\n");
    }
}

void F77_SUB(nwmhot)(int *iter, int *lstep, int *retcd, double *oarg)
{
    /*
     * More-Hebden-Levenberg-Marquardt output
     */

    char step;

    /*
     *  H MHLM (hook)step
     *  N newton step
     */

    if( *lstep <= 0 ) {
        if( *lstep == -1)
            Rprintf("  %4s %11s   %8s %8s %8s %8s %13s %13s\n",
                       "Iter","Jac","mu", "dnorm", "Dlt0", "Dltn", "Fnorm","Largest |f|");

        Rprintf("  %4d%50s" , *iter, "");
        enumout(oarg[0]);
        enumout(oarg[1]);
        Rprintf("\n");
    }
    else {
        nwrowhdr(iter);
        step = "HN"[*lstep-1];
        Rprintf( " %c ", step);

        if( *lstep == 1 )
            Rprintf( "%8.4f", oarg[0]);
        else
            Rprintf( "%8s", "");

        Rprintf(" %8.4f", oarg[3]);
        dnumout(oarg[1]);
        dnumout(oarg[2]);
        znumout(*retcd, oarg[4]);
        enumout(oarg[5]);
        Rprintf("\n");
    }
}
back to top