00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014 #ifndef _VONMISES_H
00015 #define _VONMISES_H
00016
00017 #include "cmodel.h"
00018 #include "elasplas.h"
00019
00020
00021
00022
00023 class cVonMises : public cElastoPlastic
00024 {
00025 protected:
00026 double _Qtrial;
00027 double *_Ep, *_IteEp;
00028 double _Alpha, _IteAlpha;
00029
00030 public:
00031 cVonMises ( cIntPt *, cMaterial * );
00032 ~cVonMises ( void );
00033 void Init ( void );
00034 void Update ( void );
00035 int Stress ( double *, double * );
00036 void ModifyCMatrix ( double ** );
00037 void GetPlasticVar ( double *, double * );
00038 void SetPlasticVar ( double *, double * );
00039 void InternalVar ( double *, double * );
00040 void PlasticModuli ( double *, double ** );
00041 double YieldFunction ( double *, double * );
00042 void YieldGrad ( double *, double *, double *, double * );
00043 void YieldHessian ( double *, double *, double ** );
00044 int GetNumPrintScls( void );
00045 void GetPrintSclLabs( char ** );
00046 void GetPrintSclVals( double *, double * );
00047
00048 private:
00049 void GetMatData ( double *, double * );
00050 void VecTensor3D ( double *, sTensor * );
00051 };
00052
00053 #endif