Loading [MathJax]/extensions/ams.js
 |
ALMaSS
1.2 (after EcoStack, March 2024)
The Animal, Landscape and Man Simulation System
|
BEWinterWheatCC class
.
More...
#include <BEWinterWheatCC.h>
|
TTypesOfVegetation | m_tov |
|
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...
|
|
Farm * | m_farm |
|
LE * | m_field |
|
FarmEvent * | m_ev |
|
int | m_first_date |
|
int | m_count |
|
int | m_last_date |
|
int | m_ddegstoharvest |
|
int | m_base_elements_no |
|
Landscape * | m_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< FarmManagementCategory > | m_ManagementCategories |
| Holds the translation between the farm operation enum for each crop and the farm management category associated with it. More...
|
|
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...
|
|
BEWinterWheatCC class
.
See BEWinterWheatCC.h::BEWinterWheatCCToDo 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.
◆ BEWinterWheatCC()
◆ Do()
The one and oBEy 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.
78 int l_nextcropstartdate;
113 g_msg->
Warn(
WARN_BUG,
"BEWinterWheatCC::Do(): ",
"Harvest too late for the next crop to start!!!");
114 int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->
m_next_tov);
115 g_msg->
Warn(
"Next Crop ", (
double)almassnum);
118 for (
int i = 0; i < noDates; i++) {
135 printf(
"Poly: %d\n", a_field->
GetPoly());
136 g_msg->
Warn(
WARN_BUG,
"BEWinterWheatCC::Do(): ",
"Crop start attempt between 1st Jan & 1st July");
139 int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->
m_next_tov);
140 g_msg->
Warn(
"Next Crop ", (
double)almassnum);
147 g_msg->
Warn(
WARN_BUG,
"BEWinterWheatCC::Do(): ",
"Crop start attempt after last possible start date");
150 int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->
m_next_tov);
151 g_msg->
Warn(
"Next Crop ", (
double)almassnum);
206 if (a_ev->
m_lock || a_farm->DoIt_prob(0.1))
216 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
245 if (a_farm->IsStockFarmer())
250 if (a_farm->IsStockFarmer())
258 if (a_ev->
m_lock || a_farm->DoIt_prob(1.0))
268 if (a_ev->
m_lock || a_farm->DoIt_prob(1.00))
279 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
289 if (a_ev->
m_lock || a_farm->DoIt_prob(0.9))
299 if (a_ev->
m_lock || a_farm->DoIt_prob(1.0))
308 #ifdef ECOSTACK_BIOPESTICIDE
309 if (a_ev->
m_lock || a_farm->DoIt_prob(0.85))
311 if (a_ev->
m_lock || a_farm->DoIt_prob(0.85))
318 #ifdef ECOSTACK_BIOPESTICIDE
331 #ifdef ECOSTACK_BIOPESTICIDE
339 #ifdef ECOSTACK_BIOPESTICIDE
361 if (a_ev->
m_lock || a_farm->DoIt_prob(0.80))
372 if (a_ev->
m_lock || a_farm->DoIt_prob(0.15))
383 if (a_ev->
m_lock || a_farm->DoIt_prob(0.15))
438 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
448 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
476 if (!a_farm->StrawChopping(a_field, 0.0, -1)) {
477 g_msg->
Warn(
WARN_BUG,
"BEWinterWheatCC::Do(): failure in 'StrawChopping' execution",
"");
493 if (!a_farm->HayBailing(a_field, 0.0, -1)) {
494 g_msg->
Warn(
WARN_BUG,
"BEWinterWheatCC::Do(): failure in 'HayBailing' execution",
"");
508 m_farm->
AddNewEvent(
tov_BECatchPeaCrop,
g_date->
Date(),
m_ev->
m_field,
PROG_START,
m_ev->
m_field->GetRunNum(),
false, l_nextcropstartdate,
false, l_tov,
fmc_Others,
false,
false);
519 "Unknown event type! ",
"");
References Farm::AddNewEvent(), BE_wwcc_autumn_plough, BE_wwcc_ferti_p1, BE_wwcc_ferti_p3, BE_wwcc_ferti_p4, BE_wwcc_ferti_p5, BE_wwcc_ferti_s1, BE_wwcc_ferti_s3, BE_wwcc_ferti_s4, BE_wwcc_ferti_s5, BE_wwcc_fungicide1, BE_wwcc_fungicide2, BE_wwcc_fungicide3, BE_wwcc_growth_regulator1, BE_wwcc_growth_regulator2, BE_wwcc_harvest, BE_wwcc_hay_bailing, BE_wwcc_herbicide1, BE_wwcc_herbicide2, BE_wwcc_herbicide3, BE_wwcc_herbicide4, BE_wwcc_insecticide2, BE_wwcc_insecticide2b, BE_wwcc_mole_plough, BE_wwcc_preseeding_cultivator_sow, BE_wwcc_start, BE_wwcc_straw_chopping, BE_wwcc_stubble_cultivator, Farm::BiocideTreat(), cfg_pest_product_amounts, cfg_pest_winterwheat_on, Calendar::Date(), Calendar::DayInYear(), Farm::DoIt_prob(), fmc_Others, g_date, g_msg, LE::GetMConstants(), LE::GetMDates(), Farm::GetNextCropStartDate(), LE::GetOwner(), LE::GetPoly(), Farm::GetPreviousTov(), LE::GetRotIndex(), Farm::GetType(), LE::GetUnsprayedMarginPolyRef(), Calendar::GetYearNumber(), Farm::HerbicideTreat(), Farm::InsecticideTreat(), Crop::m_date_modifier, Crop::m_ev, Crop::m_farm, FarmEvent::m_field, Crop::m_field, Crop::m_first_date, FarmEvent::m_first_year, FarmEvent::m_lock, FarmEvent::m_next_tov, Crop::m_OurLandscape, FarmEvent::m_startday, FarmEvent::m_todo, Calendar::OldDays(), ppp_1, Farm::ProductApplication(), PROG_START, LE::SetMConstants(), LE::SetMDates(), LE::SetVegPatchy(), LE::SetVegType(), Crop::SimpleEvent(), Crop::SimpleEvent_(), Farm::StubbleHarrowing(), Landscape::SupplyLEPointer(), tof_OptimisingFarm, tov_BECatchPeaCrop, tov_DKWinterWheat_CC, tov_Undefined, CfgBool::value(), CfgArray_Double::value(), MapErrorMsg::Warn(), and WARN_BUG.
The documentation for this class was generated from the following files:
int GetMDates(int a, int b)
Definition: Elements.h:405
Definition: BEWinterWheatCC.h:55
LE * SupplyLEPointer(int a_polyref)
Returns a pointer to the object referred to by the polygon number.
Definition: Landscape.h:1722
Definition: BEWinterWheatCC.h:54
void SetMDates(int a, int b, int c)
Definition: Elements.h:406
virtual bool HerbicideTreat(LE *a_field, double a_user, int a_days)
Apply herbicide to a_field.
Definition: FarmFuncs.cpp:2025
bool m_lock
Definition: Farm.h:384
Definition: BEWinterWheatCC.h:40
virtual bool ProductApplication(LE *a_field, double a_user, int a_days, double a_applicationrate, PlantProtectionProducts a_ppp, bool a_isgranularpesticide=false, int a_orcharddrifttype=0)
Apply test pesticide to a_field.
Definition: FarmFuncs.cpp:2267
int GetMConstants(int a)
Definition: Elements.h:407
Definition: BEWinterWheatCC.h:48
int GetYearNumber(void)
Definition: Calendar.h:72
bool m_first_year
Definition: Farm.h:386
Definition: BEWinterWheatCC.h:57
int GetPoly(void)
Returns the polyref number for this polygon.
Definition: Elements.h:238
Definition: LandscapeFarmingEnums.h:291
bool DoIt_prob(double a_probability)
Return chance out of 0 to 1.
Definition: Farm.cpp:864
class Calendar * g_date
Definition: Calendar.cpp:37
TTypesOfVegetation GetPreviousTov(int a_index)
Definition: Farm.h:966
Definition: BEWinterWheatCC.h:47
int GetNextCropStartDate(LE *a_field, TTypesOfVegetation &a_curr_veg)
Returns the start date of the next crop in the rotation.
Definition: Farm.cpp:920
void AddNewEvent(TTypesOfVegetation a_event, long a_date, LE *a_field, int a_todo, long a_num, bool a_lock, int a_start, bool a_first_year, TTypesOfVegetation a_crop, FarmManagementCategory a_fmc, bool a_forcespring, bool a_forcespringOK)
Adds an event to the event queue for a farm.
Definition: Farm.cpp:845
Definition: BEWinterWheatCC.h:61
TTypesOfFarm GetType(void)
Definition: Farm.h:956
Definition: BEWinterWheatCC.h:38
int m_first_date
Definition: Farm.h:501
int m_startday
Definition: Farm.h:385
Definition: BEWinterWheatCC.h:50
Definition: BEWinterWheatCC.h:58
void SimpleEvent(long a_date, int a_todo, bool a_lock)
Adds an event to this crop management.
Definition: Farm.cpp:747
Definition: BEWinterWheatCC.h:41
bool value() const
Definition: Configurator.h:164
Definition: BEWinterWheatCC.h:49
Definition: BEWinterWheatCC.h:35
long Date(void)
Definition: Calendar.h:57
Definition: LandscapeFarmingEnums.h:1003
Definition: BEWinterWheatCC.h:37
void SetVegPatchy(bool p)
Definition: Elements.h:229
long OldDays(void)
Definition: Calendar.h:60
void Warn(MapErrorState a_level, std::string a_msg1, std::string a_msg2)
Definition: MapErrorMsg.cpp:69
int GetRotIndex(void)
Definition: Elements.h:373
Definition: BEWinterWheatCC.h:53
Definition: BEWinterWheatCC.h:46
LE * m_field
Definition: Farm.h:391
Definition: BEWinterWheatCC.h:62
TTypesOfVegetation m_next_tov
Definition: Farm.h:390
Definition: BEWinterWheatCC.h:43
Farm * m_farm
Definition: Farm.h:498
LE * m_field
Definition: Farm.h:499
std::vector< double > value() const
Definition: Configurator.h:219
int m_todo
Definition: Farm.h:388
virtual bool InsecticideTreat(LE *a_field, double a_user, int a_days)
Apply insecticide to a_field.
Definition: FarmFuncs.cpp:2135
Definition: LandscapeFarmingEnums.h:610
Definition: BEWinterWheatCC.h:42
virtual void SetVegType(TTypesOfVegetation)
Definition: Elements.h:175
Definition: BEWinterWheatCC.h:52
virtual bool BiocideTreat(LE *a_field, double a_user, int a_days)
Apply Biocide to a_field.
Definition: FarmFuncs.cpp:2175
CfgArray_Double cfg_pest_product_amounts
Amount of pesticide applied in grams of active substance per hectare for each of the 10 pesticides.
Definition: LandscapeFarmingEnums.h:696
Definition: BEWinterWheatCC.h:60
Definition: Elements.h:86
Definition: BEWinterWheatCC.h:45
Definition: LandscapeFarmingEnums.h:422
CfgBool cfg_pest_winterwheat_on
Turn on pesticides for winter wheat.
MapErrorMsg * g_msg
Definition: MapErrorMsg.cpp:41
TTypesOfVegetation
Values that represent the types of vegetation that are represented in ALMaSS.
Definition: LandscapeFarmingEnums.h:192
Definition: BEWinterWheatCC.h:51
static int m_date_modifier
Holds a value that shifts test pesticide use by this many days in crops modified to use it.
Definition: Farm.h:514
Definition: BEWinterWheatCC.h:39
Definition: BEWinterWheatCC.h:44
int GetUnsprayedMarginPolyRef(void)
Definition: Elements.h:383
Farm * GetOwner(void)
Definition: Elements.h:256
int DayInYear(void)
Definition: Calendar.h:58
Definition: BEWinterWheatCC.h:56
Crop(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: Farm.cpp:733
#define PROG_START
Definition: Farm.h:69
void SetMConstants(int a, int c)
Definition: Elements.h:408
FarmEvent * m_ev
Definition: Farm.h:500
Landscape * m_OurLandscape
Definition: Farm.h:506
Definition: BEWinterWheatCC.h:59
Definition: MapErrorMsg.h:34
Definition: LandscapeFarmingEnums.h:1079
virtual bool StubbleHarrowing(LE *a_field, double a_user, int a_days)
Carry out stubble harrowing on a_field.
Definition: FarmFuncs.cpp:1523
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.
Definition: Farm.cpp:751