File failed to load: https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/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
IRWinterOats Class Reference

IRWinterOats class
. More...

#include <IRWinterOats.h>

Inheritance diagram for IRWinterOats:
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...
 
 IRWinterOats (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

IRWinterOats class
.

See IRWinterOats.h::IRWinterOatsToDo for a complete list of all possible events triggered codes by the 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

◆ IRWinterOats()

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

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

Member Function Documentation

◆ Do()

bool IRWinterOats::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.

Reimplemented from Crop.

99 {
100  m_field = a_field; // this is needed because of possible calls to other methods and currently we do not pass parameters.
101  m_farm = a_farm; // this is needed because of possible calls to other methods and currently we do not pass parameters.
102  bool done = false; // The boolean value done indicates when we are totally finished with this plan (i.e. it is set to true).
103  int d1 = 0;
104  // Depending what event has occured jump to the correct bit of code e.g. for ww_start jump to line 67 below
105  switch (a_ev->m_todo)
106  {
107  case ir_wo_start:
108  {
109  // This is just to hold a local variable in scope and prevent compiler errors
110  // ww_start just sets up all the starting conditions and reference dates that are needed to start a ww
111  // crop off
112  IR_WO_MT = false; // 10% do minimum tillage
113  IR_WO_CP = false; // 90% do conventional plough
114 
115  a_field->ClearManagementActionSum();
116 
117  // Record whether skylark scrapes are present and adjust flag accordingly
119  a_field->m_skylarkscrapes = true;
120  }
121  else {
122  a_field->m_skylarkscrapes = false;
123  }
124  // Set up the date management stuff
125  // The next bit of code just allows for altering dates after harvest if it is necessary
126  // to allow for a crop which starts its management early.
127 
128  int noDates = 1;
129  a_field->SetMDates(0, 0, g_date->DayInYear(10, 8)); // last possible day of harvest
130  a_field->SetMDates(1, 0, g_date->DayInYear(10, 8)); // las possible day of hay baling
131  // Can be up to 10 of these. If the shortening code is triggered
132  // then these will be reduced in value to 0
133 
134  a_field->SetMConstants(0, 1);
135 
136  // Check the next crop for early start, unless it is a spring crop
137  // in which case we ASSUME that no checking is necessary!!!!
138  // So DO NOT implement a crop that runs over the year boundary (i.e. from spring to spring!), at least not without fixing this.
139 
140  //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)
141  int d1;
142  if (!(a_farm->GetType() == tof_OptimisingFarm && g_date->GetYearNumber() > 0)) {
143 
144  if (a_ev->m_startday > g_date->DayInYear(1, 7)) {
145  if (a_field->GetMDates(0, 0) >= a_ev->m_startday)
146  {
147  g_msg->Warn(WARN_BUG, "IRWinterOats::Do(): ", "Harvest too late for the next crop to start!!!");
148  int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->m_next_tov);
149  g_msg->Warn("Next Crop ", (double)almassnum); // this causes exit
150  }
151  // Now fix any late finishing problems
152  for (int i = 0; i < noDates; i++) {
153  if (a_field->GetMDates(0, i) >= a_ev->m_startday) {
154  a_field->SetMDates(0, i, a_ev->m_startday - 1); //move the starting date
155  }
156  if (a_field->GetMDates(1, i) >= a_ev->m_startday) {
157  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)
158  a_field->SetMDates(1, i, a_ev->m_startday - 1); //move the finishing date
159  }
160  }
161  }
162  // Now no operations can be timed after the start of the next crop.
163 
164  if (!a_ev->m_first_year) {
165  // Are we before July 1st?
166  d1 = g_date->OldDays() + g_date->DayInYear(1, 7);
167  if (g_date->Date() < d1) {
168  // Yes, too early. We assumme this is because the last crop was late
169  printf("Poly: %d\n", a_field->GetPoly());
170  g_msg->Warn(WARN_BUG, "IRWinterOats::Do(): ", "Crop start attempt between 1st Jan & 1st July");
171  int prev = a_field->GetLandscape()->BackTranslateVegTypes(a_field->GetOwner()->GetPreviousTov(a_field->GetRotIndex()));
172  g_msg->Warn(WARN_BUG, "Previous Crop ", prev);
173  int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->m_next_tov);
174  g_msg->Warn("Next Crop ", (double)almassnum); // this causes exit
175  }
176  else {
177  d1 = g_date->OldDays() + m_first_date; // Add 365 for spring crop
178  if (g_date->Date() > d1) {
179  // Yes too late - should not happen - raise an error
180  g_msg->Warn(WARN_BUG, "IRWinterOats::Do(): ", "Crop start attempt after last possible start date");
181  g_msg->Warn(WARN_BUG, "Previous Crop ", "");
182  a_field->GetOwner()->GetPreviousTov(a_field->GetRotIndex());
183  int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->m_next_tov);
184  g_msg->Warn("Next Crop ", (double)almassnum); // this causes exit
185  }
186  }
187  }
188  else {
189  // Is the first year
190  // Some special code to cope with that first start-up year in ALMaSS - ignore for all practical purposes (start woth the first event on the after winter time) - Date here is a suggestion (not stated in crop scheme!)
191  if (a_farm->IsStockFarmer()) {
193  break;
194  }
195  else SimpleEvent(g_date->OldDays() + g_date->DayInYear(1, 2), ir_wo_ferti_p3, false);
196  break;
197  }
198  }//if
199 
200  // End single block date checking code. Please see next line comment as well.
201  // Reinit d1 to first possible starting date.
202  d1 = g_date->OldDays() + g_date->DayInYear(16, 8);
203  // OK, let's go.
204  // LKM: Here we queue up the first event - 10% do minimum tillage (mt) stubble harrow, 90% do conventional plough (cp), where half (45%) do stubble harrow as well
205  //
206  if (a_farm->IsStockFarmer()) {
207  SimpleEvent(d1, ir_wo_ferti_s1, false);
208  break;
209  }
210  else SimpleEvent(d1, ir_wo_ferti_p1, false);
211  break;
212 
213 
214 
215 
216  }
217  break;
218  // This is the first real farm operation
219 case ir_wo_ferti_s1: // 15% of all farmers do
220  if (a_ev->m_lock || a_farm->DoIt_prob(.15)) {
221  if (!a_farm->FA_Slurry(a_field, 0.0, g_date->DayInYear(10, 9) - g_date->DayInYear())) {
222  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_s1, true);
223  break;
224  }
225  }
227  break;
228 
229 case ir_wo_ferti_p1: // 15% of all farmers do
230  if (a_ev->m_lock || a_farm->DoIt_prob(.15)) {
231  if (!a_farm->FP_Slurry(a_field, 0.0, g_date->DayInYear(10, 9) - g_date->DayInYear())) {
232  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_p1, true);
233  break;
234  }
235  }
237  break;
238 
240  if (a_ev->m_lock || a_farm->DoIt_prob(.10)) {
241  if (!a_farm->StubbleHarrowing(a_field, 0.0, g_date->DayInYear(11, 9) - g_date->DayInYear())) {
243  break;
244  }
245  IR_WO_MT = true; // we need to remember who do mt
246  }
247  else if (a_ev->m_lock || a_farm->DoIt_prob(.90 / .90)) {
249  break;
250  }
251  if (a_farm->IsStockFarmer()) {
252  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_s2, false);
253  break;
254  }
255  else SimpleEvent(g_date->Date() + 1, ir_wo_ferti_p2, false);
256  break;
257 
258  case ir_wo_stubble_harrow_cp: // 27% (30% of conventional plough) do this
259  if (a_ev->m_lock || a_farm->DoIt_prob(.30)) {
260  if (!a_farm->StubbleHarrowing(a_field, 0.0, g_date->DayInYear(11, 9) - g_date->DayInYear())) {
262  break;
263  }
264  }
266  break;
267 
268  case ir_wo_autumn_plough:
269  if (!a_farm->AutumnPlough(a_field, 0.0, g_date->DayInYear(20, 10) - g_date->DayInYear())) {
271  break;
272  }
273  if (a_farm->IsStockFarmer()) {
274  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_s2, false);
275  break;
276  }
277  else SimpleEvent(g_date->Date() + 1, ir_wo_ferti_p2, false);
278  break;
279 
280  case ir_wo_ferti_s2: // 30% of all farmers do
281  if (a_ev->m_lock || a_farm->DoIt_prob(.30)) {
282  if (!a_farm->FA_PK(a_field, 0.0, g_date->DayInYear(21, 10) - g_date->DayInYear())) {
283  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_s2, true);
284  break;
285  }
286  }
287  if (IR_WO_MT == true) {
289  break;
290  }
291  else SimpleEvent(g_date->Date() + 2, ir_wo_autumn_sow, false);
292  break;
293 
294  case ir_wo_ferti_p2: // 30% of all farmers do
295  if (a_ev->m_lock || a_farm->DoIt_prob(.30)) {
296  if (!a_farm->FP_PK(a_field, 0.0, g_date->DayInYear(21, 10) - g_date->DayInYear())) {
297  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_p2, true);
298  break;
299  }
300  }
301  if (IR_WO_MT == true) {
303  break;
304  }
305  else SimpleEvent(g_date->Date() + 2, ir_wo_autumn_sow, false);
306  break;
307 
309  if (!a_farm->PreseedingCultivatorSow(a_field, 0.0,
310  g_date->DayInYear(22, 10) - g_date->DayInYear())) {
312  break;
313  }
315  break;
316 
317  case ir_wo_autumn_sow:
318  if (!a_farm->AutumnSow(a_field, 0.0,
319  g_date->DayInYear(23, 10) - g_date->DayInYear())) {
320  SimpleEvent(g_date->Date() + 1, ir_wo_autumn_sow, true);
321  break;
322  }
323  SimpleEvent(g_date->Date() + 1, ir_wo_autumn_harrow, false);
324  break;
325 
326  case ir_wo_autumn_harrow:
327  if (!a_farm->AutumnHarrow(a_field, 0.0,
328  g_date->DayInYear(24, 10) - g_date->DayInYear())) {
330  break;
331  }
333  break;
334  //CP and MT comes together for autumn roll
335  case ir_wo_autumn_roll:
336  if (!a_farm->AutumnRoll(a_field, 0.0,
337  g_date->DayInYear(25, 10) - g_date->DayInYear())) {
338  SimpleEvent(g_date->Date() + 1, ir_wo_autumn_roll, true);
339  break;
340  }
344  break;
345 
346  case ir_wo_herbicide:
347  if (!a_farm->HerbicideTreat(a_field, 0.0,
348  g_date->DayInYear(15, 11) - g_date->DayInYear())) {
349  SimpleEvent(g_date->Date() + 1, ir_wo_herbicide, true);
350  break;
351  }
352  break; // end of thread
353 
354  case ir_wo_insecticide:
355  if (a_ev->m_lock || a_farm->DoIt_prob(.80)) {
356  if (!a_farm->InsecticideTreat(a_field, 0.0,
357  g_date->DayInYear(15, 11) - g_date->DayInYear())) {
358  SimpleEvent(g_date->Date() + 1, ir_wo_insecticide, true);
359  break;
360  }
361  }
362  break; // end if thread
363 
364  case ir_wo_molluscicide:
365  if (a_ev->m_lock || a_farm->DoIt_prob(.15)) {
366  if (!a_farm->Molluscicide(a_field, 0.0,
367  g_date->DayInYear(15, 11) - g_date->DayInYear())) {
368  SimpleEvent(g_date->Date() + 1, ir_wo_molluscicide, true);
369  break;
370  }
371  }
372  if (a_farm->IsStockFarmer()) {
373  SimpleEvent(g_date->OldDays() + g_date->DayInYear(1, 2) + 365, ir_wo_ferti_s3, false);
374  break;
375  }
376  else SimpleEvent(g_date->OldDays() + g_date->DayInYear(1, 2) + 365, ir_wo_ferti_p3, false);
377  break;
378 
379  case ir_wo_ferti_s3:
380  if (!a_farm->FA_PK(a_field, 0.0, g_date->DayInYear(15, 3) - g_date->DayInYear())) {
381  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_s3, true);
382  break;
383  }
384  SimpleEvent(g_date->Date() + 7, ir_wo_ferti_s4, false);
385  break;
386 
387  case ir_wo_ferti_p3:
388  if (!a_farm->FP_PK(a_field, 0.0, g_date->DayInYear(15, 3) - g_date->DayInYear())) {
389  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_p3, true);
390  break;
391  }
392  SimpleEvent(g_date->Date() + 7, ir_wo_ferti_p4, false);
393  break;
394 
395  case ir_wo_ferti_s4:
396  if (!a_farm->FA_AmmoniumSulphate(a_field, 0.0, g_date->DayInYear(31, 3) - g_date->DayInYear())) {
397  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_s4, true);
398  break;
399  }
400  SimpleEvent(g_date->Date() + 7, ir_wo_ferti_s5, false);
402  break;
403 
404  case ir_wo_ferti_p4:
405  if (!a_farm->FP_AmmoniumSulphate(a_field, 0.0, g_date->DayInYear(31, 3) - g_date->DayInYear())) {
406  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_p4, true);
407  break;
408  }
409  SimpleEvent(g_date->Date() + 7, ir_wo_ferti_p5, false);
411  break;
412 
413  case ir_wo_ferti_s5:
414  if (!a_farm->FA_AmmoniumSulphate(a_field, 0.0, g_date->DayInYear(30, 4) - g_date->DayInYear())) {
415  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_s5, true);
416  break;
417  }
418  break;
419 
420  case ir_wo_ferti_p5:
421  if (!a_farm->FP_AmmoniumSulphate(a_field, 0.0, g_date->DayInYear(30, 4) - g_date->DayInYear())) {
422  SimpleEvent(g_date->Date() + 1, ir_wo_ferti_p5, true);
423  break;
424  }
425  break;
426 
427  case ir_wo_fungicide1:
428  if (!a_farm->FungicideTreat(a_field, 0.0, g_date->DayInYear(30, 4) - g_date->DayInYear())) {
429  SimpleEvent(g_date->Date() + 1, ir_wo_fungicide1, true);
430  break;
431  }
433  break;
434 
435  case ir_wo_fungicide2:
436  if (!a_farm->FungicideTreat(a_field, 0.0, g_date->DayInYear(31, 5) - g_date->DayInYear())) {
437  SimpleEvent(g_date->Date() + 1, ir_wo_fungicide2, true);
438  break;
439  }
440  SimpleEvent(g_date->OldDays() + g_date->DayInYear(25, 7), ir_wo_harvest, false);
441  break;
442 
443  case ir_wo_harvest:
444  if (!a_farm->Harvest(a_field, 0.0, a_field->GetMDates(0, 0) - g_date->DayInYear())) {
445  SimpleEvent(g_date->Date() + 1, ir_wo_harvest, true);
446  break;
447  }
449  break;
450 
451  case ir_wo_hay_bailing:
452  if (!a_farm->HayBailing(a_field, 0.0, a_field->GetMDates(1, 0) - g_date->DayInYear())) {
453  SimpleEvent(g_date->Date() + 1, ir_wo_hay_bailing, true);
454  break;
455  }
456  done = true;
457  // So we are done, and somewhere else the farmer will queue up the start event of the next crop
458  // END OF MAIN THREAD
459  break;
460  default:
461  g_msg->Warn(WARN_BUG, "IRWinterOats::Do(): "
462  "Unknown event type! ", "");
463  exit(1);
464  }
465  return done;
466 }

