LCOV - code coverage report
Current view: top level - synthesis/fortran - fgridsdclip.f (source / functions) Hit Total Coverage
Test: casacpp_coverage.info Lines: 85 93 91.4 %
Date: 2024-12-11 20:54:31 Functions: 3 3 100.0 %

          Line data    Source code
       1             : *=======================================================================
       2             : *     Copyright (C) 1999,2001,2002
       3             : *     Associated Universities, Inc. Washington DC, USA.
       4             : *
       5             : *     This library is free software; you can redistribute it and/or
       6             : *     modify it under the terms of the GNU Library General Public
       7             : *     License as published by the Free Software Foundation; either
       8             : *     version 2 of the License, or (at your option) any later version.
       9             : *
      10             : *     This library is distributed in the hope that it will be useful,
      11             : *     but WITHOUT ANY WARRANTY; without even the implied warranty of
      12             : *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      13             : *     GNU Library General Public License for more details.
      14             : *
      15             : *     You should have received a copy of the GNU Library General Public
      16             : *     License along with this library; if not, write to the Free
      17             : *     Software Foundation, Inc., 675 Massachusetts Ave, Cambridge,
      18             : *     MA 02139, USA.
      19             : *
      20             : *     Correspondence concerning AIPS++ should be addressed as follows:
      21             : *            Internet email: casa-feedback@nrao.edu.
      22             : *            Postal address: AIPS++ Project Office
      23             : *                            National Radio Astronomy Observatory
      24             : *                            520 Edgemont Road
      25             : *                            Charlottesville, VA 22903-2475 USA
      26             : *
      27             : *     $Id$
      28             : *-----------------------------------------------------------------------
      29             : C
      30             : C Calculate gridded coordinates
      31             : C
      32          50 :       subroutine sgridsdclip (xy, sampling, pos, loc, off)
      33             :       implicit none
      34             :       integer sampling
      35             :       integer loc(2), off(2)
      36             :       double precision xy(2)
      37             :       real pos(2)
      38             :       integer idim
      39             : 
      40         150 :       do idim=1,2
      41         100 :          pos(idim)=xy(idim)+1.0
      42         100 :          loc(idim)=nint(pos(idim))
      43         150 :          off(idim)=nint((loc(idim)-pos(idim))*sampling)
      44             :       end do
      45          50 :       return 
      46             :       end
      47             : C
      48             : C Is this on the grid?
      49             : C
      50          50 :       logical function ogridsdclip (nx, ny, loc, support)
      51             :       implicit none
      52             :       integer nx, ny, loc(2), support
      53             :       ogridsdclip=(loc(1)-support.ge.1).and.(loc(1)+support.le.nx).and.
      54          50 :      $     (loc(2)-support.ge.1).and.(loc(2)+support.le.ny)
      55          50 :       return
      56             :       end
      57             : C
      58             : C Grid a number of visibility records: single dish gridding
      59             : C but with complex images including additional process for
      60             : C min/max clipping 
      61             : C
      62             : C This subroutine assumes specific clipping process after
      63             : C all the data are accumulated
      64             : C
      65             : C Post-accumulation process is as follows. On each pixel,
      66             : C
      67             : C - if npoints == 1, grid = gmin, wgrid = wmin, sumwt must
      68             : C   be updated accordingly
      69             : C - if npoints == 2, grid = gmin + gmax, wgrid = wmin + wmax,
      70             : C   sumwt must be updated accordingly
      71             : C - otherwise, leave grid, wgrid, and sumwt as they are
      72             : C
      73          37 :       subroutine ggridsdclip (xy, values, nvispol, nvischan,
      74          37 :      $   dowt, flag, rflag, weight, nrow, irow,
      75          37 :      $   grid, wgrid, 
      76          37 :      $   npoints, gmin, wmin, gmax, wmax,
      77             :      $   nx, ny, npol, nchan, 
      78          37 :      $   support, sampling, convFunc, chanmap, polmap, sumwt)
      79             : 
      80             :       implicit none
      81             :       integer nx, ny, npol, nchan, nvispol, nvischan, nrow
      82             :       complex values(nvispol, nvischan, nrow)
      83             :       complex grid(nx, ny, npol, nchan)
      84             :       real wgrid(nx, ny, npol, nchan)
      85             :       integer npoints(nx, ny, npol, nchan)
      86             :       complex gmin(nx, ny, npol, nchan)
      87             :       complex gmax(nx, ny, npol, nchan)
      88             :       real wmin(nx, ny, npol, nchan)
      89             :       real wmax(nx, ny, npol, nchan)
      90             :       double precision xy(2,nrow)
      91             :       integer flag(nvispol, nvischan, nrow)
      92             :       integer rflag(nrow)
      93             :       real weight(nvischan, nrow)
      94             :       double precision sumwt(npol, nchan)
      95             :       integer irow
      96             :       integer support, sampling
      97             :       integer chanmap(nvischan), polmap(nvispol)
      98             :       integer dowt
      99             : 
     100             :       complex nvalue, thevalue
     101             : 
     102             :       real convFunc(*)
     103             :       real norm
     104             :       real wt, wtx, wty
     105             :       real swap, theweight, nweight
     106             : 
     107             :       logical ogridsdclip
     108             : 
     109             :       real pos(2), rloc(2)
     110             :       integer loc(2), off(2)
     111             :       integer rbeg, rend
     112          74 :       integer irad((2*support+1)**2)
     113             :       integer ix, iy, ipol, ichan
     114             :       integer apol, achan
     115             :       integer ir
     116          37 :       integer xloc(2*support+1), yloc(2*support+1)
     117             :       integer ax, ay
     118             : 
     119          37 :       if(irow.ge.0) then
     120           0 :          rbeg=irow+1
     121           0 :          rend=irow+1
     122             :       else 
     123          37 :          rbeg=1
     124          37 :          rend=nrow
     125             :       end if
     126             : 
     127          87 :       do irow=rbeg, rend
     128          87 :          if(rflag(irow).eq.0) then
     129          50 :          call sgridsdclip(xy(1,irow), sampling, pos, loc, off)
     130             : C          if (ogridsdclip(nx, ny, loc, support)) then
     131          50 :          if (ogridsdclip(nx, ny, loc, 0)) then
     132          50 :             ir=1
     133          50 :             norm=-(support+1)*sampling+off(1)
     134          50 :             rloc(2)=-(support+1)*sampling+off(2)
     135         100 :             do iy=1,2*support+1
     136          50 :                rloc(2)=rloc(2)+sampling
     137          50 :                rloc(1)=norm
     138         150 :                do ix=1,2*support+1
     139          50 :                   rloc(1)=rloc(1)+sampling
     140          50 :                   irad(ir)=sqrt(rloc(1)**2+rloc(2)**2)+1
     141         100 :                   ir=ir+1
     142             :                end do
     143             :             end do
     144          50 :             xloc(1)=loc(1)-support
     145          50 :             do ix=2,2*support+1
     146          50 :                xloc(ix)=xloc(ix-1)+1
     147             :             end do
     148          50 :             yloc(1)=loc(2)-support
     149          50 :             do iy=2,2*support+1
     150          50 :                yloc(iy)=yloc(iy-1)+1
     151             :             end do
     152         106 :             do ichan=1, nvischan
     153          56 :                achan=chanmap(ichan)+1
     154          56 :                if((achan.ge.1).and.(achan.le.nchan).and.
     155          50 :      $              (weight(ichan,irow).gt.0.0)) then
     156         112 :                   do ipol=1, nvispol
     157          56 :                      apol=polmap(ipol)+1
     158             :                      if((flag(ipol,ichan,irow).ne.1).and.
     159         112 :      $                    (apol.ge.1).and.(apol.le.npol)) then
     160          56 :                         if (dowt.eq.1) then
     161           0 :                          thevalue=1.0
     162             :                         else
     163          56 :                          thevalue=conjg(values(ipol,ichan,irow))
     164             :                         end if
     165          56 :                         theweight=weight(ichan,irow)
     166          56 :                         norm=0.0
     167          56 :                         ir=1
     168             : C                        do iy=-support,support
     169         112 :                         do iy=1,2*support+1
     170          56 :                            ay=yloc(iy)
     171         112 :                            if ((ay.ge.1).and.(ay.le.ny)) then
     172             : C                            do ix=-support,support
     173         112 :                            do ix=1,2*support+1
     174          56 :                               ax=xloc(ix)
     175         112 :                               if ((ax.ge.1).and.(ax.le.nx)) then
     176          56 :                               ir = (iy-1)*(2*support+1) + ix
     177          56 :                               wt=convFunc(irad(ir))
     178          56 :                               nweight=theweight*wt
     179          56 :                               nvalue=thevalue*nweight
     180          56 :                               if (npoints(ax,ay,apol,achan).eq.0) then
     181          22 :                                 gmin(ax,ay,apol,achan)=thevalue
     182          22 :                                 wmin(ax,ay,apol,achan)=nweight
     183             :                               else if
     184          34 :      $                          (npoints(ax,ay,apol,achan).eq.1) then
     185          18 :                                 if (real(gmin(ax,ay,apol,achan)).lt.
     186             :      $                            real(thevalue)) then
     187           4 :                                   gmax(ax,ay,apol,achan)=thevalue
     188           4 :                                   wmax(ax,ay,apol,achan)=nweight
     189             :                                 else
     190             :                                   gmax(ax,ay,apol,achan)=
     191          14 :      $                              gmin(ax,ay,apol,achan)
     192             :                                   wmax(ax,ay,apol,achan)=
     193          14 :      $                              wmin(ax,ay,apol,achan)
     194          14 :                                   gmin(ax,ay,apol,achan)=thevalue
     195          14 :                                   wmin(ax,ay,apol,achan)=nweight
     196             :                                 end if
     197             :                               else
     198          16 :                               if (real(thevalue).le.
     199             :      $                          real(gmin(ax,ay,apol,achan))) then
     200             :                                 nvalue=wmin(ax,ay,apol,achan)*
     201          14 :      $                            gmin(ax,ay,apol,achan)
     202          14 :                                 gmin(ax,ay,apol,achan)=thevalue
     203          14 :                                 swap=nweight
     204          14 :                                 nweight=wmin(ax,ay,apol,achan)
     205          14 :                                 wmin(ax,ay,apol,achan)=swap
     206           2 :                               else if (real(thevalue).ge.
     207             :      $                          real(gmax(ax,ay,apol,achan))) then
     208             :                                 nvalue=wmax(ax,ay,apol,achan)*
     209           0 :      $                            gmax(ax,ay,apol,achan)
     210           0 :                                 gmax(ax,ay,apol,achan)=thevalue
     211           0 :                                 swap=nweight
     212           0 :                                 nweight=wmax(ax,ay,apol,achan)
     213           0 :                                 wmax(ax,ay,apol,achan)=swap
     214             :                               end if
     215             :                               grid(ax,ay,apol,achan)=
     216          16 :      $                             grid(ax,ay,apol,achan)+nvalue
     217             :                               wgrid(ax,ay,apol,achan)=
     218          16 :      $                             wgrid(ax,ay,apol,achan)+nweight
     219          16 :                               norm=norm+nweight
     220             :                               end if
     221             :                               npoints(ax,ay,apol,achan)=
     222          56 :      $                          npoints(ax,ay,apol,achan)+1
     223             :                               end if
     224             :                            end do
     225             :                            end if
     226             :                         end do
     227          56 :                         sumwt(apol,achan)=sumwt(apol,achan)+norm
     228             :                      end if
     229             :                   end do
     230             :                end if
     231             :             end do
     232             :          end if
     233             :          end if
     234             :       end do
     235          37 :       return
     236             :       end

Generated by: LCOV version 1.16