LCOV - code coverage report
Current view: top level - synthesis/TransformMachines - IlluminationConvFunc.cc (source / functions) Hit Total Coverage
Test: casacpp_coverage.info Lines: 0 38 0.0 %
Date: 2024-12-11 20:54:31 Functions: 0 3 0.0 %

          Line data    Source code
       1             : //# IlluminationConvFunc.cc: Implementation for IlluminationConvFunc
       2             : //# Copyright (C) 1996,1997,1998,1999,2000,2002
       3             : //# Associated Universities, Inc. Washington DC, USA.
       4             : //#
       5             : //# This library is free software; you can redistribute it and/or modify it
       6             : //# under the terms of the GNU Library General Public License as published by
       7             : //# the Free Software Foundation; either version 2 of the License, or (at your
       8             : //# option) any later version.
       9             : //#
      10             : //# This library is distributed in the hope that it will be useful, but WITHOUT
      11             : //# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
      12             : //# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Library General Public
      13             : //# License for more details.
      14             : //#
      15             : //# You should have received a copy of the GNU Library General Public License
      16             : //# along with this library; if not, write to the Free Software Foundation,
      17             : //# Inc., 675 Massachusetts Ave, Cambridge, MA 02139, USA.
      18             : //#
      19             : //# Correspondence concerning AIPS++ should be adressed as follows:
      20             : //#        Internet email: casa-feedback@nrao.edu.
      21             : //#        Postal address: AIPS++ Project Office
      22             : //#                        National Radio Astronomy Observatory
      23             : //#                        520 Edgemont Road
      24             : //#                        Charlottesville, VA 22903-2475 USA
      25             : //#
      26             : //#
      27             : //# $Id$
      28             : 
      29             : #define USETABLES 0
      30             : #include <synthesis/TransformMachines/IlluminationConvFunc.h>
      31             : 
      32             : using namespace casacore;
      33             : namespace casa{
      34             :   //
      35             :   //------------------------------------------------------------------------
      36             :   //
      37             :   /*
      38             :   void IlluminationConvFunc::getValue(CF_TYPE *coord,
      39             :                                       CF_TYPE *raoff1, CF_TYPE *raoff2, 
      40             :                                       CF_TYPE *decoff1, CF_TYPE *decoff2,
      41             :                                       CF_TYPE *area,
      42             :                                       std::complex<CF_TYPE>& weight,
      43             :                                       std::complex<CF_TYPE>& dweight1,
      44             :                                       std::complex<CF_TYPE>& dweight2
      45             :                                       )
      46             :   */
      47           0 :   CF_TYPE IlluminationConvFunc::getValue(Double *coord,
      48             :                                          Double *raoff1, Double *raoff2, 
      49             :                                          Double *decoff1, Double *decoff2,
      50             :                                          Double *area,
      51             :                                          Int *doGrad,
      52             :                                          Complex& weight,
      53             :                                          Complex& dweight1,
      54             :                                          Complex& dweight2,
      55             :                                          Double& /*currentCFPA*/
      56             :                                          // ,Double lsigma
      57             :                                          )
      58             :   {
      59           0 :     DComplex Kij;
      60           0 :     Double Rij,u,v,dra,ddec,s, MY_PI=M_PI;
      61             :     //    Double cpa,spa;
      62             :     //
      63             :     // If the PA of the convolution function changed, set up a new
      64             :     // rotation matrix
      65             :     //
      66             :     /*
      67             :     if (pa_p != currentCFPA)
      68             :       {
      69             :         pa_p = currentCFPA;
      70             :         cpa = cos(pa_p);
      71             :         spa = sin(pa_p);
      72             :       }
      73             :     */
      74             :     //
      75             :     // Compute the PA rotated (u,v)
      76             :     //
      77             :     //    u = cpa*coord[0] - spa*coord[1];
      78             :     //    v = spa*coord[0] + cpa*coord[1];
      79           0 :     u = coord[0];
      80           0 :     v = coord[1];
      81           0 :     s=4*sigma;
      82           0 :     dra=(*raoff1- *raoff2);
      83           0 :     ddec=(*decoff1 - *decoff2);
      84           0 :     Rij = (dra*dra + ddec*ddec)*s/2.0;
      85             :     //    Kij = Complex(0,M_PI*(u*(*raoff1+*raoff2) + v*(*decoff1+*decoff2)));
      86           0 :     Kij = Complex(0,MY_PI*(u*(*raoff1+*raoff2) + v*(*decoff1+*decoff2)));
      87             :     //    Eij0 = (u*u + v*v)*M_PI*M_PI/s;
      88             : 
      89             :     //    Rij = (dra*dra + ddec*ddec);
      90           0 :     Rij = 0;
      91             : #if(USETABLES)
      92             :     //
      93             :     // Compute it using lookup tables for exponentials.
      94             :     //
      95             :     Double tt=imag(Kij);
      96             : 
      97             :     //    weight = ExpTable((-Eij0-Rij))*CExpTable(tt)/ *area;
      98             :     weight = ExpTable((-Rij))*CExpTable(tt)/ *area;
      99             : #else
     100             :     //
     101             :     // Compute it exactly
     102             :     //
     103             :     //    weight = (exp((-Eij0-Rij)+Kij)/ *area);
     104           0 :     weight = (exp((-Rij)+Kij)/ *area);
     105             :     //    cout << exp(-Rij) << " " << exp(Kij) << " " << dra << " " << ddec << endl;
     106             : #endif
     107             : 
     108           0 :     if (doGrad)
     109             :       {
     110             :         //
     111             :         // Following 2 lines when Rij is not zero
     112             :         //
     113             :         //      dweight1 = (Complex(0,M_PI*u)-Complex(dra*  s,0.0))*weight;
     114             :         //      dweight2 = (Complex(0,M_PI*v)-Complex(ddec* s,0.0))*weight;
     115             :         //
     116             : //      dweight1 = -Complex(2*ddec,0) +  (Complex(0,M_PI*u));//*weight;
     117             : //      dweight2 = -Complex(2*dra,0) + (Complex(0,M_PI*v));//*weight;
     118             :         //
     119             :         // Following 2 lines when Rij=0
     120             :         //
     121           0 :         dweight1 = (Complex(0,MY_PI*u));//*weight;
     122           0 :         dweight2 = (Complex(0,MY_PI*v));//*weight;
     123             :       }
     124             :     //    cout << "Eij: " << weight << " " << dweight1 << " " << dweight2 << endl;
     125           0 :     return 1.0;
     126             :   }
     127             :   //
     128             :   //------------------------------------------------------------------------
     129             :   //
     130           0 :   CF_TYPE IlluminationConvFunc::area(Vector<Int>& convSupport, Vector<Double>& uvScale)
     131             :   {
     132           0 :     CF_TYPE u,v, area=0;
     133             : 
     134           0 :     for(Int i=-convSupport(0);i<convSupport(0);i++)
     135             :       {
     136           0 :         u = i*M_PI/uvScale(0);
     137           0 :         u *= u;
     138           0 :         for(Int j=-convSupport(0);j<convSupport(0);j++)
     139             :           {
     140           0 :             v = j*M_PI/uvScale(1);
     141           0 :             v *= v;
     142             : #ifdef USETABLES              
     143           0 :             area += ExpTable(-(u+v)/(4*sigma));
     144             : #else
     145             :             area += exp(-(u+v)/(4*sigma));
     146             : #endif        
     147             :           }
     148             :       }
     149           0 :     return area;
     150             :   };
     151             :   //
     152             :   //------------------------------------------------------------------------
     153             :   //
     154           0 :   Vector<Int> IlluminationConvFunc::supportSize(Vector<Double>& uvScale)
     155             :   {
     156             :     CF_TYPE u;
     157           0 :     Vector<Int> supportSize(uvScale.shape());
     158             : 
     159           0 :     for(Int i=0;i<100;i++)
     160             :       {
     161           0 :         u=i*M_PI/uvScale(0);
     162           0 :         u=u*u/(4*sigma);
     163           0 :         u=exp(-u);
     164           0 :         if (u < 1e-5) 
     165             :           {
     166           0 :             supportSize(0) = i;
     167           0 :             supportSize(0)++; // Increment it by one since this is
     168             :                               // used in FORTRAN indexing
     169           0 :             break;
     170             :           }
     171             :       }
     172           0 :     return supportSize;
     173           0 :   };
     174             : 
     175             : };

Generated by: LCOV version 1.16