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
|
BEWinterBarleyCC class
.
More...
#include <BEWinterBarleyCC.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...
|
|
BEWinterBarleyCC class
.
See BEWinterBarleyCC.h::BEWinterBarleyCCToDo for a complete list of all possible events triggered codes by the winter barley management plan. When triggered these events are handled by Farm and are available as information for other objects such as animal and bird models.
◆ BEWinterBarleyCC()
◆ Do()
bool BEWinterBarleyCC::Do |
( |
Farm * |
a_farm, |
|
|
LE * |
a_field, |
|
|
FarmEvent * |
a_ev |
|
) |
| |
|
virtual |
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 Barley.
Reimplemented from Crop.
77 int l_nextcropstartdate;
112 g_msg->
Warn(
WARN_BUG,
"BEWinterBarleyCC::Do(): ",
"Harvest too late for the next crop to start!!!");
113 int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->
m_next_tov);
114 g_msg->
Warn(
"Next Crop ", (
double)almassnum);
117 for (
int i = 0; i < noDates; i++) {
134 printf(
"Poly: %d\n", a_field->
GetPoly());
135 g_msg->
Warn(
WARN_BUG,
"BEWinterBarleyCC::Do(): ",
"Crop start attempt between 1st Jan & 1st July");
138 int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->
m_next_tov);
139 g_msg->
Warn(
"Next Crop ", (
double)almassnum);
146 g_msg->
Warn(
WARN_BUG,
"BEWinterBarleyCC::Do(): ",
"Crop start attempt after last possible start date");
149 int almassnum = a_field->GetLandscape()->BackTranslateVegTypes(a_ev->
m_next_tov);
150 g_msg->
Warn(
"Next Crop ", (
double)almassnum);
205 if (a_ev->
m_lock || a_farm->DoIt_prob(0.1))
215 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
244 if (a_farm->IsStockFarmer())
249 if (a_farm->IsStockFarmer())
257 if (a_ev->
m_lock || a_farm->DoIt_prob(1.0))
267 if (a_ev->
m_lock || a_farm->DoIt_prob(1.00))
278 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
288 if (a_ev->
m_lock || a_farm->DoIt_prob(1.00))
297 if (a_ev->
m_lock || a_farm->DoIt_prob(0.85))
324 if (a_ev->
m_lock || a_farm->DoIt_prob(0.50))
335 if (a_ev->
m_lock || a_farm->DoIt_prob(0.15))
346 if (a_ev->
m_lock || a_farm->DoIt_prob(0.15))
401 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
411 if (a_ev->
m_lock || a_farm->DoIt_prob(0.70))
439 if (!a_farm->StrawChopping(a_field, 0.0, -1)) {
440 g_msg->
Warn(
WARN_BUG,
"BEWinterBarleyCC::Do(): failure in 'StrawChopping' execution",
"");
456 if (!a_farm->HayBailing(a_field, 0.0, -1)) {
457 g_msg->
Warn(
WARN_BUG,
"BEWinterBarleyCC::Do(): failure in 'HayBailing' execution",
"");
471 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);
482 "Unknown event type! ",
"");
References Farm::AddNewEvent(), BE_wbcc_autumn_plough, BE_wbcc_ferti_p1, BE_wbcc_ferti_p3, BE_wbcc_ferti_p4, BE_wbcc_ferti_p5, BE_wbcc_ferti_s1, BE_wbcc_ferti_s3, BE_wbcc_ferti_s4, BE_wbcc_ferti_s5, BE_wbcc_fungicide1, BE_wbcc_fungicide2, BE_wbcc_growth_regulator1, BE_wbcc_growth_regulator2, BE_wbcc_harvest, BE_wbcc_hay_bailing, BE_wbcc_herbicide1, BE_wbcc_herbicide2, BE_wbcc_herbicide3, BE_wbcc_herbicide4, BE_wbcc_insecticide2, BE_wbcc_mole_plough, BE_wbcc_preseeding_cultivator_sow, BE_wbcc_start, BE_wbcc_straw_chopping, BE_wbcc_stubble_cultivator, cfg_pest_product_amounts, cfg_pest_winterbarley_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_(), Farm::StubbleHarrowing(), Landscape::SupplyLEPointer(), tof_OptimisingFarm, tov_BECatchPeaCrop, tov_BEWinterBarleyCC, 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: BEWinterBarleyCC.h:39
LE * SupplyLEPointer(int a_polyref)
Returns a pointer to the object referred to by the polygon number.
Definition: Landscape.h:1722
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
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
int GetYearNumber(void)
Definition: Calendar.h:72
bool m_first_year
Definition: Farm.h:386
Definition: BEWinterBarleyCC.h:47
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
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: BEWinterBarleyCC.h:55
TTypesOfFarm GetType(void)
Definition: Farm.h:956
Definition: BEWinterBarleyCC.h:42
Definition: BEWinterBarleyCC.h:58
int m_first_date
Definition: Farm.h:501
int m_startday
Definition: Farm.h:385
Definition: BEWinterBarleyCC.h:48
Definition: BEWinterBarleyCC.h:52
Definition: BEWinterBarleyCC.h:56
bool value() const
Definition: Configurator.h:164
Definition: BEWinterBarleyCC.h:43
Definition: BEWinterBarleyCC.h:60
Definition: BEWinterBarleyCC.h:51
Definition: BEWinterBarleyCC.h:40
Definition: LandscapeFarmingEnums.h:305
long Date(void)
Definition: Calendar.h:57
Definition: BEWinterBarleyCC.h:45
Definition: BEWinterBarleyCC.h:35
Definition: LandscapeFarmingEnums.h:1003
void SetVegPatchy(bool p)
Definition: Elements.h:229
long OldDays(void)
Definition: Calendar.h:60
Definition: BEWinterBarleyCC.h:37
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: BEWinterBarleyCC.h:41
Definition: BEWinterBarleyCC.h:46
LE * m_field
Definition: Farm.h:391
TTypesOfVegetation m_next_tov
Definition: Farm.h:390
Definition: BEWinterBarleyCC.h:54
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: BEWinterBarleyCC.h:44
virtual void SetVegType(TTypesOfVegetation)
Definition: Elements.h:175
Definition: LandscapeFarmingEnums.h:696
Definition: Elements.h:86
MapErrorMsg * g_msg
Definition: MapErrorMsg.cpp:41
Definition: BEWinterBarleyCC.h:59
TTypesOfVegetation
Values that represent the types of vegetation that are represented in ALMaSS.
Definition: LandscapeFarmingEnums.h:192
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: BEWinterBarleyCC.h:57
int GetUnsprayedMarginPolyRef(void)
Definition: Elements.h:383
Farm * GetOwner(void)
Definition: Elements.h:256
int DayInYear(void)
Definition: Calendar.h:58
Definition: BEWinterBarleyCC.h:49
CfgBool cfg_pest_winterbarley_on
Turn on pesticides for winter barley.
CfgArray_Double cfg_pest_product_amounts
Amount of pesticide applied in grams of active substance per hectare for each of the 10 pesticides.
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
Definition: BEWinterBarleyCC.h:53
Definition: BEWinterBarleyCC.h:50
FarmEvent * m_ev
Definition: Farm.h:500
Landscape * m_OurLandscape
Definition: Farm.h:506
Definition: MapErrorMsg.h:34
Definition: LandscapeFarmingEnums.h:1079
Definition: BEWinterBarleyCC.h:38
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