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
BEGrassGrazed1.h
Go to the documentation of this file.
1 
16 //
17 // BEGrassGrazed1.h
18 //
19 
20 
21 #ifndef BEGRASSGRAZED1_H
22 #define BEGRASSGRAZED1_H
23 
24 #define BEGRASSGRAZED1_BASE 25800
25 
28 #define BE_GG1_FERTI_DATE a_field->m_user[1]
29 #define BE_GG1_CUT_DATE a_field->m_user[1]
30 #define BE_GG1_WATER_DATE a_field->m_user[3]
31 
32 
38 typedef enum {
39  BE_gg1_start = 1, // Compulsory, must always be 1 (one).
68 
69 
78 class BEGrassGrazed1: public Crop
79 {
80  public:
81  virtual bool Do( Farm *a_farm, LE *a_field, FarmEvent *a_ev );
82  BEGrassGrazed1(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape* a_L) : Crop(a_tov, a_toc, a_L)
83  {
84  // When we start it off, the first possible date for a farm operation is 5th November
85  // This information is used by other crops when they decide how much post processing of
86  // the management is allowed after harvest before the next crop starts.
87  m_first_date=g_date->DayInYear( 30,11 );
88  }
89 };
90 
91 #endif // BEGRASSGRAZED1_H
92 
LE::GetMDates
int GetMDates(int a, int b)
Definition: Elements.h:405
BE_gg1_ferti_p6
Definition: BEGrassGrazed1.h:59
BEGrassGrazed1
BEGrassGrazed1 class .
Definition: BEGrassGrazed1.h:78
LE::SetMDates
void SetMDates(int a, int b, int c)
Definition: Elements.h:406
BE_gg1_ferti_p4
Definition: BEGrassGrazed1.h:55
BE_GG1_WATER_DATE
#define BE_GG1_WATER_DATE
Definition: BEGrassGrazed1.h:30
BE_gg1_ferti_p8
Definition: BEGrassGrazed1.h:63
BE_gg1_ferti_p1
Definition: BEGrassGrazed1.h:42
BE_gg1_cattle_out
Definition: BEGrassGrazed1.h:65
BE_gg1_ferti_p7
Definition: BEGrassGrazed1.h:61
BE_GG1_CUT_DATE
#define BE_GG1_CUT_DATE
Definition: BEGrassGrazed1.h:29
FarmEvent::m_lock
bool m_lock
Definition: Farm.h:384
FarmEvent
A struct to hold the information required to trigger a farm event.
Definition: Farm.h:372
Calendar::GetYearNumber
int GetYearNumber(void)
Definition: Calendar.h:72
BE_gg1_preseeding_cultivator
Definition: BEGrassGrazed1.h:44
FarmEvent::m_first_year
bool m_first_year
Definition: Farm.h:386
LE::GetPoly
int GetPoly(void)
Returns the polyref number for this polygon.
Definition: Elements.h:238
BEGRASSGRAZED1_BASE
#define BEGRASSGRAZED1_BASE
Definition: BEGrassGrazed1.h:24
g_date
class Calendar * g_date
Definition: Calendar.cpp:37
Farm::GetPreviousTov
TTypesOfVegetation GetPreviousTov(int a_index)
Definition: Farm.h:966
BE_gg1_winter_plough
Definition: BEGrassGrazed1.h:41
BE_gg1_ferti_s6
Definition: BEGrassGrazed1.h:60
Farm::GetType
TTypesOfFarm GetType(void)
Definition: Farm.h:956
BE_GG1_FERTI_DATE
#define BE_GG1_FERTI_DATE
A flag used to indicate autumn ploughing status.
Definition: BEGrassGrazed1.h:28
Crop::m_first_date
int m_first_date
Definition: Farm.h:501
BEGrassGrazed1::Do
virtual bool Do(Farm *a_farm, LE *a_field, FarmEvent *a_ev)
The one and oBEy method for a crop management plan. All farm actions go through here.
Definition: BEGrassGrazed1.cpp:54
FarmEvent::m_startday
int m_startday
Definition: Farm.h:385
BE_gg1_spring_sow
Definition: BEGrassGrazed1.h:45
Crop
The base class for all crops.
Definition: Farm.h:495
BE_gg1_ferti_s4
Definition: BEGrassGrazed1.h:56
Landscape
The landscape class containing all environmental and topographical data.
Definition: Landscape.h:142
BE_gg1_cut_to_silage5
Definition: BEGrassGrazed1.h:52
Calendar::Date
long Date(void)
Definition: Calendar.h:57
BE_gg1_ferti_s8
Definition: BEGrassGrazed1.h:64
BE_gg1_ferti_s5
Definition: BEGrassGrazed1.h:58
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
BE_gg1_ferti_s7
Definition: BEGrassGrazed1.h:62
LE::GetRotIndex
int GetRotIndex(void)
Definition: Elements.h:373
BEGrassGrazed1::BEGrassGrazed1
BEGrassGrazed1(TTypesOfVegetation a_tov, TTypesOfCrops a_toc, Landscape *a_L)
Definition: BEGrassGrazed1.h:82
FarmEvent::m_next_tov
TTypesOfVegetation m_next_tov
Definition: Farm.h:390
tov_BEGrassGrazed1
Definition: LandscapeFarmingEnums.h:292
Crop::m_farm
Farm * m_farm
Definition: Farm.h:498
Crop::m_field
LE * m_field
Definition: Farm.h:499
BE_gg1_ferti_s3
Definition: BEGrassGrazed1.h:54
FarmEvent::m_todo
int m_todo
Definition: Farm.h:388
TTypesOfCrops
TTypesOfCrops
Definition: LandscapeFarmingEnums.h:781
tof_OptimisingFarm
Definition: LandscapeFarmingEnums.h:696
BE_gg1_ferti_p2
Definition: BEGrassGrazed1.h:46
LE
Definition: Elements.h:86
BE_gg1_start
Definition: BEGrassGrazed1.h:39
BE_gg1_cut_to_silage1
Definition: BEGrassGrazed1.h:48
g_msg
MapErrorMsg * g_msg
Definition: MapErrorMsg.cpp:41
BE_gg1_sleep_all_day
Definition: BEGrassGrazed1.h:40
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
Farm::WinterPlough
virtual bool WinterPlough(LE *a_field, double a_user, int a_days)
Carry out a ploughing event in the winter on a_field.
Definition: FarmFuncs.cpp:395
BE_gg1_cut_to_silage4
Definition: BEGrassGrazed1.h:51
BE_gg1_cut_to_silage3
Definition: BEGrassGrazed1.h:50
LE::GetOwner
Farm * GetOwner(void)
Definition: Elements.h:256
BE_gg1_ferti_s1
Definition: BEGrassGrazed1.h:43
Calendar::DayInYear
int DayInYear(void)
Definition: Calendar.h:58
BE_gg1_ferti_p3
Definition: BEGrassGrazed1.h:53
BE_gg1_ferti_s2
Definition: BEGrassGrazed1.h:47
LE::SetMConstants
void SetMConstants(int a, int c)
Definition: Elements.h:408
BEGrassGrazed1ToDo
BEGrassGrazed1ToDo
Definition: BEGrassGrazed1.h:38
Crop::m_ev
FarmEvent * m_ev
Definition: Farm.h:500
WARN_BUG
Definition: MapErrorMsg.h:34
BE_gg1_cut_to_silage2
Definition: BEGrassGrazed1.h:49
BE_gg1_ferti_p5
Definition: BEGrassGrazed1.h:57
BE_gg1_cattle_is_out
Definition: BEGrassGrazed1.h:66
Crop::SimpleEvent_
void SimpleEvent_(long a_date, int a_todo, bool a_lock, Farm *a_farm, LE *a_field)
Adds an event to this crop management without relying on member variables.
Definition: Farm.cpp:751