Loading [MathJax]/extensions/ams.js
ALMaSS  1.2 (after EcoStack, March 2024)
The Animal, Landscape and Man Simulation System
All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
SE_WinterWheat Class Reference

SE_WinterWheat class
. More...

#include <SE_WinterWheat.h>

Inheritance diagram for SE_WinterWheat:
Crop

Public Member Functions

virtual bool Do (Farm *a_farm, LE *a_field, FarmEvent *a_ev)
 The one and only method for a crop management plan. All farm actions go through here. More...
 
 SE_WinterWheat (TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
 
void SetUpFarmCategoryInformation ()
 
- Public Member Functions inherited from Crop
virtual ~Crop ()
 
 Crop (TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
 
int GetFirstDate (void)
 
void ChooseNextCrop (int a_no_dates)
 Chooses the next crop to grow in a field. More...
 
int GetCropClassification ()
 
void SetCropClassification (int a_classification)
 
void GetCropType (TTypesOfCrops a_toc)
 
TTypesOfCrops GetCropType ()
 
FarmManagementCategory LookUpManagementCategory (int a_todo)
 
bool GetForceSpringOK ()
 

Additional Inherited Members

- Public Attributes inherited from Crop
TTypesOfVegetation m_tov
 
- Protected Member Functions inherited from Crop
void SimpleEvent (long a_date, int a_todo, bool a_lock)
 Adds an event to this crop management. More...
 
void SimpleEvent_ (long a_date, int a_todo, bool a_lock, Farm *a_farm, LE *a_field)
 Adds an event to this crop management without relying on member variables. More...
 
bool StartUpCrop (int a_spring, std::vector< std::vector< int >> a_flexdates, int a_todo)
 
Holds the translation between the farm operation enum for each cropand the farm management category associated with it More...
 
bool AphidDamage (LE *a_field)
 Compares aphid numbers per m2 with a threshold to return true if threshold is exceeded. More...
 
- Protected Attributes inherited from Crop
Farmm_farm
 
LEm_field
 
FarmEventm_ev
 
int m_first_date
 
int m_count
 
int m_last_date
 
int m_ddegstoharvest
 
int m_base_elements_no
 
Landscapem_OurLandscape
 
bool m_forcespringpossible = false
 Used to signal that the crop can be forced to start in spring. More...
 
TTypesOfCrops m_toc
 The Crop type in terms of the TTypesOfCrops list (smaller list than tov, no country designation) More...
 
int m_CropClassification
 Contains information on whether this is a winter crop, spring crop, or catch crop that straddles the year boundary (0,1,2) More...
 
vector< FarmManagementCategorym_ManagementCategories
 Holds the translation between the farm operation enum for each crop and the farm management category associated with it. More...
 
- Static Protected Attributes inherited from Crop
static int m_date_modifier = 0
 Holds a value that shifts test pesticide use by this many days in crops modified to use it. More...
 

Detailed Description

SE_WinterWheat class
.

See SE_WinterWheat.h::SE_WinterWheatToDo for a complete list of all possible events triggered codes by the winter wheat management plan. When triggered these events are handled by Farm and are available as information for other objects such as animal and bird models.

Constructor & Destructor Documentation

◆ SE_WinterWheat()

SE_WinterWheat::SE_WinterWheat ( TTypesOfVegetation  a_tov,
TTypesOfCrops  a_toc,
Landscape a_L 
)
inline
106  : Crop(a_tov, a_toc, a_L)
107  {
108  // When we start it off, the first possible date for a farm operation is 1st October
109  // This information is used by other crops when they decide how much post processing of
110  // the management is allowed after harvest before the next crop starts.
111  m_first_date=g_date->DayInYear( 15,10 );
113  }

References Calendar::DayInYear(), g_date, Crop::m_first_date, and SetUpFarmCategoryInformation().

Member Function Documentation

◆ Do()

bool SE_WinterWheat::Do ( Farm a_farm,
LE a_field,
FarmEvent a_ev 
)
virtual

The one and only method for a crop management plan. All farm actions go through here.

Called every time something is done to the crop by the farmer in the first instance it is always called with a_ev->todo set to start, but susequently will be called whenever the farmer wants to carry out a new operation.
This method details all the management and relationships between operations necessary to grow and ALMaSS crop - in this case conventional winter wheat.

Reimplemented from Crop.

101 {
102  m_field = a_field; // this is needed because of possible calls to other methods and currently we do not pass parameters.
103  m_farm = a_farm; // this is needed because of possible calls to other methods and currently we do not pass parameters.
104  bool done = false; // The boolean value done indicates when we are totally finished with this plan (i.e. it is set to true).
105 
106  // Depending what event has occured jump to the correct bit of code e.g. for ww_start jump to line 67 below
107  switch (a_ev->m_todo)
108  {
109  case se_ww_start:
110  {
111  // This is just to hold a local variable in scope and prevent compiler errors
112  // ww_start just sets up all the starting conditions and reference dates that are needed to start a ww
113  // crop off
114  SE_WW_HERBICIDE = false;
116  SE_WW_DECIDE_TO_FI = 1;
117 
118  a_field->ClearManagementActionSum();
119 
120  // Record whether skylark scrapes are present and adjust flag accordingly
122  a_field->m_skylarkscrapes = true;
123  }
124  else {
125  a_field->m_skylarkscrapes = false;
126  }
127  // Set up the date management stuff
128  // The next bit of code just allows for altering dates after harvest if it is necessary
129  // to allow for a crop which starts its management early.
130 
131  // 3 start and stop dates for all events after harvest for this crop
132  int noDates = 1;
133  a_field->SetMDates(0, 0, g_date->DayInYear(25, 8)); // last possible day of harvest
134  a_field->SetMDates(1, 0, g_date->DayInYear(25, 8)); // last possible day of management after harvest
135 
136  // Can be up to 10 of these. If the shortening code is triggered
137  // then these will be reduced in value to 0
138 
139  a_field->SetMConstants(0, 1);
140 
141  // Check the next crop for early start, unless it is a spring crop
142  // in which case we ASSUME that no checking is necessary!!!!
143  // So DO NOT implement a crop that runs over the year boundary (i.e. from spring to spring!), at least not without fixing this.
144 
145  //new if: do the check only for non-optimising farms and if year>0. (030713 - m_rotation used only in the hidden year, so I modified the condition from >7 to >0)
146  int d1;
147  if (!(a_farm->GetType() == tof_OptimisingFarm && g_date->GetYearNumber() > 0)) {
148 
149  if (a_ev->m_startday > g_date->DayInYear(1, 7)) {
150  if (a_field->GetMDates(0, 0) >= a_ev->m_startday)
151  {
152  g_msg->Warn(WARN_BUG, "SE_WinterWheat::Do(): ", "Harvest too late for the next crop to start!!!");
153  int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->m_next_tov);
154  g_msg->Warn("Next Crop ", (double)almassnum); // this causes exit
155  }
156  // Now fix any late finishing problems
157  for (int i = 0; i < noDates; i++) {
158  if (a_field->GetMDates(0, i) >= a_ev->m_startday) {
159  a_field->SetMDates(0, i, a_ev->m_startday - 1); //move the starting date
160  }
161  if (a_field->GetMDates(1, i) >= a_ev->m_startday) {
162  a_field->SetMConstants(i, 0); //change the default value of the MConst (=1) to 0 (necessary to correctly execute farm events in case the finishing date (MDate) was moved)
163  a_field->SetMDates(1, i, a_ev->m_startday - 1); //move the finishing date
164  }
165  }
166  }
167  // Now no operations can be timed after the start of the next crop.
168 
169  if (!a_ev->m_first_year) {
170  // Are we before July 1st?
171  d1 = g_date->OldDays() + g_date->DayInYear(1, 7);
172  if (g_date->Date() < d1) {
173  // Yes, too early. We assumme this is because the last crop was late
174  printf("Poly: %d\n", a_field->GetPoly());
175  g_msg->Warn(WARN_BUG, "SE_WinterWheat::Do(): ", "Crop start attempt between 1st Jan & 1st July");
176  int prev = a_field->GetLandscape()->BackTranslateVegTypes(a_field->GetOwner()->GetPreviousTov(a_field->GetRotIndex()));
177  g_msg->Warn(WARN_BUG, "Previous Crop ", prev);
178  int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->m_next_tov);
179  g_msg->Warn("Next Crop ", (double)almassnum); // this causes exit
180  }
181  else {
182  d1 = g_date->OldDays() + m_first_date; // Add 365 for spring crop
183  if (g_date->Date() > d1) {
184  // Yes too late - should not happen - raise an error
185  g_msg->Warn(WARN_BUG, "SE_WinterWheat::Do(): ", "Crop start attempt after last possible start date");
186  g_msg->Warn(WARN_BUG, "Previous Crop ", "");
187  a_field->GetOwner()->GetPreviousTov(a_field->GetRotIndex());
188  int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->m_next_tov);
189  g_msg->Warn("Next Crop ", (double)almassnum); // this causes exit
190  }
191  }
192  }
193  else {
194  // Is the first year
195  // Some special code to cope with that first start-up year in ALMaSS - ignore for all practical purposes
197  break;
198  }
199  }//if
200 
201  // End single block date checking code. Please see next line comment as well.
202  // Reinit d1 to first possible starting date.
203  d1 = g_date->OldDays() + g_date->DayInYear(1, 8);
204  // OK, let's go.
205  // LKM: Here we queue up the first event - a fork with parallel events
206  SimpleEvent(d1, se_ww_herbicide1, false); // herbicide thread
207  SimpleEvent(d1, se_ww_straw_removal, false); // main thread
208  }
209  break;
210  // This is the first real farm operation -
211 case se_ww_herbicide1:
212  if (a_ev->m_lock || a_farm->DoIt_prob(.60)) {
213  if (!a_farm->HerbicideTreat(a_field, 0.0, g_date->DayInYear(10, 9) - g_date->DayInYear())) {
214  // If we don't suceed on the first try, then try and try again
215  SimpleEvent(g_date->Date() + 1, se_ww_herbicide1, true);
216  break;
217  }
218  else {
219  //Rest of farmers herbicide later so we need to remember who already did it
220  SE_WW_HERBICIDE = true;
221  }
222  }
223  break; // end of herbicide thread
225  if (a_ev->m_lock || a_farm->DoIt(25)) { // crop scheme says 20-30%
226  if (!a_farm->StrawRemoval(a_field, 0.0, g_date->DayInYear(1, 10) - g_date->DayInYear())) {
227  // If we don't suceed on the first try, then try and try again
229  break;
230  }
231  }
232  // Queue up the next event - in this case autumn plough
234  break;
235  case se_ww_autumn_plough:
236  if (a_ev->m_lock || a_farm->DoIt(35)) { // crop scheme says 30-40%
237  if (!a_farm->AutumnPlough(a_field, 0.0, g_date->DayInYear(1, 10) - g_date->DayInYear())) {
239  break;
240  }
241  SimpleEvent(g_date->Date()+1, se_ww_slurry, false); // no dates in scheme
242  break;
243  }
245  break;
247  if (!a_farm->StubbleCultivatorHeavy(a_field, 0.0, g_date->DayInYear(1, 10) - g_date->DayInYear())) {
249  break;
250  }
252  break;
254  if (!a_farm->StubbleCultivatorHeavy(a_field, 0.0, g_date->DayInYear(15, 10) - g_date->DayInYear())) {
256  break;
257  }
258  // Queue up the next event - in this case slurry
259  SimpleEvent(g_date->Date(), se_ww_slurry, false); // no dates in scheme
260  break;
261  case se_ww_slurry:
262  if (a_ev->m_lock || a_farm->DoIt(15)) { // crop scheme says 5-20%
263  if (!a_farm->FP_Slurry(a_field, 0.0,
264  g_date->DayInYear(15, 10) - g_date->DayInYear())) {
265  SimpleEvent(g_date->Date() + 1, se_ww_slurry, true);
266  break;
267  }
268  }
269  SimpleEvent(g_date->Date(), se_ww_autumn_harrow, false); // seedbed preparation - no dates
270  break;
271  case se_ww_autumn_harrow:
272  if (a_ev->m_lock || a_farm->DoIt(35)) { // crop scheme says 30-40%
273  if (!a_farm->ShallowHarrow(a_field, 0.0,
274  g_date->DayInYear(15, 10) - g_date->DayInYear())) {
276  break;
277  }
278  }
280  break;
281  case se_ww_autumn_sow:
282  if (a_ev->m_lock || a_farm->DoIt(25)) {
283  if (!a_farm->AutumnSow(a_field, 0.0,
284  g_date->DayInYear(15, 10) - g_date->DayInYear())) {
285  SimpleEvent(g_date->Date() + 1, se_ww_autumn_sow, true);
286  break;
287  }
288  // LKM: Here is a fork leading to parallel events
289  SimpleEvent(g_date->Date(), se_ww_herbicide2, false); // herbicide2 thread
290  SimpleEvent(g_date->OldDays() + g_date->DayInYear(15, 10), se_ww_fungicide1, false); // fungicide1 thread
291  SimpleEvent(g_date->OldDays() + g_date->DayInYear(15, 10), se_ww_insecticide1, false); // insecticide1 thread - main thread // no dates in scheme
292  break;
293  }
294  else SimpleEvent(g_date->Date(), se_ww_sow_w_fertilizer, false); // (together with sowing)
295  break;
297  if (!a_farm->AutumnSowWithFerti(a_field, 0.0,
298  g_date->DayInYear(15, 10) - g_date->DayInYear())) {
300  break;
301  }
302  // LKM: Here is a fork leading to parallel events
303  SimpleEvent(g_date->Date(), se_ww_herbicide2, false); // herbicide2 thread
304  SimpleEvent(g_date->OldDays() + g_date->DayInYear(15, 10), se_ww_fungicide1, false); // fungicide1 thread
305  SimpleEvent(g_date->OldDays() + g_date->DayInYear(15, 10), se_ww_insecticide1, false); // insecticide1 thread - main thread // no dates in scheme
306  break;
307  case se_ww_herbicide2:
308  if (a_ev->m_lock || a_farm->DoIt_prob(.15 / .40) && (SE_WW_HERBICIDE == false)) { // crop scheme says 10-20%
309  if (!a_farm->HerbicideTreat(a_field, 0.0,
310  g_date->DayInYear(15, 10) - g_date->DayInYear())) {
311  SimpleEvent(g_date->Date() + 1, se_ww_herbicide2, true);
312  break;
313  }
314  }
315  //LKM: end of herbicide2 thread
316  break;
317  case se_ww_fungicide1:
318  if (a_ev->m_lock || a_farm->DoIt(15)) { // crop scheme says 10-20%
319  if (!a_farm->FungicideTreat(a_field, 0.0,
320  g_date->DayInYear(15, 12) - g_date->DayInYear())) {
321  SimpleEvent(g_date->Date() + 1, se_ww_fungicide1, true);
322  break;
323  }
324  }
325  //LKM: end of fungicide1 thread
326  break;
327  case se_ww_insecticide1:
328  if (a_ev->m_lock || a_farm->DoIt(5)) {
329  if (!a_farm->InsecticideTreat(a_field, 0.0,
330  g_date->DayInYear(15, 12) - g_date->DayInYear())) {
331  SimpleEvent(g_date->Date() + 1, se_ww_insecticide1, true);
332  break;
333  }
334  }
335  SimpleEvent(g_date->OldDays() + g_date->DayInYear(1, 4)+365, se_ww_spring_harrow, false); // no dates in scheme
336  break;
337  case se_ww_spring_harrow:
338  if (a_ev->m_lock || a_farm->DoIt(5)) {
339  if (!a_farm->SpringHarrow(a_field, 0.0,
340  g_date->DayInYear(15, 4) - g_date->DayInYear())) {
342  break;
343  }
344  }
346  break;
347  case se_ww_n_fertilizer1: // Nitrogen fertilizer with sulphur
348  if (a_ev->m_lock || a_farm->DoIt(100)) {
349  if (!a_farm->FP_NS(a_field, 0.0,
350  g_date->DayInYear(25, 4) - g_date->DayInYear())) {
352  break;
353  }
354  }
355  // Queue up the next events - fork of parallel events
356  SimpleEvent(g_date->OldDays() + g_date->DayInYear(25, 4), se_ww_n_fertilizer2, false); // fertilizer thread
357  SimpleEvent(g_date->OldDays() + g_date->DayInYear(25, 4), se_ww_insecticide2, false); // insecticide thread
358  SimpleEvent(g_date->OldDays() + g_date->DayInYear(1, 5), se_ww_growth_regulator, false); // GR thread
359  SimpleEvent(g_date->OldDays() + g_date->DayInYear(1, 5), se_ww_herbicide3, false); // Herbicide thread
360  SimpleEvent(g_date->OldDays() + g_date->DayInYear(25, 5), se_ww_fungicide2, false); // Fungicide thread - main thread
361  break;
362  case se_ww_n_fertilizer2: // Nitrogen fertilizer with sulphur
363  if (a_ev->m_lock || a_farm->DoIt(90)) {
364  if (!a_farm->FP_NS(a_field, 0.0,
365  g_date->DayInYear(25, 5) - g_date->DayInYear())) {
367  break;
368  }
369  }
371  break;
372  case se_ww_n_fertilizer3: // Calcium Nitrate
373  if (a_ev->m_lock || a_farm->DoIt(50)) {
374  if (!a_farm->FP_NC(a_field, 0.0,
375  g_date->DayInYear(20, 6) - g_date->DayInYear())) {
377  break;
378  }
379  }
380  break; // end of fertilizer thread
381  case se_ww_insecticide2:
382  if (a_ev->m_lock || a_farm->DoIt(20)) {
383  if (!a_farm->InsecticideTreat(a_field, 0.0,
384  g_date->DayInYear(30, 6) - g_date->DayInYear())) {
385  SimpleEvent(g_date->Date() + 1, se_ww_insecticide2, true);
386  break;
387  }
388  }
389  break; // end of insecticide thread
391  if (a_ev->m_lock || a_farm->DoIt(20)) { // no % in scheme
392  if (!a_farm->GrowthRegulator(a_field, 0.0,
393  g_date->DayInYear(25, 5) - g_date->DayInYear())) {
395  break;
396  }
397  }
398  break; // end of GR thread
399  case se_ww_herbicide3:
400  if (a_ev->m_lock || a_farm->DoIt(90)) {
401  if (!a_farm->HerbicideTreat(a_field, 0.0,
402  g_date->DayInYear(25, 5) - g_date->DayInYear())) {
403  SimpleEvent(g_date->Date() + 1, se_ww_herbicide3, true);
404  break;
405  }
406  }
407  break; // end of herbicide thread
408  case se_ww_fungicide2:
409  if (a_ev->m_lock || a_farm->DoIt(50)) {
410  if (!a_farm->FungicideTreat(a_field, 0.0,
411  g_date->DayInYear(30, 6) - g_date->DayInYear())) {
412  SimpleEvent(g_date->Date() + 1, se_ww_fungicide2, true);
413  break;
414  }
415  }
416  SimpleEvent(g_date->OldDays() + g_date->DayInYear(1, 8), se_ww_harvest, false); // no dates in scheme
417  break;
418  case se_ww_harvest:
419  // We don't move harvest days
420  if (!a_farm->Harvest(a_field, 0.0, a_field->GetMDates(0, 0) - g_date->DayInYear())) {
421  SimpleEvent(g_date->Date() + 1, se_ww_harvest, true);
422  break;
423  }
424  done = true;
425  // So we are done, and somewhere else the farmer will queue up the start event of the next crop
426  // END OF MAIN THREAD
427  break;
428  default:
429  g_msg->Warn(WARN_BUG, "SE_WinterWheat::Do(): "
430  "Unknown event type! ", "");
431  exit(1);
432  }
433  return done;
434 }

