IPP Software Navigation Tools IPP Links Communication Pan-STARRS Links

Ignore:
Timestamp:
Mar 30, 2010, 1:29:50 PM (16 years ago)
Author:
eugene
Message:

add diff stats; add flux to CMF_PS1_DV1; output PSF residual mask; more accurate calculation of radius of source model

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/psModules/src/objects/models/pmModel_QGAUSS.c

    r26916 r27531  
    3939# define PM_MODEL_SET_LIMITS      pmModelSetLimits_QGAUSS
    4040
     41# define ALPHA   2.250
     42# define ALPHA_M 1.250
     43
    4144// the model is a function of the pixel coordinate (pixcoord[0,1] = x,y)
    4245// 0.5 PIX: the parameters are defined in terms of pixel coords, so the incoming pixcoords
     
    4447
    4548// Lax parameter limits
    46 static float paramsMinLax[] = { -1.0e3, 1.0e-2, -100, -100, 0.5, 0.5, -1.0, 0.1 };
     49static float paramsMinLax[] = { -1.0e3, 1.0e-2, -100, -100, 0.5, 0.5, -1.0, -1.0 };
    4750static float paramsMaxLax[] = { 1.0e5, 1.0e8, 1.0e4, 1.0e4, 100, 100, 1.0, 20.0 };
    4851
    4952// Moderate parameter limits
    50 static float *paramsMinModerate = paramsMinLax;
    51 static float *paramsMaxModerate = paramsMaxLax;
     53// Tolerate a small divot (k < 0)
     54static float paramsMinModerate[] = { -1.0e3, 1.0e-2, -100, -100, 0.5, 0.5, -1.0, -0.05 };
     55static float paramsMaxModerate[] = { 1.0e5, 1.0e8, 1.0e4, 1.0e4, 100, 100, 1.0, 20.0 };
    5256
    5357// Strict parameter limits
    54 static float *paramsMinStrict = paramsMinLax;
    55 static float *paramsMaxStrict = paramsMaxLax;
     58// k = PAR_7 < 0 is very undesirable (big divot in the middle)
     59static float paramsMinStrict[] = { -1.0e3, 1.0e-2, -100, -100, 0.5, 0.5, -1.0, 0.0 };
     60static float paramsMaxStrict[] = { 1.0e5, 1.0e8, 1.0e4, 1.0e4, 100, 100, 1.0, 20.0 };
    5661
    5762// Parameter limits to use
    5863static float *paramsMinUse = paramsMinLax;
    5964static float *paramsMaxUse = paramsMaxLax;
    60 static float betaUse[] = { 1000, 3e6, 5, 5, 1.0, 1.0, 0.5 };
     65static float betaUse[] = { 1000, 3e6, 5, 5, 1.0, 1.0, 0.5, 2.0 };
    6166
    6267static bool limitsApply = true;         // Apply limits?
     
    8186    assert (z >= 0);
    8287
    83     psF32 zp = pow(z,1.25);
     88    psF32 zp = pow(z,ALPHA_M);
    8489    psF32 r  = 1.0 / (1 + PAR[PM_PAR_7]*z + z*zp);
    8590
     
    9297        // note difference from a pure gaussian: q = params->data.F32[PM_PAR_I0]*r
    9398        psF32 t = r1*r;
    94         psF32 q = t*(PAR[PM_PAR_7] + 2.25*zp);
     99        psF32 q = t*(PAR[PM_PAR_7] + ALPHA*zp);
    95100
    96101        dPAR[PM_PAR_SKY]  = +1.0;
     
    246251    float f1, f2;
    247252    for (z = DZ; z < 50; z += DZ) {
    248         f1 = 1.0 / (1 + PAR[PM_PAR_7]*z + pow(z, 2.25));
     253        f1 = 1.0 / (1 + PAR[PM_PAR_7]*z + pow(z, ALPHA));
    249254        z += DZ;
    250         f2 = 1.0 / (1 + PAR[PM_PAR_7]*z + pow(z, 2.25));
     255        f2 = 1.0 / (1 + PAR[PM_PAR_7]*z + pow(z, ALPHA));
    251256        norm += f0 + 4*f1 + f2;
    252257        f0 = f2;
     
    263268psF64 PM_MODEL_RADIUS (const psVector *params, psF64 flux)
    264269{
    265     psF64 z, f;
     270    psF64 z;
    266271    int Nstep = 0;
    267272    psEllipseShape shape;
     
    269274    psF32 *PAR = params->data.F32;
    270275
    271     if (flux <= 0)
    272         return (1.0);
    273     if (PAR[PM_PAR_I0] <= 0)
    274         return (1.0);
    275     if (flux >= PAR[PM_PAR_I0])
    276         return (1.0);
     276    if (flux <= 0) return 1.0;
     277    if (PAR[PM_PAR_I0] <= 0) return 1.0;
     278    if (flux >= PAR[PM_PAR_I0]) return 1.0;
     279    if (PAR[PM_PAR_7] == 0.0) return powf(PAR[PM_PAR_I0] / flux - 1.0, 1.0 / ALPHA);
    277280
    278281    shape.sx  = PAR[PM_PAR_SXX] / M_SQRT2;
     
    290293
    291294    // choose a z value guaranteed to be beyond our limit
    292     float z0 = pow((1.0 / limit), (1.0 / 2.25));
    293     psAssert (isfinite(z0), "fix this code: z0 should not be nan for %f", PAR[PM_PAR_7]);
    294     float z1 = (1.0 / limit) / PAR[PM_PAR_7];
     295    float z0 = 0.0;
     296    float z1 = pow((1.0 / limit), (1.0 / ALPHA));
    295297    psAssert (isfinite(z1), "fix this code: z1 should not be nan for %f", PAR[PM_PAR_7]);
    296     z1 = PS_MAX (z0, z1);
    297     z0 = 0.0;
    298 
    299     // perform a type of bisection to find the value
    300     float f0 = 1.0 / (1 + PAR[PM_PAR_7]*z0 + pow(z0, 2.25));
    301     float f1 = 1.0 / (1 + PAR[PM_PAR_7]*z1 + pow(z1, 2.25));
    302     while ((Nstep < 10) && (fabs(z1 - z0) > 0.5)) {
    303         z = 0.5*(z0 + z1);
    304         f = 1.0 / (1 + PAR[PM_PAR_7]*z + pow(z, 2.25));
    305         if (f > limit) {
    306             z0 = z;
    307             f0 = f;
    308         } else {
    309             z1 = z;
    310             f1 = f;
    311         }
    312         Nstep ++;
     298    if (PAR[PM_PAR_7] < 0.0) z1 *= 2.0;
     299
     300    // starting guess:
     301    z = 0.5*(z0 + z1);
     302    float dz = 1.0;
     303
     304    // use Newton-Raphson to minimize f(z) - limit = 0
     305    for (int i = 0; (i < 10) && (fabs(dz) > 0.0001); i++) {
     306        float q = (1.0 + PAR[PM_PAR_7]*z + pow(z, ALPHA));
     307        float dqdz = (PAR[PM_PAR_7] + ALPHA*pow(z, ALPHA - 1.0));
     308
     309        float f = 1.0 / q;
     310        float dfdz = -dqdz * f / q;
     311
     312        dz = (f - limit) / dfdz;
     313
     314        // fprintf (stderr, "%f %f %f : %f %f\n", f, z, dz, dfdz, q);
     315        z -= dz;
    313316    }
    314317    psF64 radius = sigma * sqrt (2.0 * z);
     
    475478# undef PM_MODEL_FIT_STATUS
    476479# undef PM_MODEL_SET_LIMITS
     480# undef ALPHA
     481# undef ALPHA_M
Note: See TracChangeset for help on using the changeset viewer.