References Farm::AutumnHarrow(), Farm::AutumnPlough(), Farm::AutumnRoll(), Farm::AutumnSow(), cfg_IR_WinterOats_SkScrapes, LE::ClearManagementActionSum(), Calendar::Date(), Calendar::DayInYear(), Farm::DoIt_prob(), Farm::FA_AmmoniumSulphate(), Farm::FA_PK(), Farm::FA_Slurry(), Farm::FP_AmmoniumSulphate(), Farm::FP_PK(), Farm::FP_Slurry(), Farm::FungicideTreat(), g_date, g_msg, LE::GetMDates(), LE::GetOwner(), LE::GetPoly(), Farm::GetPreviousTov(), LE::GetRotIndex(), Farm::GetType(), Calendar::GetYearNumber(), Farm::Harvest(), Farm::HayBailing(), Farm::HerbicideTreat(), Farm::InsecticideTreat(), ir_wo_autumn_harrow, ir_wo_autumn_plough, ir_wo_autumn_roll, ir_wo_autumn_sow, IR_WO_CP, ir_wo_cultivation_sow_mt, ir_wo_ferti_p1, ir_wo_ferti_p2, ir_wo_ferti_p3, ir_wo_ferti_p4, ir_wo_ferti_p5, ir_wo_ferti_s1, ir_wo_ferti_s2, ir_wo_ferti_s3, ir_wo_ferti_s4, ir_wo_ferti_s5, ir_wo_fungicide1, ir_wo_fungicide2, ir_wo_harvest, ir_wo_hay_bailing, ir_wo_herbicide, ir_wo_insecticide, ir_wo_molluscicide, IR_WO_MT, ir_wo_start, ir_wo_stubble_harrow_cp, ir_wo_stubble_harrow_mt, Farm::IsStockFarmer(), 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, Farm::Molluscicide(), Calendar::OldDays(), Farm::PreseedingCultivatorSow(), LE::SetMConstants(), LE::SetMDates(), Crop::SimpleEvent(), Farm::StubbleHarrowing(), tof_OptimisingFarm, CfgBool::value(), MapErrorMsg::Warn(), and WARN_BUG.

