00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012 #ifndef _MultiYieldSurface_H_
00013 #define _MultiYieldSurface_H_
00014
00015 #include <T2Vector.h>
00016
00017
00018 #define LOCK_VALUE 1.0e+30
00019
00020
00021 double secondOrderEqn(double A, double B, double C, int i);
00022
00023
00024 class MultiYieldSurface
00025 {
00026
00027 public:
00028
00029 MultiYieldSurface();
00030 MultiYieldSurface(const Vector & center_init, double size_init,
00031 double plas_modul);
00032 ~MultiYieldSurface();
00033 void setData(const Vector & center_init, double size_init,
00034 double plas_modul);
00035 const Vector & center() const {return theCenter; }
00036 double size() const {return theSize; }
00037 double modulus() const {return plastShearModulus; }
00038 void setCenter(const Vector & newCenter);
00039
00040
00041
00042
00043 protected:
00044
00045 private:
00046 double theSize;
00047 Vector theCenter;
00048 double plastShearModulus;
00049
00050 };
00051
00052 #endif