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
UKSpringBarley.h
Go to the documentation of this file.
1 
13 //
14 // UKSpringBarley.h
15 //
16 
17 
18 #ifndef UKSPRINGBARLEY_H
19 #define UKSPRINGBARLEY_H
20 
21 #define UKSPRINGBARLEY_BASE 45500
22 
25 #define UK_SB_FUNGII a_field->m_user[1]
26 
27 
33 typedef enum {
34  uk_sb_start = 1, // Compulsory, must always be 1 (one).
36  uk_sb_autumn_harrow, // Stubble cultivator 60% September-October
37  uk_sb_autumn_plough, // Autumn plough 50% October-December
38  uk_sb_ferti_s1, // Slurry 40% March if no autumn plough
40  uk_sb_spring_plough, //Spring plough 20% March if Slurry
41  uk_sb_ferti_s2, // N fertiliser 85% March
43  uk_sb_ferti_s3, // NPK application 50% before preseeding
45  uk_sb_preseeding_cultivator, // Preseeding cultivation 100% April
46  uk_sb_spring_sow, // Spring sow 100% April
47  uk_sb_harrow, // Harrow 20% pre-em April
48  uk_sb_herbicide1, // Herbicide 1 90% April
49  uk_sb_fungicide1, // Fungicide 1 80% June
50  uk_sb_fungicide2, // Fungicide 2 40% 14-21 days after f1
51  uk_sb_insecticide1, // Insecticide 1 30% June
52  uk_sb_growth_regulator1, // Growth Regulator 1 40% May-June
53  uk_sb_harvest, // Harvest 100% July-August
54  uk_sb_straw_chopping, // Straw chopping 50% after harvest
55  uk_sb_hay_bailing, // Hay bailing 50% after harvest
58 
59 
68 class UKSpringBarley: public Crop
69 {
70  public:
71  virtual bool Do(Farm* a_farm, LE* a_field, FarmEvent* a_ev);
72  UKSpringBarley(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape* a_L) : Crop(a_tov, a_toc, a_L)
73  {
74  // When we start it off, the first possible date for a farm operation is 1st September
75  // This information is used by other crops when they decide how much post processing of
76  // the management is allowed after harvest before the next crop starts.
77  m_first_date=g_date->DayInYear( 10,10 );
79  }
81  const int elements = 2 + (uk_sb_foobar - UKSPRINGBARLEY_BASE);
83  FarmManagementCategory catlist[elements] =
84  {
85  fmc_Others, // this needs to be at the zero line
86  fmc_Others,//uk_sb_start = 1, // Compulsory, must always be 1 (one).
87  fmc_Others,//uk_sb_sleep_all_day = UKSPRINGBARLEY_BASE,
88  fmc_Cultivation,//uk_sb_autumn_harrow, // Stubble cultivator 60% September-October
89  fmc_Cultivation,//uk_sb_autumn_plough, // Autumn plough 50% October-December
90  fmc_Fertilizer,//uk_sb_ferti_s1, // Slurry 40% March if no autumn plough
91  fmc_Fertilizer,//uk_sb_ferti_p1,
92  fmc_Cultivation,//uk_sb_spring_plough, //Spring plough 20% March if Slurry
93  fmc_Fertilizer,//uk_sb_ferti_s2, // N fertiliser 85% March
94  fmc_Fertilizer,//uk_sb_ferti_p2,
95  fmc_Fertilizer,//uk_sb_ferti_s3, // NPK application 50% before preseeding
96  fmc_Fertilizer,//uk_sb_ferti_p3,
97  fmc_Cultivation,//uk_sb_preseeding_cultivator, // Preseeding cultivation 100% April
98  fmc_Others,//uk_sb_spring_sow, // Spring sow 100% April
99  fmc_Cultivation,//uk_sb_harrow, // Harrow 20% pre-em April
100  fmc_Herbicide,//uk_sb_herbicide1, // Herbicide 1 90% April
101  fmc_Fungicide,//uk_sb_fungicide1, // Fungicide 1 80% June
102  fmc_Fungicide,//uk_sb_fungicide2, // Fungicide 2 40% 14-21 days after f1
103  fmc_Insecticide,//uk_sb_insecticide1, // Insecticide 1 30% June
104  fmc_Others,//uk_sb_growth_regulator1, // Growth Regulator 1 40% May-June
105  fmc_Harvest,//uk_sb_harvest, // Harvest 100% July-August
106  fmc_Others,//uk_sb_straw_chopping, // Straw chopping 50% after harvest
107  fmc_Others,//uk_sb_hay_bailing, // Hay bailing 50% after harvest
108  };
109  copy(begin(catlist), end(catlist), back_inserter(m_ManagementCategories));
110  }
111 };
112 
113 #endif // UKSPRINGBARLEY_H
114 
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
fmc_Insecticide
Definition: LandscapeFarmingEnums.h:1005
Farm::PreseedingCultivator
virtual bool PreseedingCultivator(LE *a_field, double a_user, int a_days)
Carry out preseeding cultivation on a_field (tilling set including cultivator and string roller to co...
Definition: FarmFuncs.cpp:312
LE::SetMDates
void SetMDates(int a, int b, int c)
Definition: Elements.h:406
Farm::SpringPlough
virtual bool SpringPlough(LE *a_field, double a_user, int a_days)
Carry out a ploughing event in the spring on a_field.
Definition: FarmFuncs.cpp:421
uk_sb_autumn_plough
Definition: UKSpringBarley.h:37
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
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
Farm::ProductApplication
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
uk_sb_ferti_s1
Definition: UKSpringBarley.h:38
FarmEvent
A struct to hold the information required to trigger a farm event.
Definition: Farm.h:372
LE::GetMConstants
int GetMConstants(int a)
Definition: Elements.h:407
LE::ClearManagementActionSum
void ClearManagementActionSum()
clears the management action counters
Definition: Elements.h:247
Farm::FP_NPK
virtual bool FP_NPK(LE *a_field, double a_user, int a_days)
Apply NPK fertilizer, on a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:645
uk_sb_start
Definition: UKSpringBarley.h:34
Calendar::GetYearNumber
int GetYearNumber(void)
Definition: Calendar.h:72
uk_sb_ferti_s2
Definition: UKSpringBarley.h:41
FarmEvent::m_first_year
bool m_first_year
Definition: Farm.h:386
uk_sb_straw_chopping
Definition: UKSpringBarley.h:54
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
uk_sb_herbicide1
Definition: UKSpringBarley.h:48
g_date
class Calendar * g_date
Definition: Calendar.cpp:37
fmc_Herbicide
Definition: LandscapeFarmingEnums.h:1006
Farm::GetPreviousTov
TTypesOfVegetation GetPreviousTov(int a_index)
Definition: Farm.h:966
cfg_SB_InsecticideDay
CfgInt cfg_SB_InsecticideDay
Provided to allow configuration control of the first insecticide spray in spring barley crops - this ...
Definition: SpringBarleySilage.cpp:42
uk_sb_growth_regulator1
Definition: UKSpringBarley.h:52
Farm::SpringSow
virtual bool SpringSow(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 spring on a_field.
Definition: FarmFuncs.cpp:501
Farm::GetType
TTypesOfFarm GetType(void)
Definition: Farm.h:956
Crop::m_base_elements_no
int m_base_elements_no
Definition: Farm.h:505
uk_sb_fungicide2
Definition: UKSpringBarley.h:50
uk_sb_preseeding_cultivator
Definition: UKSpringBarley.h:45
Crop::m_first_date
int m_first_date
Definition: Farm.h:501
FarmEvent::m_startday
int m_startday
Definition: Farm.h:385
uk_sb_ferti_p3
Definition: UKSpringBarley.h:44
Farm::FA_NPK
virtual bool FA_NPK(LE *a_field, double a_user, int a_days)
Apply NPK fertilizer to a_field owned by an stock farmer.
Definition: FarmFuncs.cpp:982
Farm::FungicideTreat
virtual bool FungicideTreat(LE *a_field, double a_user, int a_days)
Apply fungicide to a_field.
Definition: FarmFuncs.cpp:2101
UKSpringBarley::Do
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.
Definition: UKSpringBarley.cpp:65
cfg_SB_InsecticideMonth
CfgInt cfg_SB_InsecticideMonth
Provided to allow configuration control of the first insecticide spray in spring barley crops - this ...
Definition: SpringBarleySilage.cpp:43
cfg_pest_product_amounts
CfgArray_Double cfg_pest_product_amounts
Amount of pesticide applied in grams of active substance per hectare for each of the 10 pesticides.
Crop
The base class for all crops.
Definition: Farm.h:495
CfgBool::value
bool value() const
Definition: Configurator.h:164
Landscape
The landscape class containing all environmental and topographical data.
Definition: Landscape.h:142
fmc_Fertilizer
Definition: LandscapeFarmingEnums.h:1004
uk_sb_ferti_p2
Definition: UKSpringBarley.h:42
Calendar::Date
long Date(void)
Definition: Calendar.h:57
UK_SB_FUNGII
#define UK_SB_FUNGII
A flag used to indicate autumn ploughing status.
Definition: UKSpringBarley.h:25
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
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
CfgBool
Bool configurator entry class.
Definition: Configurator.h:155
UKSPRINGBARLEY_BASE
#define UKSPRINGBARLEY_BASE
Definition: UKSpringBarley.h:21
uk_sb_hay_bailing
Definition: UKSpringBarley.h:55
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
uk_sb_ferti_p1
Definition: UKSpringBarley.h:39
fmc_Others
Definition: LandscapeFarmingEnums.h:1003
Farm::StrawChopping
virtual bool StrawChopping(LE *a_field, double a_user, int a_days)
Carry out straw chopping on a_field.
Definition: FarmFuncs.cpp:1475
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
CfgArray_Double
Definition: Configurator.h:208
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
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
CfgArray_Double::value
std::vector< double > value() const
Definition: Configurator.h:219
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
LE::GetGreenBiomass
virtual double GetGreenBiomass(void)
Definition: Elements.h:160
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
UKSpringBarley::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: UKSpringBarley.h:80
TTypesOfCrops
TTypesOfCrops
Definition: LandscapeFarmingEnums.h:781
cfg_pest_springbarley_on
CfgBool cfg_pest_springbarley_on
Turn on pesticides for spring barley.
tof_OptimisingFarm
Definition: LandscapeFarmingEnums.h:696
LE
Definition: Elements.h:86
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
UKSpringBarleyToDo
UKSpringBarleyToDo
Definition: UKSpringBarley.h:33
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
TTypesOfVegetation
TTypesOfVegetation
Values that represent the types of vegetation that are represented in ALMaSS.
Definition: LandscapeFarmingEnums.h:192
CfgInt
Integer configurator entry class.
Definition: Configurator.h:102
Farm
The base class for all farm types.
Definition: Farm.h:755
uk_sb_ferti_s3
Definition: UKSpringBarley.h:43
uk_sb_spring_sow
Definition: UKSpringBarley.h:46
CfgFloat
Double configurator entry class.
Definition: Configurator.h:126
UKSpringBarley::UKSpringBarley
UKSpringBarley(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: UKSpringBarley.h:72
tov_UKSpringBarley
Definition: LandscapeFarmingEnums.h:283
fmc_Harvest
Definition: LandscapeFarmingEnums.h:1012
uk_sb_fungicide1
Definition: UKSpringBarley.h:49
Farm::GrowthRegulator
virtual bool GrowthRegulator(LE *a_field, double a_user, int a_days)
Apply growth regulator to a_field.
Definition: FarmFuncs.cpp:2070
uk_sb_foobar
Definition: UKSpringBarley.h:56
LE::GetOwner
Farm * GetOwner(void)
Definition: Elements.h:256
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
l_pest_insecticide_amount
CfgFloat l_pest_insecticide_amount
uk_sb_autumn_harrow
Definition: UKSpringBarley.h:36
LE::SetMConstants
void SetMConstants(int a, int c)
Definition: Elements.h:408
Crop::m_ev
FarmEvent * m_ev
Definition: Farm.h:500
uk_sb_sleep_all_day
Definition: UKSpringBarley.h:35
uk_sb_insecticide1
Definition: UKSpringBarley.h:51
WARN_BUG
Definition: MapErrorMsg.h:34
uk_sb_harvest
Definition: UKSpringBarley.h:53
uk_sb_harrow
Definition: UKSpringBarley.h:47
ppp_1
Definition: LandscapeFarmingEnums.h:1079
fmc_Fungicide
Definition: LandscapeFarmingEnums.h:1007
uk_sb_spring_plough
Definition: UKSpringBarley.h:40
FarmManagementCategory
FarmManagementCategory
Definition: LandscapeFarmingEnums.h:1001
UKSpringBarley
UKSpringBarley class .
Definition: UKSpringBarley.h:68
Crop::SimpleEvent_
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