LCOV - code coverage report
Current view: top level - synthesis/TransformMachines - FTMachine.tcc (source / functions) Hit Total Coverage
Test: casacpp_coverage.info Lines: 37 84 44.0 %
Date: 2024-11-06 17:42:47 Functions: 1 1 100.0 %

          Line data    Source code
       1             : //# FTMachine.tcc //For templated functions of FTMachine class 
       2             : //# Copyright (C) 2015-2019
       3             : //# Associated Universities, Inc. Washington DC, USA.
       4             : //#
       5             : //# This library is free software; you can redistribute it and/or modify
       6             : //# it under the terms of the GNU General Public License as published by
       7             : //# the Free Software Foundation; either version 2 of the License, or
       8             : //# (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 General Public License for more details.
      14             : //# 
      15             : //# You should have received a copy of the GNU General Public License
      16             : //# along with this library; if not, write to the Free Software
      17             : //# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
      18             : //#
      19             : //# Correspondence concerning AIPS++ should be addressed 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          21 :  template <class T> void FTMachine::getGrid(casacore::Array<T>& thegrid){
      28             : 
      29          21 :     thegrid.resize();
      30          21 :     void * ptr = nullptr;
      31          21 :     casacore::Array<casacore::Float> tmpFloat;
      32          21 :     casacore::Array<casacore::Double> tmpDouble;
      33          21 :     casacore::IPosition shp;
      34             :     bool del;
      35          21 :     if((whatType<Array<T>>()==casacore::TpArrayComplex)){
      36           0 :         if(useDoubleGrid_p){
      37           0 :           griddedData.resize(griddedData2.shape());
      38           0 :           convertArray(griddedData, griddedData2);
      39           0 :           griddedData2.resize();
      40           0 :           useDoubleGrid_p=false;
      41             :         }
      42           0 :          ptr=griddedData.getStorage(del);
      43           0 :          shp=griddedData.shape();
      44             :     }
      45          21 :     else if(whatType<Array<T>>()==casacore::TpArrayDComplex){
      46           0 :       if(!useDoubleGrid_p){
      47           0 :         griddedData2.resize(griddedData.shape());
      48           0 :         convertArray(griddedData2, griddedData);
      49           0 :         griddedData.resize();
      50           0 :         useDoubleGrid_p=true;
      51             :       }
      52           0 :       ptr=griddedData2.getStorage(del);
      53           0 :       shp=griddedData2.shape();
      54             :         
      55             : 
      56             :     }
      57          21 :     else if(((whatType<Array<T>>()==casacore::TpArrayFloat))){
      58          21 :       if(!useDoubleGrid_p){
      59          21 :         tmpFloat.resize(griddedData.shape());
      60             :         
      61             :       }
      62             :       else{
      63           0 :         tmpFloat.resize(griddedData2.shape());
      64           0 :         griddedData.resize(griddedData2.shape());
      65           0 :         convertArray(griddedData, griddedData2);
      66           0 :         griddedData2.resize();
      67           0 :         useDoubleGrid_p=false;
      68             :         //convertArray(tmpFloat, real(griddedData2));
      69             :       }
      70             : 
      71             : 
      72          21 :       tmpFloat.set(0.0);
      73          21 :       shp=tmpFloat.shape();
      74          21 :       Int end_indx = 0;
      75             :       //cerr << "getgrid "  << sum(griddedData) << endl;
      76          21 :       casacore::IPosition in(4, 0, 0, 0, 0);
      77          21 :       casacore::IPosition out(4, 0,0,0,0);
      78             : 
      79          21 :       tmpFloat = real(griddedData);
      80             :       //cerr << "tmpFloat "  << sum(tmpFloat) << endl;
      81         338 :       for (casacore::Int cc=0; cc< shp[3]; ++cc){
      82         317 :         in[3]=cc;
      83         317 :         out[3]=cc;
      84         634 :         for(casacore::Int pp=0; pp< shp[2]; ++pp){
      85         317 :           in[2]=pp;
      86         317 :           out[2]=pp;
      87             : 
      88       85121 :           for (casacore::Int yy=-shp[1]/2; yy< shp[1]-shp[1]/2; ++yy){
      89             : 
      90    34258932 :             for(casacore::Int xx=-shp[0]/2; xx< shp[0]-shp[0]/2; ++xx){
      91    34174128 :               in[0]=xx + shp[0]/2;
      92    34174128 :               in[1]=yy + shp[1]/2;
      93    34174128 :               out[0]=-xx + shp[0]/2;
      94    34174128 :               out[1]=-yy + shp[1]/2;
      95             :               
      96    34174128 :               if((out[0] < shp[0]) && (out[1] < shp[1])) 
      97             :                 {
      98    33998957 :                   tmpFloat(in)+=real(griddedData(out));
      99             :                 }
     100             :             }
     101             : 
     102             :           }
     103             :         }
     104             :       }
     105             :        //cerr << "getgrid "  << sum(griddedData) << endl;
     106             :       //tmpFloat = real(griddedData);
     107             :       //cerr << "tmpFloat " << sum(tmpFloat) << endl;
     108          21 :       ptr=tmpFloat.getStorage(del);
     109             :       //ptr=griddedData.getStorage(del);
     110          21 :     }
     111           0 :     else if(((whatType<Array<T>>()==casacore::TpArrayDouble))){
     112           0 :        if(useDoubleGrid_p){
     113           0 :          tmpDouble.resize(griddedData2.shape());        
     114             :        }
     115             :        else{
     116           0 :          tmpDouble.resize(griddedData.shape());
     117           0 :          griddedData2.resize(griddedData.shape());
     118           0 :          convertArray(griddedData2, griddedData);
     119           0 :          griddedData.resize();
     120           0 :          useDoubleGrid_p=true;
     121             :          //convertArray(tmpFloat, real(griddedData2));
     122             :        }
     123             :       
     124           0 :       tmpDouble=real(griddedData2);
     125           0 :       shp=tmpDouble.shape();
     126           0 :       casacore::IPosition in(4, 0, 0, 0, 0);
     127           0 :       casacore::IPosition out(4, 0,0,0,0);
     128             : 
     129           0 :       for (casacore::Int cc=0; cc< shp[3]; ++cc){
     130           0 :         in[3]=cc;
     131           0 :         out[3]=cc;
     132           0 :         for(casacore::Int pp=0; pp< shp[2]; ++pp){
     133           0 :           in[2]=pp;
     134           0 :           out[2]=pp;
     135             : 
     136           0 :           for (casacore::Int yy=-shp[1]/2; yy< shp[1]-shp[1]/2; ++yy){
     137             : 
     138           0 :             for(casacore::Int xx=-shp[0]/2; xx< shp[0]-shp[0]/2; ++xx){
     139           0 :               in[0]=xx + shp[0]/2;
     140           0 :               in[1]=yy + shp[1]/2;
     141           0 :               out[0]=-xx + shp[0]/2;
     142           0 :               out[1]=-yy + shp[1]/2;
     143             :               
     144           0 :               if((out[0] < shp[0]) && (out[1] < shp[1])) 
     145             :                 {
     146           0 :                   tmpDouble(in)+=real(griddedData(out));
     147             :                 }
     148             :             }
     149             : 
     150             :           }
     151             :         }
     152             :       }
     153           0 :       ptr=tmpDouble.getStorage(del);
     154             : 
     155             : 
     156           0 :     }  
     157          21 :     thegrid=casacore::Array<T>(shp, (T*)(ptr));
     158          21 :     griddedData.resize();
     159          21 :     griddedData2.resize();
     160          21 :   };

Generated by: LCOV version 1.16