/*************************************************************************** fitsprocess.h - Image processing utilities ------------------- begin : Tue Feb 24 2004 copyright : (C) 2004 by Jasem Mutlaq email : mutlaqja@ikarustech.com ***************************************************************************/ /*************************************************************************** * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * ***************************************************************************/ #ifndef FITSPROCESS_H #define FITSPROCESS_H #include #include #include /*1. TQPtrList darkFrames; 2. TQPtrList flatFrames; 3. The class reads the hdu of each FITS, the size of each frame must match the original frame, if not, abort and inform the user. 4. Ignore the EXPOSURE (time in milliseconds) differences for now. We need to compensate for differences by employing different methods of extrapolation later. 5. void combine(int mode); mode is either FITS_AVERAGE or FITS_MEDIAN. 6. void subtract(unsigned int * img1, unsigned int * img2); we know numOfPixels already. 7. void divide(unsigned int * img1, unsigned int * img2); we know numOfPixels already.*/ class FITSViewer; class TQImage; class FITSProcess { public: FITSProcess(FITSViewer *parent, TQStringList darkFiles, TQStringList flatFiles, TQStringList darkflatFiles, int darkMode, int flatMode, int darkflatMode); ~FITSProcess(); TQPtrList darkFrames; TQPtrList flatFrames; TQPtrList darkflatFrames; FITSViewer *viewer; int npix; int darkCombineMode; int flatCombineMode; int darkflatCombineMode; float *finalDark; float *finalFlat; float *finalDarkFlat; float * combine(TQPtrList & frames, int mode); void subtract(float * img1, float * img2); void divide(float * img1, float * img2); void reduce(); void normalize(float *buf); float quick_select(float * arr, int n); float average(float * array, int n); float min(float *buf); }; class FITSProcessCommand : public KCommand { public: FITSProcessCommand(FITSViewer *parent); ~FITSProcessCommand(); void execute(); void unexecute(); TQString name() const; private: FITSViewer *viewer; float * buffer; TQImage *oldImage; }; #endif