00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef INC_MI32_VARIOGRAM_H
00021 #define INC_MI32_VARIOGRAM_H
00022
00023 #ifndef INC_MI32_DOUBLEAR_H
00024 #include <mi32/doublear.h>
00025 #endif
00026
00027 #ifndef INC_MI32_SIMPLEAR_H
00028 #include <mi32/simplear.h>
00029 #endif
00030
00031 #ifndef INC_MI32_MXDIALOG_H
00032 #include <mi32/mxdialog.h>
00033 #endif
00034
00035 class VARIOGRAM {
00036 public:
00037
00038 enum MODEL {
00039 MODEL_Linear = 0,
00040 MODEL_Spherical = 1,
00041 MODEL_Exponential = 2,
00042 MODEL_Quadratic = 3,
00043 MODEL_Gaussian = 4
00044 };
00045
00046 VARIOGRAM (
00047 );
00048
00049 VARIOGRAM (
00050 const VARIOGRAM& rhs
00051 );
00052
00053 ~VARIOGRAM (
00054 );
00055
00056 VARIOGRAM operator= (
00057 const VARIOGRAM& rhs
00058 );
00059
00060 void Clear (
00061 );
00062
00063 double ComputeCovariance (
00064 const DPOINT2D& p1,
00065 const DPOINT2D& p2
00066 ) const ;
00067
00068 double GetAnisotropicAngle (
00069 ) const { return m_AnisotropicAngle; }
00070
00071 double GetAnisotropicRatio (
00072 ) const { return m_AnisotropicRatio; }
00073
00074 MODEL GetModel (
00075 ) const { return m_Model; }
00076
00077 double GetNugget (
00078 ) const { return m_Nugget; }
00079
00080 double GetRange (
00081 ) const { return m_Range; }
00082
00083 double GetSill (
00084 ) const { return m_Sill; }
00085
00086 ERRVALUE Init (
00087 const DOUBLE_ARRAY<DPOINT3D>& points,
00088 const DRECT3D extents
00089 );
00090
00091 bool IsInitialized (
00092 ) const { return m_IsInitialized; }
00093
00094 void SetAnisotropicAngle (
00095 const double angle
00096 );
00097
00098 double SetAnisotropicRatio (
00099 const double ratio
00100 );
00101
00102 void SetModel (
00103 const MODEL model
00104 );
00105
00106 void SetNugget (
00107 const double nugget
00108 );
00109
00110 void SetRange (
00111 const double range
00112 );
00113
00114 void SetSill (
00115 const double sill
00116 );
00117
00118 #ifndef WIN32_NATIVE
00119 ERRVALUE DisplayPlot (
00120 );
00121
00122 ERRVALUE Save (
00123 );
00124 #endif
00125
00126
00127 private:
00128 #ifndef GENERATING_DOXYGEN_OUTPUT
00129 bool m_IsInitialized;
00130
00131 MODEL m_Model;
00132 double m_Nugget;
00133 double m_Range;
00134 double m_Sill;
00135 double m_AnisotropicAngle;
00136 double m_AnisotropicRatio;
00137 MXDHANDLE m_XYHandle;
00138
00140
00141 double m_C;
00142 double m_Sin;
00143 double m_Cos;
00144 bool m_IsAnisotropic;
00145
00147
00148 #ifndef WIN32_NATIVE
00149 static void CB_XYDestroy (McbAnyCallbackStruct *cbs, void *vdata);
00150 #endif
00151
00152 void CheckAnisotropic ();
00153 double ComputeLinear (const double distance) const;
00154 double ComputeSpherical (const double distance) const;
00155 double ComputeExponential (const double distance) const;
00156 double ComputeQuadratic (const double distance) const;
00157 double ComputeGaussian (const double distance) const;
00158
00160
00161 struct ITEM {
00162 double m_Variance;
00163 double m_Distance;
00164 INT32 m_Count;
00165 };
00166
00167 SIMPLE_ARRAY<ITEM> m_Items;
00168 double m_LagLength;
00169 INT32 m_NumLags;
00170
00172
00173 double EstimateSill (const DOUBLE_ARRAY<DPOINT3D>& points);
00174 double EstimateRange (const double sill);
00175 ERRVALUE Setup (const DRECT3D& extents, const INT32 number);
00176 ERRVALUE Normalize ();
00177 ERRVALUE Add (const DPOINT3D& point);
00178
00179 #ifndef WIN32_NATIVE
00180 ERRVALUE UpdatePlot (
00181 );
00182 #endif
00183
00185
00186 #endif // GENERATING_DOXYGEN_OUTPUT
00187 };
00188
00189 #endif