References Farm::AutumnPlough(), Farm::AutumnSow(), Farm::AutumnSowWithFerti(), cfg_SE_WinterWheat_SkScrapes, LE::ClearManagementActionSum(), Calendar::Date(), Calendar::DayInYear(), Farm::DoIt(), Farm::DoIt_prob(), Farm::FP_NC(), Farm::FP_NS(), Farm::FP_Slurry(), Farm::FungicideTreat(), g_date, g_msg, LE::GetMDates(), LE::GetOwner(), LE::GetPoly(), Farm::GetPreviousTov(), LE::GetRotIndex(), Farm::GetType(), Calendar::GetYearNumber(), Farm::GrowthRegulator(), Farm::Harvest(), Farm::HerbicideTreat(), Farm::InsecticideTreat(), Crop::m_farm, Crop::m_field, Crop::m_first_date, FarmEvent::m_first_year, FarmEvent::m_lock, FarmEvent::m_next_tov, LE::m_skylarkscrapes, FarmEvent::m_startday, FarmEvent::m_todo, Calendar::OldDays(), se_ww_autumn_harrow, se_ww_autumn_plough, se_ww_autumn_sow, SE_WW_DECIDE_TO_FI, SE_WW_DECIDE_TO_HERB, se_ww_fungicide1, se_ww_fungicide2, se_ww_growth_regulator, se_ww_harvest, SE_WW_HERBICIDE, se_ww_herbicide1, se_ww_herbicide2, se_ww_herbicide3, se_ww_insecticide1, se_ww_insecticide2, se_ww_n_fertilizer1, se_ww_n_fertilizer2, se_ww_n_fertilizer3, se_ww_slurry, se_ww_sow_w_fertilizer, se_ww_spring_harrow, se_ww_start, se_ww_straw_removal, se_ww_stubble_cultivator1, se_ww_stubble_cultivator2, LE::SetMConstants(), LE::SetMDates(), Farm::ShallowHarrow(), Crop::SimpleEvent(), Farm::SpringHarrow(), Farm::StrawRemoval(), Farm::StubbleCultivatorHeavy(), tof_OptimisingFarm, CfgBool::value(), MapErrorMsg::Warn(), and WARN_BUG.

