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
DK_OPotatoIndustry.h
Go to the documentation of this file.
1 //
2 // DK_OPotatoIndustry.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_OPotatoIndustry_H
37 #define DK_OPotatoIndustry_H
38 
39 #define DK_OPOI_BASE 69500
40 #define DK_OPOI_FORCESPRING a_field->m_user[1]
41 #define DK_OPOI_SANDY a_field->m_user[2]
42 
43 typedef enum {
44  dk_opoi_start = 1, // Compulsory, start event must always be 1 (one).
76 
77 
78 
79 class DK_OPotatoIndustry : public Crop
80 {
81 public:
82  bool Do(Farm* a_farm, LE* a_field, FarmEvent* a_ev);
83  DK_OPotatoIndustry(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_opoi_foobar - DK_OPOI_BASE);
91 
92  FarmManagementCategory catlist[elements] =
93  {
94  fmc_Others, // zero element unused but must be here
95  fmc_Others, // dk_opoi_autumn_remove_straw = DK_OPOI_BASE,
96  fmc_Others, // dk_opoi_spring_remove_straw,
97  fmc_Cultivation, // dk_opoi_autumn_stoneburier,
98  fmc_Cultivation, // dk_opoi_autumn_plough,
99  fmc_Cultivation, // dk_opoi_spring_stoneburier,
100  fmc_Cultivation, // dk_opoi_spring_plough,
101  fmc_Cultivation, // dk_opoi_deep_harrow1,
102  fmc_Fertilizer, // dk_opoi_ferti_s,
103  fmc_Fertilizer, // dk_opoi_ferti_p,
104  fmc_Others, // dk_opoi_sow,
105  fmc_Fertilizer, // dk_opoi_calcium_sand_s,
106  fmc_Fertilizer, // dk_opoi_calcium_sand_p,
107  fmc_Watering, // dk_opoi_water1,
108  fmc_Watering, // dk_opoi_water2,
109  fmc_Watering, // dk_opoi_water3,
110  fmc_Watering, // dk_opoi_water1,
111  fmc_Watering, // dk_opoi_water2,
112  fmc_Watering, // dk_opoi_water3,
113  fmc_Cultivation, // dk_opoi_row_cultivation1,
114  fmc_Cultivation, // dk_opoi_hilling_up1,
115  fmc_Cultivation, // dk_opoi_row_cultivation2,
116  fmc_Cultivation, // dk_opoi_hilling_up2,
117  fmc_Cultivation, // dk_opoi_harrow,
118  fmc_Cultivation, // dk_opoi_hilling_up3,
119  fmc_Cultivation, // dk_opoi_row_cultivation3,
120  fmc_Cultivation, // dk_opoi_hilling_up4,
121  fmc_Others, // dk_opoi_top_off,
122  fmc_Harvest, // dk_opoi_harvest,
123  fmc_Cultivation, // dk_opoi_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 #endif // DK_OPotatoIndustry_H
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
FarmEvent::m_forcespring
bool m_forcespring
Definition: Farm.h:392
dk_opoi_hilling_up1
Definition: DK_OPotatoIndustry.h:64
dk_opoi_row_cultivation3
Definition: DK_OPotatoIndustry.h:69
DK_OPotatoIndustry
Definition: DK_OPotatoIndustry.h:79
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_opoi_water1_c
Definition: DK_OPotatoIndustry.h:60
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
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_opoi_water3_s
Definition: DK_OPotatoIndustry.h:59
tos_SandyClayLoam
Definition: LandscapeFarmingEnums.h:722
dk_opoi_sow
Definition: DK_OPotatoIndustry.h:54
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_opoi_water2_c
Definition: DK_OPotatoIndustry.h:61
tos_SandyLoam
Definition: LandscapeFarmingEnums.h:721
dk_opoi_top_off
Definition: DK_OPotatoIndustry.h:71
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_opoi_hilling_up3
Definition: DK_OPotatoIndustry.h:68
DK_OPotatoIndustry::SetUpFarmCategoryInformation
void SetUpFarmCategoryInformation()
Definition: DK_OPotatoIndustry.h:88
DK_OPotatoIndustry::DK_OPotatoIndustry
DK_OPotatoIndustry(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: DK_OPotatoIndustry.h:83
tov_DKOPotatoIndustry
Definition: LandscapeFarmingEnums.h:390
Crop::m_first_date
int m_first_date
Definition: Farm.h:501
dk_opoi_foobar
Definition: DK_OPotatoIndustry.h:74
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_opoi_deep_harrow2
Definition: DK_OPotatoIndustry.h:73
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_opoi_calcium_sand_s
Definition: DK_OPotatoIndustry.h:55
dk_opoi_row_cultivation1
Definition: DK_OPotatoIndustry.h:63
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_opoi_water2_s
Definition: DK_OPotatoIndustry.h:58
fmc_Cultivation
Definition: LandscapeFarmingEnums.h:1008
LE::GetSoilType
int GetSoilType()
Definition: Elements.h:302
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
fmc_Watering
Definition: LandscapeFarmingEnums.h:1011
DK_OPOI_BASE
#define DK_OPOI_BASE
Definition: DK_OPotatoIndustry.h:39
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
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
dk_opoi_autumn_plough
Definition: DK_OPotatoIndustry.h:48
dk_opoi_ferti_p
Definition: DK_OPotatoIndustry.h:53
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_opoi_ferti_s
Definition: DK_OPotatoIndustry.h:52
dk_opoi_spring_plough
Definition: DK_OPotatoIndustry.h:50
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
dk_opoi_harvest
Definition: DK_OPotatoIndustry.h:72
FarmEvent::m_todo
int m_todo
Definition: Farm.h:388
tos_Sand
Definition: LandscapeFarmingEnums.h:719
dk_opoi_autumn_stoneburier
Definition: DK_OPotatoIndustry.h:47
dk_opoi_deep_harrow1
Definition: DK_OPotatoIndustry.h:51
dk_opoi_spring_remove_straw
Definition: DK_OPotatoIndustry.h:46
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
dk_opoi_hilling_up4
Definition: DK_OPotatoIndustry.h:70
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
dk_opoi_calcium_sand_p
Definition: DK_OPotatoIndustry.h:56
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
TTypesOfVegetation
TTypesOfVegetation
Values that represent the types of vegetation that are represented in ALMaSS.
Definition: LandscapeFarmingEnums.h:192
dk_opoi_water1_s
Definition: DK_OPotatoIndustry.h:57
dk_opoi_start
Definition: DK_OPotatoIndustry.h:44
Farm
The base class for all farm types.
Definition: Farm.h:755
DK_OPotatoIndustry::Do
bool Do(Farm *a_farm, LE *a_field, FarmEvent *a_ev)
Definition: DK_OPotatoIndustry.cpp:32
DK_OPOI_FORCESPRING
#define DK_OPOI_FORCESPRING
Definition: DK_OPotatoIndustry.h:40
fmc_Harvest
Definition: LandscapeFarmingEnums.h:1012
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
dk_opoi_water3_c
Definition: DK_OPotatoIndustry.h:62
dk_opoi_autumn_remove_straw
Definition: DK_OPotatoIndustry.h:45
DK_OPOI_SANDY
#define DK_OPOI_SANDY
Definition: DK_OPotatoIndustry.h:41
DK_OPotatoIndustryToDo
DK_OPotatoIndustryToDo
Definition: DK_OPotatoIndustry.h:43
dk_opoi_row_cultivation2
Definition: DK_OPotatoIndustry.h:65
dk_opoi_harrow
Definition: DK_OPotatoIndustry.h:67
Crop::m_ev
FarmEvent * m_ev
Definition: Farm.h:500
tos_LoamySand
Definition: LandscapeFarmingEnums.h:720
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_opoi_spring_stoneburier
Definition: DK_OPotatoIndustry.h:49
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
dk_opoi_hilling_up2
Definition: DK_OPotatoIndustry.h:66