From 7c83396e843ba28167f647c46099879fde353bb2 Mon Sep 17 00:00:00 2001
From: Peter Alexander <peter@blackhillock.co.uk>
Date: Mon, 3 Aug 2015 08:22:33 +0100
Subject: [PATCH] no message

---
 GAMS/IntExtOpt.gms                            | 37 +++++++++----------
 src/ac/ed/lurg/ModelMain.java                 |  4 +-
 .../lurg/country/gams/GamsCountryInput.java   |  2 +-
 3 files changed, 21 insertions(+), 22 deletions(-)

diff --git a/GAMS/IntExtOpt.gms b/GAMS/IntExtOpt.gms
index ecc45a22..8fab4b93 100644
--- a/GAMS/IntExtOpt.gms
+++ b/GAMS/IntExtOpt.gms
@@ -31,7 +31,7 @@
 
  SCALAR fitToPreviousAreas                   controlling parameter 0 means dont fit and 1 is to calibrate the cropAdj in the calibration year
 
-*$gdxin "/Users/peteralexander/Documents/R_Workspace/temp/GamsTest/_gams_java_gdb1.gdx"
+*$gdxin "/Users/peteralexander/Documents/R_Workspace/temp/GamsTest/_gams_java_1091455539.gdx"
 $gdxin %gdxincname% 
 $load location, suitableLandArea, previousArea, demand, landChangeEnergy
 $load yieldNone, yieldFertOnly, yieldIrrigOnly, yieldBoth
@@ -63,8 +63,11 @@ $gdxin
               starchyRoots      4.0
               pasture           0.1  / ; 
               
-  SCALAR fertiliserUnitCost / 1.5 /
-  
+ SCALAR fertiliserUnitCost / 1.5 /
+ 
+ PARAMETER previousCropTotalAreas(location);
+ previousCropTotalAreas(location) = sum(crop_less_pasture, previousArea(crop_less_pasture, location));
+ 
  VARIABLES
        area(crop, location)               total area for each crop - Mha
        fertI(crop, location)              fertilizer intensity for each crop - factor between 0 and 1
@@ -110,7 +113,7 @@ $gdxin
        PASTURE_DECREASE_CONV_CALC(location)             
        ENERGY_EQ                                        total energy objective function;
  
