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_Potato.h
Go to the documentation of this file.
1 //
2 // DK_Potato.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_Potato_h
29 #define DK_Potato_h
30 
31 #define DK_PO_BASE 65300
32 
33 #define DK_PO_FORCESPRING a_field->m_user[1]
34 
35 typedef enum {
36  dk_po_start = 1, // Compulsory, start event must always be 1 (one).
78 
79 
80 
81 class DK_Potato : public Crop
82 {
83 public:
84  bool Do(Farm* a_farm, LE* a_field, FarmEvent* a_ev);
85  DK_Potato(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape* a_L) : Crop(a_tov, a_toc, a_L)
86  {
87  m_first_date = g_date->DayInYear(1, 12); //
89  }
91  const int elements = 2 + (dk_po_foobar - DK_PO_BASE);
93 
94  FarmManagementCategory catlist[elements] =
95  {
96  fmc_Others, // zero element unused but must be here
97  fmc_Others, // dk_po_start = 1, // Compulsory, start event must always be 1 (one).
98  fmc_Harvest, // dk_po_harvest = DK_PO_BASE,
99  fmc_Others, // dk_po_remove_straw,
100  fmc_Cultivation, //dk_po_stoneburier,
101  fmc_Cultivation, //dk_po_autumn_plough,
102  fmc_Cultivation, // dk_po_deep_harrow,
103  fmc_Fertilizer, // dk_po_ferti_s1,
104  fmc_Fertilizer, // dk_po_ferti_p1,
105  fmc_Fertilizer, // dk_po_ferti_s2,
106  fmc_Fertilizer, // dk_po_ferti_p2,
107  fmc_Others, // dk_po_sow,
108  fmc_Watering, // dk_po_water,
109  fmc_Cultivation, // dk_po_strigling,
110  fmc_Cultivation, // dk_po_harrow1,
111  fmc_Cultivation, // dk_po_hill_up1,
112  fmc_Cultivation, // dk_po_hill_up2,
113  fmc_Cultivation, // dk_po_hill_up3,
114  fmc_Herbicide, // dk_po_herbicide,
115  fmc_Herbicide, // dk_po_herbicide_mw,
116  fmc_Herbicide, // dk_po_herbicide1,
117  fmc_Herbicide, // dk_po_herbicide2,
118  fmc_Herbicide, // dk_po_herbicide3,
119  fmc_Herbicide, // dk_po_herbicide4,
120  fmc_Herbicide, // dk_po_herbicide5,
121  fmc_Herbicide, // dk_po_herbicide6,
122  fmc_Fertilizer, // dk_po_ferti_s3,
123  fmc_Fertilizer, // dk_po_ferti_p3,
124  fmc_Fungicide, // dk_po_fungicide1,
125  fmc_Fungicide, // dk_po_fungicide2,
126  fmc_Fungicide, // dk_po_fungicide3,
127  fmc_Fungicide, // dk_po_fungicide4,
128  fmc_Fungicide, // dk_po_fungicide5,
129  fmc_Fungicide, // dk_po_fungicide6,
130  fmc_Fungicide, // dk_po_fungicide7,
131  fmc_Fungicide, // dk_po_fungicide8,
132  fmc_Insecticide, // dk_po_insecticide1,
133  fmc_Cultivation, // dk_po_harrow2,
134  fmc_Cultivation, // dk_po_harrow3,
135  fmc_Herbicide, // dk_po_herbicide7,
136  fmc_Herbicide, // dk_po_herbicide8,
137 
138 
139  // no foobar entry
140 
141  };
142  // Iterate over the catlist elements and copy them to vector
143  copy(begin(catlist), end(catlist), back_inserter(m_ManagementCategories));
144 
145  }
146 };
147 
148 #endif // DK_Potato_h
149 
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
dk_po_start
Definition: DK_Potato.h:36
FarmEvent::m_forcespring
bool m_forcespring
Definition: Farm.h:392
fmc_Insecticide
Definition: LandscapeFarmingEnums.h:1005
dk_po_strigling
Definition: DK_Potato.h:48
dk_po_ferti_p3
Definition: DK_Potato.h:62
Farm::HerbicideTreat
virtual bool HerbicideTreat(LE *a_field, double a_user, int a_days)
Apply herbicide to a_field.
Definition: FarmFuncs.cpp:2025
dk_po_fungicide1
Definition: DK_Potato.h:63
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_po_harrow3
Definition: DK_Potato.h:73
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
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
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
dk_po_water
Definition: DK_Potato.h:47
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
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_po_autumn_plough
Definition: DK_Potato.h:40
DK_PO_BASE
#define DK_PO_BASE
Definition: DK_Potato.h:31
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
dk_po_herbicide1
Definition: DK_Potato.h:55
dk_po_herbicide
Definition: DK_Potato.h:53
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
dk_po_hill_up2
Definition: DK_Potato.h:51
Crop::m_base_elements_no
int m_base_elements_no
Definition: Farm.h:505
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
dk_po_harrow2
Definition: DK_Potato.h:72
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_po_herbicide3
Definition: DK_Potato.h:57
dk_po_fungicide2
Definition: DK_Potato.h:64
dk_po_stoneburier
Definition: DK_Potato.h:39
cfg_herbi_app_prop
CfgFloat cfg_herbi_app_prop
Crop
The base class for all crops.
Definition: Farm.h:495
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_po_herbicide5
Definition: DK_Potato.h:59
dk_po_herbicide_mw
Definition: DK_Potato.h:54
DK_Potato::Do
bool Do(Farm *a_farm, LE *a_field, FarmEvent *a_ev)
Definition: DK_Potato.cpp:39
CfgBool::value
bool value() const
Definition: Configurator.h:164
tov_DKPotato
Definition: LandscapeFarmingEnums.h:404
cfg_greg_app_prop
CfgFloat cfg_greg_app_prop
dk_po_sow
Definition: DK_Potato.h:46
Landscape
The landscape class containing all environmental and topographical data.
Definition: Landscape.h:142
fmc_Fertilizer
Definition: LandscapeFarmingEnums.h:1004
Calendar::Date
long Date(void)
Definition: Calendar.h:57
DK_Potato::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: DK_Potato.h:90
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
CfgBool
Bool configurator entry class.
Definition: Configurator.h:155
dk_po_ferti_s2
Definition: DK_Potato.h:44
dk_po_hill_up3
Definition: DK_Potato.h:52
fmc_Others
Definition: LandscapeFarmingEnums.h:1003
LE::SetVegPatchy
void SetVegPatchy(bool p)
Definition: Elements.h:229
fmc_Watering
Definition: LandscapeFarmingEnums.h:1011
dk_po_herbicide8
Definition: DK_Potato.h:75
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_po_fungicide6
Definition: DK_Potato.h:68
MapErrorMsg::Warn
void Warn(MapErrorState a_level, std::string a_msg1, std::string a_msg2)
Definition: MapErrorMsg.cpp:69
dk_po_herbicide6
Definition: DK_Potato.h:60
CfgArray_Double
Definition: Configurator.h:208
dk_po_harrow1
Definition: DK_Potato.h:49
dk_po_remove_straw
Definition: DK_Potato.h:38
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_Potato
Definition: DK_Potato.h:81
dk_po_deep_harrow
Definition: DK_Potato.h:41
dk_po_fungicide4
Definition: DK_Potato.h:66
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
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
dk_po_ferti_p1
Definition: DK_Potato.h:43
dk_po_fungicide3
Definition: DK_Potato.h:65
dk_po_fungicide8
Definition: DK_Potato.h:70
dk_po_herbicide7
Definition: DK_Potato.h:74
LE
Definition: Elements.h:86
DK_PO_FORCESPRING
#define DK_PO_FORCESPRING
Definition: DK_Potato.h:33
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
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.
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
dk_po_fungicide7
Definition: DK_Potato.h:69
DK_PotatoToDo
DK_PotatoToDo
Definition: DK_Potato.h:35
Farm
The base class for all farm types.
Definition: Farm.h:755
dk_po_herbicide2
Definition: DK_Potato.h:56
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
cfg_fungi_app_prop1
CfgFloat cfg_fungi_app_prop1
dk_po_hill_up1
Definition: DK_Potato.h:50
fmc_Harvest
Definition: LandscapeFarmingEnums.h:1012
dk_po_foobar
Definition: DK_Potato.h:76
cfg_ins_app_prop1
CfgFloat cfg_ins_app_prop1
dk_po_ferti_s3
Definition: DK_Potato.h:61
cfg_pest_potatoes_on
CfgBool cfg_pest_potatoes_on
Turn on pesticides for potatoes.
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
DK_Potato::DK_Potato
DK_Potato(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: DK_Potato.h:85
Crop::AphidDamage
bool AphidDamage(LE *a_field)
Compares aphid numbers per m2 with a threshold to return true if threshold is exceeded.
Definition: Farm.cpp:726
dk_po_ferti_p2
Definition: DK_Potato.h:45
Crop::m_ev
FarmEvent * m_ev
Definition: Farm.h:500
dk_po_ferti_s1
Definition: DK_Potato.h:42
dk_po_harvest
Definition: DK_Potato.h:37
dk_po_herbicide4
Definition: DK_Potato.h:58
dk_po_fungicide5
Definition: DK_Potato.h:67
WARN_BUG
Definition: MapErrorMsg.h:34
ppp_1
Definition: LandscapeFarmingEnums.h:1079
fmc_Fungicide
Definition: LandscapeFarmingEnums.h:1007
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
dk_po_insecticide1
Definition: DK_Potato.h:71