ALMaSS Skylark ODDox
1.1
The skylark model description following ODdox protocol
|
#include <WinterBarley.h>
◆ WinterBarley()
WinterBarley::WinterBarley |
( |
| ) |
|
|
inline |
◆ Do()
bool WinterBarley::Do |
( |
Farm * |
a_farm, |
|
|
LE * |
a_field, |
|
|
FarmEvent * |
a_ev |
|
) |
| |
|
virtual |
Reimplemented from Crop.
56 m_field->SetMDates(0,0,g_date->DayInYear(20,7));
58 m_field->SetMDates(1,0,g_date->DayInYear(5,8));
59 m_field->SetMDates(0,1,g_date->DayInYear(25,7));
60 m_field->SetMDates(1,1,g_date->DayInYear(10,8));
61 m_field->SetMDates(0,2,g_date->DayInYear(20,7));
62 m_field->SetMDates(1,2,g_date->DayInYear(5,8));
75 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): "
76 "Harvest too late for the next crop to start!!!",
"" );
80 for (
int i=0; i<noDates; i++) {
94 int today=g_date->Date();
96 d1 = g_date->OldDays() + g_date->DayInYear( 1,7 );
99 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): "
100 "Crop start attempt between 1st Jan & 1st July",
"" );
107 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): "
108 "Crop start attempt after last possible start date",
"" );
116 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 20,7 )
125 if ( g_date->Date() > d1 ) {
150 g_date->DayInYear( 5, 9 ) -
151 g_date->DayInYear())) {
162 g_date->DayInYear( 10, 9 ) -
163 g_date->DayInYear())) {
175 g_date->DayInYear( 5, 9 ) -
176 g_date->DayInYear())) {
186 g_date->DayInYear( 5, 9 ) -
187 g_date->DayInYear())) {
196 g_date->DayInYear( 5, 9 ) -
197 g_date->DayInYear())) {
202 int d1 = g_date->Date();
203 if ( d1 < g_date->OldDays() + g_date->DayInYear( 1, 9 )) {
204 d1 = g_date->OldDays() + g_date->DayInYear( 1, 9 );
212 g_date->DayInYear( 15,9 ) -
213 g_date->DayInYear())) {
218 int d1 = g_date->Date() + 14;
219 if ( d1 < g_date->OldDays() + g_date->DayInYear( 15, 9 )) {
220 d1 = g_date->OldDays() + g_date->DayInYear( 15, 9 );
232 Field * pf = dynamic_cast<Field*>(
m_field);
233 pf->Add_missed_herb_app();
234 if(
m_farm->
DoIt(35)) pf->Add_missed_herb_app();
245 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 1,4 ) + 365,
247 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 5,4 ) + 365,
249 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 15,4 ) + 365,
251 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 1,5 ) + 365,
254 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 16,9 ),
263 g_date->DayInYear( 30,10 ) -
264 g_date->DayInYear())) {
269 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 1,4 ) + 365,
276 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 5,4 ) + 365,
278 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 15,4 ) + 365,
280 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 1,5 ) + 365,
286 g_date->DayInYear( 5,5 ) -
287 g_date->DayInYear())) {
302 g_date->DayInYear( 1,5 ) -
303 g_date->DayInYear())) {
307 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 2,5 ),
314 g_date->DayInYear( 20,5 ) -
315 g_date->DayInYear())) {
332 g_date->DayInYear( 15,5 ) -
333 g_date->DayInYear())) {
350 g_date->DayInYear( 30,4 ) -
351 g_date->DayInYear())) {
356 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 1,5 ),
363 g_date->DayInYear( 15,5 ) -
364 g_date->DayInYear())) {
381 g_date->DayInYear( 30,5 ) -
382 g_date->DayInYear())) {
403 Field * pf = dynamic_cast<Field*>(
m_field);
404 pf->Add_missed_fi_app();
438 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 15,5 ),
440 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 1,5 ),
442 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 15,5 ),
444 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 15,5 ),
457 g_date->DayInYear( 30,5 ) -
458 g_date->DayInYear())) {
468 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 20,7 ),
481 g_date->DayInYear( 31,5 ) -
482 g_date->DayInYear())) {
507 g_date->DayInYear( 15,6 ) -
508 g_date->DayInYear())) {
518 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 20,7 ),
534 Field * pf = dynamic_cast<Field*>(
m_field);
535 pf->Add_missed_fi_app();
549 SimpleEvent( g_date->OldDays() + g_date->DayInYear( 20,7 ),
555 if (
m_field->GetMConstants(0)==0) {
557 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): failure in 'Harvest' execution",
"" );
593 if (
m_field->GetMConstants(2)==0) {
595 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): failure in 'HayTurning' execution",
"" );
610 if (
m_field->GetMConstants(2)==0) {
612 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): failure in 'HayBailing' execution",
"" );
623 int d1 = g_date->Date();
624 if ( d1 < g_date->OldDays() +
m_field->GetMDates(0,1)) {
625 d1 = g_date->OldDays() +
m_field->GetMDates(0,1);
633 if (
m_field->GetMConstants(2)==0) {
635 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): failure in 'StubbleHarrowing' execution",
"" );
650 g_msg->Warn( WARN_BUG,
"WinterBarley::Do(): "
651 "Unknown event type! ",
"" );
References Farm::AutumnHarrow(), Farm::AutumnPlough(), Farm::AutumnSow(), cfg_fungi_app_prop1, cfg_greg_app_prop, cfg_herbi_app_prop, cfg_ins_app_prop1, Crop::ChooseNextCrop(), Farm::DoIt(), Farm::FA_Manure(), Farm::FA_NPK(), Farm::FA_Slurry(), Farm::FP_ManganeseSulphate(), Farm::FP_NPK(), Farm::FP_Sludge(), Farm::FungicideTreat(), Farm::GetType(), Farm::GrowthRegulator(), Farm::Harvest(), Farm::HayBailing(), Farm::HayTurning(), Farm::HerbicideTreat(), Farm::InsecticideTreat(), Farm::IsStockFarmer(), Crop::m_ev, Crop::m_farm, Crop::m_field, Crop::m_first_date, FarmEvent::m_first_year, Crop::m_last_date, FarmEvent::m_lock, FarmEvent::m_startday, FarmEvent::m_todo, Farm::Prob_multiplier(), Crop::SimpleEvent(), Farm::Spraying_fungins(), Farm::Spraying_herbicides(), Farm::StrawChopping(), Farm::StubbleHarrowing(), tof_OptimisingFarm, Farm::Water(), wb_autumn_harrow, wb_autumn_plough, wb_autumn_sow, WB_DECIDE_TO_FI, WB_DECIDE_TO_HERB, WB_DID_EIGHT_FOUR, WB_DID_EIGHT_ONE, WB_DID_EIGHT_THREE, WB_DID_EIGHT_TWO, WB_DID_SEVEN_FOUR, WB_DID_SEVEN_ONE, WB_DID_SEVEN_THREE, WB_DID_SEVEN_TWO, wb_fertmanganese_plant_one, wb_fertmanganese_plant_two, wb_fertmanure_stock, wb_fertnpk_plant_one, wb_fertnpk_plant_two, wb_fertnpk_stock_one, wb_fertnpk_stock_two, wb_fertsludge_plant_one, wb_fertslurry_stock_one, wb_fertslurry_stock_two, WB_FUNGICIDE_DATE, wb_fungicide_one, wb_fungicide_two, wb_growth_reg, wb_harvest, wb_hay_bailing, wb_hay_turning, WB_HERBICIDE_DATE, wb_herbicide_one, wb_herbicide_two, wb_insecticide, wb_start, wb_stubble_harrowing, wb_switchboard, and wb_water.
The documentation for this class was generated from the following files:
virtual bool FP_Sludge(LE *a_field, double a_user, int a_days)
Spread sewege on a_field owned by an arable farmer.
Definition: farmfuncs.cpp:822
Definition: WinterBarley.h:62
virtual bool FA_Slurry(LE *a_field, double a_user, int a_days)
Spready slurry on a_field owned by an stock farmer.
Definition: farmfuncs.cpp:965
Definition: WinterBarley.h:69
virtual bool HerbicideTreat(LE *a_field, double a_user, int a_days)
Apply herbicide to a_field.
Definition: farmfuncs.cpp:1156
bool IsStockFarmer(void)
Definition: farm.h:905
virtual bool Harvest(LE *a_field, double a_user, int a_days)
Carry out a harvest on a_field.
Definition: farmfuncs.cpp:1769
bool m_lock
Definition: farm.h:465
CfgFloat cfg_greg_app_prop
CfgFloat cfg_fungi_app_prop1
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:727
Definition: WinterBarley.h:79
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:629
bool DoIt(double a_probability)
Return chance out of 0 to 100.
Definition: farm.cpp:800
bool m_first_year
Definition: farm.h:467
Definition: WinterBarley.h:82
Definition: WinterBarley.h:67
Definition: WinterBarley.h:64
#define WB_DECIDE_TO_FI
Definition: WinterBarley.h:55
CfgFloat cfg_ins_app_prop1
virtual bool FA_Manure(LE *a_field, double a_user, int a_days)
Spread manure on a_field owned by an stock farmer.
Definition: farmfuncs.cpp:1036
TTypesOfFarm GetType(void)
Definition: farm.h:901
#define WB_DID_EIGHT_THREE
Definition: WinterBarley.h:52
Definition: WinterBarley.h:78
Definition: WinterBarley.h:77
#define WB_DID_EIGHT_ONE
Definition: WinterBarley.h:50
int m_first_date
Definition: farm.h:540
int m_startday
Definition: farm.h:466
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:917
virtual bool FungicideTreat(LE *a_field, double a_user, int a_days)
Apply fungicide to a_field.
Definition: farmfuncs.cpp:1279
Definition: WinterBarley.h:75
void SimpleEvent(long a_date, int a_todo, bool a_lock)
Adds an event to this crop management.
Definition: farm.cpp:307
Definition: WinterBarley.h:83
Definition: WinterBarley.h:59
Definition: WinterBarley.h:76
Definition: WinterBarley.h:60
Definition: WinterBarley.h:66
virtual double Prob_multiplier()
Definition: farm.h:786
virtual bool AutumnSow(LE *a_field, double a_user, int a_days)
Carry out a sowing event in the autumn on a_field.
Definition: farmfuncs.cpp:364
Definition: WinterBarley.h:63
#define WB_FUNGICIDE_DATE
Definition: WinterBarley.h:47
#define WB_DID_SEVEN_FOUR
Definition: WinterBarley.h:45
TTypesOfVegetation
Definition: tov_declaration.h:30
virtual bool Spraying_herbicides(TTypesOfVegetation)
Definition: farm.h:784
virtual bool HayBailing(LE *a_field, double a_user, int a_days)
Carry out hay bailing on a_field.
Definition: farmfuncs.cpp:2184
#define WB_DECIDE_TO_HERB
Definition: WinterBarley.h:54
virtual bool StrawChopping(LE *a_field, double a_user, int a_days)
Carry out straw chopping on a_field.
Definition: farmfuncs.cpp:2132
Definition: WinterBarley.h:61
Definition: WinterBarley.h:74
Definition: WinterBarley.h:81
Definition: WinterBarley.h:70
Farm * m_farm
Definition: farm.h:537
LE * m_field
Definition: farm.h:538
int m_todo
Definition: farm.h:469
virtual bool InsecticideTreat(LE *a_field, double a_user, int a_days)
Apply insecticide to a_field.
Definition: farmfuncs.cpp:1348
#define WB_HERBICIDE_DATE
Definition: WinterBarley.h:48
#define WB_DID_SEVEN_TWO
Definition: WinterBarley.h:43
virtual bool Water(LE *a_field, double a_user, int a_days)
Carry out a watering on a_field.
Definition: farmfuncs.cpp:1717
int m_last_date
Definition: farm.h:542
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:132
#define WB_DID_EIGHT_TWO
Definition: WinterBarley.h:51
Definition: WinterBarley.h:71
CfgFloat cfg_herbi_app_prop
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:261
Definition: WinterBarley.h:68
#define WB_DID_EIGHT_FOUR
Definition: WinterBarley.h:53
#define WB_DID_SEVEN_THREE
Definition: WinterBarley.h:44
virtual bool GrowthRegulator(LE *a_field, double a_user, int a_days)
Apply growth regulator to a_field.
Definition: farmfuncs.cpp:1250
Definition: WinterBarley.h:80
Definition: WinterBarley.h:84
void ChooseNextCrop(int a_no_dates)
Chooses the next crop to grow in a field.
Definition: farm.cpp:318
virtual bool HayTurning(LE *a_field, double a_user, int a_days)
Carry out hay turning on a_field.
Definition: farmfuncs.cpp:2159
FarmEvent * m_ev
Definition: farm.h:539
Definition: WinterBarley.h:73
virtual bool Spraying_fungins(TTypesOfVegetation)
Definition: farm.h:785
Definition: WinterBarley.h:65
virtual bool StubbleHarrowing(LE *a_field, double a_user, int a_days)
Carry out stubble harrowing on a_field.
Definition: farmfuncs.cpp:2209
#define WB_DID_SEVEN_ONE
Definition: WinterBarley.h:42
Definition: WinterBarley.h:72