◆ SetUpFarmCategoryInformation()

void SE_WinterWheat::SetUpFarmCategoryInformation ( )
inline
114  {
115  const int elements = 2 + (se_ww_foobar - SE_WW_BASE);
117 
118  FarmManagementCategory catlist[elements] =
119  {
120  fmc_Others, // zero element unused but must be here
121  fmc_Others, // se_ww_start = 1, // Compulsory, must always be 1 (one).
122  fmc_Others, // se_ww_straw_removal = SE_WW_BASE,
123  fmc_Herbicide, // se_ww_herbicide1,
124  fmc_Cultivation, // se_ww_autumn_plough,
125  fmc_Cultivation, // se_ww_stubble_cultivator1,
126  fmc_Cultivation, // se_ww_stubble_cultivator2,
127  fmc_Fertilizer, // se_ww_slurry,
128  fmc_Cultivation, // se_ww_autumn_harrow,
129  fmc_Others, // se_ww_autumn_sow,
130  fmc_Fertilizer, // se_ww_sow_w_fertilizer,
131  fmc_Herbicide, // se_ww_herbicide2,
132  fmc_Fungicide, // se_ww_fungicide1,
133  fmc_Insecticide, // se_ww_insecticide1,
134  fmc_Cultivation, // se_ww_spring_harrow,
135  fmc_Fertilizer, // se_ww_n_fertilizer1,
136  fmc_Fertilizer, // se_ww_n_fertilizer2,
137  fmc_Fertilizer, // se_ww_n_fertilizer3,
138  fmc_Herbicide, // se_ww_herbicide3,
139  fmc_Fungicide, // se_ww_fungicide2,
140  fmc_Others, // se_ww_growth_regulator,
141  fmc_Insecticide, // se_ww_insecticide2,
142  fmc_Harvest // se_ww_harvest,
143 
144 
145  // no foobar entry
146 
147  };
148  // Iterate over the catlist elements and copy them to vector
149  copy(begin(catlist), end(catlist), back_inserter(m_ManagementCategories));
150 
151  }