◆ SetUpFarmCategoryInformation()

void IRWinterOats::SetUpFarmCategoryInformation ( )
inline
119  {
120  const int elements = 2 + (ir_wo_foobar - IR_WO_BASE);
122 
123  FarmManagementCategory catlist[elements] =
124  {
125  fmc_Others, // zero element unused but must be here
126  fmc_Others, // ir_wo_start = 1, // Compulsory, must always be 1 (one).
127  fmc_Others, // ir_wo_sleep_all_day = IR_WB_BASE,
128  fmc_Fertilizer, // ir_wo_ferti_s1
129  fmc_Fertilizer, // ir_wo_ferti_p1
130  fmc_Cultivation, // ir_wo_stubble_harrow_mt,
131  fmc_Cultivation, // ir_wo_stubble_harrow_cp,
132  fmc_Cultivation, //ir_wo_autumn_plough,
133  fmc_Others, //ir_wo_autumn_sow,
134  fmc_Cultivation, //ir_wo_autumn_harrow,
135  fmc_Cultivation, //ir_wo_stubble_cultivator,
136  fmc_Herbicide, //ir_wo_herbicide,
137  fmc_Fungicide, //ir_wo_fungicide1,
138  fmc_Fungicide, //ir_wo_fungicide2,
139  fmc_Cultivation, //ir_wo_stubble_cultivator_mt,
140  fmc_Cultivation, //ir_wo_cultivation_sow_mt,
141  fmc_Fertilizer, //ir_wo_ferti_s2,
142  fmc_Fertilizer, //ir_wo_ferti_p2,
143  fmc_Others, //ir_wo_spring_roll,
144  fmc_Fertilizer, //ir_wo_ferti_s3,
145  fmc_Fertilizer, //ir_wo_ferti_p3,
146  fmc_Fertilizer, // ir_wo_ferti_s4,
147  fmc_Fertilizer, //ir_wo_ferti_p4,
148  fmc_Fertilizer, // ir_wo_ferti_s5,
149  fmc_Fertilizer, //ir_wo_ferti_p5,
150  fmc_Insecticide, //ir_wo_molluscicide,
151  fmc_Insecticide, //ir_wo_insecticide,
152  fmc_Harvest, // ir_wo_harvest,
153  fmc_Others, // ir_wo_hay_bailing,
154 
155 
156  // no foobar entry
157 
158  };
159  // Iterate over the catlist elements and copy them to vector
160  copy(begin(catlist), end(catlist), back_inserter(m_ManagementCategories));
161 
162  }

