00001 /* 00002 Arroyo - software for the simulation of electromagnetic wave propagation 00003 through turbulence and optics. 00004 00005 Copyright (c) 2000-2004 California Institute of Technology. Written by 00006 Dr. Matthew Britton. For comments or questions about this software, 00007 please contact the author at mbritton@astro.caltech.edu. 00008 00009 This program is free software; you can redistribute it and/or modify it 00010 under the terms of the GNU General Public License as published by the 00011 Free Software Foundation; either version 2 of the License, or (at your 00012 option) any later version. 00013 00014 This program is provided "as is" and distributed in the hope that it 00015 will be useful, but WITHOUT ANY WARRANTY; without even the implied 00016 warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. In no 00017 event shall California Institute of Technology be liable to any party 00018 for direct, indirect, special, incidental or consequential damages, 00019 including lost profits, arising out of the use of this software and its 00020 documentation, even if the California Institute of Technology has been 00021 advised of the possibility of such damage. The California Institute of 00022 Technology has no obligation to provide maintenance, support, updates, 00023 enhancements or modifications. See the GNU General Public License for 00024 more details. 00025 00026 You should have received a copy of the GNU General Public License along 00027 with this program; if not, write to the Free Software 00028 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. 00029 */ 00030 00031 #ifndef PALOMAR_MODEL_H 00032 #define PALOMAR_MODEL_H 00033 00034 #include <three_vector.h> 00035 #include "refractive_atmosphere.h" 00036 00037 namespace Arroyo { 00038 00044 00045 class Palomar_DIMM_MASS_model : 00046 public refractive_atmospheric_model { 00047 00048 private: 00049 00050 static const bool factory_registration; 00051 00054 string unique_name() const {return(string("Gemini GLAO study model"));}; 00055 00058 Palomar_DIMM_MASS_model(){}; 00059 00060 public: 00061 00064 Palomar_DIMM_MASS_model(const Palomar_DIMM_MASS_model & cn2_model); 00065 00068 Palomar_DIMM_MASS_model(const char * filename); 00069 00072 Palomar_DIMM_MASS_model(const iofits & iof); 00073 00079 Palomar_DIMM_MASS_model(const three_frame & tf, 00080 double r_0_meters = .087, 00081 double r_0_ref_wavelength_meters = .5e-6); 00082 00085 ~Palomar_DIMM_MASS_model(){}; 00086 00089 Palomar_DIMM_MASS_model & 00090 operator=(const Palomar_DIMM_MASS_model & cn2_model); 00091 00096 Palomar_DIMM_MASS_model * clone() const { 00097 return(new Palomar_DIMM_MASS_model(*this)); 00098 }; 00099 00102 void read(const char * filename); 00103 00106 void read(const iofits & iof); 00107 00110 void write(const char * filename) const; 00111 00114 void write(iofits & iof) const; 00115 00118 void print(ostream & os, const char * prefix="") const; 00119 00120 }; 00121 00122 } 00123 00124 #endif
1.3.9.1