00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef _AgentPopulationHandler_h
00020 #define _AgentPopulationHandler_h
00021
00022 #include <string>
00023 #include "BasicEnums.h"
00024 #include "FinancialMathFunctions.h"
00025 #include "Agent.h"
00026 #include"MainAuxiliaryFunctions.h"
00027
00028 class IrrigationMethodSector;
00029 class TimeHandler;
00030 #ifndef LP_OLD
00031 #include "MipHandler.h"
00032 #endif
00033
00034
00035 typedef struct {
00036 int sek;
00037 int sc;
00038 } s_id;
00039
00040
00041 class b_liste
00042 { private:
00043
00044 #ifndef LP_OLD
00045 bool test;
00046 MipHandler* globalProblemHandler;
00047 SolverType solver;
00048 string solvername;
00049 #endif
00050
00051
00052 protected:
00053 int bl_nr;
00054 int banzahl;
00055 int letzte_b_nr;
00056 int* banzahl_NW;
00057
00058 agent* firstBetrieb;
00059 agent* merkeBetrieb;
00060
00061 public:
00062 b_liste(int scID);
00063 virtual ~b_liste();
00064
00065 #ifndef LP_OLD
00066 virtual void setSolverType(SolverType solver);
00067 virtual void setTolerance(double eps);
00068 virtual bool readDatFile(char* filename);
00069 virtual bool writeDatFile();
00070 #endif
00071
00072
00073 virtual void makeAgentL(int scid, int skid, int numP);
00074 virtual void makeAgentF(int scid, int skid, int ppid, int clid, int nwid, int fstd, int numP);
00075
00076 virtual void deallokieren(agent*);
00077 virtual void betriebssortiert_einfuegen(agent*);
00078
00079 virtual agent* ersten_suchen(int);
00080 virtual agent* imaginaeren_suchen(int s);
00081 virtual agent* naechsten_suchen(int);
00082 virtual agent* betrieb_suchen(int);
00083 virtual agent* betrieb_herausnehmen(int);
00084 virtual s_id betrieb_SID(int);
00085 virtual int farbe_ermitteln(int);
00086
00087
00088
00089 virtual nutz ersten_nutzer_suchen(int, int);
00090 virtual nutz naechsten_nutzer_suchen(int, int);
00091
00092
00093 virtual int get_bl_nr(void);
00094 virtual void set_bl_nr(int bl_nr_);
00095 virtual int get_anzahl_NW(int);
00096 virtual int get_anzahl(void);
00097 virtual int get_nummer(void);
00098
00099 virtual void loeschen (int);
00100 virtual void betriebe_loeschen(int);
00101 virtual agent* getFirst();
00102 virtual agent* getSecond();
00103
00104 virtual void betriebe_ausstatten();
00105 virtual void writeInitialEndowmentToFile();
00106
00107 virtual void uebergang_periode();
00108
00109 #ifdef LP_OLD
00110 virtual void pacht_periode();
00111 virtual void hole_gebot(p_gebot* g, int bnr, int typ, int z, int s,
00112 w_jahr* vol, double pacht);
00113 virtual void hole_forderung(p_gebot* f, int bnr, int typ, int z, int s,
00114 w_jahr* vol);
00115
00116 virtual void kopie_loeschen(int bnr, int typ);
00117 virtual void alle_kopien_loeschen(int bnr);
00118 virtual int kapaz_aktualisieren(int, int, int, int, w_jahr*, double);
00119 virtual void alte_schattenpreise(int);
00120 virtual void neu_planen(int bnr);
00121 virtual double verpachtung_korrigieren(int bnr, double volB, int m);
00122 virtual void zupachtung_korrigieren(int bnr, double volN, int m);
00123 #endif
00124
00125
00127
00128 virtual void wasser_periode(int);
00129
00130
00131
00132
00133 virtual void wasser_periode_refactured( TimeHandler& th_const );
00134
00135
00136
00137
00138
00139
00140
00141 virtual agent* agentsComputeIrrigDemandAndReportToSector(agent* anker, int sk, int thisMonth);
00142 virtual void agentsReceiveNetInflowsFromCatchment(agent* betr, int sk, int thisMonth);
00143
00144
00145 virtual double agentsReceivePlantWaterDemandsSatisfied (agent* anker, int sk, int sc, int thisMonth, IrrigationMethodSector* sectorPointerToIrrigationMethods, double Ueb_j_tmp);
00146
00147
00148 virtual void agentsEstimatePlantWaterDemandsAndReportRest(agent* anker, int sk, int sc, int thisMonth, IrrigationMethodSector* sectorPointerToIrrigationMethods);
00149 virtual void agentsDistributeRestWater(agent* anker, int sk, int sc, int thisMonth, IrrigationMethodSector* sectorPointerToIrrigationMethods);
00150 virtual void agentsUpdatePlantWaterSupply(agent* anker, int sk, int sc, int thisMonth, IrrigationMethodSector* sectorPointerToIrrigationMethods);
00151
00152
00153
00154
00155
00156 virtual double agentsIrrigateCropsByPriorityGroups (agent* anker, int sk, int sc, int thisMonth, IrrigationMethodSector* sectorPointerToIrrigationMethods);
00157 virtual agent* computeTotIrrigAppliedInSectorAndEfficiency(agent* anker, int sk, int sc, int thisMonth, double irrigAmountSector, double& etaOfSectorAgents );
00158
00159
00160
00161
00162
00163
00164
00165
00166
00167
00168
00169
00170
00171
00172
00173 virtual void produktion_periode();
00174 virtual void einkommen_periode();
00175
00176
00177 virtual void writeAgentLndData(FILE* stream0);
00178 virtual void writeAgentPfmData(FILE* stream0, FILE* stream1);
00179 virtual void kapazitaetsdaten_periode(FILE*);
00180
00181
00182 virtual void planungsfehler_melden(int nw, int seg);
00183 virtual void printToScreen(agent*);
00184 virtual void printOnScreen_list(void);
00185
00186 virtual void betriebsaufgabe_periode();
00187 virtual void liste_loeschen(void);
00188
00189 virtual void writeAllParcelsToFile(void);
00190
00191
00192 virtual void writeAllCropWaterDataToFile(void);
00193
00194
00195
00196
00197
00198
00199
00200 virtual void allocateSpatiallyExplicit_AllCrops();
00201 virtual void agentsAllocateSpatiallyIrrigationWaterToParcels(int thisMonth);
00202
00203
00204
00205
00206
00207
00208
00209
00210
00211
00212
00213
00214 virtual void copyContent_ParcelToLandscape_monthly(Content cont, int mTot);
00215 virtual void copyContent_ParcelToLandscape(Content cont);
00216
00217 virtual void copyContent_Landscape2Parcels(Content cont);
00218 virtual void copyContent_Landscape2Parcels(Content cont, bool flag_fixCopyToCell);
00219
00220 virtual void testMeanPerAgent(Content cont);
00221
00222
00223 virtual void agentsUpdateIrrigationWater2Landscape(int m);
00224
00225
00226
00227 virtual void checkIfTrue(bool isTrue);
00228 virtual void printAllAgentsProductions();
00229
00230 virtual void aggregateAndOutputLanduseBySector(int numberOfCroppingActivities, MatrixDouble& vectorOfIDs, string*& rowNames, string fn);
00231 virtual void aggregateLanduseBySector(MatrixDouble& matrixOfCatchmentLandUses);
00232 virtual void outputLanduseBySector(MatrixDouble& matrixOfCatchmentLandUses, MatrixDouble& vectorOfIDs, string*& rowNames, string fn);
00233 int getCatchID();
00234 virtual void writeToFile_AllAgentsProduction();
00235 void writeEdicHeaderToFile(ofstream& out);
00236
00237
00238 virtual int getFirstInflowForFarmsteadID(int _fstdID);
00239 };
00240
00241 #endif
00242
00243
00244