- UNIT_ENERGY_EQ(crop, location) .. unitEnergy(crop, location) =E=  ( baseCost(crop)  +              
+ UNIT_ENERGY_EQ(crop, location) .. unitEnergy(crop, location) =E=  ( baseCost(crop) * power(cropAdj(crop), 1) +              
                                                                      (fertiliserUnitCost * fertI(crop, location)) + 
                                                                      (irrigCost(location) * irrigI(crop, location)) ) ;
  
@@ -124,7 +127,7 @@ $gdxin
    
  NET_SUPPLY_EQ(crop) .. net_supply(crop) =E= sum(location, area(crop, location) * yield(crop, location)) - feedAmount(crop) + netImportAmount(crop);
   
- NON_CEREAL_DEMAND_CONSTRAINT(non_cereal_crop) .. net_supply(non_cereal_crop) =G= demand(non_cereal_crop);
+ NON_CEREAL_DEMAND_CONSTRAINT(non_cereal_crop) .. net_supply(non_cereal_crop) =G= demand(non_cereal_crop) ;
   
  CEREAL_DEMAND_CONSTRAINT(cereal_crop) .. net_supply(cereal_crop) =G= demand('cereals') * minDemandPerCereal;
   
@@ -150,12 +153,12 @@ $gdxin
  CROP_INCREASE_CALC(location) .. cropIncrease(location) =G= sum(crop_less_pasture, area(crop_less_pasture, location) - previousArea(crop_less_pasture, location));
  CROP_DECREASE_CALC(location) .. cropDecrease(location) =G= -sum(crop_less_pasture, area(crop_less_pasture, location) - previousArea(crop_less_pasture, location));
  PASTURE_INCREASE_CONV_CALC(location) .. pastureIncrease(location) =G= area('pasture', location) - previousArea('pasture', location);
- PASTURE_DECREASE_CONV_CALC(location) .. pastureDecrease(location) =G= -area('pasture', location) - previousArea('pasture', location);
+ PASTURE_DECREASE_CONV_CALC(location) .. pastureDecrease(location) =G= -(area('pasture', location) - previousArea('pasture', location));
  
  ENERGY_EQ .. energy =E= (SUM((crop, location), area(crop, location) * unitEnergy(crop, location))         
             + (sum(location, agriLandExpansion(location)) * landChangeEnergy)
-            + (sum(location, (((cropIncrease(location) + cropDecrease(location))/sum(crop_less_pasture, previousArea(crop_less_pasture, location)))) * landChangeEnergy/5 * sum(crop_less_pasture, previousArea(crop_less_pasture, location))) )
-            + (sum(location, (((pastureIncrease(location) + pastureDecrease(location))/previousArea('pasture', location))) * landChangeEnergy/5 *previousArea('pasture', location)) )
+            + (sum(location, ((cropIncrease(location) + cropDecrease(location))/previousCropTotalAreas(location)) * landChangeEnergy/10 * previousCropTotalAreas(location)) )
+            + (sum(location, ((pastureIncrease(location) + pastureDecrease(location))/previousArea('pasture', location)) * landChangeEnergy/10 *previousArea('pasture', location)) )
             + sum(import_crop, (netImportAmount(import_crop)) * worldInputEnergy(import_crop))) / 1000000;          
  
  MODEL LAND_USE /ALL/ ;
@@ -167,7 +170,7 @@ $gdxin
  scalar newPasture     / 0 /;
  scalar newCropland    / 0 /;
  
-  parameter temp(location);
+ parameter temp(location);
  
 * if fitToPreviousAreas is zero then we just optimise
  if (fitToPreviousAreas eq 0,
@@ -180,23 +183,19 @@ $gdxin
      basePasture = sum(location, previousArea("pasture", location));
      baseCropland = sum((location, crop_less_pasture), previousArea(crop_less_pasture, location));
  
-	 while((count le 1 and not (abs(basePasture-newPasture) le 0.1 and abs(baseCropland-newCropland) le 0.1)),
+	 while((count le 10 and not (abs(basePasture-newPasture) le 0.1 and abs(baseCropland-newCropland) le 0.1)),
 	      SOLVE LAND_USE USING NLP MINIMIZING energy;
 	      
 	      display pastureIncrease.l, pastureDecrease.l, cropDecrease.l, cropIncrease.l;
-	      
-	      temp(location) = SQRT(SQR(cropIncrease.l(location)/sum(crop_less_pasture, previousArea(crop_less_pasture, location)))) * landChangeEnergy/5 * sum(crop_less_pasture, previousArea(crop_less_pasture, location))
-	      
-	      display temp;
-	      
+	      	      
 	      newPasture = sum(location, area.l("pasture", location));
 	      newCropland = sum((location, crop_less_pasture), area.l(crop_less_pasture, location));
 	      
-	      cropAdj(crop_less_pasture) = cropAdj(crop_less_pasture) * (newCropland / baseCropland);
-	      cropAdj("pasture") = cropAdj("pasture") * (newPasture / basePasture);
+	      cropAdj(crop_less_pasture) = cropAdj(crop_less_pasture) * newCropland / baseCropland;
+	      cropAdj("pasture") = cropAdj("pasture") * newPasture / basePasture;
 	      
-*	      cropAdj(crop) = max(cropAdj(crop), 0.2);
-*	      cropAdj(crop) = min(cropAdj(crop), 5);
+	      cropAdj(crop) = max(cropAdj(crop), 0.2);
+	      cropAdj(crop) = min(cropAdj(crop), 5);
 	      
 	      display area.l, count, basePasture, baseCropland, newPasture, newCropland, cropAdj;
 	      count = count+1 ;
diff --git a/src/ac/ed/lurg/ModelMain.java b/src/ac/ed/lurg/ModelMain.java
index 27bbc0c5..53fbd1f6 100644
--- a/src/ac/ed/lurg/ModelMain.java
+++ b/src/ac/ed/lurg/ModelMain.java
@@ -241,11 +241,11 @@ public class ModelMain {
 
 
 			// DEBUG code
-			if (!(country.getCountryName().equals("United States of AmericaXX") || country.getCountryName().equals("China"))) { //|| country.getCountryName().equals("China")
+			if (!(country.getCountryName().equals("United States of Americaxx") || country.getCountryName().equals("Russian Federation"))) { //|| country.getCountryName().equals("China")
 				continue;
 			}
 
-			if (demandManager.getPopulation(country, 2010) < 5 || countryExclusionList.contains(country.getCountryName())) {
+			if (demandManager.getPopulation(country, 2010) < 10 || countryExclusionList.contains(country.getCountryName())) {
 				LogWriter.printlnError("Skipping " + country);
 				continue;
 			}
diff --git a/src/ac/ed/lurg/country/gams/GamsCountryInput.java b/src/ac/ed/lurg/country/gams/GamsCountryInput.java
index 33b51176..65ad31b9 100644
--- a/src/ac/ed/lurg/country/gams/GamsCountryInput.java
+++ b/src/ac/ed/lurg/country/gams/GamsCountryInput.java
@@ -97,7 +97,7 @@ public class GamsCountryInput {
 //	}
 
 	public double getMeatEfficiency() {
-		return 0.6;  // this is already handled by the feed conversion efficiency for each animal product
+		return 0.5;  // this is already handled by the feed conversion efficiency for each animal product
 	}
 
 	public double getLandChangeEnergy() {
-- 
GitLab