00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef __GAS_NetSliceBalance__
00020 #define __GAS_NetSliceBalance__
00021
00022 #include "GAS_API.h"
00023
00024 #include "GAS_SubSolver.h"
00025 #include "GAS_Utils.h"
00026
00027 #include <SIM/SIM_SlicePlane.h>
00028 #include <GEO/GEO_AttributeHandle.h>
00029
00030 class SIM_GeometryCopy;
00031 class GU_Detail;
00032 class SIM_SlicePlane;
00033
00034 class GAS_API GAS_NetSliceBalance : public GAS_SubSolver
00035 {
00036 public:
00037 GET_DATA_FUNC_S(GAS_NAME_GEOMETRY, GeometryName);
00038
00039 GET_DATA_FUNC_S(GAS_NAME_TRACKERADDR, TrackerAddress);
00040 GET_DATA_FUNC_I(GAS_NAME_TRACKERPORT, TrackerPort);
00041 GET_DATA_FUNC_S(GAS_NAME_JOBNAME, JobName);
00042 GET_DATA_FUNC_I("slice", Slice);
00043
00044 GET_DATA_FUNC_S("sliceattr", SliceAttr);
00045 GET_DATA_FUNC_S("sliceroot", SliceRoot);
00046
00047 GET_DATA_FUNC_F("balanceweight", BalanceWeight);
00048 GET_DATA_FUNC_F("timeweight", TimeWeight);
00049
00050 protected:
00051 explicit GAS_NetSliceBalance(const SIM_DataFactory *factory);
00052 virtual ~GAS_NetSliceBalance();
00053
00054 virtual bool solveGasSubclass(SIM_Engine &engine,
00055 SIM_Object *obj,
00056 SIM_Time time,
00057 SIM_Time timestep);
00058
00059 private:
00060 void doNetBalance(SIM_GeometryCopy *geo,
00061 SIM_SlicePlane *sliceroot,
00062 int64 delta,
00063 const char *address,
00064 int port,
00065 const char *jobname);
00066
00067 static const SIM_DopDescription *getDopDescription();
00068
00069 DECLARE_STANDARD_GETCASTTOTYPE();
00070 DECLARE_DATAFACTORY(GAS_NetSliceBalance,
00071 GAS_SubSolver,
00072 "Gas Net Slice Balance",
00073 getDopDescription());
00074 };
00075
00076 #endif
00077