r319: add complex-valued imagefile support
[ctsim.git] / include / imagefile.h
index 7c7daba56eae43d69172b47763cbb2dd69fa7a28..57d093f83c397499e90c01490596a70241c8fa6a 100644 (file)
@@ -9,7 +9,7 @@
 **  This is part of the CTSim program
 **  Copyright (C) 1983-2000 Kevin Rosenberg
 **
-**  $Id: imagefile.h,v 1.24 2000/12/29 15:45:06 kevin Exp $
+**  $Id: imagefile.h,v 1.25 2000/12/29 19:30:08 kevin Exp $
 **
 **  This program is free software; you can redistribute it and/or modify
 **  it under the terms of the GNU General Public License (version 2) as
 class F32Image : public Array2dFile
 {
 public:
-  F32Image (int nx, int ny);     
+  F32Image (int nx, int ny, int dataType = Array2dFile::DATA_TYPE_REAL);     
   F32Image (void);\r
 
-  kfloat32** getArray (void)
-      { return (kfloat32**) (m_arrayData); }
-
-  kfloat32** const getArray (void) const
-       { return (kfloat32** const) (m_arrayData); }
-
+  kfloat32** getArray (void)\r
+      { return (kfloat32**) (m_arrayData); }\r
+\r
+  kfloat32** const getArray (void) const\r
+       { return (kfloat32** const) (m_arrayData); }\r
+\r
+  kfloat32** getImaginaryArray (void)\r
+      { return (kfloat32**) (m_imaginaryArrayData); }\r
+\r
+  kfloat32** const getImaginaryArray (void) const\r
+       { return (kfloat32** const) (m_imaginaryArrayData); }\r
+\r
 #ifdef HAVE_MPI
   MPI::Datatype getMPIDataType (void) const
       { return MPI::FLOAT; }
@@ -70,15 +76,21 @@ class F64Image : public Array2dFile
 {
  public:
 
-  F64Image (int nx, int ny);
+   F64Image (int nx, int ny, int dataType = Array2dFile::DATA_TYPE_REAL);
   F64Image (void);
 
-  kfloat64** getArray (void)
-      { return (kfloat64**) (m_arrayData); }
-
-  kfloat64** const getArray (void) const
-      { return (kfloat64** const) (m_arrayData); }
-
+  kfloat64** getArray (void)\r
+      { return (kfloat64**) (m_arrayData); }\r
+\r
+  kfloat64** const getArray (void) const\r
+      { return (kfloat64** const) (m_arrayData); }\r
+\r
+  kfloat64** getImaginaryArray (void)\r
+      { return (kfloat64**) (m_imaginaryArrayData); }\r
+\r
+  kfloat64** const getImaginaryArray (void) const\r
+      { return (kfloat64** const) (m_imaginaryArrayData); }\r
+\r
 #ifdef HAVE_MPI
   MPI::Datatype getMPIDataType (void) const
       { return MPI::DOUBLE; }
@@ -116,10 +128,14 @@ class ImageFile : public ImageFileBase
   ImageFile (void)
       : ImageFileBase ()
   {}
+\r
+  bool convertRealToComplex ();\r
+  bool convertComplexToReal ();\r
 
   void filterResponse (const char* const domainName, double bw, const char* const filterName, double filt_param);
 
-  void statistics (double& min, double& max, double& mean, double& mode, double& median, double& stddev) const;
+  void statistics (double& min, double& max, double& mean, double& mode, double& median, double& stddev) const;\r
+  void statistics (ImageFileArrayConst& v, double& min, double& max, double& mean, double& mode, double& median, double& stddev) const;\r
   void getMinMax (double& min, double& max) const;
   void printStatistics (std::ostream& os) const;
   bool comparativeStatistics (const ImageFile& imComp, double& d, double& r, double& e) const;
@@ -135,8 +151,10 @@ class ImageFile : public ImageFileBase
   bool square (ImageFile& result) const;\r
   bool log (ImageFile& result) const;\r
   bool exp (ImageFile& result) const;\r
-  bool FFTMagnitude (ImageFile& result) const;\r
-  bool FFTPhase (ImageFile& result) const;\r
+  bool fourier (ImageFile& result) const;\r
+  bool inverseFourier (ImageFile& result) const;\r
+  bool magnitude (ImageFile& result) const;\r
+  bool phase (ImageFile& result) const;\r
 \r
   int display (void) const;
   int displayScaling (const int scaleFactor, ImageFileValue pmin, ImageFileValue pmax) const;