References fmc_Cultivation, fmc_Fertilizer, fmc_Fungicide, fmc_Harvest, fmc_Herbicide, fmc_Insecticide, fmc_Others, Crop::m_base_elements_no, Crop::m_ManagementCategories, SE_WW_BASE, and se_ww_foobar.

Referenced by SE_WinterWheat().


The documentation for this class was generated from the following files:
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
se_ww_stubble_cultivator1
Definition: SE_WinterWheat.h:72
se_ww_herbicide2
Definition: SE_WinterWheat.h:78
fmc_Insecticide
Definition: LandscapeFarmingEnums.h:1005
LE::SetMDates
void SetMDates(int a, int b, int c)
Definition: Elements.h:406
Farm::HerbicideTreat
virtual bool HerbicideTreat(LE *a_field, double a_user, int a_days)
Apply herbicide to a_field.
Definition: FarmFuncs.cpp:2025
se_ww_autumn_sow
Definition: SE_WinterWheat.h:76
Farm::Harvest
virtual bool Harvest(LE *a_field, double a_user, int a_days)
Carry out a harvest on a_field.
Definition: FarmFuncs.cpp:1364
FarmEvent::m_lock
bool m_lock
Definition: Farm.h:384
se_ww_fungicide2
Definition: SE_WinterWheat.h:86
Farm::StubbleCultivatorHeavy
virtual bool StubbleCultivatorHeavy(LE *a_field, double a_user, int a_days)
Carry out a stubble cultivation event on a_field. This is non-inversion type of cultivation which can...
Definition: FarmFuncs.cpp:245
se_ww_n_fertilizer1
Definition: SE_WinterWheat.h:82
LE::ClearManagementActionSum
void ClearManagementActionSum()
clears the management action counters
Definition: Elements.h:247
Farm::DoIt
bool DoIt(double a_probability)
Return chance out of 0 to 100.
Definition: Farm.cpp:856
se_ww_start
Definition: SE_WinterWheat.h:68
Calendar::GetYearNumber
int GetYearNumber(void)
Definition: Calendar.h:72
SE_WinterWheat::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: SE_WinterWheat.h:114
FarmEvent::m_first_year
bool m_first_year
Definition: Farm.h:386
Farm::StrawRemoval
virtual bool StrawRemoval(LE *a_field, double a_user, int a_days)
Straw covering applied on a_field.
Definition: FarmFuncs.cpp:1752
LE::GetPoly
int GetPoly(void)
Returns the polyref number for this polygon.
Definition: Elements.h:238
Farm::DoIt_prob
bool DoIt_prob(double a_probability)
Return chance out of 0 to 1.
Definition: Farm.cpp:864
g_date
class Calendar * g_date
Definition: Calendar.cpp:37
SE_WW_DECIDE_TO_FI
#define SE_WW_DECIDE_TO_FI
Definition: SE_WinterWheat.h:59
se_ww_herbicide3
Definition: SE_WinterWheat.h:85
SE_WW_DECIDE_TO_HERB
#define SE_WW_DECIDE_TO_HERB
Definition: SE_WinterWheat.h:58
fmc_Herbicide
Definition: LandscapeFarmingEnums.h:1006
Farm::GetPreviousTov
TTypesOfVegetation GetPreviousTov(int a_index)
Definition: Farm.h:966
Farm::GetType
TTypesOfFarm GetType(void)
Definition: Farm.h:956
Crop::m_base_elements_no
int m_base_elements_no
Definition: Farm.h:505
se_ww_autumn_plough
Definition: SE_WinterWheat.h:71
se_ww_slurry
Definition: SE_WinterWheat.h:74
Crop::m_first_date
int m_first_date
Definition: Farm.h:501
FarmEvent::m_startday
int m_startday
Definition: Farm.h:385
Farm::FungicideTreat
virtual bool FungicideTreat(LE *a_field, double a_user, int a_days)
Apply fungicide to a_field.
Definition: FarmFuncs.cpp:2101
Farm::AutumnSowWithFerti
virtual bool AutumnSowWithFerti(LE *a_field, double a_user, int a_days, double a_seed_coating_amount=-1, PlantProtectionProducts a_ppp=ppp_foobar)
Carry out a sowing event with start fertilizer in the autumn on a_field.
Definition: FarmFuncs.cpp:592
se_ww_growth_regulator
Definition: SE_WinterWheat.h:87
Crop::SimpleEvent
void SimpleEvent(long a_date, int a_todo, bool a_lock)
Adds an event to this crop management.
Definition: Farm.cpp:747
CfgBool::value
bool value() const
Definition: Configurator.h:164
fmc_Fertilizer
Definition: LandscapeFarmingEnums.h:1004
cfg_SE_WinterWheat_SkScrapes
CfgBool cfg_SE_WinterWheat_SkScrapes("SE_CROP_WW_SK_SCRAPES", CFG_CUSTOM, false)
LE::m_skylarkscrapes
bool m_skylarkscrapes
For management testing of skylark scrapes.
Definition: Elements.h:95
Calendar::Date
long Date(void)
Definition: Calendar.h:57
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
se_ww_insecticide2
Definition: SE_WinterWheat.h:88
fmc_Others
Definition: LandscapeFarmingEnums.h:1003
se_ww_straw_removal
Definition: SE_WinterWheat.h:69
Farm::FP_NC
virtual bool FP_NC(LE *a_field, double a_user, int a_days)
Apply NC fertilizer, on a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:753
Calendar::OldDays
long OldDays(void)
Definition: Calendar.h:60
SE_WW_BASE
#define SE_WW_BASE
Definition: SE_WinterWheat.h:53
MapErrorMsg::Warn
void Warn(MapErrorState a_level, std::string a_msg1, std::string a_msg2)
Definition: MapErrorMsg.cpp:69
LE::GetRotIndex
int GetRotIndex(void)
Definition: Elements.h:373
Farm::FP_NS
virtual bool FP_NS(LE *a_field, double a_user, int a_days)
Apply NS fertilizer, on a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:740
se_ww_n_fertilizer3
Definition: SE_WinterWheat.h:84
FarmEvent::m_next_tov
TTypesOfVegetation m_next_tov
Definition: Farm.h:390
Crop::m_farm
Farm * m_farm
Definition: Farm.h:498
Crop::m_field
LE * m_field
Definition: Farm.h:499
Crop::m_ManagementCategories
vector< FarmManagementCategory > m_ManagementCategories
Holds the translation between the farm operation enum for each crop and the farm management category ...
Definition: Farm.h:530
FarmEvent::m_todo
int m_todo
Definition: Farm.h:388
Farm::InsecticideTreat
virtual bool InsecticideTreat(LE *a_field, double a_user, int a_days)
Apply insecticide to a_field.
Definition: FarmFuncs.cpp:2135
Farm::ShallowHarrow
virtual bool ShallowHarrow(LE *a_field, double a_user, int a_days)
Carry out a shallow harrow event on a_field, e.g., after grass cutting event.
Definition: FarmFuncs.cpp:473
Farm::FP_Slurry
virtual bool FP_Slurry(LE *a_field, double a_user, int a_days)
Apply slurry to a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:823
tof_OptimisingFarm
Definition: LandscapeFarmingEnums.h:696
se_ww_spring_harrow
Definition: SE_WinterWheat.h:81
Farm::AutumnPlough
virtual bool AutumnPlough(LE *a_field, double a_user, int a_days)
Carry out a ploughing event in the autumn on a_field.
Definition: FarmFuncs.cpp:212
g_msg
MapErrorMsg * g_msg
Definition: MapErrorMsg.cpp:41
se_ww_insecticide1
Definition: SE_WinterWheat.h:80
se_ww_fungicide1
Definition: SE_WinterWheat.h:79
Farm::AutumnSow
virtual bool AutumnSow(LE *a_field, double a_user, int a_days, double a_seed_coating_amount=-1, PlantProtectionProducts a_ppp=ppp_foobar)
Carry out a sowing event in the autumn on a_field.
Definition: FarmFuncs.cpp:360
fmc_Harvest
Definition: LandscapeFarmingEnums.h:1012
se_ww_n_fertilizer2
Definition: SE_WinterWheat.h:83
Farm::GrowthRegulator
virtual bool GrowthRegulator(LE *a_field, double a_user, int a_days)
Apply growth regulator to a_field.
Definition: FarmFuncs.cpp:2070
LE::GetOwner
Farm * GetOwner(void)
Definition: Elements.h:256
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
se_ww_herbicide1
Definition: SE_WinterWheat.h:70
se_ww_autumn_harrow
Definition: SE_WinterWheat.h:75
se_ww_stubble_cultivator2
Definition: SE_WinterWheat.h:73
Crop::Crop
Crop(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: Farm.cpp:733
SE_WW_HERBICIDE
#define SE_WW_HERBICIDE
A flag used to indicate autumn ploughing status.
Definition: SE_WinterWheat.h:57
se_ww_sow_w_fertilizer
Definition: SE_WinterWheat.h:77
LE::SetMConstants
void SetMConstants(int a, int c)
Definition: Elements.h:408
se_ww_foobar
Definition: SE_WinterWheat.h:90
WARN_BUG
Definition: MapErrorMsg.h:34
fmc_Fungicide
Definition: LandscapeFarmingEnums.h:1007
FarmManagementCategory
FarmManagementCategory
Definition: LandscapeFarmingEnums.h:1001
Farm::SpringHarrow
virtual bool SpringHarrow(LE *a_field, double a_user, int a_days)
Carry out a harrow event in the spring on a_field.
Definition: FarmFuncs.cpp:459
se_ww_harvest
Definition: SE_WinterWheat.h:89