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
DK_PotatoSeed.h
Go to the documentation of this file.
1 //
2 // DK_PotatoSeed.h
3 //
4 /*
5 *******************************************************************************************************
6 Copyright (c) 2021, Christopher John Topping, Aarhus University - modified by Luna Kondrup Marcussen, 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 DK_PotatoSeed_h
29 #define DK_PotatoSeed_h
30 
31 #define DK_PS_BASE 65500
32 
33 #define DK_PS_FORCESPRING a_field->m_user[1]
34 
35 typedef enum {
36  dk_ps_start = 1, // Compulsory, start event must always be 1 (one).
85 
86 
87 
88 class DK_PotatoSeed : public Crop
89 {
90 public:
91  bool Do(Farm* a_farm, LE* a_field, FarmEvent* a_ev);
92  DK_PotatoSeed(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape* a_L) : Crop(a_tov, a_toc, a_L)
93  {
94  m_first_date = g_date->DayInYear(1, 12); //
96  }
98  const int elements = 2 + (dk_ps_foobar - DK_PS_BASE);
100 
101  FarmManagementCategory catlist[elements] =
102  {
103  fmc_Others, // zero element unused but must be here
104  fmc_Others, // dk_ps_start = 1, // Compulsory, start event must always be 1 (one).
105  fmc_Harvest, // dk_ps_harvest = DK_PS_BASE,
106  fmc_Others, // dk_ps_remove_straw,
107  fmc_Cultivation, //dk_ps_stoneburier,
108  fmc_Cultivation, //dk_ps_autumn_plough,
109  fmc_Cultivation, // dk_ps_deep_harrow,
110  fmc_Fertilizer, // dk_ps_ferti_s1,
111  fmc_Fertilizer, // dk_ps_ferti_p1,
112  fmc_Fertilizer, // dk_ps_ferti_s2,
113  fmc_Fertilizer, // dk_ps_ferti_p2,
114  fmc_Others, // dk_ps_sow,
115  fmc_Watering, // dk_ps_water,
116  fmc_Cultivation, // dk_ps_strigling,
117  fmc_Cultivation, // dk_ps_harrow1,
118  fmc_Cultivation, // dk_ps_hill_up1,
119  fmc_Cultivation, // dk_ps_hill_up2,
120  fmc_Cultivation, // dk_ps_hill_up3,
121  fmc_Herbicide, // dk_ps_herbicide,
122  fmc_Herbicide, // dk_ps_herbicide_mw,
123  fmc_Herbicide, // dk_ps_herbicide1,
124  fmc_Herbicide, // dk_ps_herbicide2,
125  fmc_Herbicide, // dk_ps_herbicide3,
126  fmc_Herbicide, // dk_ps_herbicide4,
127  fmc_Herbicide, // dk_ps_herbicide5,
128  fmc_Herbicide, // dk_ps_herbicide6,
129  fmc_Fertilizer, // dk_ps_ferti_s3,
130  fmc_Fertilizer, // dk_ps_ferti_p3,
131  fmc_Fungicide, // dk_ps_fungicide1,
132  fmc_Fungicide, // dk_ps_fungicide2,
133  fmc_Fungicide, // dk_ps_fungicide3,
134  fmc_Fungicide, // dk_ps_fungicide4,
135  fmc_Fungicide, // dk_ps_fungicide5,
136  fmc_Fungicide, // dk_ps_fungicide6,
137  fmc_Fungicide, // dk_ps_fungicide7,
138  fmc_Fungicide, // dk_ps_fungicide8,
139  fmc_Fungicide, // dk_ps_fungicide9,
140  fmc_Fungicide, // dk_ps_fungicide10,
141  fmc_Insecticide, // dk_ps_insecticide1,
142  fmc_Insecticide, // dk_ps_insecticide2,
143  fmc_Insecticide, // dk_ps_insecticide3,
144  fmc_Cultivation, // dk_ps_harrow2,
145  fmc_Cultivation, // dk_ps_harrow3,
146  fmc_Herbicide, // dk_ps_herbicide7,
147  fmc_Herbicide, // dk_ps_herbicide8,
148 
149 
150  // no foobar entry
151 
152  };
153  // Iterate over the catlist elements and copy them to vector
154  copy(begin(catlist), end(catlist), back_inserter(m_ManagementCategories));
155 
156  }
157 };
158 
159 #endif // DK_PotatoSeed_h
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
DK_PotatoSeed
Definition: DK_PotatoSeed.h:88
FarmEvent::m_forcespring
bool m_forcespring
Definition: Farm.h:392
dk_ps_harrow2
Definition: DK_PotatoSeed.h:79
fmc_Insecticide
Definition: LandscapeFarmingEnums.h:1005
dk_ps_fungicide5
Definition: DK_PotatoSeed.h:67
dk_ps_harrow1
Definition: DK_PotatoSeed.h:49
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::Strigling
virtual bool Strigling(LE *a_field, double a_user, int a_days)
Carry out a mechanical weeding on a_field.
Definition: FarmFuncs.cpp:1206
dk_ps_insecticide1b
Definition: DK_PotatoSeed.h:74
cfg_greg_app_prop
CfgFloat cfg_greg_app_prop
dk_ps_insecticide3b
Definition: DK_PotatoSeed.h:78
FarmEvent::m_lock
bool m_lock
Definition: Farm.h:384
Farm::FP_ManganeseSulphate
virtual bool FP_ManganeseSulphate(LE *a_field, double a_user, int a_days)
Apply Manganse Sulphate to a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:840
cfg_herbi_app_prop
CfgFloat cfg_herbi_app_prop
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
dk_ps_insecticide3
Definition: DK_PotatoSeed.h:77
Farm::StubbleCultivatorHeavy
virtual bool StubbleCultivatorHeavy(LE *a_field, double a_user, int a_days)
Carry out a stubble cultivation event on a_field. This is non-inversion type of cultivation which can...
Definition: FarmFuncs.cpp:245
FarmEvent
A struct to hold the information required to trigger a farm event.
Definition: Farm.h:372
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
dk_ps_herbicide3
Definition: DK_PotatoSeed.h:57
dk_ps_sow
Definition: DK_PotatoSeed.h:46
Farm::StrawRemoval
virtual bool StrawRemoval(LE *a_field, double a_user, int a_days)
Straw covering applied on a_field.
Definition: FarmFuncs.cpp:1752
dk_ps_ferti_p1
Definition: DK_PotatoSeed.h:43
dk_ps_harrow3
Definition: DK_PotatoSeed.h:80
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
fmc_Herbicide
Definition: LandscapeFarmingEnums.h:1006
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
Crop::m_base_elements_no
int m_base_elements_no
Definition: Farm.h:505
dk_ps_herbicide2
Definition: DK_PotatoSeed.h:56
dk_ps_ferti_p2
Definition: DK_PotatoSeed.h:45
DK_PS_BASE
#define DK_PS_BASE
Definition: DK_PotatoSeed.h:31
Crop::m_first_date
int m_first_date
Definition: Farm.h:501
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
Farm::HillingUp
virtual bool HillingUp(LE *a_field, double a_user, int a_days)
Do hilling up on a_field, probably of potatoes.
Definition: FarmFuncs.cpp:1302
dk_ps_remove_straw
Definition: DK_PotatoSeed.h:38
Crop
The base class for all crops.
Definition: Farm.h:495
dk_ps_ferti_s2
Definition: DK_PotatoSeed.h:44
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::SimpleEvent
void SimpleEvent(long a_date, int a_todo, bool a_lock)
Adds an event to this crop management.
Definition: Farm.cpp:747
dk_ps_herbicide1
Definition: DK_PotatoSeed.h:55
dk_ps_fungicide2
Definition: DK_PotatoSeed.h:64
dk_ps_water
Definition: DK_PotatoSeed.h:47
CfgBool::value
bool value() const
Definition: Configurator.h:164
dk_ps_insecticide2b
Definition: DK_PotatoSeed.h:76
tov_DKPotatoSeed
Definition: LandscapeFarmingEnums.h:406
dk_ps_ferti_s1
Definition: DK_PotatoSeed.h:42
dk_ps_fungicide6
Definition: DK_PotatoSeed.h:68
Landscape
The landscape class containing all environmental and topographical data.
Definition: Landscape.h:142
fmc_Fertilizer
Definition: LandscapeFarmingEnums.h:1004
dk_ps_ferti_p3
Definition: DK_PotatoSeed.h:62
dk_ps_ferti_s3
Definition: DK_PotatoSeed.h:61
dk_ps_hill_up3
Definition: DK_PotatoSeed.h:52
dk_ps_hill_up1
Definition: DK_PotatoSeed.h:50
dk_ps_fungicide8
Definition: DK_PotatoSeed.h:70
cfg_ins_app_prop1
CfgFloat cfg_ins_app_prop1
Calendar::Date
long Date(void)
Definition: Calendar.h:57
dk_ps_harvest
Definition: DK_PotatoSeed.h:37
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
CfgBool
Bool configurator entry class.
Definition: Configurator.h:155
fmc_Others
Definition: LandscapeFarmingEnums.h:1003
LE::SetVegPatchy
void SetVegPatchy(bool p)
Definition: Elements.h:229
dk_ps_herbicide6
Definition: DK_PotatoSeed.h:60
fmc_Watering
Definition: LandscapeFarmingEnums.h:1011
DK_PotatoSeed::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: DK_PotatoSeed.h:97
Farm::FA_ManganeseSulphate
virtual bool FA_ManganeseSulphate(LE *a_field, double a_user, int a_days)
Apply manganese sulphate to a_field owned by an stock farmer.
Definition: FarmFuncs.cpp:1095
Calendar::OldDays
long OldDays(void)
Definition: Calendar.h:60
dk_ps_foobar
Definition: DK_PotatoSeed.h:83
MapErrorMsg::Warn
void Warn(MapErrorState a_level, std::string a_msg1, std::string a_msg2)
Definition: MapErrorMsg.cpp:69
DK_PotatoSeedToDo
DK_PotatoSeedToDo
Definition: DK_PotatoSeed.h:35
cfg_pest_potatoes_on
CfgBool cfg_pest_potatoes_on
Turn on pesticides for potatoes.
CfgArray_Double
Definition: Configurator.h:208
dk_ps_start
Definition: DK_PotatoSeed.h:36
dk_ps_insecticide2
Definition: DK_PotatoSeed.h:75
Crop::StartUpCrop
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 a...
Definition: Farm.cpp:652
dk_ps_autumn_plough
Definition: DK_PotatoSeed.h:40
dk_ps_fungicide7
Definition: DK_PotatoSeed.h:69
DK_PotatoSeed::DK_PotatoSeed
DK_PotatoSeed(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: DK_PotatoSeed.h:92
dk_ps_herbicide5
Definition: DK_PotatoSeed.h:59
dk_ps_strigling
Definition: DK_PotatoSeed.h:48
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
dk_ps_fungicide3
Definition: DK_PotatoSeed.h:65
dk_ps_insecticide1
Definition: DK_PotatoSeed.h:73
dk_ps_herbicide_mw
Definition: DK_PotatoSeed.h:54
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
dk_ps_fungicide10
Definition: DK_PotatoSeed.h:72
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::HarvestLong
virtual bool HarvestLong(LE *a_field, double a_user, int a_days)
Carry out a harvest on a_field (only differs in the DoIt chance cf harvest)
Definition: FarmFuncs.cpp:1421
Farm::BiocideTreat
virtual bool BiocideTreat(LE *a_field, double a_user, int a_days)
Apply Biocide to a_field.
Definition: FarmFuncs.cpp:2175
TTypesOfCrops
TTypesOfCrops
Definition: LandscapeFarmingEnums.h:781
cfg_fungi_app_prop1
CfgFloat cfg_fungi_app_prop1
dk_ps_hill_up2
Definition: DK_PotatoSeed.h:51
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
g_msg
MapErrorMsg * g_msg
Definition: MapErrorMsg.cpp:41
dk_ps_herbicide7
Definition: DK_PotatoSeed.h:81
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
TTypesOfVegetation
TTypesOfVegetation
Values that represent the types of vegetation that are represented in ALMaSS.
Definition: LandscapeFarmingEnums.h:192
Farm
The base class for all farm types.
Definition: Farm.h:755
dk_ps_herbicide
Definition: DK_PotatoSeed.h:53
dk_ps_fungicide1
Definition: DK_PotatoSeed.h:63
Crop::m_date_modifier
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
CfgFloat
Double configurator entry class.
Definition: Configurator.h:126
fmc_Harvest
Definition: LandscapeFarmingEnums.h:1012
dk_ps_herbicide4
Definition: DK_PotatoSeed.h:58
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
dk_ps_deep_harrow
Definition: DK_PotatoSeed.h:41
dk_ps_fungicide9
Definition: DK_PotatoSeed.h:71
dk_ps_fungicide4
Definition: DK_PotatoSeed.h:66
DK_PS_FORCESPRING
#define DK_PS_FORCESPRING
Definition: DK_PotatoSeed.h:33
dk_ps_herbicide8
Definition: DK_PotatoSeed.h:82
Crop::m_ev
FarmEvent * m_ev
Definition: Farm.h:500
DK_PotatoSeed::Do
bool Do(Farm *a_farm, LE *a_field, FarmEvent *a_ev)
Definition: DK_PotatoSeed.cpp:39
WARN_BUG
Definition: MapErrorMsg.h:34
ppp_1
Definition: LandscapeFarmingEnums.h:1079
fmc_Fungicide
Definition: LandscapeFarmingEnums.h:1007
dk_ps_stoneburier
Definition: DK_PotatoSeed.h:39
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