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_OPotato.h
Go to the documentation of this file.
1 //
2 // DK_OPotato.h
3 //
4 /*
5 
6 Copyright (c) 2022, Christopher John Topping, Aarhus University
7 All rights reserved.
8 
9 
10 Redistribution and use in source and binary forms, with or without
11 modification, are permitted provided that the following conditions are met:
12 
13 *) Redistributions of source code must retain the above copyright notice, this
14 list of conditions and the following disclaimer.
15 *) Redistributions in binary form must reproduce the above copyright notice,
16 this list of conditions and the following disclaimer in the documentation
17 and/or other materials provided with the distribution.
18 *) Neither the name of the NERI nor the names of its contributors
19 may be used to endorse or promote products derived from this software without
20 specific prior written permission.
21 
22 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
26 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 POSSIBILITY OF SUCH DAMAGE.
33 
34 */
35 
36 #ifndef DK_OPotato_H
37 #define DK_OPotato_H
38 
39 #define DK_OPO_BASE 69400
40 #define DK_OPO_FORCESPRING a_field->m_user[1]
41 #define DK_OPO_SANDY a_field->m_user[2]
42 
43 typedef enum {
44  dk_opo_start = 1, // Compulsory, start event must always be 1 (one).
76 
77 
78 
79 class DK_OPotato : public Crop
80 {
81 public:
82  bool Do(Farm* a_farm, LE* a_field, FarmEvent* a_ev);
83  DK_OPotato(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape* a_L) : Crop(a_tov, a_toc, a_L)
84  {
85  m_first_date = g_date->DayInYear(1, 12);
87  }
89  const int elements = 2 + (dk_opo_foobar - DK_OPO_BASE);
91 
92  FarmManagementCategory catlist[elements] =
93  {
94  fmc_Others, // zero element unused but must be here
95  fmc_Others, // dk_opo_autumn_remove_straw = DK_OPO_BASE,
96  fmc_Others, // dk_opo_spring_remove_straw,
97  fmc_Cultivation, // dk_opo_autumn_stoneburier,
98  fmc_Cultivation, // dk_opo_autumn_plough,
99  fmc_Cultivation, // dk_opo_spring_stoneburier,
100  fmc_Cultivation, // dk_opo_spring_plough,
101  fmc_Cultivation, // dk_opo_deep_harrow1,
102  fmc_Fertilizer, // dk_opo_ferti_s,
103  fmc_Fertilizer, // dk_opo_ferti_p,
104  fmc_Fertilizer, // dk_opo_ferti_sow,
105  fmc_Fertilizer, // dk_opo_calcium_sand_s,
106  fmc_Fertilizer, // dk_opo_calcium_sand_p,
107  fmc_Watering, // dk_opo_water1,
108  fmc_Watering, // dk_opo_water2,
109  fmc_Watering, // dk_opo_water3,
110  fmc_Watering, // dk_opo_water1,
111  fmc_Watering, // dk_opo_water2,
112  fmc_Watering, // dk_opo_water3,
113  fmc_Cultivation, // dk_opo_row_cultivation1,
114  fmc_Cultivation, // dk_opo_hilling_up1,
115  fmc_Cultivation, // dk_opo_row_cultivation2,
116  fmc_Cultivation, // dk_opo_hilling_up2,
117  fmc_Cultivation, // dk_opo_harrow,
118  fmc_Cultivation, // dk_opo_hilling_up3,
119  fmc_Cultivation, // dk_opo_row_cultivation3,
120  fmc_Cultivation, // dk_opo_hilling_up4,
121  fmc_Others, // dk_opo_top_off,
122  fmc_Harvest, // dk_opo_harvest,
123  fmc_Cultivation, // dk_opo_deep_harrow2,
124  };
125  // Iterate over the catlist elements and copy them to vector
126  copy(begin(catlist), end(catlist), back_inserter(m_ManagementCategories));
127  }
128 };
129 
130 
131 
132 #endif // DK_OPotato_H
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
FarmEvent::m_forcespring
bool m_forcespring
Definition: Farm.h:392
DK_OPotato::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: DK_OPotato.h:88
dk_opo_spring_plough
Definition: DK_OPotato.h:50
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::IsStockFarmer
bool IsStockFarmer(void)
Definition: Farm.h:961
DK_OPO_BASE
#define DK_OPO_BASE
Definition: DK_OPotato.h:39
FarmEvent::m_lock
bool m_lock
Definition: Farm.h:384
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_opo_harrow
Definition: DK_OPotato.h:67
dk_opo_water1_c
Definition: DK_OPotato.h:60
dk_opo_deep_harrow2
Definition: DK_OPotato.h:73
dk_opo_water2_s
Definition: DK_OPotato.h:58
Farm::StrawRemoval
virtual bool StrawRemoval(LE *a_field, double a_user, int a_days)
Straw covering applied on a_field.
Definition: FarmFuncs.cpp:1752
tos_SandyClayLoam
Definition: LandscapeFarmingEnums.h:722
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_opo_ferti_p
Definition: DK_OPotato.h:53
tos_SandyLoam
Definition: LandscapeFarmingEnums.h:721
dk_opo_row_cultivation2
Definition: DK_OPotato.h:65
Crop::m_base_elements_no
int m_base_elements_no
Definition: Farm.h:505
dk_opo_spring_remove_straw
Definition: DK_OPotato.h:46
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::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_opo_top_off
Definition: DK_OPotato.h:71
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_opo_start
Definition: DK_OPotato.h:44
dk_opo_water1_s
Definition: DK_OPotato.h:57
dk_opo_deep_harrow1
Definition: DK_OPotato.h:51
DK_OPO_SANDY
#define DK_OPO_SANDY
Definition: DK_OPotato.h:41
Landscape
The landscape class containing all environmental and topographical data.
Definition: Landscape.h:142
DK_OPotatoToDo
DK_OPotatoToDo
Definition: DK_OPotato.h:43
fmc_Fertilizer
Definition: LandscapeFarmingEnums.h:1004
dk_opo_spring_stoneburier
Definition: DK_OPotato.h:49
dk_opo_calcium_sand_s
Definition: DK_OPotato.h:55
dk_opo_ferti_s
Definition: DK_OPotato.h:52
dk_opo_water2_c
Definition: DK_OPotato.h:61
dk_opo_water3_c
Definition: DK_OPotato.h:62
dk_opo_row_cultivation3
Definition: DK_OPotato.h:69
dk_opo_foobar
Definition: DK_OPotato.h:74
Calendar::Date
long Date(void)
Definition: Calendar.h:57
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
LE::GetSoilType
int GetSoilType()
Definition: Elements.h:302
DK_OPO_FORCESPRING
#define DK_OPO_FORCESPRING
Definition: DK_OPotato.h:40
fmc_Others
Definition: LandscapeFarmingEnums.h:1003
Farm::FA_Calcium
virtual bool FA_Calcium(LE *a_field, double a_user, int a_days)
Calcium applied on a_field owned by a stock farmer.
Definition: FarmFuncs.cpp:1168
dk_opo_hilling_up1
Definition: DK_OPotato.h:64
fmc_Watering
Definition: LandscapeFarmingEnums.h:1011
DK_OPotato
Definition: DK_OPotato.h:79
Calendar::OldDays
long OldDays(void)
Definition: Calendar.h:60
dk_opo_row_cultivation1
Definition: DK_OPotato.h:63
MapErrorMsg::Warn
void Warn(MapErrorState a_level, std::string a_msg1, std::string a_msg2)
Definition: MapErrorMsg.cpp:69
Farm::FP_Calcium
virtual bool FP_Calcium(LE *a_field, double a_user, int a_days)
Calcium applied on a_field owned by an arable farmer.
Definition: FarmFuncs.cpp:954
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_OPotato::DK_OPotato
DK_OPotato(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: DK_OPotato.h:83
dk_opo_hilling_up4
Definition: DK_OPotato.h:70
DK_OPotato::Do
bool Do(Farm *a_farm, LE *a_field, FarmEvent *a_ev)
Definition: DK_OPotato.cpp:32
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
tos_Sand
Definition: LandscapeFarmingEnums.h:719
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
TTypesOfCrops
TTypesOfCrops
Definition: LandscapeFarmingEnums.h:781
dk_opo_hilling_up2
Definition: DK_OPotato.h:66
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
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
Farm::SpringSowWithFerti
virtual bool SpringSowWithFerti(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 with start fertilizer in the spring on a_field.
Definition: FarmFuncs.cpp:537
TTypesOfVegetation
TTypesOfVegetation
Values that represent the types of vegetation that are represented in ALMaSS.
Definition: LandscapeFarmingEnums.h:192
dk_opo_autumn_remove_straw
Definition: DK_OPotato.h:45
Farm
The base class for all farm types.
Definition: Farm.h:755
fmc_Harvest
Definition: LandscapeFarmingEnums.h:1012
dk_opo_water3_s
Definition: DK_OPotato.h:59
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
dk_opo_hilling_up3
Definition: DK_OPotato.h:68
dk_opo_autumn_stoneburier
Definition: DK_OPotato.h:47
dk_opo_autumn_plough
Definition: DK_OPotato.h:48
Crop::m_ev
FarmEvent * m_ev
Definition: Farm.h:500
tov_DKOPotato
Definition: LandscapeFarmingEnums.h:389
tos_LoamySand
Definition: LandscapeFarmingEnums.h:720
dk_opo_calcium_sand_p
Definition: DK_OPotato.h:56
dk_opo_harvest
Definition: DK_OPotato.h:72
Farm::BurnTop
virtual bool BurnTop(LE *a_field, double a_user, int a_days)
Burn tops of e.g. potatoes on a_field.
Definition: FarmFuncs.cpp:1587
dk_opo_ferti_sow
Definition: DK_OPotato.h:54
WARN_BUG
Definition: MapErrorMsg.h:34
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
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