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
FodderBeet.h
Go to the documentation of this file.
1 //
2 // FodderBeet.h
3 //
4 /*
5 *******************************************************************************************************
6 Copyright (c) 2011, Christopher John Topping, Aarhus University
7 All rights reserved.
8 
9 Redistribution and use in source and binary forms, with or without modification, are permitted provided
10 that the following conditions are met:
11 
12 Redistributions of source code must retain the above copyright notice, this list of conditions and the
13 following disclaimer.
14 Redistributions in binary form must reproduce the above copyright notice, this list of conditions and
15 the following disclaimer in the documentation and/or other materials provided with the distribution.
16 
17 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
18 IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
19 FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS
20 BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
22 BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 ********************************************************************************************************
26 */
27 
28 #ifndef FodderBeet_h
29 #define FodderBeet_h
30 
31 #define FBeet_BASE 1800
32 
33 #define FB_DID_HARROW m_field->m_user[0]
34 #define FB_DID_NPKS_ONE m_field->m_user[1]
35 #define FB_DID_SLURRY m_field->m_user[2]
36 #define FB_SOW_DATE m_field->m_user[3]
37 
38 #define FB_DID_ROW_TWO m_field->m_user[0]
39 #define FB_DID_INSECT_ONE m_field->m_user[1]
40 #define FB_DID_NPKS_TWO m_field->m_user[2]
41 #define FB_DID_WATER_ONE m_field->m_user[3]
42 #define FB_TRULY_DID_WATER_ONE m_field->m_user[4]
43 #define FB_DECIDE_TO_HERB m_field->m_user[5]
44 #define FB_DECIDE_TO_FI m_field->m_user[6]
45 
46 typedef enum {
47  fb_start = 1, // Compulsory, start event must always be 1 (one).
69 } FBToDo;
70 
71 
72 
73 class FodderBeet: public Crop
74 {
75 public:
76  bool Do( Farm *a_farm, LE *a_field, FarmEvent *a_ev );
77  FodderBeet(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape* a_L) : Crop(a_tov, a_toc, a_L)
78  {
79  m_first_date=g_date->DayInYear(11,10); // Was 1,10 - changed just for sake of getting year on year beet
81  }
83  const int elements = 2 + (fb_foobar - FBeet_BASE);
85 
86  FarmManagementCategory catlist[elements] =
87  {
88  fmc_Others, // zero element unused but must be here
89  fmc_Others, // fb_start = 1, // Compulsory, start event must always be 1 (one).
90  fmc_Cultivation, // fb_autumn_plough = FBeet_BASE,
91  fmc_Fertilizer, // fb_fertmanure,
92  fmc_Cultivation, // fb_spring_plough,
93  fmc_Others, // fb_start_threads_one,
94  fmc_Cultivation, // fb_spring_harrow,
95  fmc_Fertilizer, // fb_fertnpks_one,
96  fmc_Fertilizer, // fb_fertslurry,
97  fmc_Others, // fb_spring_sow,
98  fmc_Cultivation, // fb_spring_roll,
99  fmc_Herbicide, // fb_herbicide_one,
100  fmc_Herbicide, // fb_herbicide_two,
101  fmc_Herbicide, // fb_herbicide_three,
102  fmc_Cultivation, // fb_row_cultivation_one,
103  fmc_Cultivation, // fb_row_cultivation_two,
104  fmc_Insecticide, // fb_insecticide_one,
105  fmc_Fertilizer, // fb_fertnpks_two,
106  fmc_Watering, // fb_water_one,
107  fmc_Insecticide, // fb_insecticide_two,
108  fmc_Watering, // fb_water_two,
109  fmc_Harvest // fb_harvest,
110 
111 
112  // no foobar entry
113 
114  };
115  // Iterate over the catlist elements and copy them to vector
116  copy(begin(catlist), end(catlist), back_inserter(m_ManagementCategories));
117 
118  }
119 };
120 
121 #endif // FodderBeet_h
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
Farm::SpringRoll
virtual bool SpringRoll(LE *a_field, double a_user, int a_days)
Carry out a roll event in the spring on a_field.
Definition: FarmFuncs.cpp:487
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
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
Farm::HerbicideTreat
virtual bool HerbicideTreat(LE *a_field, double a_user, int a_days)
Apply herbicide to a_field.
Definition: FarmFuncs.cpp:2025
FB_DID_WATER_ONE
#define FB_DID_WATER_ONE
Definition: FodderBeet.h:41
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
fb_harvest
Definition: FodderBeet.h:67
fb_insecticide_two
Definition: FodderBeet.h:65
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::DoIt
bool DoIt(double a_probability)
Return chance out of 0 to 100.
Definition: Farm.cpp:856
Calendar::GetYearNumber
int GetYearNumber(void)
Definition: Calendar.h:72
FarmEvent::m_first_year
bool m_first_year
Definition: Farm.h:386
fb_insecticide_one
Definition: FodderBeet.h:62
fb_start
Definition: FodderBeet.h:47
fb_autumn_plough
Definition: FodderBeet.h:48
g_date
class Calendar * g_date
Definition: Calendar.cpp:37
fb_fertnpks_two
Definition: FodderBeet.h:63
fmc_Herbicide
Definition: LandscapeFarmingEnums.h:1006
FB_SOW_DATE
#define FB_SOW_DATE
Definition: FodderBeet.h:36
fb_foobar
Definition: FodderBeet.h:68
Farm::FA_Manure
virtual bool FA_Manure(LE *a_field, double a_user, int a_days)
Spread manure on a_field owned by an stock farmer.
Definition: FarmFuncs.cpp:1110
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
CfgFloat::value
double value() const
Definition: Configurator.h:142
Farm::GetType
TTypesOfFarm GetType(void)
Definition: Farm.h:956
fb_spring_plough
Definition: FodderBeet.h:50
Crop::m_base_elements_no
int m_base_elements_no
Definition: Farm.h:505
FB_DID_SLURRY
#define FB_DID_SLURRY
Definition: FodderBeet.h:35
fb_herbicide_two
Definition: FodderBeet.h:58
Crop::m_first_date
int m_first_date
Definition: Farm.h:501
FB_DECIDE_TO_FI
#define FB_DECIDE_TO_FI
Definition: FodderBeet.h:44
FarmEvent::m_startday
int m_startday
Definition: Farm.h:385
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
Crop
The base class for all crops.
Definition: Farm.h:495
cfg_fungi_app_prop1
CfgFloat cfg_fungi_app_prop1
fb_water_one
Definition: FodderBeet.h:64
Crop::SimpleEvent
void SimpleEvent(long a_date, int a_todo, bool a_lock)
Adds an event to this crop management.
Definition: Farm.cpp:747
FodderBeet
Definition: FodderBeet.h:73
cfg_greg_app_prop
CfgFloat cfg_greg_app_prop
fb_row_cultivation_two
Definition: FodderBeet.h:61
cfg_ins_app_prop1
CfgFloat cfg_ins_app_prop1
Farm::Prob_multiplier
virtual double Prob_multiplier()
Definition: Farm.h:778
Landscape
The landscape class containing all environmental and topographical data.
Definition: Landscape.h:142
fmc_Fertilizer
Definition: LandscapeFarmingEnums.h:1004
FB_DID_NPKS_TWO
#define FB_DID_NPKS_TWO
Definition: FodderBeet.h:40
Calendar::Date
long Date(void)
Definition: Calendar.h:57
FB_DID_NPKS_ONE
#define FB_DID_NPKS_ONE
Definition: FodderBeet.h:34
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
fb_herbicide_three
Definition: FodderBeet.h:59
fmc_Others
Definition: LandscapeFarmingEnums.h:1003
LE::SetVegPatchy
void SetVegPatchy(bool p)
Definition: Elements.h:229
fb_spring_roll
Definition: FodderBeet.h:56
fmc_Watering
Definition: LandscapeFarmingEnums.h:1011
FB_DID_INSECT_ONE
#define FB_DID_INSECT_ONE
Definition: FodderBeet.h:39
Calendar::OldDays
long OldDays(void)
Definition: Calendar.h:60
FodderBeet::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: FodderBeet.h:82
fb_fertnpks_one
Definition: FodderBeet.h:53
fb_water_two
Definition: FodderBeet.h:66
MapErrorMsg::Warn
void Warn(MapErrorState a_level, std::string a_msg1, std::string a_msg2)
Definition: MapErrorMsg.cpp:69
FodderBeet::Do
bool Do(Farm *a_farm, LE *a_field, FarmEvent *a_ev)
Definition: FodderBeet.cpp:37
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
TTypesOfCrops
TTypesOfCrops
Definition: LandscapeFarmingEnums.h:781
Farm::RowCultivation
virtual bool RowCultivation(LE *a_field, double a_user, int a_days)
Carry out a harrowing between crop rows on a_field.
Definition: FarmFuncs.cpp:1183
tof_OptimisingFarm
Definition: LandscapeFarmingEnums.h:696
FBToDo
FBToDo
Definition: FodderBeet.h:46
fb_fertmanure
Definition: FodderBeet.h:49
FBeet_BASE
#define FBeet_BASE
Definition: FodderBeet.h:31
LE
Definition: Elements.h:86
Farm::Water
virtual bool Water(LE *a_field, double a_user, int a_days)
Carry out a watering on a_field.
Definition: FarmFuncs.cpp:1330
Crop::m_last_date
int m_last_date
Definition: Farm.h:503
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
FB_TRULY_DID_WATER_ONE
#define FB_TRULY_DID_WATER_ONE
Definition: FodderBeet.h:42
TTypesOfVegetation
TTypesOfVegetation
Values that represent the types of vegetation that are represented in ALMaSS.
Definition: LandscapeFarmingEnums.h:192
fb_spring_sow
Definition: FodderBeet.h:55
fb_start_threads_one
Definition: FodderBeet.h:51
Farm
The base class for all farm types.
Definition: Farm.h:755
FB_DID_HARROW
#define FB_DID_HARROW
Definition: FodderBeet.h:33
CfgFloat
Double configurator entry class.
Definition: Configurator.h:126
fmc_Harvest
Definition: LandscapeFarmingEnums.h:1012
FB_DECIDE_TO_HERB
#define FB_DECIDE_TO_HERB
Definition: FodderBeet.h:43
FodderBeet::FodderBeet
FodderBeet(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: FodderBeet.h:77
fb_spring_harrow
Definition: FodderBeet.h:52
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
fb_herbicide_one
Definition: FodderBeet.h:57
fb_row_cultivation_one
Definition: FodderBeet.h:60
fb_fertslurry
Definition: FodderBeet.h:54
FB_DID_ROW_TWO
#define FB_DID_ROW_TWO
Definition: FodderBeet.h:38
LE::SetMConstants
void SetMConstants(int a, int c)
Definition: Elements.h:408
Crop::ChooseNextCrop
void ChooseNextCrop(int a_no_dates)
Chooses the next crop to grow in a field.
Definition: Farm.cpp:756
Crop::m_ev
FarmEvent * m_ev
Definition: Farm.h:500
WARN_BUG
Definition: MapErrorMsg.h:34
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
cfg_herbi_app_prop
CfgFloat cfg_herbi_app_prop