References fmc_Cultivation, fmc_Fertilizer, fmc_Fungicide, fmc_Harvest, fmc_Herbicide, fmc_Insecticide, fmc_Others, IR_WO_BASE, ir_wo_foobar, Crop::m_base_elements_no, and Crop::m_ManagementCategories.

Referenced by IRWinterOats().


The documentation for this class was generated from the following files:
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
Farm::FA_Slurry
virtual bool FA_Slurry(LE *a_field, double a_user, int a_days)
Spready slurry on a_field owned by an stock farmer.
Definition: FarmFuncs.cpp:1067
ir_wo_herbicide
Definition: IRWinterOats.h:77
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
Farm::IsStockFarmer
bool IsStockFarmer(void)
Definition: Farm.h:961
ir_wo_ferti_s1
Definition: IRWinterOats.h:69
IR_WO_BASE
#define IR_WO_BASE
Definition: IRWinterOats.h:53
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
IR_WO_CP
#define IR_WO_CP
Definition: IRWinterOats.h:58
LE::ClearManagementActionSum
void ClearManagementActionSum()
clears the management action counters
Definition: Elements.h:247
Calendar::GetYearNumber
int GetYearNumber(void)
Definition: Calendar.h:72
FarmEvent::m_first_year
bool m_first_year
Definition: Farm.h:386
Farm::Molluscicide
virtual bool Molluscicide(LE *a_field, double a_user, int a_days)
Apply molluscicide to a_field.
Definition: FarmFuncs.cpp:2310
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
ir_wo_ferti_p5
Definition: IRWinterOats.h:90
fmc_Herbicide
Definition: LandscapeFarmingEnums.h:1006
Farm::GetPreviousTov
TTypesOfVegetation GetPreviousTov(int a_index)
Definition: Farm.h:966
ir_wo_ferti_s5
Definition: IRWinterOats.h:89
ir_wo_ferti_p1
Definition: IRWinterOats.h:70
Farm::GetType
TTypesOfFarm GetType(void)
Definition: Farm.h:956
Crop::m_base_elements_no
int m_base_elements_no
Definition: Farm.h:505
ir_wo_harvest
Definition: IRWinterOats.h:93
Crop::m_first_date
int m_first_date
Definition: Farm.h:501
FarmEvent::m_startday
int m_startday
Definition: Farm.h:385
ir_wo_stubble_harrow_cp
Definition: IRWinterOats.h:72
Farm::FungicideTreat
virtual bool FungicideTreat(LE *a_field, double a_user, int a_days)
Apply fungicide to a_field.
Definition: FarmFuncs.cpp:2101
ir_wo_ferti_s3
Definition: IRWinterOats.h:85
IR_WO_MT
#define IR_WO_MT
A flag used to indicate autumn ploughing status.
Definition: IRWinterOats.h:57
Farm::FP_PK
virtual bool FP_PK(LE *a_field, double a_user, int a_days)
Apply PK fertilizer, on a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:673
Crop::SimpleEvent
void SimpleEvent(long a_date, int a_todo, bool a_lock)
Adds an event to this crop management.
Definition: Farm.cpp:747
ir_wo_ferti_s4
Definition: IRWinterOats.h:87
CfgBool::value
bool value() const
Definition: Configurator.h:164
ir_wo_fungicide1
Definition: IRWinterOats.h:78
ir_wo_ferti_s2
Definition: IRWinterOats.h:82
ir_wo_cultivation_sow_mt
Definition: IRWinterOats.h:81
ir_wo_ferti_p2
Definition: IRWinterOats.h:83
ir_wo_hay_bailing
Definition: IRWinterOats.h:94
fmc_Fertilizer
Definition: LandscapeFarmingEnums.h:1004
IRWinterOats::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: IRWinterOats.h:119
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
ir_wo_fungicide2
Definition: IRWinterOats.h:79
Farm::FP_AmmoniumSulphate
virtual bool FP_AmmoniumSulphate(LE *a_field, double a_user, int a_days)
Apply Ammonium Sulphate to a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:882
ir_wo_ferti_p4
Definition: IRWinterOats.h:88
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
Farm::HayBailing
virtual bool HayBailing(LE *a_field, double a_user, int a_days)
Carry out hay bailing on a_field.
Definition: FarmFuncs.cpp:1507
fmc_Others
Definition: LandscapeFarmingEnums.h:1003
Calendar::OldDays
long OldDays(void)
Definition: Calendar.h:60
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
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
ir_wo_insecticide
Definition: IRWinterOats.h:92
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
ir_wo_autumn_roll
Definition: IRWinterOats.h:84
Farm::PreseedingCultivatorSow
virtual bool PreseedingCultivatorSow(LE *a_field, double a_user, int a_days, double a_seed_coating_amount=-1, PlantProtectionProducts a_ppp=ppp_foobar)
Carry out preseeding cultivation together with sow on a_field (tilling and sowing set including culti...
Definition: FarmFuncs.cpp:325
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::AutumnRoll
virtual bool AutumnRoll(LE *a_field, double a_user, int a_days)
Carry out a roll event in the autumn on a_field.
Definition: FarmFuncs.cpp:299
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
ir_wo_autumn_plough
Definition: IRWinterOats.h:73
tof_OptimisingFarm
Definition: LandscapeFarmingEnums.h:696
cfg_IR_WinterOats_SkScrapes
CfgBool cfg_IR_WinterOats_SkScrapes("IR_CROP_WO_SK_SCRAPES", CFG_CUSTOM, false)
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
Farm::AutumnHarrow
virtual bool AutumnHarrow(LE *a_field, double a_user, int a_days)
Carry out a harrow event in the autumn on a_field.
Definition: FarmFuncs.cpp:285
Farm::FA_AmmoniumSulphate
virtual bool FA_AmmoniumSulphate(LE *a_field, double a_user, int a_days)
Apply ammonium sulphate to a_field owned by an stock farmer.
Definition: FarmFuncs.cpp:1081
ir_wo_start
Definition: IRWinterOats.h:67
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
ir_wo_autumn_sow
Definition: IRWinterOats.h:74
ir_wo_autumn_harrow
Definition: IRWinterOats.h:75
LE::GetOwner
Farm * GetOwner(void)
Definition: Elements.h:256
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
Crop::Crop
Crop(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: Farm.cpp:733
Farm::FA_PK
virtual bool FA_PK(LE *a_field, double a_user, int a_days)
Apply PK fertilizer to a_field owned by an stock farmer.
Definition: FarmFuncs.cpp:1010
ir_wo_ferti_p3
Definition: IRWinterOats.h:86
LE::SetMConstants
void SetMConstants(int a, int c)
Definition: Elements.h:408
ir_wo_foobar
Definition: IRWinterOats.h:95
WARN_BUG
Definition: MapErrorMsg.h:34
fmc_Fungicide
Definition: LandscapeFarmingEnums.h:1007
FarmManagementCategory
FarmManagementCategory
Definition: LandscapeFarmingEnums.h:1001
Farm::StubbleHarrowing
virtual bool StubbleHarrowing(LE *a_field, double a_user, int a_days)
Carry out stubble harrowing on a_field.
Definition: FarmFuncs.cpp:1523
ir_wo_molluscicide
Definition: IRWinterOats.h:91
ir_wo_stubble_harrow_mt
Definition: IRWinterOats.h:71