diff --git a/Conversion-Script/Convert_Wiliam_result_IAMC-format.ipynb b/Conversion-Script/Convert_Wiliam_result_IAMC-format.ipynb
index 16ec6e0..eb58989 100644
--- a/Conversion-Script/Convert_Wiliam_result_IAMC-format.ipynb
+++ b/Conversion-Script/Convert_Wiliam_result_IAMC-format.ipynb
@@ -161,13 +161,24 @@
"metadata": {},
"outputs": [],
"source": [
+ "# Check for duplicate rows\n",
+ "duplicate_rows = scenario_variable_df[scenario_variable_df.duplicated()]\n",
+ "\n",
+ "# Display duplicate rows\n",
+ "print(\"Duplicate Rows:\")\n",
+ "print(duplicate_rows)\n",
+ "\n",
+ "# Count the number of duplicate rows\n",
+ "num_duplicate_rows = duplicate_rows.shape[0]\n",
+ "print(\"Number of Duplicate Rows:\", num_duplicate_rows)\n",
+ "\n",
"# Read the CSV file into a pandas DataFrame\n",
- "data_name_df = pd.read_excel('Variable_Reference/Variable_name_IAMC.xlsx')\n",
+ "data_name_df = pd.read_excel(\"Variable_Reference/Variable_name_IAMC.xlsx\")\n",
"# Remplacer les tirets du bas par des espaces dans la colonne\n",
"# data_name_df['WILIAM_variable'] = data_name_df['WILIAM_variable'].str.replace('_', ' ')\n",
"# Drop rows with NaN values which corresponds to values not conserv for the final upload of data in IAMC format\n",
- "data_name_df.dropna(subset=['IAMC_variable'],inplace=True)\n",
- "data_name_df"
+ "data_name_df.dropna(subset=[\"IAMC_variable\"], inplace=True)\n",
+ "data_name_df\n"
]
},
{
@@ -184,7 +195,7 @@
"\n",
"# Keep only the rows where the value in column 'Variable' belongs to the list of wanted values \n",
"variable_required_list = data_name_df['IAMC_variable'].to_list()\n",
- "scenario_variable_df = scenario_variable_df[scenario_variable_df['Variable'].isin(variable_required_list)]"
+ "# scenario_variable_df = scenario_variable_df[scenario_variable_df['Variable'].isin(variable_required_list)]\n"
]
},
{
@@ -273,39 +284,79 @@
"outputs": [],
"source": [
"# Dict used to check if the subscripts are a country\n",
- "country_dict= {'EU27':1, 'UK':1,'CHINA':1,'EASOC':1,'INDIA':1,'LATAM':1,'RUSSIA':1,'USMCA':1,'LROW':1,'AUSTRIA':1,'BELGIUM':1,'BULGARIA':1,'CROATIA':1,'CYPRUS':1,'CZECH_REPUBLIC':1,'DENMARK':1,'ESTONIA':1,'FINLAND':1,'FRANCE':1,'GERMANY':1,'GREECE':1,'HUNGARY':1,'IRELAND':1,'ITALY':1,'LATVIA':1,'LITHUANIA':1,'LUXEMBOURG':1,'MALTA':1,'NETHERLANDS':1,'POLAND':1,'PORTUGAL':1,'ROMANIA':1,'SLOVAKIA':1,'SLOVENIA':1,'SPAIN':1,'SWEDEN':1}\n",
- "\n",
- "# Aggregate the subscripts at the end of the variable \n",
+ "country_dict = {\n",
+ " \"EU27\": 1,\n",
+ " \"UK\": 1,\n",
+ " \"CHINA\": 1,\n",
+ " \"EASOC\": 1,\n",
+ " \"INDIA\": 1,\n",
+ " \"LATAM\": 1,\n",
+ " \"RUSSIA\": 1,\n",
+ " \"USMCA\": 1,\n",
+ " \"LROW\": 1,\n",
+ " \"AUSTRIA\": 1,\n",
+ " \"BELGIUM\": 1,\n",
+ " \"BULGARIA\": 1,\n",
+ " \"CROATIA\": 1,\n",
+ " \"CYPRUS\": 1,\n",
+ " \"CZECH_REPUBLIC\": 1,\n",
+ " \"DENMARK\": 1,\n",
+ " \"ESTONIA\": 1,\n",
+ " \"FINLAND\": 1,\n",
+ " \"FRANCE\": 1,\n",
+ " \"GERMANY\": 1,\n",
+ " \"GREECE\": 1,\n",
+ " \"HUNGARY\": 1,\n",
+ " \"IRELAND\": 1,\n",
+ " \"ITALY\": 1,\n",
+ " \"LATVIA\": 1,\n",
+ " \"LITHUANIA\": 1,\n",
+ " \"LUXEMBOURG\": 1,\n",
+ " \"MALTA\": 1,\n",
+ " \"NETHERLANDS\": 1,\n",
+ " \"POLAND\": 1,\n",
+ " \"PORTUGAL\": 1,\n",
+ " \"ROMANIA\": 1,\n",
+ " \"SLOVAKIA\": 1,\n",
+ " \"SLOVENIA\": 1,\n",
+ " \"SPAIN\": 1,\n",
+ " \"SWEDEN\": 1,\n",
+ "}\n",
+ "\n",
+ "\n",
+ "\n",
+ "\n",
+ "# Aggregate the subscripts at the end of the variable\n",
"def aggregate_variable_name(row, counter):\n",
" for k in range(counter):\n",
- " subscript=row[\"Subscript \"+str(k)]\n",
- " \n",
- " if k==0 :\n",
- " if country_dict.get(subscript)==1: \n",
- " #Give the name of the region for that variable\n",
- " row[\"Region\"]=subscript\n",
- " \n",
- " row[\"Subscript 0\"]=np.nan\n",
+ " subscript = row[\"Subscript \" + str(k)]\n",
+ "\n",
+ " if k == 0:\n",
+ " if country_dict.get(subscript) == 1:\n",
+ " # Give the name of the region for that variable\n",
+ " row[\"Region\"] = subscript\n",
+ "\n",
+ " row[\"Subscript 0\"] = np.nan\n",
" continue\n",
- " \n",
+ "\n",
" if not pd.isnull(subscript):\n",
- " \n",
" if energy_dict.get(subscript, None) is not None:\n",
- " \n",
" subscript = energy_dict[subscript]\n",
- " elif rest_dict.get(subscript,None): \n",
+ " elif rest_dict.get(subscript, None):\n",
" subscript = rest_dict[subscript]\n",
- " \n",
- " row[\"Variable\"]=row[\"Variable\"]+\"|\"+subscript\n",
- " \n",
- " return row \n",
"\n",
+ " row[\"Variable\"] = row[\"Variable\"] + \"|\" + subscript\n",
+ "\n",
+ " return row\n",
"\n",
- "# Apply the previous function on all the lines \n",
- "scenario_variable_df= scenario_variable_df.apply(aggregate_variable_name, args=(counter,),axis=1)\n",
+ "\n",
+ "# Apply the previous function on all the lines\n",
+ "scenario_variable_df = scenario_variable_df.apply(\n",
+ " aggregate_variable_name, args=(counter,), axis=1\n",
+ ")\n",
"\n",
"# Remove the subscript columns once they have been added at the end of the variable name\n",
- "drop_columns_list=[\"Subscript \" + str(k) for k in range(counter)]\n",
+ "drop_columns_list = [\"Subscript \" + str(k) for k in range(counter)]\n",
"scenario_variable_df.drop(columns=drop_columns_list, inplace=True)\n",
"\n",
"scenario_variable_df"
@@ -359,7 +410,26 @@
"\n",
"# Capitalize each variable's name\n",
"scenario_variable_df['Variable'] = scenario_variable_df['Variable'].apply(transform_string)\n",
- "scenario_variable_df"
+ "scenario_variable_df.head(60)"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "import csv\n",
+ "\n",
+ "\n",
+ "# Step 1: Write to the first column\n",
+ "data_first_column = scenario_variable_df[\"Variable\"].to_list()\n",
+ "\n",
+ "# Open the CSV file in write mode and write the first column\n",
+ "with open(\"example.csv\", \"w\", newline=\"\") as csvfile:\n",
+ " csvwriter = csv.writer(csvfile)\n",
+ " for row in data_first_column:\n",
+ " csvwriter.writerow([row])\n"
]
},
{
@@ -645,7 +715,7 @@
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
- "version": "3.12.1"
+ "version": "3.10.14"
}
},
"nbformat": 4,
diff --git a/Conversion-Script/Create_Variable_Dict/aggregation.txt b/Conversion-Script/Create_Variable_Dict/aggregation.txt
new file mode 100644
index 0000000..23f974c
--- /dev/null
+++ b/Conversion-Script/Create_Variable_Dict/aggregation.txt
@@ -0,0 +1,4 @@
+{
+ ('world_PE_by_commodity|PE_waste', 'world_PE_by_commodity|PE_solar'): 'Primary Energy|New',
+ ('C', 'D', 'E'): 'Y'
+}
\ No newline at end of file
diff --git a/Conversion-Script/Create_Variable_Dict/economy_dashboard_dict.txt b/Conversion-Script/Create_Variable_Dict/economy_dashboard_dict.txt
new file mode 100644
index 0000000..90fc135
--- /dev/null
+++ b/Conversion-Script/Create_Variable_Dict/economy_dashboard_dict.txt
@@ -0,0 +1,37 @@
+{'DB CAPITAL STOCK': 'Capital Stock',
+ 'DB CONSUMPTION FIXED CAPITAL': 'Value Added|Consumption Fixed Capital',
+ 'DB DISPOSABLE INCOME PER CAPITA': 'Households|Consumer Price [index]',
+ 'DB EMPLOYMENT': 'Employment',
+ 'DB EXPORTS': 'Trade|Value|Exports',
+ 'DB GDP': 'GDP|PPP',
+ 'DB GDP PER CAPITA': 'Revenue|Households|Disposable [per capita]',
+ 'DB GOV BALANCE': 'Government|Budget Balance',
+ 'DB GOV BALANCE TO GDP': 'Government|Budget Balance to GDP',
+ 'DB GOV CONSUMPTION': 'Public Consumption',
+ 'DB GOV DEBT': 'Debt|Public',
+ 'DB GOV DEBT TO GDP': 'Revenues|Households|Disposable income',
+ 'DB GOV EXPENDITURE': 'Expenditure|Government',
+ 'DB GOV REVENUE': 'Revenue|Government',
+ 'DB GROSS FIXED CAPITAL FORMATION': 'Capital Formation',
+ 'DB GVA AGRICULTURE': 'Value Added|Agriculture',
+ 'DB GVA ENERGY': 'Value Added|Industry|Energy',
+ 'DB GVA EXTRACTION': 'Value Added|Extraction',
+ 'DB GVA INDUSTRY': 'Value Added|Industry',
+ 'DB GVA SERVICES': 'Value Added|Services',
+ 'DB GVA TAXES PRODUCTS TOTAL': 'Value Added|Taxes on products',
+ 'DB HH CONSUMPTION': 'Expenditure|Household',
+ 'DB HH CONSUMPTION COICOP': 'Households|Savings|Real',
+ 'DB HH CONSUMPTION COICOP NOMINAL': 'Households|Savings',
+ 'DB HH DISPOSABLE INCOME': 'Households|Consumption|COICOP',
+ 'DB HH DISPOSABLE INCOME NOMINAL': 'Households|Consumption nominal|COICOP',
+ 'DB HH SAVINGS': 'Revenues|Households|Disposable income|Nominal',
+ 'DB HH SAVINGS NOMINAL': 'GDP|Country [per capita]',
+ 'DB IMPORTS': 'Trade|Value|Imports',
+ 'DB LABOUR COMPENSATION': 'Value Added|Labour Compensation',
+ 'DB LABOUR FORCE': 'Labour Supply',
+ 'DB NET OPERATING SURPLUS': 'Value Added|Net Operating Surplus',
+ 'DB OTHER FINAL DEMAND': 'Final Demand|Other',
+ 'DB OUTPUT': 'Output',
+ 'DB TAXES PRODUCTION': 'Value Added|Taxes on production',
+ 'DB TRADE BALANCE': 'Trade|Value|Balance',
+ 'DB UNEMPLOYMENT RATE': 'Unemployment|Rate'}
diff --git a/Conversion-Script/Create_Variable_Dict/energy_dict.txt b/Conversion-Script/Create_Variable_Dict/energy_dict.txt
index b024359..3c79d4f 100644
--- a/Conversion-Script/Create_Variable_Dict/energy_dict.txt
+++ b/Conversion-Script/Create_Variable_Dict/energy_dict.txt
@@ -2,9 +2,9 @@
'FE_gas': 'Gas',
'FE_heat': 'Heat',
'FE_hydrogen': 'Hydrogen',
- 'FE_liquid': 'Liquid',
- 'FE_solid_bio': 'Solid|Biomass',
- 'FE_solid_fossil': 'Solid|Fossil',
+ 'FE_liquid': 'Liquids',
+ 'FE_solid_bio': 'Solids|Biomass',
+ 'FE_solid_fossil': 'Solids|Fossil',
'PE_agriculture_products': 'Agriculture Products',
'PE_coal': 'Coal',
'PE_forestry_products': 'Forestry Products',
@@ -17,44 +17,44 @@
'PE_solar': 'Solar',
'PE_waste': 'Waste',
'PE_wind': 'Wind',
- 'PROTRA_CHP_gas_fuels': 'Electricity and Heat|gas fuels|w/o CCS',
- 'PROTRA_CHP_gas_fuels_CCS': 'Electricity and Heat|gas fuels|w/ CCS',
+ 'PROTRA_CHP_gas_fuels': 'Electricity and Heat|Gas fuels|w/o CCS',
+ 'PROTRA_CHP_gas_fuels_CCS': 'Electricity and Heat|Gas fuels|w/ CCS',
'PROTRA_CHP_geothermal_DEACTIVATED': 'Electricity and '
- 'Heat|geothermal|DEACTIVATED',
- 'PROTRA_CHP_liquid_fuels': 'Electricity and Heat|liquid fuels|w/o CCS',
- 'PROTRA_CHP_liquid_fuels_CCS': 'Electricity and Heat|liquid fuels|w/ CCS',
- 'PROTRA_CHP_solid_bio': 'Electricity and Heat|solid|biomass|w/o CCS',
- 'PROTRA_CHP_solid_bio_CCS': 'Electricity and Heat|solid|biomass|w/ CCS',
- 'PROTRA_CHP_solid_fossil': 'Electricity and Heat|solid|fossil|w/o CCS',
- 'PROTRA_CHP_solid_fossil_CCS': 'Electricity and Heat|solid|fossil|w/ CCS',
- 'PROTRA_CHP_waste': 'Electricity and Heat|waste',
- 'PROTRA_HP_gas_fuels': 'Heat|gas fuels',
- 'PROTRA_HP_geothermal': 'Heat|geothermal',
- 'PROTRA_HP_liquid_fuels': 'Heat|liquid fuels',
- 'PROTRA_HP_solar_DEACTIVATED': 'Heat|solar|DEACTIVATED',
- 'PROTRA_HP_solid_bio': 'Heat|solid|biomass',
- 'PROTRA_HP_solid_fossil': 'Heat|solid|fossil',
- 'PROTRA_HP_waste': 'Heat|waste',
- 'PROTRA_PP_gas_fuels': 'Electricity|gas fuels|w/o CCS',
- 'PROTRA_PP_gas_fuels_CCS': 'Electricity|gas fuels|w/ CCS',
- 'PROTRA_PP_geothermal': 'Electricity|geothermal',
- 'PROTRA_PP_hydropower_dammed': 'Electricity|hydro|dammed',
- 'PROTRA_PP_hydropower_run_of_river': 'Electricity|hydro|run of river',
- 'PROTRA_PP_liquid_fuels': 'Electricity|liquid fuels|w/o CCS',
- 'PROTRA_PP_liquid_fuels_CCS': 'Electricity|liquid fuels|w/ CCS',
- 'PROTRA_PP_nuclear': 'Electricity|nuclear',
- 'PROTRA_PP_oceanic': 'Electricity|ocean',
- 'PROTRA_PP_solar_CSP': 'Electricity|solar|CSP',
- 'PROTRA_PP_solar_open_space_PV': 'Electricity|solar|open space|PV',
- 'PROTRA_PP_solar_urban_PV': 'Electricity|solar|urban|PV',
- 'PROTRA_PP_solid_bio': 'Electricity|solid|biomass|w/o CCS',
- 'PROTRA_PP_solid_bio_CCS': 'Electricity|solid|biomass|w/ CCS',
- 'PROTRA_PP_solid_fossil': 'Electricity|solid|fossil|w/o CCS',
- 'PROTRA_PP_solid_fossil_CCS': 'Electricity|solid|fossil|w/ CCS',
- 'PROTRA_PP_waste': 'Electricity|waste|w/o CCS',
- 'PROTRA_PP_waste_CCS': 'Electricity|waste|w/ CCS',
- 'PROTRA_PP_wind_offshore': 'Electricity|wind|offshore',
- 'PROTRA_PP_wind_onshore': 'Electricity|wind|onshore',
+ 'Heat|Geothermal|Deactivated',
+ 'PROTRA_CHP_liquid_fuels': 'Electricity and Heat|Liquid fuels|w/o CCS',
+ 'PROTRA_CHP_liquid_fuels_CCS': 'Electricity and Heat|Liquid fuels|w/ CCS',
+ 'PROTRA_CHP_solid_bio': 'Electricity and Heat|Solid|Biomass|w/o CCS',
+ 'PROTRA_CHP_solid_bio_CCS': 'Electricity and Heat|Solid|Biomass|w/ CCS',
+ 'PROTRA_CHP_solid_fossil': 'Electricity and Heat|Solid|Fossil|w/o CCS',
+ 'PROTRA_CHP_solid_fossil_CCS': 'Electricity and Heat|Solid|Fossil|w/ CCS',
+ 'PROTRA_CHP_waste': 'Electricity and Heat|Waste',
+ 'PROTRA_HP_gas_fuels': 'Heat|Gas fuels',
+ 'PROTRA_HP_geothermal': 'Heat|Geothermal',
+ 'PROTRA_HP_liquid_fuels': 'Heat|Liquid fuels',
+ 'PROTRA_HP_solar_DEACTIVATED': 'Heat|Solar|Deactivated',
+ 'PROTRA_HP_solid_bio': 'Heat|Solid|Biomass',
+ 'PROTRA_HP_solid_fossil': 'Heat|Solid|Fossil',
+ 'PROTRA_HP_waste': 'Heat|Waste',
+ 'PROTRA_PP_gas_fuels': 'Electricity|Gas fuels|w/o CCS',
+ 'PROTRA_PP_gas_fuels_CCS': 'Electricity|Gas fuels|w/ CCS',
+ 'PROTRA_PP_geothermal': 'Electricity|Geothermal',
+ 'PROTRA_PP_hydropower_dammed': 'Electricity|Hydro|Dammed',
+ 'PROTRA_PP_hydropower_run_of_river': 'Electricity|Hydro|Run of River',
+ 'PROTRA_PP_liquid_fuels': 'Electricity|Liquid fuels|w/o CCS',
+ 'PROTRA_PP_liquid_fuels_CCS': 'Electricity|Liquid fuels|w/ CCS',
+ 'PROTRA_PP_nuclear': 'Electricity|Nuclear',
+ 'PROTRA_PP_oceanic': 'Electricity|Ocean',
+ 'PROTRA_PP_solar_CSP': 'Electricity|Solar|Csp',
+ 'PROTRA_PP_solar_open_space_PV': 'Electricity|Solar|PV|Open Land',
+ 'PROTRA_PP_solar_urban_PV': 'Electricity|Solar|PV|Urban',
+ 'PROTRA_PP_solid_bio': 'Electricity|Solid|Biomass|w/o CCS',
+ 'PROTRA_PP_solid_bio_CCS': 'Electricity|Solid|Biomass|w/ CCS',
+ 'PROTRA_PP_solid_fossil': 'Electricity|Solid|Fossil|w/o CCS',
+ 'PROTRA_PP_solid_fossil_CCS': 'Electricity|Solid|Fossil|w/ CCS',
+ 'PROTRA_PP_waste': 'Electricity|Waste|w/o CCS',
+ 'PROTRA_PP_waste_CCS': 'Electricity|Waste|w/ CCS',
+ 'PROTRA_PP_wind_offshore': 'Electricity|Wind|Offshore',
+ 'PROTRA_PP_wind_onshore': 'Electricity|Wind|Onshore',
'PROTRA_blending_gas_fuels': 'Gas Fuels',
'PROTRA_blending_liquid_fuels': 'Liquid Fuels',
'PROTRA_no_process_TI_hydrogen': 'Hydrogen',
@@ -64,6 +64,6 @@
'TO_gas': 'Gas',
'TO_heat': 'Heat',
'TO_hydrogen': 'Hydrogen',
- 'TO_liquid': 'Liquid',
- 'TO_solid_bio': 'Solid Biomass',
- 'TO_solid_fossil': 'Solid Fossil'}
+ 'TO_liquid': 'Liquids',
+ 'TO_solid_bio': 'Solids|Biomass',
+ 'TO_solid_fossil': 'Solids|Fossil'}
diff --git a/Conversion-Script/Create_Variable_Dict/land_dict.txt b/Conversion-Script/Create_Variable_Dict/land_dict.txt
new file mode 100644
index 0000000..f3d0629
--- /dev/null
+++ b/Conversion-Script/Create_Variable_Dict/land_dict.txt
@@ -0,0 +1,12 @@
+{'CROPLAND IRRIGATED': 'Cropland|Irrigated',
+ 'CROPLAND RAINFED': 'Cropland|Rainfed',
+ 'FOREST MANAGED': 'Forest|Managed',
+ 'FOREST PLANTATIONS': 'Forest|Forestry|Harvested Area',
+ 'FOREST PRIMARY': 'Forest|Natural Forest',
+ 'GRASSLAND': 'Grassland',
+ 'OTHER LAND': 'Other',
+ 'SHRUBLAND': 'Shrubland',
+ 'SNOW ICE WATERBODIES': 'Snow and Ice Land',
+ 'SOLAR LAND': 'Built-up Area|Solar',
+ 'URBAN LAND': 'Built-up Area',
+ 'WETLAND': 'Water Ecosystems|Wetlands'}
diff --git a/Conversion-Script/Create_Variable_Dict/sectors_dict.txt b/Conversion-Script/Create_Variable_Dict/sectors_dict.txt
new file mode 100644
index 0000000..44262b8
--- /dev/null
+++ b/Conversion-Script/Create_Variable_Dict/sectors_dict.txt
@@ -0,0 +1,66 @@
+{'ACCOMMODATION': 'Accommodation',
+ 'ANIMALS': 'Animals',
+ 'COKE': 'Coke',
+ 'CONSTRUCTION': 'Construction',
+ 'CROPS': 'Crops',
+ 'DISTRIBUTION_ELECTRICITY': 'Distribution|Electricity',
+ 'DISTRIBUTION_GAS': 'Distribution|Gas',
+ 'EDUCATION': 'Education',
+ 'ELECTRICITY_COAL': 'Electricity|Coal',
+ 'ELECTRICITY_GAS': 'Electricity|Gas',
+ 'ELECTRICITY_HYDRO': 'Electricity|Hydro',
+ 'ELECTRICITY_NUCLEAR': 'Electricity|Nuclear',
+ 'ELECTRICITY_OIL': 'Electricity|Oil',
+ 'ELECTRICITY_OTHER': 'Electricity|Other',
+ 'ELECTRICITY_SOLAR_PV': 'Electricity|Solar|PV',
+ 'ELECTRICITY_SOLAR_THERMAL': 'Electricity|Solar|CSP',
+ 'ELECTRICITY_WIND': 'Electricity|Wind',
+ 'ENTERTAIMENT': 'Entertainment',
+ 'EXTRACTION_GAS': 'Extraction|Gas',
+ 'EXTRACTION_OIL': 'Extraction|Oil',
+ 'EXTRACTION_OTHER_GAS': 'Extraction|Other Gas',
+ 'FINANCE': 'Finance',
+ 'FISHING': 'Fishing',
+ 'FORESTRY': 'Forestry',
+ 'HEALTH': 'Health',
+ 'HYDROGEN_PRODUCTION': 'Hydrogen Production',
+ 'MANUFACTURE_CHEMICAL': 'Manufacture|Chemicals',
+ 'MANUFACTURE_ELECTRICAL_EQUIPMENT': 'Manufacture|Electrical Equipment',
+ 'MANUFACTURE_ELECTRONICS': 'Manufacture|Electronics',
+ 'MANUFACTURE_FOOD': 'Manufacture|Food',
+ 'MANUFACTURE_MACHINERY': 'Manufacture|Machinery',
+ 'MANUFACTURE_METAL_PRODUCTS': 'Manufacture|Metal Products',
+ 'MANUFACTURE_OTHER': 'Manufacture|Other',
+ 'MANUFACTURE_OTHER_NON_METAL': 'Manufacture|Other Non Metals',
+ 'MANUFACTURE_PLASTIC': 'Manufacture|Plastics',
+ 'MANUFACTURE_VEHICLES': 'Manufacture|Vehicles',
+ 'MANUFACTURE_WOOD': 'Manufacture|Wood',
+ 'MINING_AND_MANUFACTURING_ALUMINIUM': 'Mining and Manufacturing|Aluminium',
+ 'MINING_AND_MANUFACTURING_COPPER': 'Mining and Manufacturing|Copper',
+ 'MINING_AND_MANUFACTURING_IRON': 'Mining and Manufacturing|Iron',
+ 'MINING_AND_MANUFACTURING_LEAD_ZINC_TIN': 'Mining and Manufacturing|Lead Zinc '
+ 'Tin',
+ 'MINING_AND_MANUFACTURING_NICKEL': 'Mining and Manufacturing|Nickel',
+ 'MINING_AND_MANUFACTURING_OTHER_METALS': 'Mining and Manufacturing|Other '
+ 'Metals',
+ 'MINING_AND_MANUFACTURING_PRECIOUS_METALS': 'Mining and '
+ 'Manufacturing|Precious Metals',
+ 'MINING_AND_MANUFACTURING_URANIUM_THORIUM': 'Mining and Manufacturing|Uranium '
+ 'Thorium',
+ 'MINING_COAL': 'Mining|Coal',
+ 'MINING_NON_METALS': 'Mining|Non Metals',
+ 'OTHER_SERVICES': 'Other Services',
+ 'PRIVATE_HOUSEHOLDS': 'Private Households',
+ 'PUBLIC_ADMINISTRATION': 'Public Administration',
+ 'REAL_ESTATE': 'Real Estate',
+ 'REFINING': 'Refining',
+ 'STEAM_HOT_WATER': 'Steam Hot Water',
+ 'TELECOMMUNICATIONS': 'Telecommunications',
+ 'TRADE_REPAIR_VEHICLES': 'Trade Repair Vehicles',
+ 'TRANSPORT_AIR': 'Transportation|Aviation',
+ 'TRANSPORT_INLAND_WATER': 'Transportation|Inland Water',
+ 'TRANSPORT_OTHER_LAND': 'Transportation|Other Land',
+ 'TRANSPORT_PIPELINE': 'Transportation|Pipeline',
+ 'TRANSPORT_RAIL': 'Transportation|Rail',
+ 'TRANSPORT_SEA': 'Transportation|Maritime',
+ 'WASTE_MANAGEMENT': 'Waste Management'}
diff --git a/Conversion-Script/Create_Variable_Dict/transport_mode_dict.txt b/Conversion-Script/Create_Variable_Dict/transport_mode_dict.txt
new file mode 100644
index 0000000..8801a4b
--- /dev/null
+++ b/Conversion-Script/Create_Variable_Dict/transport_mode_dict.txt
@@ -0,0 +1,11 @@
+{'AIR DOMESTIC': 'Domestic Aviation',
+ 'AIR INTERNATIONAL': 'International Aviation',
+ 'AIR INTRA EU': 'European Aviation',
+ 'BUS': 'Bus',
+ 'HDV': 'High Duty Vehicle',
+ 'LDV': 'Light Duty Vehicle',
+ 'MARINE': 'Navigation',
+ 'MDV': 'Medium Duty Vehicle',
+ 'MOTORCYCLES 2W 3W': '2W and 3W',
+ 'NMT': 'Bicycling and Walking',
+ 'RAIL': 'Rail'}
diff --git a/Conversion-Script/Create_Variable_Dict/variable_dict.ipynb b/Conversion-Script/Create_Variable_Dict/variable_dict.ipynb
index 05b5d96..babc667 100644
--- a/Conversion-Script/Create_Variable_Dict/variable_dict.ipynb
+++ b/Conversion-Script/Create_Variable_Dict/variable_dict.ipynb
@@ -2,7 +2,7 @@
"cells": [
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 28,
"metadata": {},
"outputs": [],
"source": [
@@ -19,9 +19,111 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 29,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "name": "stderr",
+ "output_type": "stream",
+ "text": [
+ "C:\\Users\\AdGeeds\\AppData\\Roaming\\Python\\Python310\\site-packages\\openpyxl\\styles\\stylesheet.py:226: UserWarning: Workbook contains no default style, apply openpyxl's default\n",
+ " warn(\"Workbook contains no default style, apply openpyxl's default\")\n"
+ ]
+ },
+ {
+ "data": {
+ "text/html": [
+ "
\n",
+ "\n",
+ "
\n",
+ " \n",
+ " \n",
+ " | \n",
+ " ID | \n",
+ " Name | \n",
+ " Hierarchy | \n",
+ " Parent | \n",
+ " Synonyms | \n",
+ "
\n",
+ " \n",
+ " \n",
+ " \n",
+ " 0 | \n",
+ " 0 | \n",
+ " World | \n",
+ " Compare (global) | \n",
+ " World | \n",
+ " NaN | \n",
+ "
\n",
+ " \n",
+ " 1 | \n",
+ " 13 | \n",
+ " Sao Tome and Principe | \n",
+ " Compare (individual countries and regions) | \n",
+ " World | \n",
+ " STP | \n",
+ "
\n",
+ " \n",
+ " 2 | \n",
+ " 14 | \n",
+ " Turkmenistan | \n",
+ " Compare (individual countries and regions) | \n",
+ " World | \n",
+ " TKM | \n",
+ "
\n",
+ " \n",
+ " 3 | \n",
+ " 15 | \n",
+ " Saint Helena | \n",
+ " Compare (individual countries and regions) | \n",
+ " World | \n",
+ " SHN | \n",
+ "
\n",
+ " \n",
+ " 4 | \n",
+ " 16 | \n",
+ " Lithuania | \n",
+ " Compare (individual countries and regions) | \n",
+ " World | \n",
+ " LTU | \n",
+ "
\n",
+ " \n",
+ "
\n",
+ "
"
+ ],
+ "text/plain": [
+ " ID Name Hierarchy \\\n",
+ "0 0 World Compare (global) \n",
+ "1 13 Sao Tome and Principe Compare (individual countries and regions) \n",
+ "2 14 Turkmenistan Compare (individual countries and regions) \n",
+ "3 15 Saint Helena Compare (individual countries and regions) \n",
+ "4 16 Lithuania Compare (individual countries and regions) \n",
+ "\n",
+ " Parent Synonyms \n",
+ "0 World NaN \n",
+ "1 World STP \n",
+ "2 World TKM \n",
+ "3 World SHN \n",
+ "4 World LTU "
+ ]
+ },
+ "execution_count": 29,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"file_path = \"../Variable_Reference/reference.xlsx\" # Update this with the correct path\n",
"\n",
@@ -34,9 +136,56 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 30,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "data": {
+ "text/plain": [
+ "['World',\n",
+ " 'EU27',\n",
+ " 'UK',\n",
+ " 'CHINA',\n",
+ " 'EASOC',\n",
+ " 'INDIA',\n",
+ " 'LATAM',\n",
+ " 'RUSSIA',\n",
+ " 'USMCA',\n",
+ " 'LROW',\n",
+ " 'AUSTRIA',\n",
+ " 'BELGIUM',\n",
+ " 'BULGARIA',\n",
+ " 'CROATIA',\n",
+ " 'CYPRUS',\n",
+ " 'CZECH_REPUBLIC',\n",
+ " 'DENMARK',\n",
+ " 'ESTONIA',\n",
+ " 'FINLAND',\n",
+ " 'FRANCE',\n",
+ " 'GERMANY',\n",
+ " 'GREECE',\n",
+ " 'HUNGARY',\n",
+ " 'IRELAND',\n",
+ " 'ITALY',\n",
+ " 'LATVIA',\n",
+ " 'LITHUANIA',\n",
+ " 'LUXEMBOURG',\n",
+ " 'MALTA',\n",
+ " 'NETHERLANDS',\n",
+ " 'POLAND',\n",
+ " 'PORTUGAL',\n",
+ " 'ROMANIA',\n",
+ " 'SLOVAKIA',\n",
+ " 'SLOVENIA',\n",
+ " 'SPAIN',\n",
+ " 'SWEDEN']"
+ ]
+ },
+ "execution_count": 30,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"# Put the country in list \n",
"country_IPCC_list = country_IPCC_df[\"Name\"].to_list()\n",
@@ -84,9 +233,23 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 31,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Eu27\n",
+ "Uk\n",
+ "Easoc\n",
+ "Latam\n",
+ "Usmca\n",
+ "Lrow\n",
+ "Slovakia\n"
+ ]
+ }
+ ],
"source": [
"# Put the country in lowercase except for the first letter (format used by IPCC for the Countries)\n",
"new_country_Wiliam_list=[]\n",
@@ -105,7 +268,7 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 32,
"metadata": {},
"outputs": [],
"source": [
@@ -124,7 +287,7 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 33,
"metadata": {},
"outputs": [],
"source": [
@@ -142,9 +305,36 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 34,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "data": {
+ "text/plain": [
+ "{'c0c4': 'Age 0-4',\n",
+ " 'c5c9': 'Age 5-9',\n",
+ " 'c10c14': 'Age 10-14',\n",
+ " 'c15c19': 'Age 15-19',\n",
+ " 'c20c24': 'Age 20-24',\n",
+ " 'c25c29': 'Age 25-29',\n",
+ " 'c30c34': 'Age 30-34',\n",
+ " 'c35c39': 'Age 35-39',\n",
+ " 'c40c44': 'Age 40-44',\n",
+ " 'c45c49': 'Age 45-49',\n",
+ " 'c50c54': 'Age 50-54',\n",
+ " 'c55c59': 'Age 55-59',\n",
+ " 'c60c64': 'Age 60-64',\n",
+ " 'c65c69': 'Age 65-69',\n",
+ " 'c70c74': 'Age 70-74',\n",
+ " 'c75c79': 'Age 75-79',\n",
+ " 'cover80': 'Age +80'}"
+ ]
+ },
+ "execution_count": 34,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"# Create the subscript list of the Wiliam model \n",
"number_list= [[0+5*k, 4+5*k] for k in range(16)]\n",
@@ -171,15 +361,39 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 35,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "data": {
+ "text/plain": [
+ "{'CO2': 'CO2',\n",
+ " 'CH4': 'CH4',\n",
+ " 'N2O': 'N2O',\n",
+ " 'PFCs': 'PFC',\n",
+ " 'SF6': 'SF6',\n",
+ " 'HFC134a': 'HFC134a',\n",
+ " 'HFC23': 'HFC23',\n",
+ " 'HFC32': 'HFC32',\n",
+ " 'HFC125': 'HFC125',\n",
+ " 'HFC143a': 'HFC143a',\n",
+ " 'HFC152a': 'HFC152a',\n",
+ " 'HFC227ea': 'HFC227ea',\n",
+ " 'HFC245ca': 'HFC245ca',\n",
+ " 'HFC4310mee': 'HFC43-10'}"
+ ]
+ },
+ "execution_count": 35,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"# Old list of GHGs in Wiliam \n",
"old_ghgs_list = ['CO2', 'CH4', 'N2O', 'PFCs', 'SF6', 'HFC134a', 'HFC23', 'HFC32', 'HFC125', 'HFC143a', 'HFC152a', 'HFC227ea', 'HFC245ca', 'HFC4310mee']\n",
"\n",
"# New list for GHGs \n",
- "new_ghgs_list = ['CO2', 'CH4', 'N2O', 'PFC', 'SF6', 'HFC134a', 'HFC23', 'HFC32', 'HFC125', 'HFC143a', 'HFC152a', 'HFC227ea', 'HFC245ca', 'HFC43-10']\n",
+ "new_ghgs_list = ['CO2', 'CH4', 'N2O', 'PFC', 'SF6', 'HFC134a', 'HFC23', 'HFC32', 'HFC125', 'HFC143a', 'HFC152a', 'HFC227ea', 'HFC245ca', 'HFC4310mee']\n",
"\n",
"\n",
"GHG_dict = dict(zip(old_ghgs_list, new_ghgs_list))\n",
@@ -188,7 +402,7 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 36,
"metadata": {},
"outputs": [],
"source": [
@@ -210,18 +424,35 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 37,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "data": {
+ "text/plain": [
+ "{'TO_elec': 'Electricity',\n",
+ " 'TO_gas': 'Gas',\n",
+ " 'TO_heat': 'Heat',\n",
+ " 'TO_hydrogen': 'Hydrogen',\n",
+ " 'TO_liquid': 'Liquids',\n",
+ " 'TO_solid_bio': 'Solids|Biomass',\n",
+ " 'TO_solid_fossil': 'Solids|Fossil'}"
+ ]
+ },
+ "execution_count": 37,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"energy_sources_new = [\n",
" \"Electricity\",\n",
" \"Gas\",\n",
" \"Heat\",\n",
" \"Hydrogen\",\n",
- " \"Liquid\",\n",
- " \"Solid Biomass\",\n",
- " \"Solid Fossil\"\n",
+ " \"Liquids\",\n",
+ " \"Solids|Biomass\",\n",
+ " \"Solids|Fossil\"\n",
"]\n",
"energy_sources_old = [\n",
" \"TO_elec\",\n",
@@ -238,9 +469,26 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 38,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "data": {
+ "text/plain": [
+ "{'FE_elec': 'Electricity',\n",
+ " 'FE_gas': 'Gas',\n",
+ " 'FE_heat': 'Heat',\n",
+ " 'FE_hydrogen': 'Hydrogen',\n",
+ " 'FE_liquid': 'Liquids',\n",
+ " 'FE_solid_bio': 'Solids|Biomass',\n",
+ " 'FE_solid_fossil': 'Solids|Fossil'}"
+ ]
+ },
+ "execution_count": 38,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"energy_final_old = [\n",
" \"FE_elec\",\n",
@@ -258,9 +506,9 @@
" \"Gas\",\n",
" \"Heat\",\n",
" \"Hydrogen\",\n",
- " \"Liquid\",\n",
- " \"Solid|Biomass\",\n",
- " \"Solid|Fossil\"\n",
+ " \"Liquids\",\n",
+ " \"Solids|Biomass\",\n",
+ " \"Solids|Fossil\"\n",
"]\n",
"\n",
"energy_final_dict= dict(zip(energy_final_old, energy_final_new))\n",
@@ -269,9 +517,31 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 39,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "data": {
+ "text/plain": [
+ "{'PE_agriculture_products': 'Agriculture Products',\n",
+ " 'PE_coal': 'Coal',\n",
+ " 'PE_oil': 'Oil',\n",
+ " 'PE_forestry_products': 'Forestry Products',\n",
+ " 'PE_geothermal': 'Geothermal',\n",
+ " 'PE_hydropower': 'Hydropower',\n",
+ " 'PE_natural_gas': 'Natural Gas',\n",
+ " 'PE_nuclear': 'Nuclear',\n",
+ " 'PE_oceanic': 'Ocean',\n",
+ " 'PE_solar': 'Solar',\n",
+ " 'PE_waste': 'Waste',\n",
+ " 'PE_wind': 'Wind'}"
+ ]
+ },
+ "execution_count": 39,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"input_string = \"PE agriculture products,PE coal,PE oil,PE forestry products,PE geothermal,PE hydropower,PE natural gas,PE nuclear,PE oceanic,PE solar,PE waste,PE wind\"\n",
"\n",
@@ -302,9 +572,56 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 40,
"metadata": {},
- "outputs": [],
+ "outputs": [
+ {
+ "data": {
+ "text/plain": [
+ "['PROTRA_CHP_gas fuels_w/o CCS',\n",
+ " 'PROTRA_CHP_gas fuels_w/ CCS',\n",
+ " 'PROTRA_CHP_geothermal_DEACTIVATED',\n",
+ " 'PROTRA_CHP_liquid fuels_w/o CCS',\n",
+ " 'PROTRA_CHP_liquid fuels_w/ CCS',\n",
+ " 'PROTRA_CHP_solid_fossil_w/o CCS',\n",
+ " 'PROTRA_CHP_solid_fossil_w/ CCS',\n",
+ " 'PROTRA_CHP_waste',\n",
+ " 'PROTRA_CHP_solid_biomass_w/o CCS',\n",
+ " 'PROTRA_CHP_solid_biomass_w/ CCS',\n",
+ " 'PROTRA_HP_gas fuels',\n",
+ " 'PROTRA_HP_solid_biomass',\n",
+ " 'PROTRA_HP_geothermal',\n",
+ " 'PROTRA_HP_liquid fuels',\n",
+ " 'PROTRA_HP_solar_DEACTIVATED',\n",
+ " 'PROTRA_HP_solid_fossil',\n",
+ " 'PROTRA_HP_waste',\n",
+ " 'PROTRA_PP_solid_biomass_w/o CCS',\n",
+ " 'PROTRA_PP_solid_biomass_w/ CCS',\n",
+ " 'PROTRA_PP_gas fuels_w/o CCS',\n",
+ " 'PROTRA_PP_gas fuels_w/ CCS',\n",
+ " 'PROTRA_PP_geothermal',\n",
+ " 'PROTRA_PP_hydro_dammed',\n",
+ " 'PROTRA_PP_hydro_run of river',\n",
+ " 'PROTRA_PP_liquid fuels_w/o CCS',\n",
+ " 'PROTRA_PP_liquid fuels_w/ CCS',\n",
+ " 'PROTRA_PP_nuclear',\n",
+ " 'PROTRA_PP_ocean',\n",
+ " 'PROTRA_PP_solar_CSP',\n",
+ " 'PROTRA_PP_solar_open space_PV',\n",
+ " 'PROTRA_PP_solar_urban_PV',\n",
+ " 'PROTRA_PP_solid_fossil_w/o CCS',\n",
+ " 'PROTRA_PP_solid_fossil_w/ CCS',\n",
+ " 'PROTRA_PP_waste_w/o CCS',\n",
+ " 'PROTRA_PP_waste_w/ CCS',\n",
+ " 'PROTRA_PP_wind_offshore',\n",
+ " 'PROTRA_PP_wind_onshore']"
+ ]
+ },
+ "execution_count": 40,
+ "metadata": {},
+ "output_type": "execute_result"
+ }
+ ],
"source": [
"energy_processes_old = [\n",
" \"PROTRA_CHP_gas_fuels\",\n",
@@ -390,14 +707,14 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 41,
"metadata": {},
"outputs": [],
"source": [
"# Fonction de modification de l'élément\n",
"def modify_element(element):\n",
" # Remplacer les underscores par des espaces et mettre chaque mot en majuscule\n",
- " return \"|\".join([word for word in element.split(\"_\")])\n",
+ " return \"|\".join([word.capitalize() for word in element.split(\"_\")])\n",
"\n",
"\n",
"energy_processes_new = []\n",
@@ -429,15 +746,65 @@
" else : \n",
" new_elem = new_elem + '|' + modify_element(elem[4:])\n",
" energy_processes_new.append(new_elem)\n",
- "\n",
- " \n",
- "energy_processes_dict = dict(zip(energy_processes_old, energy_processes_new))\n",
- "energy_processes_dict"
+ "\n"
]
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 42,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "energy_processes_dict = {\n",
+ " 'PROTRA_CHP_gas_fuels': 'Electricity and Heat|Gas fuels|w/o CCS',\n",
+ " 'PROTRA_CHP_gas_fuels_CCS': 'Electricity and Heat|Gas fuels|w/ CCS',\n",
+ " 'PROTRA_CHP_geothermal_DEACTIVATED': 'Electricity and '\n",
+ " 'Heat|Geothermal|Deactivated',\n",
+ " 'PROTRA_CHP_liquid_fuels': 'Electricity and Heat|Liquid fuels|w/o CCS',\n",
+ " 'PROTRA_CHP_liquid_fuels_CCS': 'Electricity and Heat|Liquid fuels|w/ CCS',\n",
+ " 'PROTRA_CHP_solid_bio': 'Electricity and Heat|Solid|Biomass|w/o CCS',\n",
+ " 'PROTRA_CHP_solid_bio_CCS': 'Electricity and Heat|Solid|Biomass|w/ CCS',\n",
+ " 'PROTRA_CHP_solid_fossil': 'Electricity and Heat|Solid|Fossil|w/o CCS',\n",
+ " 'PROTRA_CHP_solid_fossil_CCS': 'Electricity and Heat|Solid|Fossil|w/ CCS',\n",
+ " 'PROTRA_CHP_waste': 'Electricity and Heat|Waste',\n",
+ " 'PROTRA_HP_gas_fuels': 'Heat|Gas fuels',\n",
+ " 'PROTRA_HP_geothermal': 'Heat|Geothermal',\n",
+ " 'PROTRA_HP_liquid_fuels': 'Heat|Liquid fuels',\n",
+ " 'PROTRA_HP_solar_DEACTIVATED': 'Heat|Solar|Deactivated',\n",
+ " 'PROTRA_HP_solid_bio': 'Heat|Solid|Biomass',\n",
+ " 'PROTRA_HP_solid_fossil': 'Heat|Solid|Fossil',\n",
+ " 'PROTRA_HP_waste': 'Heat|Waste',\n",
+ " 'PROTRA_PP_gas_fuels': 'Electricity|Gas fuels|w/o CCS',\n",
+ " 'PROTRA_PP_gas_fuels_CCS': 'Electricity|Gas fuels|w/ CCS',\n",
+ " 'PROTRA_PP_geothermal': 'Electricity|Geothermal',\n",
+ " 'PROTRA_PP_hydropower_dammed': 'Electricity|Hydro|Dammed',\n",
+ " 'PROTRA_PP_hydropower_run_of_river': 'Electricity|Hydro|Run of River',\n",
+ " 'PROTRA_PP_liquid_fuels': 'Electricity|Liquid fuels|w/o CCS',\n",
+ " 'PROTRA_PP_liquid_fuels_CCS': 'Electricity|Liquid fuels|w/ CCS',\n",
+ " 'PROTRA_PP_nuclear': 'Electricity|Nuclear',\n",
+ " 'PROTRA_PP_oceanic': 'Electricity|Ocean',\n",
+ " 'PROTRA_PP_solar_CSP': 'Electricity|Solar|Csp',\n",
+ " 'PROTRA_PP_solar_open_space_PV': 'Electricity|Solar|PV|Open Land',\n",
+ " 'PROTRA_PP_solar_urban_PV': 'Electricity|Solar|PV|Urban',\n",
+ " 'PROTRA_PP_solid_bio': 'Electricity|Solid|Biomass|w/o CCS',\n",
+ " 'PROTRA_PP_solid_bio_CCS': 'Electricity|Solid|Biomass|w/ CCS',\n",
+ " 'PROTRA_PP_solid_fossil': 'Electricity|Solid|Fossil|w/o CCS',\n",
+ " 'PROTRA_PP_solid_fossil_CCS': 'Electricity|Solid|Fossil|w/ CCS',\n",
+ " 'PROTRA_PP_waste': 'Electricity|Waste|w/o CCS',\n",
+ " 'PROTRA_PP_waste_CCS': 'Electricity|Waste|w/ CCS',\n",
+ " 'PROTRA_PP_wind_offshore': 'Electricity|Wind|Offshore',\n",
+ " 'PROTRA_PP_wind_onshore': 'Electricity|Wind|Onshore',\n",
+ " 'PROTRA_blending_gas_fuels': 'Gas Fuels',\n",
+ " 'PROTRA_blending_liquid_fuels': 'Liquid Fuels',\n",
+ " 'PROTRA_no_process_TI_hydrogen': 'Hydrogen',\n",
+ " 'PROTRA_no_process_TI_solid_bio': 'Solids|Biomass',\n",
+ " 'PROTRA_no_process_TI_solid_fossil': 'Solids|Fossils'\n",
+ "}"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 43,
"metadata": {},
"outputs": [],
"source": [
@@ -461,7 +828,7 @@
},
{
"cell_type": "code",
- "execution_count": null,
+ "execution_count": 44,
"metadata": {},
"outputs": [],
"source": [
@@ -475,6 +842,365 @@
"with open('energy_dict.txt', 'w') as f:\n",
" pprint.pprint(energy_dict, f)"
]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "### Sectors Dictionnary \n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 45,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "sector_list = [\n",
+ " \"CROPS\",\n",
+ " \"ANIMALS\",\n",
+ " \"FORESTRY\",\n",
+ " \"FISHING\",\n",
+ " \"MINING_COAL\",\n",
+ " \"EXTRACTION_OIL\",\n",
+ " \"EXTRACTION_GAS\",\n",
+ " \"EXTRACTION_OTHER_GAS\",\n",
+ " \"MINING_AND_MANUFACTURING_URANIUM_THORIUM\",\n",
+ " \"MINING_AND_MANUFACTURING_IRON\",\n",
+ " \"MINING_AND_MANUFACTURING_COPPER\",\n",
+ " \"MINING_AND_MANUFACTURING_NICKEL\",\n",
+ " \"MINING_AND_MANUFACTURING_ALUMINIUM\",\n",
+ " \"MINING_AND_MANUFACTURING_PRECIOUS_METALS\",\n",
+ " \"MINING_AND_MANUFACTURING_LEAD_ZINC_TIN\",\n",
+ " \"MINING_AND_MANUFACTURING_OTHER_METALS\",\n",
+ " \"MINING_NON_METALS\",\n",
+ " \"MANUFACTURE_FOOD\",\n",
+ " \"MANUFACTURE_WOOD\",\n",
+ " \"COKE\",\n",
+ " \"REFINING\",\n",
+ " \"MANUFACTURE_CHEMICAL\",\n",
+ " \"MANUFACTURE_PLASTIC\",\n",
+ " \"MANUFACTURE_OTHER_NON_METAL\",\n",
+ " \"HYDROGEN_PRODUCTION\",\n",
+ " \"MANUFACTURE_METAL_PRODUCTS\",\n",
+ " \"MANUFACTURE_ELECTRONICS\",\n",
+ " \"MANUFACTURE_ELECTRICAL_EQUIPMENT\",\n",
+ " \"MANUFACTURE_MACHINERY\",\n",
+ " \"MANUFACTURE_VEHICLES\",\n",
+ " \"MANUFACTURE_OTHER\",\n",
+ " \"ELECTRICITY_COAL\",\n",
+ " \"ELECTRICITY_GAS\",\n",
+ " \"ELECTRICITY_NUCLEAR\",\n",
+ " \"ELECTRICITY_HYDRO\",\n",
+ " \"ELECTRICITY_WIND\",\n",
+ " \"ELECTRICITY_OIL\",\n",
+ " \"ELECTRICITY_SOLAR_PV\",\n",
+ " \"ELECTRICITY_SOLAR_THERMAL\",\n",
+ " \"ELECTRICITY_OTHER\",\n",
+ " \"DISTRIBUTION_ELECTRICITY\",\n",
+ " \"DISTRIBUTION_GAS\",\n",
+ " \"STEAM_HOT_WATER\",\n",
+ " \"WASTE_MANAGEMENT\",\n",
+ " \"CONSTRUCTION\",\n",
+ " \"TRADE_REPAIR_VEHICLES\",\n",
+ " \"TRANSPORT_RAIL\",\n",
+ " \"TRANSPORT_OTHER_LAND\",\n",
+ " \"TRANSPORT_PIPELINE\",\n",
+ " \"TRANSPORT_SEA\",\n",
+ " \"TRANSPORT_INLAND_WATER\",\n",
+ " \"TRANSPORT_AIR\",\n",
+ " \"ACCOMMODATION\",\n",
+ " \"TELECOMMUNICATIONS\",\n",
+ " \"FINANCE\",\n",
+ " \"REAL_ESTATE\",\n",
+ " \"OTHER_SERVICES\",\n",
+ " \"PUBLIC_ADMINISTRATION\",\n",
+ " \"EDUCATION\",\n",
+ " \"HEALTH\",\n",
+ " \"ENTERTAIMENT\",\n",
+ " \"PRIVATE_HOUSEHOLDS\"\n",
+ "]\n",
+ "\n",
+ "\n",
+ "\n",
+ "new_sectors_list = [\n",
+ " \"Crops\",\n",
+ " \"Animals\",\n",
+ " \"Forestry\",\n",
+ " \"Fishing\",\n",
+ " \"Mining|Coal\",\n",
+ " \"Extraction|Oil\",\n",
+ " \"Extraction|Gas\",\n",
+ " \"Extraction|Other Gas\",\n",
+ " \"Mining and Manufacturing|Uranium Thorium\",\n",
+ " \"Mining and Manufacturing|Iron\",\n",
+ " \"Mining and Manufacturing|Copper\",\n",
+ " \"Mining and Manufacturing|Nickel\",\n",
+ " \"Mining and Manufacturing|Aluminium\",\n",
+ " \"Mining and Manufacturing|Precious Metals\",\n",
+ " \"Mining and Manufacturing|Lead Zinc Tin\",\n",
+ " \"Mining and Manufacturing|Other Metals\",\n",
+ " \"Mining|Non Metals\",\n",
+ " \"Manufacture|Food\",\n",
+ " \"Manufacture|Wood\",\n",
+ " \"Coke\",\n",
+ " \"Refining\",\n",
+ " \"Manufacture|Chemicals\",\n",
+ " \"Manufacture|Plastics\",\n",
+ " \"Manufacture|Other Non Metals\",\n",
+ " \"Hydrogen Production\",\n",
+ " \"Manufacture|Metal Products\",\n",
+ " \"Manufacture|Electronics\",\n",
+ " \"Manufacture|Electrical Equipment\",\n",
+ " \"Manufacture|Machinery\",\n",
+ " \"Manufacture|Vehicles\",\n",
+ " \"Manufacture|Other\",\n",
+ " \"Electricity|Coal\",\n",
+ " \"Electricity|Gas\",\n",
+ " \"Electricity|Nuclear\",\n",
+ " \"Electricity|Hydro\",\n",
+ " \"Electricity|Wind\",\n",
+ " \"Electricity|Oil\",\n",
+ " \"Electricity|Solar|PV\",\n",
+ " \"Electricity|Solar|CSP\",\n",
+ " \"Electricity|Other\",\n",
+ " \"Distribution|Electricity\",\n",
+ " \"Distribution|Gas\",\n",
+ " \"Steam Hot Water\",\n",
+ " \"Waste Management\",\n",
+ " \"Construction\",\n",
+ " \"Trade Repair Vehicles\",\n",
+ " \"Transportation|Rail\",\n",
+ " \"Transportation|Other Land\",\n",
+ " \"Transportation|Pipeline\",\n",
+ " \"Transportation|Maritime\",\n",
+ " \"Transportation|Inland Water\",\n",
+ " \"Transportation|Aviation\",\n",
+ " \"Accommodation\",\n",
+ " \"Telecommunications\",\n",
+ " \"Finance\",\n",
+ " \"Real Estate\",\n",
+ " \"Other Services\",\n",
+ " \"Public Administration\",\n",
+ " \"Education\",\n",
+ " \"Health\",\n",
+ " \"Entertainment\",\n",
+ " \"Private Households\"\n",
+ "]\n",
+ "\n",
+ "sectors_dict = dict(zip(sector_list, new_sectors_list))\n",
+ "# Save dictionary with pprint\n",
+ "with open('sectors_dict.txt', 'w') as f:\n",
+ " pprint.pprint(sectors_dict, f)\n",
+ " "
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Economy Dashboard Dict"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 46,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "economy_dashboard_list = [\n",
+ " 'DB GDP',\n",
+ " 'DB GVA AGRICULTURE',\n",
+ " 'DB GVA EXTRACTION',\n",
+ " 'DB GVA ENERGY',\n",
+ " 'DB GVA INDUSTRY',\n",
+ " 'DB GVA SERVICES',\n",
+ " 'DB GVA TAXES PRODUCTS TOTAL',\n",
+ " 'DB LABOUR COMPENSATION',\n",
+ " 'DB NET OPERATING SURPLUS',\n",
+ " 'DB CONSUMPTION FIXED CAPITAL',\n",
+ " 'DB TAXES PRODUCTION',\n",
+ " 'DB HH CONSUMPTION',\n",
+ " 'DB GOV CONSUMPTION',\n",
+ " 'DB GROSS FIXED CAPITAL FORMATION',\n",
+ " 'DB OTHER FINAL DEMAND',\n",
+ " 'DB TRADE BALANCE',\n",
+ " 'DB EXPORTS',\n",
+ " 'DB IMPORTS',\n",
+ " 'DB OUTPUT',\n",
+ " 'DB CAPITAL STOCK',\n",
+ " 'DB EMPLOYMENT',\n",
+ " 'DB LABOUR FORCE',\n",
+ " 'DB UNEMPLOYMENT RATE',\n",
+ " 'DB GOV REVENUE',\n",
+ " 'DB GOV EXPENDITURE',\n",
+ " 'DB GOV BALANCE',\n",
+ " 'DB GOV BALANCE TO GDP',\n",
+ " 'DB GOV DEBT',\n",
+ " 'DB GOV DEBT TO GDP',\n",
+ " 'DB HH DISPOSABLE INCOME',\n",
+ " 'DB HH CONSUMPTION COICOP',\n",
+ " 'DB HH SAVINGS',\n",
+ " 'DB HH DISPOSABLE INCOME NOMINAL',\n",
+ " 'DB HH CONSUMPTION COICOP NOMINAL',\n",
+ " 'DB HH SAVINGS NOMINAL',\n",
+ " 'DB GDP PER CAPITA',\n",
+ " 'DB DISPOSABLE INCOME PER CAPITA',\n",
+ " 'DB CONSUMER PRICE INDEX'\n",
+ "]\n",
+ "\n",
+ "new_economy_dashboard_list = [\n",
+ " \"GDP|PPP\",\n",
+ " \"Value Added|Agriculture\",\n",
+ " \"Value Added|Extraction\",\n",
+ " \"Value Added|Industry|Energy\",\n",
+ " \"Value Added|Industry\",\n",
+ " \"Value Added|Services\",\n",
+ " \"Value Added|Taxes on products\",\n",
+ " \"Value Added|Labour Compensation\",\n",
+ " \"Value Added|Net Operating Surplus\",\n",
+ " \"Value Added|Consumption Fixed Capital\",\n",
+ " \"Value Added|Taxes on production\",\n",
+ " \"Expenditure|Household\",\n",
+ " \"Public Consumption\",\n",
+ " \"Capital Formation\",\n",
+ " \"Final Demand|Other\",\n",
+ " \"Trade|Value|Balance\",\n",
+ " \"Trade|Value|Exports\",\n",
+ " \"Trade|Value|Imports\",\n",
+ " \"Output\",\n",
+ " \"Capital Stock\",\n",
+ " \"Employment\",\n",
+ " \"Labour Supply\",\n",
+ " \"Unemployment|Rate\",\n",
+ " \"Revenue|Government\",\n",
+ " \"Expenditure|Government\",\n",
+ " \"Government|Budget Balance\",\n",
+ " \"Government|Budget Balance to GDP\",\n",
+ " \"Debt|Public\",\n",
+ " \"Revenues|Households|Disposable income\",\n",
+ " \"Households|Consumption|COICOP\",\n",
+ " \"Households|Savings|Real\",\n",
+ " \"Revenues|Households|Disposable income|Nominal\",\n",
+ " \"Households|Consumption nominal|COICOP\",\n",
+ " \"Households|Savings\",\n",
+ " \"GDP|Country [per capita]\",\n",
+ " \"Revenue|Households|Disposable [per capita]\",\n",
+ " \"Households|Consumer Price [index]\"\n",
+ "]\n",
+ "\n",
+ "economy_dashboard_dict = dict(zip(economy_dashboard_list, new_economy_dashboard_list))\n",
+ "# Save dictionary with pprint\n",
+ "with open('economy_dashboard_dict.txt', 'w') as f:\n",
+ " pprint.pprint(economy_dashboard_dict, f)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Land Dict\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 47,
+ "metadata": {},
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "12 12\n",
+ "{'CROPLAND RAINFED': 'Cropland|Rainfed', 'CROPLAND IRRIGATED': 'Cropland|Irrigated', 'FOREST MANAGED': 'Forest|Managed', 'FOREST PRIMARY': 'Forest|Natural Forest', 'FOREST PLANTATIONS': 'Forest|Forestry|Harvested Area', 'SHRUBLAND': 'Shrubland', 'GRASSLAND': 'Grassland', 'WETLAND': 'Water Ecosystems|Wetlands', 'URBAN LAND': 'Built-up Area', 'SOLAR LAND': 'Built-up Area|Solar', 'SNOW ICE WATERBODIES': 'Snow and Ice Land', 'OTHER LAND': 'Other'}\n"
+ ]
+ }
+ ],
+ "source": [
+ "land_types = [\n",
+ " \"CROPLAND RAINFED\",\n",
+ " \"CROPLAND IRRIGATED\",\n",
+ " \"FOREST MANAGED\",\n",
+ " \"FOREST PRIMARY\",\n",
+ " \"FOREST PLANTATIONS\",\n",
+ " \"SHRUBLAND\",\n",
+ " \"GRASSLAND\",\n",
+ " \"WETLAND\",\n",
+ " \"URBAN LAND\",\n",
+ " \"SOLAR LAND\",\n",
+ " \"SNOW ICE WATERBODIES\",\n",
+ " \"OTHER LAND\"\n",
+ "]\n",
+ "\n",
+ "new_land_types = [\n",
+ " \"Cropland|Rainfed\",\n",
+ " \"Cropland|Irrigated\",\n",
+ " \"Forest|Managed\",\n",
+ " \"Forest|Natural Forest\",\n",
+ " \"Forest|Forestry|Harvested Area\",\n",
+ " \"Shrubland\",\n",
+ " \"Grassland\",\n",
+ " \"Water Ecosystems|Wetlands\",\n",
+ " \"Built-up Area\",\n",
+ " \"Built-up Area|Solar\",\n",
+ " \"Snow and Ice Land\",\n",
+ " \"Other\"\n",
+ "]\n",
+ "\n",
+ "print(len(land_types), len(new_land_types))\n",
+ "land_dict = dict(zip(land_types, new_land_types))\n",
+ "print(land_dict)\n",
+ "# Save dictionary with pprint\n",
+ "with open('land_dict.txt', 'w') as f:\n",
+ " pprint.pprint(land_dict, f)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "Transport Mode Dict"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 48,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "transportation_categories = [\n",
+ " \"LDV\", # Light-Duty Vehicles\n",
+ " \"MDV\", # Medium-Duty Vehicles\n",
+ " \"HDV\", # Heavy-Duty Vehicles\n",
+ " \"BUS\", # Buses\n",
+ " \"MOTORCYCLES 2W 3W\", # Motorcycles, 2/3 Wheels\n",
+ " \"RAIL\", # Rail transport\n",
+ " \"AIR DOMESTIC\", # Domestic Air transport\n",
+ " \"AIR INTRA EU\", # Intra-European Union Air transport\n",
+ " \"AIR INTERNATIONAL\", # International Air transport\n",
+ " \"MARINE\", # Marine transport\n",
+ " \"NMT\" # Non-Motorized Transport\n",
+ "]\n",
+ "\n",
+ "new_transport_categories = [\n",
+ " \"Light Duty Vehicle\",\n",
+ " \"Medium Duty Vehicle\", \n",
+ " \"High Duty Vehicle\",\n",
+ " \"Bus\",\n",
+ " \"2W and 3W\",\n",
+ " \"Rail\",\n",
+ " \"Domestic Aviation\", \n",
+ " \"European Aviation\", \n",
+ " \"International Aviation\",\n",
+ " \"Navigation\",\n",
+ " \"Bicycling and Walking\"\n",
+ "]\n",
+ "\n",
+ "transport_mode_dict = dict(zip(transportation_categories, new_transport_categories))\n",
+ "# Save dictionary with pprint\n",
+ "with open('transport_mode_dict.txt', 'w') as f:\n",
+ " pprint.pprint(transport_mode_dict, f)"
+ ]
}
],
"metadata": {
@@ -493,7 +1219,7 @@
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
- "version": "3.12.1"
+ "version": "3.10.14"
}
},
"nbformat": 4,
diff --git a/Conversion-Script/Create_Variable_Dict/variable_name_dict.txt b/Conversion-Script/Create_Variable_Dict/variable_name_dict.txt
new file mode 100644
index 0000000..3638e91
--- /dev/null
+++ b/Conversion-Script/Create_Variable_Dict/variable_name_dict.txt
@@ -0,0 +1,14 @@
+{
+ "world_PE_by_commodity|PE_agriculture_products": "Primary Energy|Agriculture Products",
+ "world_PE_by_commodity|PE_coal": "Primary Energy|Coal",
+ "world_PE_by_commodity|PE_oil": "Primary Energy|Oil",
+ "world_PE_by_commodity|PE_forestry_products": "Primary Energy|Forestry Products",
+ "world_PE_by_commodity|PE_geothermal": "Primary Energy|Geothermal",
+ "world_PE_by_commodity|PE_hydropower": "Primary Energy|Hydropower",
+ "world_PE_by_commodity|PE_natural_gas": "Primary Energy|Natural Gas",
+ "world_PE_by_commodity|PE_nuclear": "Primary Energy|Nuclear",
+ "world_PE_by_commodity|PE_oceanic": "Primary Energy|Ocean",
+ "world_PE_by_commodity|PE_solar": "Primary Energy|Solar",
+ "world_PE_by_commodity|PE_waste": "Primary Energy|Waste",
+ "total_PE_by_region": "Primary Energy"
+}
\ No newline at end of file
diff --git a/Conversion-Script/Variable_Reference/Variable_name_IAMC.xlsx b/Conversion-Script/Variable_Reference/Variable_name_IAMC.xlsx
index 8938885..a69ae5d 100644
Binary files a/Conversion-Script/Variable_Reference/Variable_name_IAMC.xlsx and b/Conversion-Script/Variable_Reference/Variable_name_IAMC.xlsx differ
diff --git a/Conversion-Script/translation-one-by-one/Creation_global_dict_helpers.ipynb b/Conversion-Script/translation-one-by-one/Creation_global_dict_helpers.ipynb
new file mode 100644
index 0000000..d64336e
--- /dev/null
+++ b/Conversion-Script/translation-one-by-one/Creation_global_dict_helpers.ipynb
@@ -0,0 +1,826 @@
+{
+ "cells": [
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "import numpy as np\n",
+ "import pandas as pd\n",
+ "import os\n",
+ "import time\n",
+ "import ast\n"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Read normal variables"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "time0 = time.time()\n",
+ "\n",
+ "\n",
+ "def get_last_added_file(folder_path):\n",
+ " # Get a list of all files in the folder\n",
+ " files = os.listdir(folder_path)\n",
+ "\n",
+ " # Filter Excel files\n",
+ " excel_files = [\n",
+ " file\n",
+ " for file in files\n",
+ " if file.endswith(\".xlsx\") or file.endswith(\".xls\") or file.endswith(\".csv\")\n",
+ " ]\n",
+ "\n",
+ " if not excel_files:\n",
+ " return None # No Excel files found\n",
+ " print()\n",
+ " # Sort files by modification time (newest first)\n",
+ " excel_files.sort(\n",
+ " key=lambda x: os.path.getctime(os.path.join(folder_path, x)), reverse=True\n",
+ " )\n",
+ "\n",
+ " # Return the path to the last added Excel file\n",
+ " return os.path.join(folder_path, excel_files[0])\n",
+ "\n",
+ "\n",
+ "def create_folder_if_not_exists(folder_name):\n",
+ " # Get current folder\n",
+ " folder_path = os.getcwd()\n",
+ "\n",
+ " try:\n",
+ " os.makedirs(\"pip\")\n",
+ " print(\"DONE\")\n",
+ " except FileExistsError:\n",
+ " pass\n",
+ " if not os.path.exists(os.path.join(folder_path, folder_name)):\n",
+ " os.makedirs(folder_name)\n",
+ " print(\"Folder '{}' created.\".format(folder_name))\n",
+ " else:\n",
+ " print(\"Folder '{}' already exists.\".format(folder_name))\n",
+ "\n",
+ "\n",
+ "# Folder name to create\n",
+ "folder_name_to_convert = \"File_To_Convert\"\n",
+ "folder_name_converted = \"File_Converted\"\n",
+ "\n",
+ "# Get current folder\n",
+ "folder_path = os.getcwd()\n",
+ "\n",
+ "\n",
+ "# Create new folder\n",
+ "create_folder_if_not_exists(folder_name_converted)\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Get the last upload excel file\n",
+ "real_folder_path = os.path.join(folder_path, folder_name_to_convert)\n",
+ "\n",
+ "last_file = get_last_added_file(real_folder_path)\n",
+ "\n",
+ "\n",
+ "if last_file:\n",
+ " print(\"Last added file:\", last_file)\n",
+ "else:\n",
+ " print(\"No files found in the folder.\")\n",
+ "\n",
+ "# Get the correct naming for the converted file\n",
+ "filename_with_extension = os.path.basename(last_file)\n",
+ "splited_filename_with_extension = os.path.splitext(filename_with_extension)\n",
+ "print(splited_filename_with_extension)\n",
+ "filename = (\n",
+ " splited_filename_with_extension[0]\n",
+ " + \"converted\"\n",
+ " + splited_filename_with_extension[1]\n",
+ ")\n",
+ "\n",
+ "# Possibility to create a thread to run all the code during the wait for the user answer.\n",
+ "# scenario = input(\"Give the name of the scenario\")\n",
+ "scenario = splited_filename_with_extension[0]\n",
+ "\n",
+ "# Read the selected file\n",
+ "if (\n",
+ " splited_filename_with_extension[1] == \".xls\"\n",
+ " or splited_filename_with_extension[1] == \".xlsx\"\n",
+ "):\n",
+ " scenario_variable_df = pd.read_excel(last_file)\n",
+ "elif splited_filename_with_extension[1] == \".csv\":\n",
+ " scenario_variable_df = pd.read_csv(last_file)\n",
+ "\n",
+ "\n",
+ "scenario_variable_df\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Check for duplicate rows\n",
+ "duplicate_rows = scenario_variable_df[scenario_variable_df.duplicated()]\n",
+ "\n",
+ "# Display duplicate rows\n",
+ "print(\"Duplicate Rows:\")\n",
+ "print(duplicate_rows)\n",
+ "\n",
+ "# Count the number of duplicate rows\n",
+ "num_duplicate_rows = duplicate_rows.shape[0]\n",
+ "print(\"Number of Duplicate Rows:\", num_duplicate_rows)\n",
+ "\n",
+ "scenario_variable_df = scenario_variable_df.drop_duplicates()\n",
+ "print(len(scenario_variable_df))"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Rename the column of the file\n",
+ "columns = scenario_variable_df.columns.str.replace(\"Unnamed:\", \"Subscript\")\n",
+ "columns = columns.str.replace(\".\", \" \")\n",
+ "\n",
+ "# Define the string you want in column names\n",
+ "search_string = \"Subscript\"\n",
+ "counter = 0\n",
+ "\n",
+ "for k in range(len(columns)):\n",
+ " if search_string in columns[k]:\n",
+ " columns.values[k] = search_string + \" \" + str(counter)\n",
+ " counter += 1\n",
+ "\n",
+ "\n",
+ "# Create a dictionary using zip() and dictionary comprehension\n",
+ "my_dict = {k: v for k, v in zip(scenario_variable_df.columns[2:6], columns[2:6])}\n",
+ "scenario_variable_df.rename(columns=my_dict, inplace=True)\n",
+ "scenario_variable_df.rename(\n",
+ " columns={\"Time\": \"Variable\", \"Year\": \"Unit\", \"Subscript\": \"Subscript 0\"},\n",
+ " inplace=True,\n",
+ ")\n",
+ "\n",
+ "# Insert the three columns in the right place for IAMC format\n",
+ "scenario_variable_df.insert(0, \"Model\", \"WILIAM\")\n",
+ "scenario_variable_df.insert(1, \"Scenario\", scenario)\n",
+ "scenario_variable_df.insert(2, \"Region\", \"World\")\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Dict used to check if the subscripts are a country\n",
+ "country_dict = {\n",
+ " \"EU27\": 1,\n",
+ " \"UK\": 1,\n",
+ " \"CHINA\": 1,\n",
+ " \"EASOC\": 1,\n",
+ " \"INDIA\": 1,\n",
+ " \"LATAM\": 1,\n",
+ " \"RUSSIA\": 1,\n",
+ " \"USMCA\": 1,\n",
+ " \"LROW\": 1,\n",
+ " \"AUSTRIA\": 1,\n",
+ " \"BELGIUM\": 1,\n",
+ " \"BULGARIA\": 1,\n",
+ " \"CROATIA\": 1,\n",
+ " \"CYPRUS\": 1,\n",
+ " \"CZECH_REPUBLIC\": 1,\n",
+ " \"DENMARK\": 1,\n",
+ " \"ESTONIA\": 1,\n",
+ " \"FINLAND\": 1,\n",
+ " \"FRANCE\": 1,\n",
+ " \"GERMANY\": 1,\n",
+ " \"GREECE\": 1,\n",
+ " \"HUNGARY\": 1,\n",
+ " \"IRELAND\": 1,\n",
+ " \"ITALY\": 1,\n",
+ " \"LATVIA\": 1,\n",
+ " \"LITHUANIA\": 1,\n",
+ " \"LUXEMBOURG\": 1,\n",
+ " \"MALTA\": 1,\n",
+ " \"NETHERLANDS\": 1,\n",
+ " \"POLAND\": 1,\n",
+ " \"PORTUGAL\": 1,\n",
+ " \"ROMANIA\": 1,\n",
+ " \"SLOVAKIA\": 1,\n",
+ " \"SLOVENIA\": 1,\n",
+ " \"SPAIN\": 1,\n",
+ " \"SWEDEN\": 1,\n",
+ "}\n",
+ "\n",
+ "\n",
+ "# Aggregate the subscripts at the end of the variable\n",
+ "def aggregate_variable_name(row, counter):\n",
+ " for k in range(counter):\n",
+ " subscript = row[\"Subscript \" + str(k)]\n",
+ "\n",
+ " if k == 0:\n",
+ " if country_dict.get(subscript) == 1:\n",
+ " # Give the name of the region for that variable\n",
+ " row[\"Region\"] = subscript\n",
+ "\n",
+ " row[\"Subscript 0\"] = np.nan\n",
+ " continue\n",
+ "\n",
+ " if not pd.isnull(subscript):\n",
+ " row[\"Variable\"] = row[\"Variable\"] + \"|\" + subscript\n",
+ "\n",
+ " return row\n",
+ "\n",
+ "\n",
+ "# Apply the previous function on all the lines\n",
+ "scenario_variable_df = scenario_variable_df.apply(\n",
+ " aggregate_variable_name, args=(counter,), axis=1\n",
+ ")\n",
+ "\n",
+ "# Remove the subscript columns once they have been added at the end of the variable name\n",
+ "drop_columns_list = [\"Subscript \" + str(k) for k in range(counter)]\n",
+ "scenario_variable_df.drop(columns=drop_columns_list, inplace=True)\n",
+ "\n",
+ "scenario_variable_df\n"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Read Transform variables "
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Get the last upload excel file\n",
+ "real_folder_path= os.path.join(folder_path , folder_name_to_convert)\n",
+ "\n",
+ "last_file = get_last_added_file(real_folder_path)\n",
+ "\n",
+ "\n",
+ "if last_file:\n",
+ " print(\"Last added file:\", last_file)\n",
+ "else:\n",
+ " print(\"No files found in the folder.\")\n",
+ "\n",
+ "# Get the correct naming for the converted file \n",
+ "filename_with_extension = os.path.basename(last_file)\n",
+ "splited_filename_with_extension = os.path.splitext(filename_with_extension)\n",
+ "print(splited_filename_with_extension)\n",
+ "filename = splited_filename_with_extension[0] + 'converted' + splited_filename_with_extension[1]\n",
+ "\n",
+ "# Possibility to create a thread to run all the code during the wait for the user answer. \n",
+ "# scenario = input(\"Give the name of the scenario\")\n",
+ "scenario = splited_filename_with_extension[0]\n",
+ "\n",
+ "# Read the selected file \n",
+ "if splited_filename_with_extension[1] == '.xls' or splited_filename_with_extension[1] == '.xlsx':\n",
+ " scenario_variable_2_df = pd.read_excel(last_file)\n",
+ "elif splited_filename_with_extension[1] == '.csv': \n",
+ " scenario_variable_2_df = pd.read_csv(last_file)\n",
+ "\n",
+ "\n",
+ "scenario_variable_2_df"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#Rename the column of the file \n",
+ "columns = scenario_variable_2_df.columns.str.replace('Unnamed:', 'Subscript')\n",
+ "columns = columns.str.replace('.', ' ')\n",
+ "\n",
+ "# Define the string you want in column names\n",
+ "search_string = 'Subscript'\n",
+ "counter=0 \n",
+ "\n",
+ "for k in range(len(columns)): \n",
+ " if search_string in columns[k]: \n",
+ " columns.values[k]= search_string + ' ' + str(counter)\n",
+ " counter+=1\n",
+ "\n",
+ "\n",
+ "\n",
+ "# Create a dictionary using zip() and dictionary comprehension\n",
+ "my_dict = {k: v for k, v in zip(scenario_variable_2_df.columns[2:6], columns[2:6])}\n",
+ "scenario_variable_2_df.rename(columns=my_dict, inplace=True)\n",
+ "scenario_variable_2_df.rename(columns={\"Time\": \"Variable\", \"Year\": \"Unit\", \"Subscript\":\"Subscript 0\"}, inplace=True)\n",
+ "\n",
+ "\n",
+ "\n",
+ "# Insert the three columns in the right place for IAMC format\n",
+ "scenario_variable_2_df.insert(0, 'Model', \"WILIAM\")\n",
+ "scenario_variable_2_df.insert(1, 'Scenario', scenario)\n",
+ "scenario_variable_2_df.insert(2,\"Region\",\"World\")\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Check for duplicate rows\n",
+ "duplicate_rows = scenario_variable_2_df[scenario_variable_2_df.duplicated()]\n",
+ "\n",
+ "# Display duplicate rows\n",
+ "print(\"Duplicate Rows:\")\n",
+ "print(duplicate_rows)\n",
+ "\n",
+ "# Count the number of duplicate rows\n",
+ "num_duplicate_rows = duplicate_rows.shape[0]\n",
+ "print(\"Number of Duplicate Rows:\", num_duplicate_rows)\n",
+ "\n",
+ "scenario_variable_2_df = scenario_variable_2_df.drop_duplicates()\n",
+ "print(len(scenario_variable_2_df))\n",
+ "\n",
+ "# Read the CSV file into a pandas DataFrame\n",
+ "data_name_df = pd.read_excel(\"../Variable_Reference/Variable_name_IAMC.xlsx\")\n",
+ "# Remplacer les tirets du bas par des espaces dans la colonne\n",
+ "# data_name_df['WILIAM_variable'] = data_name_df['WILIAM_variable'].str.replace('_', ' ')\n",
+ "# Drop rows with NaN values which corresponds to values not conserv for the final upload of data in IAMC format\n",
+ "data_name_df.dropna(subset=[\"IAMC_variable\"], inplace=True)\n",
+ "data_name_df"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Create a dict with Wiliam's name as key, IAMC's name as value\n",
+ "IAMC_WILIAM_name_dict = data_name_df.set_index('WILIAM_variable')['IAMC_variable'].to_dict()\n",
+ "print(IAMC_WILIAM_name_dict)\n",
+ "# Replace the variable name used in William to the ones used for IAMC format. \n",
+ "scenario_variable_2_df['Variable']= scenario_variable_2_df['Variable'].replace(IAMC_WILIAM_name_dict)\n",
+ "\n",
+ "# Keep only the rows where the value in column 'Variable' belongs to the list of wanted values \n",
+ "variable_required_list = data_name_df['IAMC_variable'].to_list()\n",
+ "# scenario_variable_df = scenario_variable_df[scenario_variable_df['Variable'].isin(variable_required_list)]\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "variables_used_list = scenario_variable_2_df['Variable'].to_list()\n",
+ "variables_required_not_in = list(set(variable_required_list) - set(variables_used_list))\n",
+ "print('The missing variable in the export dataset are the following:', variables_required_not_in)\n",
+ "print('The number of missing varibles is ', len(variables_required_not_in))"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Open the text file containing the energy dictionary\n",
+ "with open('../Create_Variable_Dict/energy_dict.txt', 'r') as f:\n",
+ " # Read the contents of the file\n",
+ " energy_dict_str = f.read()\n",
+ "\n",
+ "# Convert the string representation of the dictionary back to a dictionary object\n",
+ "energy_dict = ast.literal_eval(energy_dict_str)\n",
+ "\n",
+ "\n",
+ "# Open the text file containing the rest dictionary\n",
+ "with open('../Create_Variable_Dict/rest_dict.txt', 'r') as f:\n",
+ " # Read the contents of the file\n",
+ " rest_dict_str = f.read()\n",
+ "\n",
+ "# Convert the string representation of the dictionary back to a dictionary object\n",
+ "rest_dict = ast.literal_eval(rest_dict_str)\n",
+ "\n",
+ "\n",
+ "# Open the text file containing the sectors dictionary\n",
+ "with open('../Create_Variable_Dict/sectors_dict.txt', 'r') as f:\n",
+ " # Read the contents of the file\n",
+ " sectors_str = f.read()\n",
+ "\n",
+ "# Convert the string representation of the dictionary back to a dictionary object\n",
+ "sectors_dict = ast.literal_eval(sectors_str)\n",
+ "\n",
+ "# Open the text file containing the dictionary\n",
+ "with open('../Create_Variable_Dict/country_dict.txt', 'r') as f:\n",
+ " # Read the contents of the file\n",
+ " dict_str = f.read()\n",
+ "\n",
+ "# Convert the string representation of the dictionary back to a dictionary object\n",
+ "country_Wiliam_dict = ast.literal_eval(dict_str)\n",
+ "\n",
+ "# Open the text file containing the dictionary\n",
+ "with open('../Create_Variable_Dict/economy_dashboard_dict.txt', 'r') as f:\n",
+ " # Read the contents of the file\n",
+ " economy_dashboard_str = f.read()\n",
+ "\n",
+ "# Convert the string representation of the dictionary back to a dictionary object\n",
+ "economy_dashboard_dict = ast.literal_eval(economy_dashboard_str)\n",
+ "\n",
+ "# Replace the region name by the ones adapted for Wiliam. \n",
+ "scenario_variable_2_df['Region'] = scenario_variable_2_df['Region'].replace(country_Wiliam_dict)\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Dict used to check if the subscripts are a country\n",
+ "country_dict = {\n",
+ " \"EU27\": 1,\n",
+ " \"UK\": 1,\n",
+ " \"CHINA\": 1,\n",
+ " \"EASOC\": 1,\n",
+ " \"INDIA\": 1,\n",
+ " \"LATAM\": 1,\n",
+ " \"RUSSIA\": 1,\n",
+ " \"USMCA\": 1,\n",
+ " \"LROW\": 1,\n",
+ " \"AUSTRIA\": 1,\n",
+ " \"BELGIUM\": 1,\n",
+ " \"BULGARIA\": 1,\n",
+ " \"CROATIA\": 1,\n",
+ " \"CYPRUS\": 1,\n",
+ " \"CZECH_REPUBLIC\": 1,\n",
+ " \"DENMARK\": 1,\n",
+ " \"ESTONIA\": 1,\n",
+ " \"FINLAND\": 1,\n",
+ " \"FRANCE\": 1,\n",
+ " \"GERMANY\": 1,\n",
+ " \"GREECE\": 1,\n",
+ " \"HUNGARY\": 1,\n",
+ " \"IRELAND\": 1,\n",
+ " \"ITALY\": 1,\n",
+ " \"LATVIA\": 1,\n",
+ " \"LITHUANIA\": 1,\n",
+ " \"LUXEMBOURG\": 1,\n",
+ " \"MALTA\": 1,\n",
+ " \"NETHERLANDS\": 1,\n",
+ " \"POLAND\": 1,\n",
+ " \"PORTUGAL\": 1,\n",
+ " \"ROMANIA\": 1,\n",
+ " \"SLOVAKIA\": 1,\n",
+ " \"SLOVENIA\": 1,\n",
+ " \"SPAIN\": 1,\n",
+ " \"SWEDEN\": 1,\n",
+ "}\n",
+ "\n",
+ "\n",
+ "\n",
+ "\n",
+ "# Aggregate the subscripts at the end of the variable\n",
+ "def aggregate_variable_name(row, counter):\n",
+ " for k in range(counter):\n",
+ " subscript = row[\"Subscript \" + str(k)]\n",
+ "\n",
+ " if k == 0:\n",
+ " if country_dict.get(subscript) == 1:\n",
+ " # Give the name of the region for that variable\n",
+ " row[\"Region\"] = subscript\n",
+ "\n",
+ " row[\"Subscript 0\"] = np.nan\n",
+ " continue\n",
+ "\n",
+ " if not pd.isnull(subscript):\n",
+ " if energy_dict.get(subscript, None):\n",
+ " subscript = energy_dict[subscript]\n",
+ " elif rest_dict.get(subscript, None):\n",
+ " subscript = rest_dict[subscript]\n",
+ " elif sectors_dict.get(subscript, None):\n",
+ " subscript = sectors_dict[subscript]\n",
+ " elif economy_dashboard_dict.get(subscript, None):\n",
+ " subscript = economy_dashboard_dict[subscript]\n",
+ "\n",
+ " row[\"Variable\"] = row[\"Variable\"] + \"|\" + subscript\n",
+ "\n",
+ " return row\n",
+ "\n",
+ "\n",
+ "# Apply the previous function on all the lines\n",
+ "scenario_variable_2_df = scenario_variable_2_df.apply(\n",
+ " aggregate_variable_name, args=(counter,), axis=1\n",
+ ")\n",
+ "\n",
+ "# Remove the subscript columns once they have been added at the end of the variable name\n",
+ "drop_columns_list = [\"Subscript \" + str(k) for k in range(counter)]\n",
+ "scenario_variable_2_df.drop(columns=drop_columns_list, inplace=True)\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# List with the words in uppercase which will not be capitalized by the next functions\n",
+ "upper_word_list = ['CO2', 'CH4', 'N2O', 'PFC', 'SF6', 'HFC134a', 'HFC23', 'HFC32', 'HFC125', 'HFC143a', 'HFC152a', 'HFC227ea', 'HFC245ca', 'HFC43-10', 'HFC', 'w/o CCS' ,'w/ CCS', 'PV', 'CSP', 'AFOLU', 'CO2eq', 'EROI', 'PV', 'CSP','ICE_gasoline','ICE_diesel', 'ICE_gas', 'ICE_LPG', 'BEV', 'PHEV', 'HEV', 'FCEV', 'EV', 'HPV', 'LMO', 'NMC622', 'NMC811', 'NCA', 'LFP', 'LDV','MDV','HDV','NMT','GDP', 'PPP']\n",
+ "vehicule_list = ['gasoline', 'gas' , 'diesel']\n",
+ "\n",
+ "# Change the format of the string to respect IAMC's format\n",
+ "def transform_string(s):\n",
+ " # Split the string into words\n",
+ " if pd.isnull(s): \n",
+ " return s\n",
+ " words = s.split('|')\n",
+ "\n",
+ " capitalized_words = []\n",
+ " # Capitalize the first letter of each word\n",
+ " for word in words: \n",
+ " if word not in upper_word_list:\n",
+ " new_word_list = word.split('_')\n",
+ " new_word_list = [new_word.capitalize() for new_word in new_word_list] \n",
+ " capitalized_words += [' '.join(new_word_list) + '|']\n",
+ " else: \n",
+ " new_word_list = word.split('_')\n",
+ " capitalized_words += [new_word + '|' if new_word in vehicule_list else new_word.capitalize() + '|' for new_word in new_word_list]\n",
+ " \n",
+ " # Join the words with spaces\n",
+ " transformed_string = ''.join(capitalized_words)\n",
+ "\n",
+ " result = ''\n",
+ " capitalize_next=False\n",
+ " # Capitalize the letter after each space\n",
+ " for char in transformed_string[:-1]:\n",
+ " if char == ' ' or char == '-':\n",
+ " capitalize_next = True\n",
+ " result += char\n",
+ " elif capitalize_next:\n",
+ " result += char.upper()\n",
+ " capitalize_next = False\n",
+ " else:\n",
+ " result += char\n",
+ " \n",
+ " \n",
+ " return result\n",
+ "\n",
+ "# Capitalize each variable's name\n",
+ "scenario_variable_2_df['Variable'] = scenario_variable_2_df['Variable'].apply(transform_string)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Make modifications on some variables"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Select rows with the name 'Emission'\n",
+ "emission_rows = scenario_variable_2_df[scenario_variable_2_df['Variable'].str.contains('Emission')]\n",
+ "emission_name_old = emission_rows['Variable'].to_list()\n",
+ "# List of Greenhouses Gases used in Wiliam \n",
+ "# We differentiate the treatment of HFC and others GHGs because they are handle differently in IAMC Format. \n",
+ "GHGs_to_check = ['CH4', 'N2O', 'PFC', 'SF6','CO2']\n",
+ "HFC_list = ['HFC134a', 'HFC23', 'HFC32', 'HFC125', 'HFC143a', 'HFC152a', 'HFC227ea', 'HFC245ca', 'HFC43-10']\n",
+ "\n",
+ "\n",
+ "# Iterate over the rows to create the name and the unit of emissions correctly. \n",
+ "# The new list of variables and unit is then updated to the real dataframe.\n",
+ "variable_list = []\n",
+ "unit_list = []\n",
+ "\n",
+ "for row_index, row in emission_rows[['Variable','Unit']].iterrows():\n",
+ " specific_word = 'Emissions'\n",
+ " ghg_bool = False\n",
+ " for string in GHGs_to_check:\n",
+ " \n",
+ " if string in row['Variable']:\n",
+ " \n",
+ " index_emission = row['Variable'].find('Emissions') + len(specific_word)\n",
+ " index_gas = row['Variable'].find(string)\n",
+ " row['Variable'] = row['Variable'][:index_emission] + '|' + string + row['Variable'][index_emission:index_gas-1] + row['Variable'][index_gas+len(string):] \n",
+ " ghg = string\n",
+ " ghg_bool = True\n",
+ " \n",
+ " break\n",
+ " \n",
+ " for string in HFC_list:\n",
+ " if string in row['Variable']:\n",
+ " \n",
+ " index_emission = row['Variable'].find('Emissions') + len(specific_word)\n",
+ " index_gas = row['Variable'].find(string)\n",
+ " row['Variable'] = row['Variable'][:index_emission] + '|HFC|' + string + row['Variable'][index_emission:index_gas-1] + row['Variable'][index_gas+len(string):]\n",
+ " \n",
+ " break\n",
+ " index_year = row['Unit'].find('/yr')\n",
+ " if row['Unit'] == 'Mt/yr' or row['Unit'] == 'Gt/yr':\n",
+ " if ghg_bool: \n",
+ " row['Unit'] = row['Unit'][:index_year] + ' ' + ghg + row['Unit'][index_year:]\n",
+ " else : \n",
+ " row['Unit'] = row['Unit'][:index_year] + ' ' + string + row['Unit'][index_year:]\n",
+ " variable_list.append(row['Variable'])\n",
+ " unit_list.append(row['Unit'])\n",
+ "\n",
+ "indexes = emission_rows.index\n",
+ "\n",
+ "# Assign new values to specific rows in the column for the Variable and Unit \n",
+ "scenario_variable_2_df.loc[indexes, 'Variable'] = variable_list\n",
+ "scenario_variable_2_df.loc[indexes, 'Unit'] = unit_list"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Change Primary Energy Naming\n",
+ "# Select the rows where the primary energy word \n",
+ "energy_rows = scenario_variable_2_df[scenario_variable_2_df['Variable'].str.contains('Per Capita')]\n",
+ "\n",
+ "\n",
+ "energy_name_old = energy_rows['Variable'].to_list()\n",
+ "\n",
+ "# Function to move the matched string after the specific word\n",
+ "def move_crochets(s):\n",
+ " specific_word_1 = '[per capita]'\n",
+ " specific_word_2 = '[intensity]'\n",
+ " specific_word_3 = '[share]'\n",
+ " \n",
+ " if specific_word_1 in s:\n",
+ " index_emission = s.find(specific_word_1) \n",
+ " \n",
+ " s = s[:index_emission-1] + s[index_emission+len(specific_word_1):] + specific_word_1\n",
+ " \n",
+ " if specific_word_2 in s:\n",
+ " index_emission = s.find(specific_word_2) \n",
+ " \n",
+ " s = s[:index_emission-1] + s[index_emission+len(specific_word_2):] + '[Intensity]'\n",
+ " \n",
+ " if specific_word_3 in s:\n",
+ " index_emission = s.find(specific_word_3) \n",
+ " \n",
+ " s = s[:index_emission-1] + s[index_emission+len(specific_word_1):] + '[Share]'\n",
+ "\n",
+ " return s\n",
+ "\n",
+ "# Apply the function to the 'Variable' column\n",
+ "energy_rows['Variable'] = energy_rows['Variable'].apply(move_crochets)\n",
+ "energy_name_new = energy_rows['Variable'].to_list()\n",
+ "\n",
+ "energy_per_capita_dict = dict(zip(energy_name_old, energy_name_new))\n",
+ "\n",
+ "scenario_variable_2_df['Variable'] = scenario_variable_2_df['Variable'].replace(energy_per_capita_dict)\n",
+ "scenario_variable_2_df['Variable'] = scenario_variable_2_df['Variable'].apply(move_crochets)\n"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# Change Secondary Energy Naming \n",
+ "secondary_energy_rows = scenario_variable_2_df[scenario_variable_2_df['Variable'].str.contains('Secondary Energy')]\n",
+ "\n",
+ "\n",
+ "# Change Secondary Energy Naming \n",
+ "# Select the rows for Primary Energy Price \n",
+ "price_energy_rows = scenario_variable_2_df[scenario_variable_2_df['Variable'].str.contains('Price')]\n",
+ "price_energy_rows = price_energy_rows[price_energy_rows['Variable'].str.contains('Primary Energy')]\n",
+ "price_energy_rows\n",
+ "\n",
+ "def remove_characters_between_indices(input_string, start_index, end_index):\n",
+ " \"\"\"\n",
+ " Remove characters between two given indices of a string.\n",
+ "\n",
+ " Args:\n",
+ " - input_string (str): The original string.\n",
+ " - start_index (int): The index of the first character to remove (inclusive).\n",
+ " - end_index (int): The index of the last character to remove (inclusive).\n",
+ "\n",
+ " Returns:\n",
+ " - str: The modified string with characters removed between the specified indices.\n",
+ " \"\"\"\n",
+ " if start_index >= end_index:\n",
+ " return input_string # Return the original string if start index is greater than or equal to end index\n",
+ " \n",
+ " # Ensure indices are within the range of the string\n",
+ " start_index = max(start_index, 0)\n",
+ " end_index = min(end_index, len(input_string) - 1)\n",
+ " \n",
+ " # Construct the new string by concatenating substrings before and after the characters to be removed\n",
+ " return input_string[:start_index] + input_string[end_index + 1:]\n",
+ "\n",
+ "def remove_string_between_pipe(input_string):\n",
+ " \"\"\"\n",
+ " Remove the string between the second and third '|' characters in the input string.\n",
+ "\n",
+ " Args:\n",
+ " - input_string (str): The original string.\n",
+ "\n",
+ " Returns:\n",
+ " - str: The modified string with the content between '|' characters removed.\n",
+ " \"\"\"\n",
+ " second_occurrence = input_string.find('|', input_string.find('|') + 1)\n",
+ " third_occurrence = input_string.find('|', second_occurrence + 1)-1\n",
+ " \n",
+ " # Remove characters between the '|' characters using the previous function\n",
+ " result = remove_characters_between_indices(input_string, second_occurrence, third_occurrence)\n",
+ "\n",
+ " # Remove CCS extension because it is not relevant \n",
+ " result = result.replace('|w/ CCS', '').replace('|w/o CCS', '')\n",
+ " \n",
+ " return result\n",
+ "\n",
+ "price_energy_rows['Variable'] = price_energy_rows['Variable'].apply(remove_string_between_pipe)\n",
+ "indexes = price_energy_rows.index\n",
+ "\n",
+ "# Assign new values to specific rows in the column for the Variable and Unit \n",
+ "scenario_variable_2_df.loc[indexes, 'Variable'] = price_energy_rows['Variable']"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "import csv\n",
+ "# Remove the duplication on the variable column \n",
+ "scenario_variable_df = scenario_variable_df.drop_duplicates(subset=[\"Variable\"])\n",
+ "print(len(scenario_variable_df))\n",
+ "\n",
+ "# Step 1: Get the column of old name\n",
+ "data_first_column = scenario_variable_df[\"Variable\"].to_list()\n",
+ "\n",
+ "\n",
+ "# Remove the duplication of the Variable column except when the region is 'World'\n",
+ "# Assign a temporary index column to keep track of the original order\n",
+ "scenario_variable_2_df['temp_index'] = scenario_variable_2_df.index\n",
+ "\n",
+ "\n",
+ "# Drop duplicates based on 'Variable' for non-'World' rows\n",
+ "non_world_rows = scenario_variable_2_df.drop_duplicates(subset='Variable')\n",
+ "\n",
+ "\n",
+ "\n",
+ "# Step 2: Get the column of old name\n",
+ "data_second_column = non_world_rows[\"Variable\"].to_list()\n",
+ "print(len(data_second_column))\n",
+ "\n",
+ "\n",
+ "\n",
+ "# Write the new data along with the existing data\n",
+ "with open(\"example.csv\", \"w\", newline=\"\") as csvfile:\n",
+ " csvwriter = csv.writer(csvfile)\n",
+ " for k in range(len(data_second_column)):\n",
+ " csvwriter.writerow([data_first_column[k], data_second_column[k]])\n",
+ " for k in range(len(data_second_column), len(data_first_column)): \n",
+ " csvwriter.writerow([data_first_column[k]])\n"
+ ]
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "IAMC_format",
+ "language": "python",
+ "name": "python3"
+ },
+ "language_info": {
+ "codemirror_mode": {
+ "name": "ipython",
+ "version": 3
+ },
+ "file_extension": ".py",
+ "mimetype": "text/x-python",
+ "name": "python",
+ "nbconvert_exporter": "python",
+ "pygments_lexer": "ipython3",
+ "version": "3.10.14"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 2
+}
diff --git a/Final_script/Geeds.jpg b/Final_script/Geeds.jpg
new file mode 100644
index 0000000..a522e81
Binary files /dev/null and b/Final_script/Geeds.jpg differ
diff --git a/Final_script/report_pdf.py b/Final_script/report_pdf.py
new file mode 100644
index 0000000..6a452a1
--- /dev/null
+++ b/Final_script/report_pdf.py
@@ -0,0 +1,23 @@
+# Create a PDF class
+from fpdf import FPDF
+
+class PDFReport(FPDF):
+
+
+ def header(self):
+ # Logo
+ self.image('Geeds.jpg', 10, 8, 33)
+ # Arial bold 15
+ self.set_font('Arial', 'B', 15)
+ # Move to the right
+ self.cell(80)
+ # Title
+ self.cell(30, 10, 'Report Scenario', 1, 0, 'C')
+ # Line break
+ self.ln(20)
+
+ def footer(self):
+ # Add page number at the bottom of each page
+ self.set_y(-15)
+ self.set_font("Arial", "I", 8)
+ self.cell(0, 10, f"Page {self.page_no()}", align="C")
diff --git a/Final_script/translation.py b/Final_script/translation.py
new file mode 100644
index 0000000..395cdb7
--- /dev/null
+++ b/Final_script/translation.py
@@ -0,0 +1,382 @@
+import numpy as np
+import pandas as pd
+import os
+import ast
+import pyam
+import matplotlib.pyplot as plt
+import report_pdf
+import argparse
+import translation_helpers
+
+
+def get_last_added_file(folder_path):
+ # Get a list of all files in the folder
+ files = os.listdir(folder_path)
+
+ # Filter Excel files
+ excel_files = [
+ file
+ for file in files
+ if file.endswith(".xlsx") or file.endswith(".xls") or file.endswith(".csv")
+ ]
+
+ if not excel_files:
+ return None # No Excel files found
+ print()
+ # Sort files by modification time (newest first)
+ excel_files.sort(
+ key=lambda x: os.path.getctime(os.path.join(folder_path, x)), reverse=True
+ )
+
+ # Return the path to the last added Excel file
+ return os.path.join(folder_path, excel_files[0])
+
+
+def create_folder_if_not_exists(folder_name):
+ # Get current folder
+ folder_path = os.getcwd()
+
+ try:
+ os.makedirs("pip")
+ print("DONE")
+ except FileExistsError:
+ pass
+ if not os.path.exists(os.path.join(folder_path, folder_name)):
+ os.makedirs(folder_name)
+ print("Folder '{}' created.".format(folder_name))
+ else:
+ print("Folder '{}' already exists.".format(folder_name))
+
+
+# Aggregate the subscripts at the end of the variable
+def aggregate_subscript_variable_name(row, counter, existing_country_Wiliam_dict, country_dict):
+ for k in range(counter):
+ subscript = row["Subscript " + str(k)]
+
+ if k == 0:
+ if existing_country_Wiliam_dict.get(subscript) == 1:
+ # Give the name of the region for that variable
+ row["Region"] = country_dict.get(subscript)
+
+ row["Subscript 0"] = np.nan
+ continue
+
+ if not pd.isnull(subscript):
+ row["Variable"] = row["Variable"] + "|" + subscript
+
+ return row
+
+# Function to replace values and track missing ones
+def replace_and_track(value, variable_name_dict,missing_variable):
+ if value in variable_name_dict:
+ return variable_name_dict[value]
+ else:
+ missing_variable.append(value)
+ return value
+
+# Function to create the aggregations of each row
+def aggregate_rows(df, aggregations):
+ # List of new rows
+ new_rows = []
+ # Get the list of all regions
+ regions = df['Region'].unique()
+
+ for region in regions:
+ # Filter the dataframe on the actual region
+ df_region = df[df['Region'] == region]
+ for names, new_name in aggregations.items():
+ # Check if all the names are present
+ if all(name in df_region["Variable"].values for name in names):
+ # Filter the dataframe with the names of interest
+ df_subset = df_region[df_region["Variable"].isin(names)]
+
+ # Compute the sum of the aggregation of the value
+ summed_values = df_subset.drop(columns=["Variable", "Unit", "Model", "Scenario", "Region"]).sum()
+
+ # Create the new aggreagted rows
+ new_row = {
+ "Model": df_subset["Model"].iloc[0],
+ "Scenario": df_subset["Scenario"].iloc[0],
+ "Region": region,
+ "Variable": new_name,
+ "Unit": df_subset["Unit"].iloc[0],
+ ** summed_values.to_dict(),
+ }
+ new_rows.append(new_row)
+
+ # Create a dataframe with the new rows
+ new_df = pd.DataFrame(new_rows)
+
+ # Concatenate the two dataframe to get the aggregated rows
+ df_final = pd.concat([df, new_df], ignore_index=True)
+
+ return df_final
+
+def open_dict(dict_filename):
+ # Open the text file containing the dictionary
+ with open("../Conversion-Script/Create_Variable_Dict/" + dict_filename, "r") as f:
+ # Read the contents of the file
+ read_dict_str = f.read()
+
+ # Convert the string representation of the dictionary back to a dictionary object
+ read_dict = ast.literal_eval(read_dict_str)
+ return read_dict
+
+
+def main():
+ # Parse the argument put in the command line.
+ parser = argparse.ArgumentParser()
+ parser.add_argument("--arguments", help="insert argg")
+ args = parser.parse_args()
+
+ # Inform the user if a report will be created
+ report_creation_bool = False
+ if args.arguments == 'report':
+ report_creation_bool = True
+
+ # Folder name to create
+ folder_name_to_convert = "File_To_Convert"
+ folder_name_converted = "File_Converted"
+
+ # Get current folder
+ folder_path = os.getcwd()
+
+
+ # Create new folder
+ create_folder_if_not_exists(folder_name_converted)
+
+ # Check the existence of the File_To_Convert folder
+ folder_created_bool = os.path.isdir(os.path.join(folder_path, folder_name_to_convert))
+ if not folder_created_bool:
+ print('The path to the File_To_Convert folder', folder_path + folder_name_to_convert, ' is not a directory.' )
+
+
+ # Get the last upload excel file
+ real_folder_path = os.path.join(folder_path, folder_name_to_convert)
+
+ last_file = get_last_added_file(real_folder_path)
+
+
+ if last_file:
+ print("Last added file:", last_file)
+ else:
+ print("No files found in the folder.")
+
+ # Get the correct naming for the converted file
+ filename_with_extension = os.path.basename(last_file)
+ splited_filename_with_extension = os.path.splitext(filename_with_extension)
+
+ filename = (
+ splited_filename_with_extension[0]
+ + "converted"
+ + splited_filename_with_extension[1]
+ )
+
+
+
+ # The scenario name is the name of the file to translate.
+ # Possibility to create a thread to run all the code during the wait for the user answer.
+ # scenario = input("Give the name of the scenario")
+ scenario = splited_filename_with_extension[0]
+
+ # Read the selected file
+ if (
+ splited_filename_with_extension[1] == ".xls"
+ or splited_filename_with_extension[1] == ".xlsx"
+ ):
+ scenario_variable_df = pd.read_excel(last_file)
+ elif splited_filename_with_extension[1] == ".csv":
+ scenario_variable_df = pd.read_csv(last_file)
+
+ # Remove duplicated rows in the file.
+ scenario_variable_df = scenario_variable_df.drop_duplicates()
+ # Rename the column of the file
+
+
+ columns = scenario_variable_df.columns.str.replace("Unnamed:", "Subscript")
+ columns = columns.str.replace(".", " ")
+
+ # Define the string you want in column names
+ search_string = "Subscript"
+ counter = 0
+
+ for k in range(len(columns)):
+ if search_string in columns[k]:
+ columns.values[k] = search_string + " " + str(counter)
+ counter += 1
+
+
+ # Create a dictionary using zip() and dictionary comprehension
+ my_dict = {k: v for k, v in zip(scenario_variable_df.columns[2:6], columns[2:6])}
+ scenario_variable_df.rename(columns=my_dict, inplace=True)
+ scenario_variable_df.rename(
+ columns={"Time": "Variable", "Year": "Unit", "Subscript": "Subscript 0"},
+ inplace=True,
+ )
+
+ # Insert the three columns in the right place for IAMC format
+ scenario_variable_df.insert(0, "Model", "WILIAM")
+ scenario_variable_df.insert(1, "Scenario", scenario)
+ scenario_variable_df.insert(2, "Region", "World")
+
+ # Dict used to check if the subscripts is a region used in Wiliam.
+ existing_country_Wiliam_dict = {
+ "EU27": 1,
+ "UK": 1,
+ "CHINA": 1,
+ "EASOC": 1,
+ "INDIA": 1,
+ "LATAM": 1,
+ "RUSSIA": 1,
+ "USMCA": 1,
+ "LROW": 1,
+ "AUSTRIA": 1,
+ "BELGIUM": 1,
+ "BULGARIA": 1,
+ "CROATIA": 1,
+ "CYPRUS": 1,
+ "CZECH_REPUBLIC": 1,
+ "DENMARK": 1,
+ "ESTONIA": 1,
+ "FINLAND": 1,
+ "FRANCE": 1,
+ "GERMANY": 1,
+ "GREECE": 1,
+ "HUNGARY": 1,
+ "IRELAND": 1,
+ "ITALY": 1,
+ "LATVIA": 1,
+ "LITHUANIA": 1,
+ "LUXEMBOURG": 1,
+ "MALTA": 1,
+ "NETHERLANDS": 1,
+ "POLAND": 1,
+ "PORTUGAL": 1,
+ "ROMANIA": 1,
+ "SLOVAKIA": 1,
+ "SLOVENIA": 1,
+ "SPAIN": 1,
+ "SWEDEN": 1,
+ }
+
+ # Open the text file containing the country dictionary to translate the country name of Wiliam to the IAMC format.
+ country_dict = open_dict("country_dict.txt")
+
+ # Order the subscript of each variable and give the right region to each row
+ scenario_variable_df = scenario_variable_df.apply(
+ aggregate_subscript_variable_name, args=(counter, existing_country_Wiliam_dict, country_dict),axis=1
+ )
+
+ # Remove the subscript columns once they have been added at the end of the variable name
+ drop_columns_list = ["Subscript " + str(k) for k in range(counter)]
+ scenario_variable_df.drop(columns=drop_columns_list, inplace=True)
+
+ # Open the text file containing the variable dictionary to translate each variable name of Wiliam to the variable name in the IAMC format.
+ variable_name_dict = open_dict("variable_name_dict.txt")
+
+ # Convert all the variable name to the IAMC format and get the variables with a missing translation.
+ # Create the list of missing variable.
+ missing_variable = []
+
+ # Apply the function to the DataFrame column
+ scenario_variable_df["Variable"] = scenario_variable_df["Variable"].apply(
+ replace_and_track, args=(variable_name_dict, missing_variable)
+ )
+
+ # Open the text file containing the aggregation dictionary .
+ aggregation_dict = open_dict("aggregation.txt")
+
+ # Create the aggregations rows in the dataframe.
+ scenario_variable_df = aggregate_rows(scenario_variable_df, aggregation_dict)
+
+ # Create the path for the file containing the missing variable.
+ print(
+ "The translation of ",
+ len(missing_variable),
+ " variables are missing. You can find all the translation in the file called new_variable_name_dict.txt")
+ # Process the automatic translation of missing variables.
+ translation_helpers.create_automatic_translation(missing_variable)
+
+
+ # Write the new excel file in the File_Converted folder
+ folder_file_converted = os.path.join(folder_path, folder_name_converted)
+
+ # Get the correct naming for the converted file
+ filename_with_extension = os.path.basename(last_file)
+ filename = (
+ splited_filename_with_extension[0]
+ + "converted"
+ + splited_filename_with_extension[1]
+ )
+
+ # Check for duplicate rows
+ duplicate_rows = scenario_variable_df[
+ scenario_variable_df.duplicated(subset=["Region", "Variable", "Unit"])
+ ]
+
+ # Count the number of duplicate rows. Normally we should find zero duplicates.
+ num_duplicate_rows = duplicate_rows.shape[0]
+ if num_duplicate_rows > 0:
+ print("Number of Duplicate Rows:", num_duplicate_rows)
+
+ # Remove duplicate rows
+ scenario_variable_df.drop_duplicates(subset=["Region", "Variable", "Unit"], inplace=True)
+
+ # Write the following dataframe to excel
+ if (
+ splited_filename_with_extension[1] == ".xls"
+ or splited_filename_with_extension[1] == ".xlsx"
+ ):
+ scenario_variable_df.to_excel(os.path.join(folder_file_converted, filename))
+ elif splited_filename_with_extension[1] == ".csv":
+ scenario_variable_df.to_csv(
+ os.path.join(folder_file_converted, filename), index=False
+ )
+
+ print("Conversion Done")
+
+ if not report_creation_bool:
+ exit()
+
+ # Structure to check the existance of the file
+ try:
+ scenario_df = pyam.IamDataFrame(
+ os.path.join(folder_file_converted, filename)
+ )
+ except:
+ print("ERROR opening the file with results in IAMC format")
+ exit()
+
+ # 3. This defines the model and scenario used for the report
+ args = dict(model="WILIAM", scenario=scenario)
+
+ # Create instance of FPDF class
+ pdf = report_pdf.PDFReport()
+
+ # Plot
+ data = scenario_df.filter(
+ model=args["model"], scenario=args["scenario"], variable="Primary Energy|*"
+ )
+ if len(data.variable)> 0:
+
+ data.plot(color="region", title= 'Primary Energy')
+ data.timeseries()
+ plt.legend(loc=1)
+ plt.tight_layout()
+ plt.savefig('Primary_Energy.png')
+
+ # Add a page
+ pdf.add_page()
+ pdf.cell(0, 10, "Figure 1: World Primary Energy Consumption", ln=True)
+ pdf.image("Primary_Energy.png", x=10, y=30, w=190)
+
+ print("Report's creation in process")
+ pdf.output(scenario + "report.pdf", "F")
+
+
+
+if __name__ == "__main__":
+ main()
+
+
+
diff --git a/Final_script/translation_helpers.py b/Final_script/translation_helpers.py
new file mode 100644
index 0000000..5058ef8
--- /dev/null
+++ b/Final_script/translation_helpers.py
@@ -0,0 +1,233 @@
+import pandas as pd
+import ast
+import csv
+import pprint
+
+# Function to move the matched string after the specific word
+def move_crochets(s):
+ specific_word_1 = "[per capita]"
+ specific_word_2 = "[intensity]"
+ specific_word_3 = "[share]"
+
+ if specific_word_1 in s:
+ index_emission = s.find(specific_word_1)
+
+ s = (
+ s[: index_emission - 1]
+ + s[index_emission + len(specific_word_1) :]
+ + specific_word_1
+ )
+
+ if specific_word_2 in s:
+ index_emission = s.find(specific_word_2)
+
+ s = (
+ s[: index_emission - 1]
+ + s[index_emission + len(specific_word_2) :]
+ + "[Intensity]"
+ )
+
+ if specific_word_3 in s:
+ index_emission = s.find(specific_word_3)
+
+ s = (
+ s[: index_emission - 1]
+ + s[index_emission + len(specific_word_1) :]
+ + "[Share]"
+ )
+
+ return s
+
+
+
+
+
+# Change the format of the string to respect IAMC's format
+def format_string(s, upper_word_list, vehicule_list):
+ # Split the string into words
+ if pd.isnull(s):
+ return s
+ words = s.split("|")
+
+ capitalized_words = []
+ # Capitalize the first letter of each word
+ for word in words:
+ if word not in upper_word_list:
+ new_word_list = word.split("_")
+ new_word_list = [new_word.capitalize() for new_word in new_word_list]
+ capitalized_words += [" ".join(new_word_list) + "|"]
+ else:
+ new_word_list = word.split("_")
+ capitalized_words += [
+ new_word + "|"
+ if new_word in vehicule_list
+ else new_word.capitalize() + "|"
+ for new_word in new_word_list
+ ]
+
+ # Join the words with spaces
+ transformed_string = "".join(capitalized_words)
+
+ result = ""
+ capitalize_next = False
+ # Capitalize the letter after each space
+ for char in transformed_string[:-1]:
+ if char == " " or char == "-":
+ capitalize_next = True
+ result += char
+ elif capitalize_next:
+ result += char.upper()
+ capitalize_next = False
+ else:
+ result += char
+
+ return result
+
+def process_list(
+ missing_variable_list,
+ IAMC_WILIAM_name_dict,
+ energy_dict,
+ rest_dict,
+ sectors_dict,
+ economy_dashboard_dict,
+ upper_word_list,
+ vehicle_list,
+):
+ original_to_transformed = {}
+
+
+
+ for row in missing_variable_list:
+ original_string = row[0] # Get the original string
+ # Split the string by '|' to extract parts
+ parts = original_string.split("|")
+
+ # Replace parts with dictionary values if they are keys in the dictionary
+ transformed_parts = []
+ for part in parts:
+ if IAMC_WILIAM_name_dict.get(part,None):
+ part = IAMC_WILIAM_name_dict.get(part, None)
+ elif energy_dict.get(part, None):
+ part = energy_dict[part]
+ elif rest_dict.get(part, None):
+ part = rest_dict[part]
+ elif sectors_dict.get(part, None):
+ part = sectors_dict[part]
+ elif economy_dashboard_dict.get(part, None):
+ part = economy_dashboard_dict[part]
+
+ transformed_parts.append(part)
+
+ # Reconstruct the string with transformed parts
+ transformed_string = "|".join(transformed_parts)
+
+ # Move the word in the brackets at the end of the word.
+ transformed_string = move_crochets(transformed_string)
+
+ # Transform the string to respect the IAMC format
+ transformed_string = format_string(transformed_string, upper_word_list, vehicle_list)
+
+ # Map the original string to the transformed string
+ original_to_transformed[original_string] = transformed_string
+
+ return original_to_transformed
+
+def open_dict(dict_filename):
+ # Open the text file containing the dictionary
+ with open("../Conversion-Script/Create_Variable_Dict/" + dict_filename, "r") as f:
+ # Read the contents of the file
+ read_dict_str = f.read()
+
+ # Convert the string representation of the dictionary back to a dictionary object
+ read_dict = ast.literal_eval(read_dict_str)
+ return read_dict
+
+
+def create_automatic_translation(missing_variable_list):
+
+
+ # Open the text file containing the energy dictionary
+ energy_dict = open_dict("energy_dict.txt")
+
+
+ # Open the text file containing the rest dictionary
+ rest_dict = open_dict("rest_dict.txt")
+
+
+ # Open the text file containing the sectors dictionary
+ sectors_dict = open_dict("sectors_dict.txt")
+
+
+ # Open the text file containing the dictionary for the economy dashboard subscript.
+ economy_dashboard_dict = open_dict("economy_dashboard_dict.txt")
+
+ # List with the words in uppercase which will not be capitalized by the next functions
+ upper_word_list = [
+ "CO2",
+ "CH4",
+ "N2O",
+ "PFC",
+ "SF6",
+ "HFC134a",
+ "HFC23",
+ "HFC32",
+ "HFC125",
+ "HFC143a",
+ "HFC152a",
+ "HFC227ea",
+ "HFC245ca",
+ "HFC4310mee",
+ "HFC",
+ "w/o CCS",
+ "w/ CCS",
+ "PV",
+ "CSP",
+ "AFOLU",
+ "CO2eq",
+ "EROI",
+ "PV",
+ "CSP",
+ "ICE_gasoline",
+ "ICE_diesel",
+ "ICE_gas",
+ "ICE_LPG",
+ "BEV",
+ "PHEV",
+ "HEV",
+ "FCEV",
+ "EV",
+ "HPV",
+ "LMO",
+ "NMC622",
+ "NMC811",
+ "NCA",
+ "LFP",
+ "LDV",
+ "MDV",
+ "HDV",
+ "NMT",
+ "GDP",
+ "PPP",
+ ]
+ vehicle_list = ["gasoline", "gas", "diesel"]
+
+ # Read the CSV file into a pandas DataFrame
+ data_name_df = pd.read_excel("../Conversion-Script/Variable_Reference/Variable_name_IAMC.xlsx")
+ # Create a dict with Wiliam's name as key, IAMC's name as value
+ IAMC_WILIAM_name_dict = data_name_df.set_index('WILIAM_variable')['IAMC_variable'].to_dict()
+
+ translation_dict = process_list(
+ missing_variable_list,
+ IAMC_WILIAM_name_dict,
+ energy_dict,
+ rest_dict,
+ sectors_dict,
+ economy_dashboard_dict,
+ upper_word_list,
+ vehicle_list,
+ )
+
+ # Save dictionary with pprint
+ with open("new_variable_name_dict.txt", "w") as f:
+ pprint.pprint(translation_dict, f)
+
diff --git a/Final_script/update_variable_dict.py b/Final_script/update_variable_dict.py
new file mode 100644
index 0000000..645cbe8
--- /dev/null
+++ b/Final_script/update_variable_dict.py
@@ -0,0 +1,191 @@
+import pprint
+import ast
+
+def check_brackets(s):
+ """
+ Checks that a string contains no hook or has a balanced pair of one open
+ and one close hook, with the close hook being the last character if present.
+ """
+ # Count occurrences of open and close hook
+ open_bracket_count = s.count("[")
+ close_bracket_count = s.count("]")
+
+ # Check if the string contains no hook
+ if open_bracket_count == 0 and close_bracket_count == 0:
+ return True
+
+ # Check for exactly one pair of hook and proper placement
+ if open_bracket_count == 1 and close_bracket_count == 1:
+ # Ensure that the close hook is the last character
+ if s.endswith("]") and " [" in s:
+ if "[ " not in s and " ]" not in s:
+ return True
+ else:
+ print("A space should not be presented after the opening hook and before the closing hook: ", s)
+ return False
+ else:
+ print("The string does not finished by a closing hook or needs a supplementary space: ", s)
+ return False
+ print("The number of crochets is greater than the maximum number of crochets or the position of them are not good in the following string: ", s)
+ return False
+
+def is_valid_string(s):
+ """
+ Checks that the string contains only spaces, letters, digits, or pipes.
+ """
+ valid_string_bool = True
+ for char in s:
+ if not (char.isalnum() or char in " |[]"):
+ print('This character is not authorized in the IAMC Format: ', char)
+ valid_string_bool = False
+ # Check for spaces before or after each pipe
+ if " |" in s or "| " in s:
+ print('There is some unusual space before or after a pipe in the following string: ', s)
+ valid_string_bool = False
+
+ # Check double space in the string.
+ if " " in s:
+ print("There is some double space: ", s)
+ valid_string_bool = False
+
+ # Check the bracket conditions
+ if not check_brackets(s):
+ valid_string_bool = False
+
+ # Check that the string is not finishing by a space.
+ if s.endswith(" "):
+ print("The string should not finished by a space: ", s)
+ valid_string_bool = False
+
+ return valid_string_bool
+
+def remove_bracketed_parts(s):
+ """
+ Removes all substrings enclosed in square brackets from the input string.
+
+ This function iterates over the input string and removes any part of the string
+ that is enclosed within square brackets, including the brackets themselves.
+ """
+ result = []
+ inside_brackets = False
+
+ for char in s:
+ if char == "[":
+ inside_brackets = True
+ elif char == "]":
+ inside_brackets = False
+ elif not inside_brackets:
+ result.append(char)
+
+ return "".join(result)
+
+
+def check_capitalization(words, conjunctions):
+ """
+ Checks that each word is capitalized unless it is a conjunction.
+ """
+ valid_capitalization_bool = True
+ for word in words:
+ if word.lower() in conjunctions:
+ if word != word.lower():
+ print("This word should be in lowercase: ", word)
+ valid_capitalization_bool = False
+ else:
+ if word != word.capitalize():
+ print("This word should be capitalized: ", word)
+ valid_capitalization_bool = False
+ return valid_capitalization_bool
+
+
+def process_dictionary(data_dict):
+ """
+ Checks and processes the values in a dictionary.
+ """
+ # List of conjunctions and words that should not be capitalized
+ conjunctions = {"and", "or", "nor", "but", "so", "for", "yet", "of", "w/", "w/o"}
+ correct_format_bool = True
+ for key, value in data_dict.items():
+ if isinstance(value, str):
+ # Check if the string contains only valid characters
+ if not is_valid_string(value):
+ print(
+ f"The value associated with key '{key}' is not following IAMC format rules."
+ )
+ correct_format_bool = False
+
+
+
+ # Split the string into words using spaces and pipes as separators
+ value = remove_bracketed_parts(value)
+ words = value.split()
+ split_words = []
+ for word in words:
+ split_words.extend(word.split("|"))
+
+ # Check the capitalization of words
+ if not check_capitalization(split_words, conjunctions):
+ print(
+ f"The value associated with key '{key}' does not have all words written properly."
+ )
+ correct_format_bool = False
+
+ return correct_format_bool
+
+
+def open_dict(dict_path):
+ # Open the text file containing the dictionary
+ with open(dict_path, "r") as f:
+ # Read the contents of the file
+ read_dict_str = f.read()
+
+ # Convert the string representation of the dictionary back to a dictionary object
+ read_dict = ast.literal_eval(read_dict_str)
+ return read_dict
+
+def check_and_merge_dicts(dict1, dict2):
+ # Find overlapping keys
+ overlapping_keys = set(dict1.keys()) & set(dict2.keys())
+
+ # Check if there are any differences in the overlapping keys
+ for key in overlapping_keys:
+ if dict1[key] != dict2[key]:
+ print(f"Conflict found for key '{key}':")
+ print(f" - Dict1 has {dict1[key]}")
+ print(f" - Dict2 has {dict2[key]}")
+ return None # Return None if there's a conflict
+
+ # Merge the dictionaries if there are no conflicts
+ merged_dict = dict1.copy() # Start with a copy of the first dictionary
+ merged_dict.update(dict2) # Update it with the second dictionary
+ return merged_dict
+
+def write_dict(dict_path, name_dict):
+ # Save dictionary with pprint
+ with open(dict_path, 'w') as f:
+ pprint.pprint( name_dict, f)
+
+def main():
+ # Read the dict file that contain the update of the translation dict
+ new_variable_dict = open_dict('new_variable_name_dict.txt')
+
+ # Check the format of the new variable to translate
+ correct_foramt_bool = process_dictionary(new_variable_dict)
+ if not correct_foramt_bool:
+ exit()
+
+ current_variable_translation_dict_path = (
+ "../Conversion-Script/Create_Variable_Dict/variable_name_dict.txt"
+ )
+ # Read the current dictionary of translation variable
+ current_variable_translation_dict = open_dict(current_variable_translation_dict_path)
+
+ updated_variable_translation_dict = check_and_merge_dicts(new_variable_dict, current_variable_translation_dict)
+
+ if updated_variable_translation_dict:
+ write_dict(
+ current_variable_translation_dict_path, updated_variable_translation_dict
+ )
+ print("Update of the translation dictionary done.")
+
+if __name__ == "__main__":
+ main()
diff --git a/Visualization/Plot_timeseries.ipynb b/Visualization/Plot_timeseries.ipynb
index fab78fa..4fabb1b 100644
--- a/Visualization/Plot_timeseries.ipynb
+++ b/Visualization/Plot_timeseries.ipynb
@@ -2,17 +2,31 @@
"cells": [
{
"cell_type": "code",
- "execution_count": 38,
+ "execution_count": 2,
"metadata": {},
"outputs": [],
"source": [
"import os\n",
- "import pandas as pd\n",
"import pyam\n",
+ "import matplotlib.pyplot as plt\n",
"# Import the library to efficiently search variables\n",
"import triesearching"
]
},
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "Helpers : \n",
+ "This text is to help a future user to plot timeseries data in the IAMC format.\n",
+ "First of all, make sure you have done the translation of the Wiliam's variable before using this file. \n",
+ "If not, go to the ReadMe to know how to do it. \n",
+ "\n",
+ "The first three cells should be executed to load the file with the data and get all the required variable in the file. \n",
+ "\n",
+ "If you want to have the list of all scenario, model, region, variables, the execution in a python cell of df.category_wanted gives you a list all the available elements in the Region, Variable, Model and Scenario category. If you want a globally known the name of your variable the completion helpers can be useful. Put the beginning of your variable's name and it gives you all the variable corresponding to this prefix."
+ ]
+ },
{
"cell_type": "markdown",
"metadata": {},
@@ -22,16 +36,16 @@
},
{
"cell_type": "code",
- "execution_count": 43,
+ "execution_count": 3,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
- "[INFO] 14:09:20 - pyam.core: Reading file ..\\Conversion-Script\\File_Converted\\Baseline no policies no CO2taxconverted.csv\n",
- "c:\\Users\\34670\\.conda\\envs\\wiliamcformat\\Lib\\site-packages\\pyam\\utils.py:318: FutureWarning: The previous implementation of stack is deprecated and will be removed in a future version of pandas. See the What's New notes for pandas 2.1.0 for details. Specify future_stack=True to adopt the new implementation and silence this warning.\n",
- " .stack(dropna=True)\n"
+ "[INFO] 10:50:57 - pyam.core: Reading file ..\\Conversion-Script\\File_Converted\\Baseline no policies no CO2taxconverted.csv\n",
+ "C:\\Users\\AdGeeds\\AppData\\Roaming\\Python\\Python310\\site-packages\\pyam\\utils.py:316: FutureWarning: The previous implementation of stack is deprecated and will be removed in a future version of pandas. See the What's New notes for pandas 2.1.0 for details. Specify future_stack=True to adopt the new implementation and silence this warning.\n",
+ " df.set_index(index + REQUIRED_COLS + extra_cols)\n"
]
}
],
@@ -56,7 +70,7 @@
},
{
"cell_type": "code",
- "execution_count": 40,
+ "execution_count": 4,
"metadata": {},
"outputs": [],
"source": [
@@ -69,55 +83,379 @@
},
{
"cell_type": "code",
- "execution_count": 41,
+ "execution_count": 5,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
- "Completions: Secondary Energy|Electricity And Heat|Gas Fuels|w/ CCS\n",
- "Secondary Energy|Electricity And Heat|Gas Fuels|w/o CCS\n",
- "Secondary Energy|Electricity And Heat|Geothermal|Deactivated\n",
- "Secondary Energy|Electricity And Heat|Liquid Fuels|w/ CCS\n",
- "Secondary Energy|Electricity And Heat|Liquid Fuels|w/o CCS\n",
- "Secondary Energy|Electricity And Heat|Solid|Biomass|w/ CCS\n",
- "Secondary Energy|Electricity And Heat|Solid|Biomass|w/o CCS\n",
- "Secondary Energy|Electricity And Heat|Solid|Fossil|w/ CCS\n",
- "Secondary Energy|Electricity And Heat|Solid|Fossil|w/o CCS\n",
- "Secondary Energy|Electricity And Heat|Waste\n",
- "Secondary Energy|Electricity|Gas Fuels|w/ CCS\n",
- "Secondary Energy|Electricity|Gas Fuels|w/o CCS\n",
- "Secondary Energy|Electricity|Geothermal\n",
- "Secondary Energy|Electricity|Hydro|Dammed\n",
- "Secondary Energy|Electricity|Hydro|Run Of River\n",
- "Secondary Energy|Electricity|Liquid Fuels|w/ CCS\n",
- "Secondary Energy|Electricity|Liquid Fuels|w/o CCS\n",
- "Secondary Energy|Electricity|Nuclear\n",
- "Secondary Energy|Electricity|Ocean\n",
- "Secondary Energy|Electricity|Solar|CSP\n",
- "Secondary Energy|Electricity|Solar|Open Space|PV\n",
- "Secondary Energy|Electricity|Solar|Urban|PV\n",
- "Secondary Energy|Electricity|Solid|Biomass|w/ CCS\n",
- "Secondary Energy|Electricity|Solid|Biomass|w/o CCS\n",
- "Secondary Energy|Electricity|Solid|Fossil|w/ CCS\n",
- "Secondary Energy|Electricity|Solid|Fossil|w/o CCS\n",
- "Secondary Energy|Electricity|Waste|w/ CCS\n",
- "Secondary Energy|Electricity|Waste|w/o CCS\n",
- "Secondary Energy|Electricity|Wind|Offshore\n",
- "Secondary Energy|Electricity|Wind|Onshore\n",
- "Secondary Energy|Gas Fuels\n",
- "Secondary Energy|Heat|Gas Fuels\n",
- "Secondary Energy|Heat|Geothermal\n",
- "Secondary Energy|Heat|Liquid Fuels\n",
- "Secondary Energy|Heat|Solar|Deactivated\n",
- "Secondary Energy|Heat|Solid|Biomass\n",
- "Secondary Energy|Heat|Solid|Fossil\n",
- "Secondary Energy|Heat|Waste\n",
- "Secondary Energy|Hydrogen\n",
- "Secondary Energy|Liquid Fuels\n",
- "Secondary Energy|Solids|Biomass\n",
- "Secondary Energy|Solids|Fossils\n"
+ "Completions: Final Energy|Accommodation|Electricity\n",
+ "Final Energy|Accommodation|Gas\n",
+ "Final Energy|Accommodation|Heat\n",
+ "Final Energy|Accommodation|Hydrogen\n",
+ "Final Energy|Accommodation|Liquid\n",
+ "Final Energy|Accommodation|Solid|Biomass\n",
+ "Final Energy|Accommodation|Solid|Fossil\n",
+ "Final Energy|Animals|Electricity\n",
+ "Final Energy|Animals|Gas\n",
+ "Final Energy|Animals|Heat\n",
+ "Final Energy|Animals|Hydrogen\n",
+ "Final Energy|Animals|Liquid\n",
+ "Final Energy|Animals|Solid|Biomass\n",
+ "Final Energy|Animals|Solid|Fossil\n",
+ "Final Energy|Construction|Electricity\n",
+ "Final Energy|Construction|Gas\n",
+ "Final Energy|Construction|Heat\n",
+ "Final Energy|Construction|Hydrogen\n",
+ "Final Energy|Construction|Liquid\n",
+ "Final Energy|Construction|Solid|Biomass\n",
+ "Final Energy|Construction|Solid|Fossil\n",
+ "Final Energy|Crops|Electricity\n",
+ "Final Energy|Crops|Gas\n",
+ "Final Energy|Crops|Heat\n",
+ "Final Energy|Crops|Hydrogen\n",
+ "Final Energy|Crops|Liquid\n",
+ "Final Energy|Crops|Solid|Biomass\n",
+ "Final Energy|Crops|Solid|Fossil\n",
+ "Final Energy|Education|Electricity\n",
+ "Final Energy|Education|Gas\n",
+ "Final Energy|Education|Heat\n",
+ "Final Energy|Education|Hydrogen\n",
+ "Final Energy|Education|Liquid\n",
+ "Final Energy|Education|Solid|Biomass\n",
+ "Final Energy|Education|Solid|Fossil\n",
+ "Final Energy|Electricity\n",
+ "Final Energy|Electricity|Renewable|Share|Electricity\n",
+ "Final Energy|Electricity|Renewable|Share|Gas\n",
+ "Final Energy|Electricity|Renewable|Share|Heat\n",
+ "Final Energy|Electricity|Renewable|Share|Hydrogen\n",
+ "Final Energy|Electricity|Renewable|Share|Liquid\n",
+ "Final Energy|Electricity|Renewable|Share|Solid|Biomass\n",
+ "Final Energy|Electricity|Renewable|Share|Solid|Fossil\n",
+ "Final Energy|Entertaiment|Electricity\n",
+ "Final Energy|Entertaiment|Gas\n",
+ "Final Energy|Entertaiment|Heat\n",
+ "Final Energy|Entertaiment|Hydrogen\n",
+ "Final Energy|Entertaiment|Liquid\n",
+ "Final Energy|Entertaiment|Solid|Biomass\n",
+ "Final Energy|Entertaiment|Solid|Fossil\n",
+ "Final Energy|Extraction Gas|Electricity\n",
+ "Final Energy|Extraction Gas|Gas\n",
+ "Final Energy|Extraction Gas|Heat\n",
+ "Final Energy|Extraction Gas|Hydrogen\n",
+ "Final Energy|Extraction Gas|Liquid\n",
+ "Final Energy|Extraction Gas|Solid|Biomass\n",
+ "Final Energy|Extraction Gas|Solid|Fossil\n",
+ "Final Energy|Extraction Oil|Electricity\n",
+ "Final Energy|Extraction Oil|Gas\n",
+ "Final Energy|Extraction Oil|Heat\n",
+ "Final Energy|Extraction Oil|Hydrogen\n",
+ "Final Energy|Extraction Oil|Liquid\n",
+ "Final Energy|Extraction Oil|Solid|Biomass\n",
+ "Final Energy|Extraction Oil|Solid|Fossil\n",
+ "Final Energy|Extraction Other Gas|Electricity\n",
+ "Final Energy|Extraction Other Gas|Gas\n",
+ "Final Energy|Extraction Other Gas|Heat\n",
+ "Final Energy|Extraction Other Gas|Hydrogen\n",
+ "Final Energy|Extraction Other Gas|Liquid\n",
+ "Final Energy|Extraction Other Gas|Solid|Biomass\n",
+ "Final Energy|Extraction Other Gas|Solid|Fossil\n",
+ "Final Energy|Finance|Electricity\n",
+ "Final Energy|Finance|Gas\n",
+ "Final Energy|Finance|Heat\n",
+ "Final Energy|Finance|Hydrogen\n",
+ "Final Energy|Finance|Liquid\n",
+ "Final Energy|Finance|Solid|Biomass\n",
+ "Final Energy|Finance|Solid|Fossil\n",
+ "Final Energy|Fishing|Electricity\n",
+ "Final Energy|Fishing|Gas\n",
+ "Final Energy|Fishing|Heat\n",
+ "Final Energy|Fishing|Hydrogen\n",
+ "Final Energy|Fishing|Liquid\n",
+ "Final Energy|Fishing|Solid|Biomass\n",
+ "Final Energy|Fishing|Solid|Fossil\n",
+ "Final Energy|Flexibility Options|Electricity\n",
+ "Final Energy|Flexibility Options|Gas\n",
+ "Final Energy|Flexibility Options|Heat\n",
+ "Final Energy|Flexibility Options|Hydrogen\n",
+ "Final Energy|Flexibility Options|Liquid\n",
+ "Final Energy|Flexibility Options|Solid Biomass\n",
+ "Final Energy|Flexibility Options|Solid Fossil\n",
+ "Final Energy|Forestry|Electricity\n",
+ "Final Energy|Forestry|Gas\n",
+ "Final Energy|Forestry|Heat\n",
+ "Final Energy|Forestry|Hydrogen\n",
+ "Final Energy|Forestry|Liquid\n",
+ "Final Energy|Forestry|Solid|Biomass\n",
+ "Final Energy|Forestry|Solid|Fossil\n",
+ "Final Energy|Gas\n",
+ "Final Energy|Health|Electricity\n",
+ "Final Energy|Health|Gas\n",
+ "Final Energy|Health|Heat\n",
+ "Final Energy|Health|Hydrogen\n",
+ "Final Energy|Health|Liquid\n",
+ "Final Energy|Health|Solid|Biomass\n",
+ "Final Energy|Health|Solid|Fossil\n",
+ "Final Energy|Heat\n",
+ "Final Energy|Hydrogen\n",
+ "Final Energy|Liquid\n",
+ "Final Energy|Manufacture Chemical|Electricity\n",
+ "Final Energy|Manufacture Chemical|Gas\n",
+ "Final Energy|Manufacture Chemical|Heat\n",
+ "Final Energy|Manufacture Chemical|Hydrogen\n",
+ "Final Energy|Manufacture Chemical|Liquid\n",
+ "Final Energy|Manufacture Chemical|Solid|Biomass\n",
+ "Final Energy|Manufacture Chemical|Solid|Fossil\n",
+ "Final Energy|Manufacture Electrical Equipment|Electricity\n",
+ "Final Energy|Manufacture Electrical Equipment|Gas\n",
+ "Final Energy|Manufacture Electrical Equipment|Heat\n",
+ "Final Energy|Manufacture Electrical Equipment|Hydrogen\n",
+ "Final Energy|Manufacture Electrical Equipment|Liquid\n",
+ "Final Energy|Manufacture Electrical Equipment|Solid|Biomass\n",
+ "Final Energy|Manufacture Electrical Equipment|Solid|Fossil\n",
+ "Final Energy|Manufacture Electronics|Electricity\n",
+ "Final Energy|Manufacture Electronics|Gas\n",
+ "Final Energy|Manufacture Electronics|Heat\n",
+ "Final Energy|Manufacture Electronics|Hydrogen\n",
+ "Final Energy|Manufacture Electronics|Liquid\n",
+ "Final Energy|Manufacture Electronics|Solid|Biomass\n",
+ "Final Energy|Manufacture Electronics|Solid|Fossil\n",
+ "Final Energy|Manufacture Food|Electricity\n",
+ "Final Energy|Manufacture Food|Gas\n",
+ "Final Energy|Manufacture Food|Heat\n",
+ "Final Energy|Manufacture Food|Hydrogen\n",
+ "Final Energy|Manufacture Food|Liquid\n",
+ "Final Energy|Manufacture Food|Solid|Biomass\n",
+ "Final Energy|Manufacture Food|Solid|Fossil\n",
+ "Final Energy|Manufacture Machinery|Electricity\n",
+ "Final Energy|Manufacture Machinery|Gas\n",
+ "Final Energy|Manufacture Machinery|Heat\n",
+ "Final Energy|Manufacture Machinery|Hydrogen\n",
+ "Final Energy|Manufacture Machinery|Liquid\n",
+ "Final Energy|Manufacture Machinery|Solid|Biomass\n",
+ "Final Energy|Manufacture Machinery|Solid|Fossil\n",
+ "Final Energy|Manufacture Metal Products|Electricity\n",
+ "Final Energy|Manufacture Metal Products|Gas\n",
+ "Final Energy|Manufacture Metal Products|Heat\n",
+ "Final Energy|Manufacture Metal Products|Hydrogen\n",
+ "Final Energy|Manufacture Metal Products|Liquid\n",
+ "Final Energy|Manufacture Metal Products|Solid|Biomass\n",
+ "Final Energy|Manufacture Metal Products|Solid|Fossil\n",
+ "Final Energy|Manufacture Other Non Metal|Electricity\n",
+ "Final Energy|Manufacture Other Non Metal|Gas\n",
+ "Final Energy|Manufacture Other Non Metal|Heat\n",
+ "Final Energy|Manufacture Other Non Metal|Hydrogen\n",
+ "Final Energy|Manufacture Other Non Metal|Liquid\n",
+ "Final Energy|Manufacture Other Non Metal|Solid|Biomass\n",
+ "Final Energy|Manufacture Other Non Metal|Solid|Fossil\n",
+ "Final Energy|Manufacture Other|Electricity\n",
+ "Final Energy|Manufacture Other|Gas\n",
+ "Final Energy|Manufacture Other|Heat\n",
+ "Final Energy|Manufacture Other|Hydrogen\n",
+ "Final Energy|Manufacture Other|Liquid\n",
+ "Final Energy|Manufacture Other|Solid|Biomass\n",
+ "Final Energy|Manufacture Other|Solid|Fossil\n",
+ "Final Energy|Manufacture Plastic|Electricity\n",
+ "Final Energy|Manufacture Plastic|Gas\n",
+ "Final Energy|Manufacture Plastic|Heat\n",
+ "Final Energy|Manufacture Plastic|Hydrogen\n",
+ "Final Energy|Manufacture Plastic|Liquid\n",
+ "Final Energy|Manufacture Plastic|Solid|Biomass\n",
+ "Final Energy|Manufacture Plastic|Solid|Fossil\n",
+ "Final Energy|Manufacture Vehicles|Electricity\n",
+ "Final Energy|Manufacture Vehicles|Gas\n",
+ "Final Energy|Manufacture Vehicles|Heat\n",
+ "Final Energy|Manufacture Vehicles|Hydrogen\n",
+ "Final Energy|Manufacture Vehicles|Liquid\n",
+ "Final Energy|Manufacture Vehicles|Solid|Biomass\n",
+ "Final Energy|Manufacture Vehicles|Solid|Fossil\n",
+ "Final Energy|Manufacture Wood|Electricity\n",
+ "Final Energy|Manufacture Wood|Gas\n",
+ "Final Energy|Manufacture Wood|Heat\n",
+ "Final Energy|Manufacture Wood|Hydrogen\n",
+ "Final Energy|Manufacture Wood|Liquid\n",
+ "Final Energy|Manufacture Wood|Solid|Biomass\n",
+ "Final Energy|Manufacture Wood|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Aluminium|Electricity\n",
+ "Final Energy|Mining And Manufacturing Aluminium|Gas\n",
+ "Final Energy|Mining And Manufacturing Aluminium|Heat\n",
+ "Final Energy|Mining And Manufacturing Aluminium|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Aluminium|Liquid\n",
+ "Final Energy|Mining And Manufacturing Aluminium|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Aluminium|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Copper|Electricity\n",
+ "Final Energy|Mining And Manufacturing Copper|Gas\n",
+ "Final Energy|Mining And Manufacturing Copper|Heat\n",
+ "Final Energy|Mining And Manufacturing Copper|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Copper|Liquid\n",
+ "Final Energy|Mining And Manufacturing Copper|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Copper|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Iron|Electricity\n",
+ "Final Energy|Mining And Manufacturing Iron|Gas\n",
+ "Final Energy|Mining And Manufacturing Iron|Heat\n",
+ "Final Energy|Mining And Manufacturing Iron|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Iron|Liquid\n",
+ "Final Energy|Mining And Manufacturing Iron|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Iron|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Lead Zinc Tin|Electricity\n",
+ "Final Energy|Mining And Manufacturing Lead Zinc Tin|Gas\n",
+ "Final Energy|Mining And Manufacturing Lead Zinc Tin|Heat\n",
+ "Final Energy|Mining And Manufacturing Lead Zinc Tin|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Lead Zinc Tin|Liquid\n",
+ "Final Energy|Mining And Manufacturing Lead Zinc Tin|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Lead Zinc Tin|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Nickel|Electricity\n",
+ "Final Energy|Mining And Manufacturing Nickel|Gas\n",
+ "Final Energy|Mining And Manufacturing Nickel|Heat\n",
+ "Final Energy|Mining And Manufacturing Nickel|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Nickel|Liquid\n",
+ "Final Energy|Mining And Manufacturing Nickel|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Nickel|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Other Metals|Electricity\n",
+ "Final Energy|Mining And Manufacturing Other Metals|Gas\n",
+ "Final Energy|Mining And Manufacturing Other Metals|Heat\n",
+ "Final Energy|Mining And Manufacturing Other Metals|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Other Metals|Liquid\n",
+ "Final Energy|Mining And Manufacturing Other Metals|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Other Metals|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Precious Metals|Electricity\n",
+ "Final Energy|Mining And Manufacturing Precious Metals|Gas\n",
+ "Final Energy|Mining And Manufacturing Precious Metals|Heat\n",
+ "Final Energy|Mining And Manufacturing Precious Metals|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Precious Metals|Liquid\n",
+ "Final Energy|Mining And Manufacturing Precious Metals|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Precious Metals|Solid|Fossil\n",
+ "Final Energy|Mining And Manufacturing Uranium Thorium|Electricity\n",
+ "Final Energy|Mining And Manufacturing Uranium Thorium|Gas\n",
+ "Final Energy|Mining And Manufacturing Uranium Thorium|Heat\n",
+ "Final Energy|Mining And Manufacturing Uranium Thorium|Hydrogen\n",
+ "Final Energy|Mining And Manufacturing Uranium Thorium|Liquid\n",
+ "Final Energy|Mining And Manufacturing Uranium Thorium|Solid|Biomass\n",
+ "Final Energy|Mining And Manufacturing Uranium Thorium|Solid|Fossil\n",
+ "Final Energy|Mining Coal|Electricity\n",
+ "Final Energy|Mining Coal|Gas\n",
+ "Final Energy|Mining Coal|Heat\n",
+ "Final Energy|Mining Coal|Hydrogen\n",
+ "Final Energy|Mining Coal|Liquid\n",
+ "Final Energy|Mining Coal|Solid|Biomass\n",
+ "Final Energy|Mining Coal|Solid|Fossil\n",
+ "Final Energy|Mining Non Metals|Electricity\n",
+ "Final Energy|Mining Non Metals|Gas\n",
+ "Final Energy|Mining Non Metals|Heat\n",
+ "Final Energy|Mining Non Metals|Hydrogen\n",
+ "Final Energy|Mining Non Metals|Liquid\n",
+ "Final Energy|Mining Non Metals|Solid|Biomass\n",
+ "Final Energy|Mining Non Metals|Solid|Fossil\n",
+ "Final Energy|Net [per Capita]\n",
+ "Final Energy|Non-Energy Use|Electricity\n",
+ "Final Energy|Non-Energy Use|Gas\n",
+ "Final Energy|Non-Energy Use|Heat\n",
+ "Final Energy|Non-Energy Use|Hydrogen\n",
+ "Final Energy|Non-Energy Use|Liquid\n",
+ "Final Energy|Non-Energy Use|Solid|Biomass\n",
+ "Final Energy|Non-Energy Use|Solid|Fossil\n",
+ "Final Energy|Other Services|Electricity\n",
+ "Final Energy|Other Services|Gas\n",
+ "Final Energy|Other Services|Heat\n",
+ "Final Energy|Other Services|Hydrogen\n",
+ "Final Energy|Other Services|Liquid\n",
+ "Final Energy|Other Services|Solid|Biomass\n",
+ "Final Energy|Other Services|Solid|Fossil\n",
+ "Final Energy|Private Households|Electricity\n",
+ "Final Energy|Private Households|Gas\n",
+ "Final Energy|Private Households|Heat\n",
+ "Final Energy|Private Households|Hydrogen\n",
+ "Final Energy|Private Households|Liquid\n",
+ "Final Energy|Private Households|Solid|Biomass\n",
+ "Final Energy|Private Households|Solid|Fossil\n",
+ "Final Energy|Public Administration|Electricity\n",
+ "Final Energy|Public Administration|Gas\n",
+ "Final Energy|Public Administration|Heat\n",
+ "Final Energy|Public Administration|Hydrogen\n",
+ "Final Energy|Public Administration|Liquid\n",
+ "Final Energy|Public Administration|Solid|Biomass\n",
+ "Final Energy|Public Administration|Solid|Fossil\n",
+ "Final Energy|Real Estate|Electricity\n",
+ "Final Energy|Real Estate|Gas\n",
+ "Final Energy|Real Estate|Heat\n",
+ "Final Energy|Real Estate|Hydrogen\n",
+ "Final Energy|Real Estate|Liquid\n",
+ "Final Energy|Real Estate|Solid|Biomass\n",
+ "Final Energy|Real Estate|Solid|Fossil\n",
+ "Final Energy|Regional Consumption|Electricity\n",
+ "Final Energy|Regional Consumption|Gas\n",
+ "Final Energy|Regional Consumption|Heat\n",
+ "Final Energy|Regional Consumption|Hydrogen\n",
+ "Final Energy|Regional Consumption|Liquid\n",
+ "Final Energy|Regional Consumption|Solid|Biomass\n",
+ "Final Energy|Regional Consumption|Solid|Fossil\n",
+ "Final Energy|Renewable|Share\n",
+ "Final Energy|Solid|Biomass\n",
+ "Final Energy|Solid|Fossil\n",
+ "Final Energy|Telecommunications|Electricity\n",
+ "Final Energy|Telecommunications|Gas\n",
+ "Final Energy|Telecommunications|Heat\n",
+ "Final Energy|Telecommunications|Hydrogen\n",
+ "Final Energy|Telecommunications|Liquid\n",
+ "Final Energy|Telecommunications|Solid|Biomass\n",
+ "Final Energy|Telecommunications|Solid|Fossil\n",
+ "Final Energy|Trade Repair Vehicles|Electricity\n",
+ "Final Energy|Trade Repair Vehicles|Gas\n",
+ "Final Energy|Trade Repair Vehicles|Heat\n",
+ "Final Energy|Trade Repair Vehicles|Hydrogen\n",
+ "Final Energy|Trade Repair Vehicles|Liquid\n",
+ "Final Energy|Trade Repair Vehicles|Solid|Biomass\n",
+ "Final Energy|Trade Repair Vehicles|Solid|Fossil\n",
+ "Final Energy|Transport Air|Electricity\n",
+ "Final Energy|Transport Air|Gas\n",
+ "Final Energy|Transport Air|Heat\n",
+ "Final Energy|Transport Air|Hydrogen\n",
+ "Final Energy|Transport Air|Liquid\n",
+ "Final Energy|Transport Air|Solid|Biomass\n",
+ "Final Energy|Transport Air|Solid|Fossil\n",
+ "Final Energy|Transport Inland Water|Electricity\n",
+ "Final Energy|Transport Inland Water|Gas\n",
+ "Final Energy|Transport Inland Water|Heat\n",
+ "Final Energy|Transport Inland Water|Hydrogen\n",
+ "Final Energy|Transport Inland Water|Liquid\n",
+ "Final Energy|Transport Inland Water|Solid|Biomass\n",
+ "Final Energy|Transport Inland Water|Solid|Fossil\n",
+ "Final Energy|Transport Other Land|Electricity\n",
+ "Final Energy|Transport Other Land|Gas\n",
+ "Final Energy|Transport Other Land|Heat\n",
+ "Final Energy|Transport Other Land|Hydrogen\n",
+ "Final Energy|Transport Other Land|Liquid\n",
+ "Final Energy|Transport Other Land|Solid|Biomass\n",
+ "Final Energy|Transport Other Land|Solid|Fossil\n",
+ "Final Energy|Transport Pipeline|Electricity\n",
+ "Final Energy|Transport Pipeline|Gas\n",
+ "Final Energy|Transport Pipeline|Heat\n",
+ "Final Energy|Transport Pipeline|Hydrogen\n",
+ "Final Energy|Transport Pipeline|Liquid\n",
+ "Final Energy|Transport Pipeline|Solid|Biomass\n",
+ "Final Energy|Transport Pipeline|Solid|Fossil\n",
+ "Final Energy|Transport Rail|Electricity\n",
+ "Final Energy|Transport Rail|Gas\n",
+ "Final Energy|Transport Rail|Heat\n",
+ "Final Energy|Transport Rail|Hydrogen\n",
+ "Final Energy|Transport Rail|Liquid\n",
+ "Final Energy|Transport Rail|Solid|Biomass\n",
+ "Final Energy|Transport Rail|Solid|Fossil\n",
+ "Final Energy|Transport Sea|Electricity\n",
+ "Final Energy|Transport Sea|Gas\n",
+ "Final Energy|Transport Sea|Heat\n",
+ "Final Energy|Transport Sea|Hydrogen\n",
+ "Final Energy|Transport Sea|Liquid\n",
+ "Final Energy|Transport Sea|Solid|Biomass\n",
+ "Final Energy|Transport Sea|Solid|Fossil\n",
+ "Final Energy|Waste Management|Electricity\n",
+ "Final Energy|Waste Management|Gas\n",
+ "Final Energy|Waste Management|Heat\n",
+ "Final Energy|Waste Management|Hydrogen\n",
+ "Final Energy|Waste Management|Liquid\n",
+ "Final Energy|Waste Management|Solid|Biomass\n",
+ "Final Energy|Waste Management|Solid|Fossil\n"
]
}
],
@@ -129,592 +467,61 @@
"print(\"Completions:\", \"\\n\".join(completions))\n"
]
},
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Plot differentiate by variable for a same region \n"
+ ]
+ },
{
"cell_type": "code",
- "execution_count": 42,
+ "execution_count": 6,
"metadata": {},
"outputs": [
{
"data": {
- "text/html": [
- "\n",
- "\n",
- "
\n",
- " \n",
- " \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " 2005 | \n",
- " 2006 | \n",
- " 2007 | \n",
- " 2008 | \n",
- " 2009 | \n",
- " 2010 | \n",
- " 2011 | \n",
- " 2012 | \n",
- " 2013 | \n",
- " 2014 | \n",
- " ... | \n",
- " 2061 | \n",
- " 2062 | \n",
- " 2063 | \n",
- " 2064 | \n",
- " 2065 | \n",
- " 2066 | \n",
- " 2067 | \n",
- " 2068 | \n",
- " 2069 | \n",
- " 2070 | \n",
- "
\n",
- " \n",
- " model | \n",
- " scenario | \n",
- " region | \n",
- " variable | \n",
- " unit | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- " | \n",
- "
\n",
- " \n",
- " \n",
- " \n",
- " WILIAM | \n",
- " Baseline no policies no CO2tax | \n",
- " China | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.000725 | \n",
- " 0.000725 | \n",
- " 0.000688 | \n",
- " 0.000626 | \n",
- " 0.000626 | \n",
- " 0.000626 | \n",
- " 0.000655 | \n",
- " 0.000704 | \n",
- " 0.000704 | \n",
- " 0.000704 | \n",
- " ... | \n",
- " 0.640144 | \n",
- " 0.611040 | \n",
- " 0.587707 | \n",
- " 0.566017 | \n",
- " 0.701597 | \n",
- " 0.665704 | \n",
- " 0.640081 | \n",
- " 0.617566 | \n",
- " 0.589881 | \n",
- " 0.561562 | \n",
- "
\n",
- " \n",
- " East Asia and Oceania | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.098442 | \n",
- " 0.099530 | \n",
- " 0.103210 | \n",
- " 0.108532 | \n",
- " 0.113571 | \n",
- " 0.114161 | \n",
- " 0.113096 | \n",
- " 0.116885 | \n",
- " 0.120688 | \n",
- " 0.125068 | \n",
- " ... | \n",
- " 0.853833 | \n",
- " 0.820184 | \n",
- " 0.852033 | \n",
- " 0.818461 | \n",
- " 0.849846 | \n",
- " 0.813574 | \n",
- " 0.834648 | \n",
- " 0.802674 | \n",
- " 0.831823 | \n",
- " 0.795460 | \n",
- "
\n",
- " \n",
- " European Union (27 member countries) | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.017934 | \n",
- " 0.018254 | \n",
- " 0.018291 | \n",
- " 0.018583 | \n",
- " 0.019379 | \n",
- " 0.020052 | \n",
- " 0.020303 | \n",
- " 0.020501 | \n",
- " 0.021099 | \n",
- " 0.021732 | \n",
- " ... | \n",
- " 0.393090 | \n",
- " 0.372561 | \n",
- " 0.401736 | \n",
- " 0.388353 | \n",
- " 0.373291 | \n",
- " 0.389484 | \n",
- " 0.375624 | \n",
- " 0.364750 | \n",
- " 0.387195 | \n",
- " 0.370103 | \n",
- "
\n",
- " \n",
- " India | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " ... | \n",
- " 0.458206 | \n",
- " 0.424978 | \n",
- " 0.440630 | \n",
- " 0.427114 | \n",
- " 0.445782 | \n",
- " 0.414364 | \n",
- " 0.426094 | \n",
- " 0.467019 | \n",
- " 0.445350 | \n",
- " 0.416520 | \n",
- "
\n",
- " \n",
- " Latin America | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.004330 | \n",
- " 0.004330 | \n",
- " 0.004330 | \n",
- " 0.004330 | \n",
- " 0.004330 | \n",
- " 0.004771 | \n",
- " 0.005573 | \n",
- " 0.005687 | \n",
- " 0.005687 | \n",
- " 0.005677 | \n",
- " ... | \n",
- " 1.070650 | \n",
- " 1.043190 | \n",
- " 1.044780 | \n",
- " 1.047020 | \n",
- " 1.053170 | \n",
- " 1.005780 | \n",
- " 1.027230 | \n",
- " 1.025420 | \n",
- " 1.009230 | \n",
- " 0.976543 | \n",
- "
\n",
- " \n",
- " Rest of the World | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.023452 | \n",
- " 0.024887 | \n",
- " 0.028227 | \n",
- " 0.030650 | \n",
- " 0.032522 | \n",
- " 0.034413 | \n",
- " 0.037644 | \n",
- " 0.041575 | \n",
- " 0.048268 | \n",
- " 0.057504 | \n",
- " ... | \n",
- " 1.888570 | \n",
- " 1.748170 | \n",
- " 1.765670 | \n",
- " 1.931880 | \n",
- " 1.881490 | \n",
- " 1.743370 | \n",
- " 1.839330 | \n",
- " 1.784380 | \n",
- " 1.764510 | \n",
- " 1.683820 | \n",
- "
\n",
- " \n",
- " Russia | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.002061 | \n",
- " 0.002089 | \n",
- " 0.002136 | \n",
- " 0.002136 | \n",
- " 0.002136 | \n",
- " 0.002136 | \n",
- " 0.002137 | \n",
- " 0.002139 | \n",
- " 0.002139 | \n",
- " 0.002139 | \n",
- " ... | \n",
- " 0.092825 | \n",
- " 0.088376 | \n",
- " 0.085639 | \n",
- " 0.082554 | \n",
- " 0.079163 | \n",
- " 0.107793 | \n",
- " 0.104399 | \n",
- " 0.101185 | \n",
- " 0.096227 | \n",
- " 0.091961 | \n",
- "
\n",
- " \n",
- " United Kingdom | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " 0.000000 | \n",
- " ... | \n",
- " 0.013473 | \n",
- " 0.012885 | \n",
- " 0.012455 | \n",
- " 0.011983 | \n",
- " 0.011486 | \n",
- " 0.010958 | \n",
- " 0.010568 | \n",
- " 0.010126 | \n",
- " 0.014696 | \n",
- " 0.014009 | \n",
- "
\n",
- " \n",
- " United States, Mexico and Canada | \n",
- " Secondary Energy|Electricity|Geothermal | \n",
- " EJ/yr | \n",
- " 0.084363 | \n",
- " 0.083776 | \n",
- " 0.082994 | \n",
- " 0.084816 | \n",
- " 0.087523 | \n",
- " 0.087156 | \n",
- " 0.087135 | \n",
- " 0.089239 | \n",
- " 0.088468 | \n",
- " 0.087969 | \n",
- " ... | \n",
- " 0.687098 | \n",
- " 0.657721 | \n",
- " 0.630744 | \n",
- " 0.660829 | \n",
- " 0.636016 | \n",
- " 0.668544 | \n",
- " 0.641752 | \n",
- " 0.667759 | \n",
- " 0.642032 | \n",
- " 0.648005 | \n",
- "
\n",
- " \n",
- "
\n",
- "
9 rows × 66 columns
\n",
- "
"
- ],
+ "image/png": "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110lovbHH388KE1mZiYGDhwIk8mEuLg4zJgxA263OyjNzp070blzZxgMBjRv3pz/CiSqAv5WgMBFo9GUuBXTuHFjvPjiixg3bhyio6PRqFEjLF++PCivmTNnomXLljCZTGjatClmz54Nl8tV4TLVrVu3RJl0Oh2A4ttK77//Pho3bgyLxYLhw4cjPz9fPV9RFMybNw9NmjRBREQEOnTogH//+9/q8Z07d0KSJHz55Zfo0qULDAYDvvnmG+Tn52PkyJGIjIxEgwYN8MorrwTVw9y5c9G2bdsS5e3YsSNmz55d6rX07dsXNpsN3333XdD7P/PMMzhw4ADsdjsA78SnBw4cUAO7sury+++/R9++fREdHQ2z2YwuXbrgu+++w86dO/HII48gLy9P/T32tww6HA5Mnz4dt912GyIjI9G9e/dy3fYbOXIkdu3ahfPnz6v73n33XYwcObJEMLx48WK0a9cOkZGRSEpKwhNPPAGbzaYe97cmbt68GSkpKYiKikL//v1x8eJFNc3Bgwdxzz33oF69erBYLOjTpw/+85//BL3PDz/8gJ49e8JoNKJ169bYunVr0C06ADh//jwefPBBxMTEoE6dOhg8eDDOnTunHvffknzxxRcRHx+PmJgYzJ07F263GzNmzECdOnXQsGHDEv/wKW++CxcuRIMGDVC3bl1MmjRJ/fvddddd+PnnnzF16lT1b1Sa3NxcfP3113j55ZfRt29fJCcn44477sCsWbPw+9//Xk2XmZmJwYMHIyoqCmazGQ8++CCys7Ov8dcseSu2oKAAo0ePRlRUFBo0aFChR7Nd/V31B40OhwNPPfUU4uLiYDQa0bNnTxw8eFA978qVKxg5ciTq16+PiIgItGjRQq1np9OJyZMno0GDBjAajUhOTsa8efPUc6/+O9dG1RrY7dq1C5MmTcL+/fuxZcsWuFwu9OvXDwUFBUHpHn30UVy8eFFd5s+frx7zeDwYOHAgnE4n9u7di1WrVmHlypV49tln1TRnz57FwIED0bdvX2RkZGDKlCmYMGECNm/eXGXXShQqQggoTk+1LJX5oJpFixaha9euOHz4MJ544glMnDgx6B960dHRWLlyJU6cOIGlS5firbfewiuvvBLycpw5cwbr16/Hhg0bsGHDBuzatQsvvfSSenzevHl477338Oabb+L48eOYOnUqHn74YezatSson2eeeQYvvfQSTp48ifbt22PatGnYs2cPPvvsM2zZsgVff/11UEAxbtw4nDx5Muh/UIcPH8aRI0fwyCOPlFrWli1bIjExETt27ADgfcbpf/7zH/zxj39E48aNsW/fPgDA3r174XA41MCurLocOXIkGjZsiIMHD+LQoUN45plnoNPpcOedd2LJkiUwm83q7/H06dMBAJMnT8a+ffuwZs0aHDlyBH/84x/Rv39//Pjjj9et7/j4eKSnp2PVqlUAgMLCQqxduxbjxo0rkVaWZbz66qs4fvw4Vq1ahe3bt+Ppp58OSlNYWIiFCxfi/fffx+7du5GZmamW0V9HY8aMwTfffIP9+/ejRYsWuPfee9Xg3ePxYMiQITCZTDhw4ACWL1+Ov/71r0Hv4XK5kJ6ejujoaHz99dfYs2ePGkQ6nU413fbt2/HLL79g9+7dWLx4MebMmYP77rsPsbGxOHDgAB5//HH86U9/woULFyqU744dO3DmzBns2LFD/X+ev7Hik08+QcOGDTF37lz1b1SaqKgoREVFYf369XA4HKWmURQFgwcPRk5ODnbt2oUtW7bgp59+wrBhw0pNX5oZM2Zg165d+PTTT/HVV19h586dJQLpinr66afx8ccfY9WqVfjPf/6D5s2bIz09HTk5OQCA2bNn48SJE/jyyy9x8uRJvPHGG+ozmV999VV89tln+PDDD3Hq1CmsXr26Rj5m7aaIGuTSpUsCgNi1a5e6r0+fPuLPf/7zNc/54osvhCzLIisrS933xhtvCLPZLBwOhxBCiKefflq0adMm6Lxhw4aJ9PT0cpUrLy9PABB5eXkVuBqim1dUVCROnDghioqK1H0eh1ucn7m7WhaPw13uso8ZM0ZoNBoRGRmpLg888IAQouT3Ojk5WTz88MPqa0VRRFxcnHjjjTeumf+CBQtEly5d1Ndz5swRHTp0uGb6s2fPCgAiIiIiqEyRkZFBeZhMJmG1WtV9M2bMEN27dxdCCGG324XJZBJ79+4Nynv8+PFixIgRQgghduzYIQCI9evXq8etVqvQ6XTio48+Uvfl5uYKk8kUVA8DBgwQEydOVF8/+eST4q677ipxDYFGjhwp+vXrJ4QQYuPGjaJ169ZCCCEee+wx8eyzzwohhJg9e7Zo0qTJNevm6rqMjo4WK1euLDXtihUrhMViCdr3888/C41GI/7v//4vaP/dd98tZs2adc33TU5OFq+88opYv369aNasmVAURaxatUp06tRJCCGExWIRK1asuOb5H330kahbt25Q2QCI06dPq/tef/11ER8ff808PB6PiI6OFp9//rkQQogvv/xSaLVacfHiRTXNli1bBACxbt06IYQQ77//vmjVqpVQFEVN43A4REREhNi8ebMQwvv5T05OFh6PR03TqlUr0atXL/W12+0WkZGR4oMPPqhwvm538Xfxj3/8oxg2bJj62l+vV0tOThY7duxQX//73/8WsbGxwmg0ijvvvFPMmjVLfP/99+rxr776Smg0GpGZmanuO378uAAgvv32WyFEye/dmDFjxODBg4UQQuTn5wu9Xi8+/PBD9fjly5dFRERE0Od+xYoVok+fPurra31X//Of/wibzSZ0Op1YvXq1mt7pdIrExEQxf/58IYQQgwYNEo888kiJ6xfC+536n//5n6A6DhT4d/aX4/Dhw6WmDbXSfu/9KhKH1KjBE3l5eQCAOnXqBO1fvXo16tWrh7Zt22LWrFkoLCxUj+3btw/t2rVDfHy8ui89PR1WqxXHjx9X06SlpQXlmZ6erv5r9moOhwNWqzVoIaKK87eS+5dXX331mmnbt2+vbkuShISEBFy6dEndt3btWvTo0QMJCQmIiorC3/72N2RmZla4TGvXrg0q09Uj3ho3bozo6Gj1dYMGDdRynD59GoWFhbjnnnvUFo+oqCi89957OHPmTFA+Xbt2Vbd/+uknuFwu3HHHHeo+i8WCVq1aBZ3z6KOP4oMPPoDdbofT6cS//vWvUluuAt11113Ys2cPXC4Xdu7cqY4u7NOnj3ordOfOnUH968qqy2nTpmHChAlIS0vDSy+9VOLarnb06FF4PB60bNkyqF527dpV5rkAMHDgQNhsNuzevRvvvvvuNa9569atuPvuu3HbbbchOjoao0aNwuXLl4P+n2AymdCsWTP1deDfDwCys7Px6KOPokWLFrBYLDCbzbDZbOr1nzp1CklJSUF9rQL/boD3VvXp06cRHR2tXmudOnVgt9uDrrdNmzaQ5eL/zcbHx6Ndu3bqa41Gg7p166rlq0i+gf1Ur77G8ho6dCh++eUXfPbZZ+jfv7/aZcnf+nfy5EkkJSUhKSlJPad169aIiYnByZMny8z/zJkzcDqd6N69u7qvTp06JT7313L1d7V169Y4c+YMXC4XevTooabT6XS444471DJNnDgRa9asQceOHfH0009j7969atqxY8ciIyMDrVq1wlNPPYWvvvqqXGWpTWrM4AlFUTBlyhT06NEjqJ/JQw89hOTkZCQmJuLIkSOYOXMmTp06hU8++QQAkJWVFRTUAVBfZ2VlXTeN1WpFUVFRiQ6Z8+bNw/PPPx/yayQKBUknI3HundX23hURGRmJ5s2blyutv5+b+l6SBEVRAHj/cTZy5Eg8//zzSE9Ph8ViwZo1ayrUX8cvKSnpumW6Xjn8/bk2btyI2267LSidwWAIen0jHf8HDRoEg8GAdevWQa/Xw+Vy4YEHHrjuOX379kVBQQEOHjyIHTt2YMaMGQC8gd24ceOQk5ODAwcO4E9/+hOA8tXlc889h4ceeggbN27El19+iTlz5mDNmjX4wx/+UGoZbDYbNBoNDh06VGJgTFRUVJnXrdVqMWrUKMyZMwcHDhzAunXrSqQ5d+4c7rvvPkycOBF///vfUadOHXzzzTcYP348nE4nTCYTgNL/fiKgC8GYMWNw+fJlLF26FMnJyTAYDEhNTQ261VkWm82GLl26YPXq1SWO1a9fX90urSxlfb5uNF9/HhVlNBpxzz334J577sHs2bMxYcIEzJkzB2PHjr2h/EKprO/qtQwYMAA///wzvvjiC2zZsgV33303Jk2ahIULF6Jz5844e/YsvvzyS2zduhUPPvgg0tLSgvrJ1nY1JrCbNGkSjh07hm+++SZo/2OPPaZut2vXDg0aNMDdd9+NM2fOBP2rLJRmzZqFadOmqa+tVmvQv1iIqpMkSZD01TeqtDrs3bsXycnJQX2dfv755yovR+vWrWEwGJCZmYk+ffqU+7ymTZtCp9Ph4MGD6pQjeXl5+O9//4vevXur6bRaLcaMGYMVK1ZAr9dj+PDhZY4EbNasGZKSkvDZZ58hIyNDLddtt92G2267DYsWLYLT6VRb7Mpbly1btkTLli0xdepUjBgxAitWrMAf/vAH6PV6eDyeoLSdOnWCx+PBpUuX0KtXr3LXS6Bx48Zh4cKFGDZsGGJjY0scP3ToEBRFwaJFi9RWsA8//LDC77Nnzx4sW7YM9957LwDvYIXffvtNPd6qVSucP38e2dnZaoNAYL9HAOjcuTPWrl2LuLg4mM3mCpfhWkKVb2l/o/Jq3bq1OnggJSUF58+fx/nz59X/B544cQK5ublo3bp1mXk1a9YMOp0OBw4cUD/3V65cwX//+98KfX+uzlOv12PPnj1ITk4G4O2bePDgwaABWfXr18eYMWMwZswY9OrVCzNmzMDChQsBAGazGcOGDcOwYcPwwAMPoH///sjJySlxt7C2qhGB3eTJk7Fhwwbs3r0bDRs2vG5af5Pu6dOn0axZMyQkJODbb78NSuMfseNvSk9ISCgxiic7Oxtms7nUH02DwVDiX99EVH1atGiBzMxMrFmzBt26dcPGjRtLbdUpj8uXL6ut+X4xMTEwGo1lnhsdHY3p06dj6tSpUBQFPXv2RF5eHvbs2QOz2YwxY8Zc87wxY8aooyHj4uIwZ84cyLJcYtTihAkTkJKSAgDlnk+sb9++WLZsGZo3bx50d6JPnz547bXX1EEWQNl1WVRUhBkzZuCBBx5AkyZNcOHCBRw8eBBDhw4F4L1VbbPZsG3bNnTo0AEmkwktW7bEyJEjMXr0aCxatAidOnXCr7/+im3btqF9+/YYOHBgmdeQkpKC3377TW15u1rz5s3hcrnw2muvYdCgQdizZw/efPPNctVPoBYtWuD9999H165dYbVaMWPGjKD/D9xzzz1o1qwZxowZg/nz5yM/Px9/+9vfAED9W40cORILFizA4MGDMXfuXDRs2BA///wzPvnkEzz99NNl/n/sWkKVb+PGjbF7924MHz4cBoNBHTgQ6PLly/jjH/+IcePGoX379oiOjsZ3332H+fPnY/DgwQCAtLQ0tGvXDiNHjsSSJUvgdrvxxBNPoE+fPkFdDa4lKioK48ePx4wZM1C3bl3ExcXhr3/9a9Dt6YqKjIzExIkT1e9So0aNMH/+fBQWFmL8+PEAgGeffRZdunRBmzZt4HA4sGHDBvU7tXjxYjRo0ACdOnWCLMv46KOPkJCQELK5GWuCau1jJ4TA5MmTsW7dOmzfvh1NmjQp8xx/f5gGDRoAAFJTU3H06NGg/gVbtmyB2WxW/0WRmpqKbdu2BeWzZcsWpKamhuhKiKgy/f73v8fUqVMxefJkdOzYEXv37r3mFCBlSUtLQ4MGDYKWikxv8MILL2D27NmYN28eUlJS0L9/f2zcuLHM36/FixcjNTUV9913H9LS0tCjRw+kpKSUCChbtGiBO++8E7fffntQ36Tr6du3L/Lz80vM3t+nTx/k5+cH9a8rqy41Gg0uX76M0aNHo2XLlnjwwQcxYMAAtXvKnXfeiccffxzDhg1D/fr11VkKVqxYgdGjR+Mvf/kLWrVqhSFDhgS1UJZH3bp1r9lC2aFDByxevBgvv/wy2rZti9WrVwdNU1Fe77zzDq5cuYLOnTtj1KhR6rQZgde/fv162Gw2dOvWDRMmTFBbN/1/K5PJhN27d6NRo0a4//77kZKSgvHjx8Nut99US1uo8p07dy7OnTuHZs2aBd3CDRQVFYXu3bvjlVdeQe/evdG2bVvMnj0bjz76KP7xj38A8Aayn376KWJjY9G7d2+kpaWhadOmWLt2bbnLsmDBAvTq1QuDBg1CWloaevbsiS5dupT7/NK89NJLGDp0KEaNGoXOnTvj9OnT2Lx5s9rSq9frMWvWLLRv3x69e/eGRqNRJ8GOjo7G/Pnz0bVrV3Tr1g3nzp3DF198cVPBZo0T+nEd5Tdx4kRhsVjEzp07xcWLF9WlsLBQCCHE6dOnxdy5c8V3330nzp49Kz799FPRtGlT0bt3bzUPt9st2rZtK/r16ycyMjLEpk2bRP369YNGYv3000/CZDKJGTNmiJMnT4rXX39daDQasWnTpnKVk6Niqbpcb5QU1W42m01YLBbx9ttvB+1XFEU0a9ZMLFq0qMQ5pY2Kpcr3zTfflBhtWxtdPSq2prh6VOytKlSjYqv1Vuwbb7wBACX+lblixQqMHTsWer0eW7duxZIlS1BQUICkpCQMHTpUbRYHvP+62rBhAyZOnIjU1FRERkZizJgxmDt3rpqmSZMm2LhxI6ZOnYqlS5eiYcOGePvtt5Genl4l10lEdPjwYfzwww+44447kJeXp/5G+W97Ad5HPK1ZswZZWVnXnLuOKt+6desQFRWFFi1a4PTp0/jzn/+MHj16VFq/bqJQqtbATpQx2WlSUlKJST9Lk5ycjC+++OK6ae666y4cPny4QuUjIgqlhQsX4tSpU9Dr9ejSpQu+/vrroP5PcXFxqFevHpYvX17qAAKqGvn5+Zg5cyYyMzNRr149pKWl3dAIbKLqUCMGTxARhbtOnTrh0KFD101T1j92Y2JiMGfOnFAWi0oxevRojB49urqLEXJTpkypkU9Z6NixY42YXiVcSKKsXxKC1WqFxWJBXl5eSIe2E5XFbrfj7NmzaNKkSblGbRIRUe10vd/7isQhYTQMhIiIiOjWxsCOqBZgwzoRUXgL1e88AzuiGsz/6KDAZ2ESEVH48f/OX/3IuIri4AmiGkyj0SAmJkadgNtkMpV4UgEREdVeQggUFhbi0qVLiImJKfG85YpiYEdUw/kfjRf4dBUiIgovMTEx6u/9zWBgR1TDSZKEBg0aIC4uDi6Xq7qLQ0REIabT6W66pc6PgR1RLaHRaEL2xSciovDEwRNEREREYYKBHREREVGYYGBHREREFCYY2BERERGFCQZ2RERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYWJCgV2QghkZmbCbrdXVnmIiIiI6AZVOLBr3rw5zp8/X1nlISIiIqIbVKHATpZltGjRApcvX66s8hARERHRDapwH7uXXnoJM2bMwLFjxyqjPERERER0gyQhhKjICbGxsSgsLITb7YZer0dERETQ8ZycnJAWsCawWq2wWCzIy8uD2Wyu7uIQERHRLaQicYi2opm/8sorkCTphgtHRERERJWjwoHd2LFjK6EYRERERHSzKtzHrk+fPnjvvfdQVFRUGeUhIiIiohtU4cCuU6dOmD59OhISEvDoo49i//79lVEuIiIiIqqgCgd2S5YswS+//IIVK1bg0qVL6N27N1q3bo2FCxciOzu7MspIREREROVwQ48U02q1uP/++/Hpp5/iwoULeOihhzB79mwkJSVhyJAh2L59e6jLSURERERluKlnxX777beYM2cOFi1ahLi4OMyaNQv16tXDfffdh+nTp5d5/rx589CtWzdER0cjLi4OQ4YMwalTp4LS2O12TJo0CXXr1kVUVBSGDh1aomUwMzMTAwcOhMlkQlxcHGbMmAG32x2UZufOnejcuTMMBgOaN2+OlStX3sylExEREdU4FQ7sLl26hEWLFqFt27bo1asXfv31V3zwwQc4d+4cnn/+ebz99tv46quv8Oabb5aZ165duzBp0iTs378fW7ZsgcvlQr9+/VBQUKCmmTp1Kj7//HN89NFH2LVrF3755Rfcf//96nGPx4OBAwfC6XRi7969WLVqFVauXIlnn31WTXP27FkMHDgQffv2RUZGBqZMmYIJEyZg8+bNFb18IiIiohqrwhMU6/V6NGvWDOPGjcPYsWNRv379EmmsVisGDx6MHTt2VKgwv/76K+Li4rBr1y707t0beXl5qF+/Pv71r3/hgQceAAD88MMPSElJwb59+/C73/0OX375Je677z788ssviI+PBwC8+eabmDlzJn799Vfo9XrMnDkTGzduDHpaxvDhw5Gbm4tNmzaVWS5OUExERETVpSJxSLlb7AoLCwEA27Ztw8mTJzFjxoxSgzoAMJvNFQ7qACAvLw8AUKdOHQDAoUOH4HK5kJaWpqa5/fbb0ahRI+zbtw8AsG/fPrRr104N6gAgPT0dVqsVx48fV9ME5uFP48+DiIiIKByUO7Dz9507efJkpYx+VRQFU6ZMQY8ePdC2bVsAQFZWFvR6PWJiYoLSxsfHIysrS00TGNT5j/uPXS+N1WotdT4+h8MBq9UatBARERHVdOUO7H744Qekp6fjww8/RHJyMrp3746///3vOHr0aEgKMmnSJBw7dgxr1qwJSX43Y968ebBYLOqSlJRU3UUiIiIiKlO5A7tGjRrhySefxNatW5GdnY0pU6bg6NGj6NWrF5o2bYopU6Zg+/bt8Hg8FS7E5MmTsWHDBuzYsQMNGzZU9yckJMDpdCI3NzcofXZ2NhISEtQ0V7cg+l+XlcZsNiMiIqJEeWbNmoW8vDx1OX/+fIWviYiIiKiq3dB0JxaLBSNGjMCaNWvw66+/4s0334TH48EjjzyC+vXrY/Xq1eXKRwiByZMnY926ddi+fTuaNGkSdLxLly7Q6XTYtm2buu/UqVPIzMxEamoqACA1NRVHjx7FpUuX1DRbtmyB2WxG69at1TSBefjT+PO4msFggNlsDlqIiIiIaroKj4oty+HDh+F2u9GtW7cy0z7xxBP417/+hU8//RStWrVS91ssFrUlbeLEifjiiy+wcuVKmM1mPPnkkwCAvXv3AvBOd9KxY0ckJiZi/vz5yMrKwqhRozBhwgS8+OKLALzTnbRt2xaTJk3CuHHjsH37djz11FPYuHEj0tPTyywnR8USERFRdalIHFLuwO7IkSNlptFqtUhISFBHtZZFkqRS969YsQJjx44F4J2g+C9/+Qs++OADOBwOpKenY9myZeptVgD4+eefMXHiROzcuRORkZEYM2YMXnrpJWi1WjXNzp07MXXqVJw4cQINGzbE7Nmz1fcoCwM7IiIiqi6VEtjJsgxJklBWckmS0LFjR6xatUod3VrbMbAjIiKi6lKROER73aMBzp49W2YaRVGQnZ2NBQsWYOLEifj666/Lmz0RERER3aRyB3arVq3C9OnTYTKZrpuuSZMmePnll9GhQ4ebLhwRERERlV+5R8U+//zzsNls5UrbpEkTdXADEREREVWNcgd2FRk8q9Fo2GJHREREVMUqNI/dtUaxEhEREVH1K3cfOwBo2bJlmcFdTk7OTRWIiIiIiG5MhQK7559/HhaLpbLKQkREREQ3oUKB3fDhwxEXF1dZZSEiIiKim1DuPnbsX0dERERUs1XKqFgiIiIiqnrlvhWrKEplloOIiIiIblKFpjshIiIiopqLgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJBnZEREREYYKBHREREVGYYGBHREREFCYY2BERERGFCQZ2RERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJBnZEREREYYKBHREREVGYqNbAbvfu3Rg0aBASExMhSRLWr18fdHzs2LGQJClo6d+/f1CanJwcjBw5EmazGTExMRg/fjxsNltQmiNHjqBXr14wGo1ISkrC/PnzK/vSiIiIiKpctQZ2BQUF6NChA15//fVrpunfvz8uXryoLh988EHQ8ZEjR+L48ePYsmULNmzYgN27d+Oxxx5Tj1utVvTr1w/Jyck4dOgQFixYgOeeew7Lly+vtOsiIiIiqg7a6nzzAQMGYMCAAddNYzAYkJCQUOqxkydPYtOmTTh48CC6du0KAHjttddw7733YuHChUhMTMTq1avhdDrx7rvvQq/Xo02bNsjIyMDixYuDAkAiIiKi2q7G97HbuXMn4uLi0KpVK0ycOBGXL19Wj+3btw8xMTFqUAcAaWlpkGUZBw4cUNP07t0ber1eTZOeno5Tp07hypUrpb6nw+GA1WoNWoiIiIhquhod2PXv3x/vvfcetm3bhpdffhm7du3CgAED4PF4AABZWVmIi4sLOker1aJOnTrIyspS08THxwel8b/2p7navHnzYLFY1CUpKSnUl0ZEREQUctV6K7Ysw4cPV7fbtWuH9u3bo1mzZti5cyfuvvvuSnvfWbNmYdq0aeprq9XK4I6IiIhqvBrdYne1pk2bol69ejh9+jQAICEhAZcuXQpK43a7kZOTo/bLS0hIQHZ2dlAa/+tr9d0zGAwwm81BCxEREVFNV6sCuwsXLuDy5cto0KABACA1NRW5ubk4dOiQmmb79u1QFAXdu3dX0+zevRsul0tNs2XLFrRq1QqxsbFVewFERERElahaAzubzYaMjAxkZGQAAM6ePYuMjAxkZmbCZrNhxowZ2L9/P86dO4dt27Zh8ODBaN68OdLT0wEAKSkp6N+/Px599FF8++232LNnDyZPnozhw4cjMTERAPDQQw9Br9dj/PjxOH78ONauXYulS5cG3WolIiIiCgeSEEJU15vv3LkTffv2LbF/zJgxeOONNzBkyBAcPnwYubm5SExMRL9+/fDCCy8EDYbIycnB5MmT8fnnn0OWZQwdOhSvvvoqoqKi1DRHjhzBpEmTcPDgQdSrVw9PPvkkZs6cWe5yWq1WWCwW5OXl8bYsERERVamKxCHVGtjVFgzsiIiIqLpUJA6pVX3siIiIiOjaGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJBnZEREREYYKBHREREVGYYGBHREREFCYY2BERERGFCQZ2RERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJBnZEREREYYKBHREREVGYYGBHREREFCYY2BERERGFCQZ2RERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJBnZEREREYYKBHREREVGYYGBHREREFCaqNbDbvXs3Bg0ahMTEREiShPXr1wcdF0Lg2WefRYMGDRAREYG0tDT8+OOPQWlycnIwcuRImM1mxMTEYPz48bDZbEFpjhw5gl69esFoNCIpKQnz58+v7EsjIiIiqnLVGtgVFBSgQ4cOeP3110s9Pn/+fLz66qt48803ceDAAURGRiI9PR12u11NM3LkSBw/fhxbtmzBhg0bsHv3bjz22GPqcavVin79+iE5ORmHDh3CggUL8Nxzz2H58uWVfn1EREREVUkSQojqLgQASJKEdevWYciQIQC8rXWJiYn4y1/+gunTpwMA8vLyEB8fj5UrV2L48OE4efIkWrdujYMHD6Jr164AgE2bNuHee+/FhQsXkJiYiDfeeAN//etfkZWVBb1eDwB45plnsH79evzwww/lKpvVaoXFYkFeXh7MZnPoL56IiIjoGioSh9TYPnZnz55FVlYW0tLS1H0WiwXdu3fHvn37AAD79u1DTEyMGtQBQFpaGmRZxoEDB9Q0vXv3VoM6AEhPT8epU6dw5cqVUt/b4XDAarUGLUREREQ1XY0N7LKysgAA8fHxQfvj4+PVY1lZWYiLiws6rtVqUadOnaA0peUR+B5XmzdvHiwWi7okJSXd/AURERERVbIaG9hVp1mzZiEvL09dzp8/X91FIiIiIipTjQ3sEhISAADZ2dlB+7Ozs9VjCQkJuHTpUtBxt9uNnJycoDSl5RH4HlczGAwwm81BCxEREVFNV2MDuyZNmiAhIQHbtm1T91mtVhw4cACpqakAgNTUVOTm5uLQoUNqmu3bt0NRFHTv3l1Ns3v3brhcLjXNli1b0KpVK8TGxlbR1RARERFVvmoN7Gw2GzIyMpCRkQHAO2AiIyMDmZmZkCQJU6ZMwf/+7//is88+w9GjRzF69GgkJiaqI2dTUlLQv39/PProo/j222+xZ88eTJ48GcOHD0diYiIA4KGHHoJer8f48eNx/PhxrF27FkuXLsW0adOq6aqJiIiIKke1Tneyc+dO9O3bt8T+MWPGYOXKlRBCYM6cOVi+fDlyc3PRs2dPLFu2DC1btlTT5uTkYPLkyfj8888hyzKGDh2KV199FVFRUWqaI0eOYNKkSTh48CDq1auHJ598EjNnzix3OTndCREREVWXisQhNWYeu5qMgR0RERFVl7CYx46IiIiIKoaBHREREVGYYGBHREREFCYY2BERERGFCQZ2RERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJBnZEREREYYKBHREREVGYYGBHREREFCYY2BERERGFCQZ2RERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJBnZEREREYYKBHREREVGYYGBHREREFCYY2BERERGFCQZ2RERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhYkaHdg999xzkCQpaLn99tvV43a7HZMmTULdunURFRWFoUOHIjs7OyiPzMxMDBw4ECaTCXFxcZgxYwbcbndVXwoRERFRpdNWdwHK0qZNG2zdulV9rdUWF3nq1KnYuHEjPvroI1gsFkyePBn3338/9uzZAwDweDwYOHAgEhISsHfvXly8eBGjR4+GTqfDiy++WOXXQkRERFSZanxgp9VqkZCQUGJ/Xl4e3nnnHfzrX//C//zP/wAAVqxYgZSUFOzfvx+/+93v8NVXX+HEiRPYunUr4uPj0bFjR7zwwguYOXMmnnvuOej1+qq+HCIiIqJKU6NvxQLAjz/+iMTERDRt2hQjR45EZmYmAODQoUNwuVxIS0tT095+++1o1KgR9u3bBwDYt28f2rVrh/j4eDVNeno6rFYrjh8/XrUXQkRERFTJanSLXffu3bFy5Uq0atUKFy9exPPPP49evXrh2LFjyMrKgl6vR0xMTNA58fHxyMrKAgBkZWUFBXX+4/5j1+JwOOBwONTXVqs1RFdEREREVHlqdGA3YMAAdbt9+/bo3r07kpOT8eGHHyIiIqLS3nfevHl4/vnnKy1/IiIiKqYoAna3Bw6XAkkCJEmCHLCWJQkAoJUlaGTvYMrrEULA7lJQ4HSjyOlR125FwOVW4PKt3YoCp0fA7fG+r0GrgV4jw6CTfWvva71WVssjAd4yQkJgMepHG2DUaSqxlsqnRgd2V4uJiUHLli1x+vRp3HPPPXA6ncjNzQ1qtcvOzlb75CUkJODbb78NysM/ara0fnt+s2bNwrRp09TXVqsVSUlJIbwSIiKqTfyBR6HTgyKnb+3ywO7yQCNL0MoSdBoZWo0ErSxDp5Gg1Xh7OzlcHjjcindxeWD3rR1uBUUub35FLm+edpcHhU43ipwKXB4FJr0GkQYtIv1rgxZRvrUswVcGBXZfWRzu4m2n7z2dbgUOj3ftXzxCwKjTwKiVEaHXwKjVIEKvgUEnw6jVwK0osNndyLe7ke9wI9/ugs3hfV3g8MCglWHUec816bQw6jWI0Mkw6bXQyBLcHgUuj4DTo5TY9pe3yL84veWuCJ3GV9+yBL1Whlb21r3DraDQ4UahywMh/Kk9gMYOSbZDkl2A5IQkOwHZCUlyedeyC4ACQAIgA0LybUsQvm1JUrxpJA8gKZCgAFLx6yUDHsO9rduE6BN342pVYGez2XDmzBmMGjUKXbp0gU6nw7Zt2zB06FAAwKlTp5CZmYnU1FQAQGpqKv7+97/j0qVLiIuLAwBs2bIFZrMZrVu3vub7GAwGGAyGyr8gIiJSeRSBQqcbhU4PChzB6yKXt7VFUQQ8ioBH+LaF97XTrZQIkAK3FSGgKIAiBITwrQHffgGXR8CtKHB7BFz+tUfAo3gDkSKXp7qrp5ZTAMnlDaBkOySNHZLsgCTbgUg7dLI38PIGWx5AEr5zFADCuw/Ct6g5wulbAHjP8eUZoSmCpCmCJBdB0jhRFXKdQwAwsLuu6dOnY9CgQUhOTsYvv/yCOXPmQKPRYMSIEbBYLBg/fjymTZuGOnXqwGw248knn0Rqaip+97vfAQD69euH1q1bY9SoUZg/fz6ysrLwt7/9DZMmTWLgRkRUQYoiUOB0w2p3w1rkgrXIhXy7G1a7d9vmcAe1TKnbbm/rkd3l3S5t7W9tqg2MvpapCJ23hatEYOhR4FYE3B5vEGLQyTBoNTBoZbVFzLtPRoTO21IWodMiQl+cb4ReA60swe7ywObwBrgFTrd37fDA5nBDADBqZW/Lm8671msENFoHZK0TsuwEJAegcULAASE5oEgOKLDDI9xQFAkeRYJHkaEoEtye4kVIDkiaQihSATxSAVwogMOTjyLFCru7AJIkQ4IMWdJChgYSNABkSEIDBQIe4YRb2OEWTrgU77q6RWgj1MWoMXrX2uK1VtJCgQJFKBBCQBEKFBRvayQNtLIWGlmjbmtlLbSSd1+Ppk2r+xIB1PDA7sKFCxgxYgQuX76M+vXro2fPnti/fz/q168PAHjllVcgyzKGDh0Kh8OB9PR0LFu2TD1fo9Fgw4YNmDhxIlJTUxEZGYkxY8Zg7ty51XVJREQ3RQjvLS1FgdpapSgCivC3YgF2l8d3C80Fm90Nm8Ot3kbLt7tR5HRfdeuv+JaY3eWBKyA48fZHUnytV6LsAoaALMF3+1ELk0GDSF+wo/H1r5JlCRoJ3m3Ju8/gv6Wo08Ck1yBC59/WwqiT1bSy2nfL33/L+1qrkaGTvbdPtRoJOtl7jk4jwagGX95FliW4FBdsThsK3YVQxLUDUpfiQpGrCAWuAhS6C9V1ocu7bXPZYHPaYHPZcMm3zrflo8BVALvbDq2shU6jg17WQ6/XQx+hh16jR6ysh0d4UOAqQLarAAW+xeVwVcnf6GaYtCZE6aMQpYtClD4K0bpoROoiEa2Phkln8gZPkkZdZElWgylZuv5kHhHaCJgNZph1ZpgNZkTro2HWmxGlj4JO1lXRFVYvSQhRNd/UWsxqtcJisSAvLw9ms7m6i0NEtYzd5VFbtfKKvC1chQ4PHG5Pqa1bdpe3f5PV7oLV7msVK3KpLWXuKgqwrkWvkWGO0MFs1CLatzZH6BBt0MKo87VMaYs7nvtbp/Rab2uVmsa39r+ONGhh0nu3y+ocfz0exYMCdwEKnN7AqcBVAKfHCZfiUpfA106PE3a3HQ6PA3aPvXjbty5wFajBV77TF3R57CGs0dAzaoww6UwwaU2I0EXApPVum3QmRGgjoNfo4VE88AgPPIoHbuFWX7sVN4xaI2IMMbAYLIgxxCDGEAOzwYwYQwyi9dEAALfiVheP8MCluOBWvE92itB63zOwRcyoMcKoNZYZnFFJFYlDanSLHRFRVRNCoNDpQW6RCwUOt7ezuUfxtlx5BJweD5xub6uZLeA2pNXuC9rUbResviDOWYW3GDWyBKNWRrRRhyijt6N9tNG7+DvdR+q1xS1Qem8Ll7+ly6DV+DqjS+pa5xsVqJUlRPqCt1BxeVy+Fqx8/ObMR74tHzanDfmufOQ7fdu+YMrhccCpOOH0BCyKEw6PA0XuIjWQK3QXhqx8ZTFqrh+oaGQNInWRiNRGqoGWSWdSt9WWK10UovXRaitWlC4KRq0RbsUNp+KEy+NSr9e/liEjSheFSL03/0hdJCL1kTBpva1edGviX56Iajz/1AVXCp24UuhEbqHLt+0NvopvR0LtVF98a9K3XxEQwt/Z3punyyOQV+RCXpE3z9wiF/IKXXB6Qh+ISRJgNupgjtDCbNQhUq8t7nvla9EK7IcVbdD6WsWKzzFH6BBt1MKk16rTPvhvJZZnCohQUYSCfGc+rA4rch25yHPmIdeRC6vDikJ3IYrcRSh0+da+10WuIvUWZKG7UN12KZV361Av6xGlj4JJa4JBY4BOo4NO9i2+bb2sh06jU1uTDBqD2rrk3zbpTEG3C/2BV6QukgEU1Tj8RBJRqYQQsNrdyPUFUEVO76hAETAqzb8pALWvln9UY9C2wwObr+N3oa/jt78juM0XmPn7P3mDFaj9qQCpylu9AO90CtFGHfQaGTqtr9XK13Kl03ins4gyBAddlsDbkkYtLP59ETpE6bWQ5aoJvK4mhEChuxD5znzkOfLU/lj+Pl6B24WuQtg9djjcV92W9G3nO/NhdVqv26/sRviDsGh9NKJ10cXbvteRukgYtAZvXzONdzFoDGpgFqGNQLTem84fdOk1fGwk3XoY2BHVUv4WJ6dvfiqH29v53T9izj+Kzr9t8/Xp8o/aUzvI+7Ydbo/aEuZvvaqqzvK+KyozhVaWEGPSI9akQ6xJjxiTDtFGHTQygjrHl9aSpZEBjeTf9h+TYYnQIcakQ0yEDjG+PGNMOkToNFXWAlYat+JWA7E8Z5537ciD1WlFvjO/RB+xwHWBq0ANwKwOb3q3cIe8jBHaCLUflsVggVlvRqQuUu1f5R+B6O/XFaGN8N4u1EUG3ZKM0EbcMh3biSobAzuiKiCEgMOtqFMV+DvE51+99rVgFfnm7/KPXAzc9ne0d3oUVMXQpwidBrEmHUwGLfxhTmC8I/n2qpOV+vpvRQZsm3SaoIlVIw0adTvKoIVWI/lupwaM9AxYm43eYCvKoK3WYKu83IobVqdVDcb8wVmuPVcN0mwuG4pcRd7blKUsNpct5OXSylqY9d6Rgv7+Xf5Ay9/K5Q/ASrsladQaEaWLUoM5togR1TwM7IiuQ1EEbE53UPDln7vLPxt7vt3tm6G9eH+h03vLsSBgXdmNXzqNBKNWUyJwKg6ovLPLazUy9L5Z8f23FP2d4/2tV7EmvdoiVhMekVNVhBCwuWzIdeQi156LfFc+HG6H2jnf4QneVlvUrmpVC2VQFq2Lhtlg9raK6b0tY5G6SG+fMVkHvUZfor+YSWuCWe+d7sGsN6vbRo2xVgTGRHTjGNjVEL/ZHFV826v2U4SAw6XA7vbPv6X4njUY/Igd7+N7FPU5hHZ38aN3nNeYTNXhUmD1PUIn1K1iETqNOkox2ujti2X2raONwaMWTb5WL+9jhbyTmBY/w1CGQaNRX1dX/62q5vQ4ccV+xRt8OXJhc9qCprFweVzXnNYi6JjHBYfHobak5TpykefIC+kty2hdtHqbMjAwsxgsiNZHB02YevVtS3/LGjvnE1FF8Bejhhj2z30482tBdReDrkGnkQKCL13A9BH+wEwbNL1ElNE3uWrAcx5NhuJJVsOZIhR18tUCd0HxRKy+ecAC5wILnMZCQAAC6kzv/v8URYHV6R19ecV+pUqmsvD3HYvSRyFCE1FytKTWAKPGiGh9tNq37OrgjUEZEVUH/urUEFrZO0cUlZ8kAQat91E6/rX/Ydb+R+wEToDqf4xP8br4uD5wqgnffn/wZjbqbnrC1JpGEYp3TjCPM+j2ov9W4hXHFeQ5iluych25KHIXeScjvWoiU/+6yO2dXb/IXVTp5ddIGlgMFsQaYhGtj/bejgyYxkIra4tfB05tEZjO99o/6WqsIVadjNWoNVb6NRARVQYGdjXE5qm9q7sIVAN5FE/xY4h8838VuYvUKSj8fb3sbjvsHnuJxxQFTmdhc9nUdP7Z4SuTRtLApDOpk7NG6aOCJmMNnIhVr9FDkiRIkCBLsjogQ5ZkyJKMaH20N/gyxqoz33P2eiKikhjYEVUCl8el3opUgzJXIQrcwY8mClz8+/yBmH8+scomS7L3NqPGGPT4IIvBglhjcSuWfzJW9UHYkiboYdgR2gh1dn1/5/5wauUkIqoNGNgRBRBCqC1hJR5rFLBtdVrVVrF8V35QsGZz2uBUnCEtl1bSBs355Z8l39/fK0ITEdTvK3BmfP+krf65w/wTuxo0Bug1evYDIyIKI/xFryF+tv4Mpye0wUC48/cT89+aDJwDzO7xvna4Hepru9u7FHmK1O3SbmeGkkFjUAMqNbjSmRCtj4ZZb1afD+lf/K8DJ3KN1EVCJ+vY+kVERGViYFdDPLn9SZzNO1vdxaAAEdqIoEcbRemjYNaZ1b5i0bpodX9QOl9LmUln4mz6RERUpRjY1RAWvQV1jHWquxi1jlFjVOf/MmqNQevA/YG3Lv3rCK3v9uXVs+v70vAWJRER1Tb8P1cN8f6971d3EYiIiKiW43wBRERERGGCgR0RERFRmGBgR0RERBQmGNgRERERhQkGdkRERERhgoEdERERUZhgYEdEREQUJhjYEREREYUJTlBMVAahCCiKgOLxroXH/1op3hd43LctFAEhBBTFm4c/HyFQnIeiBOQXnIcQUPPwngsIIQDhXQsBQACAgFC8m/60wiOgCEB4FO/al3/xRXm3RdB1wntNioDi9l6bx+29To9H+M6RIPn+OShJEvyPr5VkqbjMIrj8SuC1+OvhqteSLEHWytBoJWi0csAiQdbIkGTve0kSAMm/LQESIMsSNDoZWp0MjU7jW3tfa3Ua6AwydAYNdEatb62BzqCB3vdaH6GFLPM5vEQUHhjY1RCb3z6G/MuhfQB9uPMGNoHBRGDAc1VgJAKCosAAxBcclThPFAdbQdEPhSW9UQODSQe9SQtDhBYGk3/RwRiphTFSB0OkDkb/EqWDweQNDCWJQSER1RwM7GqIyxdsuJJVWN3FoAqQZQmyRoKkkYq3Ze+2JAdvyzJ8rU7F+2WNb5ED8vBte9MBslScV3Grla+lTAIkSIAMSEBxS1Zp7+vfd3UQ4m9x861ljQxZ4201kzUSNBoZstZ3bZLkDYIRHBD71/5r85chaNt/PQF1EFhWIQQ8bgUet3+tQAnYvlbwLQS8LYsubzq30+NbK3C7FXicClxOD1x2N5x2D1wOD1y+tdPhhuL2Ru1OuwdOuwfIqdhnQJIl6P0tgBG+FkCjrzXQqIFOr4FWr4HWoIFWL0On96bV+tYlWhCN3hZHBotEdKMY2NUQvUe0gsvhqe5i1DrFgUNxwOMPIry3DYP3+W/fBd7KCzwPgHquGnhpigMljUb2BV7g/3zDgMelwFHkhrPIDXuhC85CNxxFbjgK3XAUuuAo8O53FLhhL3AFLYrbexvZm9YNXHGEpEySBDX40+pl31oDnd57q1mnl6E1FAeG3sBSqwaIOkNAQKmXvYtOo65lbSkBPhGFDQZ2NUTDVrHVXQSiW45GJ8Ok08Nk1lfoPCGE2vrn9LcGXrV22t1w+1oM3U4FbofHt+1tMXQ7FTjtbrUF0f8POyECWhArgT9w9Pc51Bv9rYZa37a2OEC8evG1Qqp9GPXBfRplDcfjEVU3BnZERBUkSRL0Ri30Ri0iYQhJnkIR3tvGvoDR7fIEB4a+oNDtVLxpnMW3lV12t/f2st0fNPrOcRWf6xsvU6mBo6yRigM+fXHgpw1sQVQDQV9QqC8e6KLRFQ+YUQfP+AfSaIoH2JToMnDVmi2SdCtjYEdEVAN4++t5g0VYQpu3EN6BQG6Xr+XQt/hbDJ2O4pZDp90Dt8MDp8MDlyO4RVENGl0KPC5vX0aPW1HfR/EIOD2V19pYXmqQp/V2n9BofcFk4G1pf9Cpk6HRa6AJPCcgUFS3dXLQiG05YAS3v/9kYEDLkdZUXRjYERGFOUmS1KlkDBGh/dkXilAHqqgthK7AVsbiVkePyxsUqmlcAee5ggfMeKfbUYIG1ahTDLkFPB5FXV89ct07dZAHCE23xxsSGEj6g0Ktr0XS+1oTsB08xY8/ENVo5WvfEvcPwvEFk7wNTn4M7IiI6IZJsuQd7avXANBVSxn8AZ8/CFQ8wcGgxyWCAkmX0+NtcVQDUQWK2ztfo+IPJgO33YHbwaO3vfl4W0LdruLWS4+vVdMBd5XUgayRgloMdYEDb9RBNb6BN3pvcBh0zNffMnCfPz+NliO1a5NbKrB7/fXXsWDBAmRlZaFDhw547bXXcMcdd1R3sYiI6CZ4+9wBWr2mWsvhb70MHCDjnYJHqEFgYDDoCQgWFX/AGLjfpRT3u3QETNfj618Z2HdS8Qg4i9xwFlXChUkoDhZ9t7L9A3CCBt8EtCYGBofB28F9LjVsaQy5WyawW7t2LaZNm4Y333wT3bt3x5IlS5Ceno5Tp04hLi6uuotHRES1XGDrZURU5b+fEN7b0kEDbFweuBwlR2H7+0e6HMXBYmB/y6sXt9NT/LQaAW+LpMMDwBXSa5BkqUSfx6DR1nqN2o9RHWSjl9Xpf4IG6wQOwvH3nwzoXxnYZzKcWyAlIcQtMa9+9+7d0a1bN/zjH/8AACiKgqSkJDz55JN45plnrnuu1WqFxWJBXl4ezGZzyMumKAqcv+bgFvlTVKnrf3er64tdM//O/PgRkZ8kAR7f5N9ulwK3S8DlUqD4+kS6nIp3gI1Tgcc/Stsh4HR64PH3rfQHmf4WSt8+t6v6n+ij0frmJvX3aQwYde0dSOMfTCOrA2sk/6TtvuOBa1mW0bxHY8TERVZKeSsSh9wSLXZOpxOHDh3CrFmz1H2yLCMtLQ379u0rkd7hcMDhKO51a7VaK7V8rrxc/PTyNzDr61bq+xAREd0MCd6elDoApnKfJXsXPbxLTeX2LQC8kafHt5RPboQWMf1bhb5cFXRL3Nz+7bff4PF4EB8fH7Q/Pj4eWVlZJdLPmzcPFotFXZKSkqqqqERERFQLGUw1o62sZpSihpk1axamTZumvrZarZUa3OksMWg6q2el5X/LCGXTfnnyCscuGjd6TZVZX+Imzq3OvMNVONbXrdgNobZec7WVu+w31tWpUwXlKNstEdjVq1cPGo0G2dnZQfuzs7ORkJBQIr3BYIDBEJrZ5MtDlmUY69ersvcjIiKi8HRL3IrV6/Xo0qULtm3bpu5TFAXbtm1DampqNZaMiIiIKHRuiRY7AJg2bRrGjBmDrl274o477sCSJUtQUFCARx55pLqLRkRERBQSt0xgN2zYMPz666949tlnkZWVhY4dO2LTpk0lBlQQERER1Va3zDx2N6Oy57EjIiIiupaKxCG3RB87IiIiolsBAzsiIiKiMMHAjoiIiChMMLAjIiIiChMM7IiIiIjCBAM7IiIiojDBwI6IiIgoTDCwIyIiIgoTDOyIiIiIwgQDOyIiIqIwccs8K/Zm+J+6ZrVaq7kkREREdKvxxx/leQosA7tyyM/PBwAkJSVVc0mIiIjoVpWfnw+LxXLdNJIoT/h3i1MUBb/88guio6MhSVJ1F6dKWa1WJCUl4fz582U+eJi8WGcVw/qqGNZXxbHOKob1VTFVUV9CCOTn5yMxMRGyfP1edGyxKwdZltGwYcPqLka1MpvN/IJXEOusYlhfFcP6qjjWWcWwviqmsuurrJY6Pw6eICIiIgoTDOyIiIiIwgQDO7oug8GAOXPmwGAwVHdRag3WWcWwviqG9VVxrLOKYX1VTE2rLw6eICIiIgoTbLEjIiIiChMM7IiIiIjCBAM7IiIiojDBwO4WMG/ePHTr1g3R0dGIi4vDkCFDcOrUqaA0drsdkyZNQt26dREVFYWhQ4ciOzs7KM1TTz2FLl26wGAwoGPHjqW+15EjR9CrVy8YjUYkJSVh/vz5lXVZlSYU9fX9999jxIgRSEpKQkREBFJSUrB06dIS77Vz50507twZBoMBzZs3x8qVKyv78kIuFPV1+fJl9O/fH4mJiTAYDEhKSsLkyZNLPMYvHOoLCN130u/y5cto2LAhJElCbm5u0LFwqLNQ1ZckSSWWNWvWBKVhfQVbuXIl2rdvD6PRiLi4OEyaNCnoeDj85gOhqbOVK1eW+hmTJAmXLl1S01X6Z0xQ2EtPTxcrVqwQx44dExkZGeLee+8VjRo1EjabTU3z+OOPi6SkJLFt2zbx3Xffid/97nfizjvvDMrnySefFP/4xz/EqFGjRIcOHUq8T15enoiPjxcjR44Ux44dEx988IGIiIgQ//znPyv7EkMqFPX1zjvviKeeekrs3LlTnDlzRrz//vsiIiJCvPbaa2qan376SZhMJjFt2jRx4sQJ8dprrwmNRiM2bdpUpdd7s0JRXzk5OWLZsmXi4MGD4ty5c2Lr1q2iVatWYsSIEWqacKkvIUL3nfQbPHiwGDBggAAgrly5ou4PlzoLVX0BECtWrBAXL15Ul6KiIvU46yu4vhYtWiQSExPF6tWrxenTp8X3338vPv30U/V4uPzmCxGaOissLAz6bF28eFGkp6eLPn36qGmq4jPGwO4WdOnSJQFA7Nq1SwghRG5urtDpdOKjjz5S05w8eVIAEPv27Stx/pw5c0oN7JYtWyZiY2OFw+FQ982cOVO0atUq9BdRhW62vvyeeOIJ0bdvX/X1008/Ldq0aROUZtiwYSI9PT3EV1C1QlVfS5cuFQ0bNlRfh2t9CXFzdbZs2TLRp08fsW3bthKBXbjW2Y3WFwCxbt26a+bL+iqur5ycHBERESG2bt16zXzD9TdfiND8jl26dEnodDrx3nvvqfuq4jPGW7G3oLy8PABAnTp1AACHDh2Cy+VCWlqamub2229Ho0aNsG/fvnLnu2/fPvTu3Rt6vV7dl56ejlOnTuHKlSshKn3VC1V95eXlqXkA3voKzAPw1ldF6rwmCkV9/fLLL/jkk0/Qp08fdV+41hdw43V24sQJzJ07F++9916pz48M1zq7mc/YpEmTUK9ePdxxxx149913IQJm/GJ9FdfXli1boCgK/u///g8pKSlo2LAhHnzwQZw/f149J1x/84HQ/I699957MJlMeOCBB9R9VfEZY2B3i1EUBVOmTEGPHj3Qtm1bAEBWVhb0ej1iYmKC0sbHxyMrK6vceWdlZSE+Pr5EHv5jtVGo6mvv3r1Yu3YtHnvsMXXfterLarWiqKgotBdSRW62vkaMGAGTyYTbbrsNZrMZb7/9tnosHOsLuPE6czgcGDFiBBYsWIBGjRqVmnc41tnNfMbmzp2LDz/8EFu2bMHQoUPxxBNP4LXXXlOPs76K6+unn36Coih48cUXsWTJEvz73/9GTk4O7rnnHjidTjWfcPvNB0L3u//OO+/goYceQkREhLqvKj5j2pDkQrXGpEmTcOzYMXzzzTfVXZRaIRT1dezYMQwePBhz5sxBv379Qli6mudm6+uVV17BnDlz8N///hezZs3CtGnTsGzZshCXsma50TqbNWsWUlJS8PDDD1dSyWqmm/mMzZ49W93u1KkTCgoKsGDBAjz11FOhLGKNcqP1pSgKXC4XXn31VfV364MPPkBCQgJ27NiB9PT0yihujRCK3/19+/bh5MmTeP/990NYsvJhi90tZPLkydiwYQN27NiBhg0bqvsTEhLgdDpLjKbLzs5GQkJCufNPSEgoMarK/7oi+dQUoaivEydO4O6778Zjjz2Gv/3tb0HHrlVfZrM56F94tUUo6ishIQG33347fv/73+Of//wn3njjDVy8eFE9Fk71BdxcnW3fvh0fffQRtFottFot7r77bgBAvXr1MGfOHDWfcKqzUP+Gde/eHRcuXIDD4VDzYX1566tBgwYAgNatW6vH69evj3r16iEzM1PNJ5x+84HQfcbefvttdOzYEV26dAnaXxWfMQZ2twAhBCZPnox169Zh+/btaNKkSdDxLl26QKfTYdu2beq+U6dOITMzE6mpqeV+n9TUVOzevRsul0vdt2XLFrRq1QqxsbE3fyFVJFT1dfz4cfTt2xdjxozB3//+9xLvk5qaGpQH4K2vitR5TVBZny9FUQBA/Z9uuNQXEJo6+/jjj/H9998jIyMDGRkZ6m3rr7/+Wp2SIlzqrLI+YxkZGYiNjVWf8cn6Kq6vHj16qPv9cnJy8NtvvyE5ORlA+PzmA6H9jNlsNnz44YcYP358ifepks9YyIZhUI01ceJEYbFYxM6dO4OGYRcWFqppHn/8cdGoUSOxfft28d1334nU1FSRmpoalM+PP/4oDh8+LP70pz+Jli1bisOHD4vDhw+rI6Jyc3NFfHy8GDVqlDh27JhYs2aNMJlMtW7oeyjq6+jRo6J+/fri4YcfDsrj0qVLahr/sPcZM2aIkydPitdff71WTq0QivrauHGjePfdd8XRo0fF2bNnxYYNG0RKSoro0aOHmiZc6kuI0H0nA+3YseOa053U9joLRX199tln4q233hJHjx4VP/74o1i2bJkwmUzi2WefVdOwvoI/X4MHDxZt2rQRe/bsEUePHhX33XefaN26tXA6nUKI8PnNFyK038m3335bGI3GoO+iX1V8xhjY3QIAlLqsWLFCTVNUVCSeeOIJERsbK0wmk/jDH/4gLl68GJRPnz59Ss3n7Nmzaprvv/9e9OzZUxgMBnHbbbeJl156qYquMnRCUV9z5swpNY/k5OSg99qxY4fo2LGj0Ov1omnTpkHvUVuEor62b98uUlNThcViEUajUbRo0ULMnDmzxA9jONSXEKH7TgYqLbDz76/tdRaK+vryyy9Fx44dRVRUlIiMjBQdOnQQb775pvB4PEHvxfoqlpeXJ8aNGydiYmJEnTp1xB/+8AeRmZkZlCYcfvOFCO13MjU1VTz00EPXfK/K/oxJvgsiIiIiolqOfeyIiIiIwgQDOyIiIqIwwcCOiIiIKEwwsCMiIiIKEwzsiIiIiMIEAzsiIiKiMMHAjoiIiChMMLAjIiIiChMM7IiIiIjCBAM7IqJyEkIgLS0N6enpJY4tW7YMMTExuHDhQjWUjIjIi4EdEVE5SZKEFStW4MCBA/jnP/+p7j979iyefvppvPbaa2jYsGFI39PlcoU0PyIKbwzsiIgqICkpCUuXLsX06dNx9uxZCCEwfvx49OvXD506dcKAAQMQFRWF+Ph4jBo1Cr/99pt67qZNm9CzZ0/ExMSgbt26uO+++3DmzBn1+Llz5yBJEtauXYs+ffrAaDRi9erV1XGZRFRLSUIIUd2FICKqbYYMGYK8vDzcf//9eOGFF3D8+HG0adMGEyZMwOjRo1FUVISZM2fC7XZj+/btAICPP/4YkiShffv2sNlsePbZZ3Hu3DlkZGRAlmWcO3cOTZo0QePGjbFo0SJ06tQJRqMRDRo0qOarJaLagoEdEdENuHTpEtq0aYOcnBx8/PHHOHbsGL7++mts3rxZTXPhwgUkJSXh1KlTaNmyZYk8fvvtN9SvXx9Hjx5F27Zt1cBuyZIl+POf/1yVl0NEYYK3YomIbkBcXBz+9Kc/ISUlBUOGDMH333+PHTt2ICoqSl1uv/12AFBvt/74448YMWIEmjZtCrPZjMaNGwMAMjMzg/Lu2rVrlV4LEYUPbXUXgIiottJqtdBqvT+jNpsNgwYNwssvv1winf9W6qBBg5CcnIy33noLiYmJUBQFbdu2hdPpDEofGRlZ+YUnorDEwI6IKAQ6d+6Mjz/+GI0bN1aDvUCXL1/GqVOn8NZbb6FXr14AgG+++aaqi0lEYY63YomIQmDSpEnIycnBiBEjcPDgQZw5cwabN2/GI488Ao/Hg9jYWNStWxfLly/H6dOnsX37dkybNq26i01EYYaBHRFRCCQmJmLPnj3weDzo168f2rVrhylTpiAmJgayLEOWZaxZswaHDh1C27ZtMXXqVCxYsKC6i01EYYajYomIiIjCBFvsiIiIiMIEAzsiIiKiMMHAjoiIiChMMLAjIiIiChMM7IiIiIjCBAM7IiIiojDBwI6IiIgoTDCwIyIiIgoTDOyIiIiIwgQDOyIiIqIwwcCOiIiIKEwwsCMiIiIKE/8f2QPJUqP/ewoAAAAASUVORK5CYII=",
"text/plain": [
- " 2005 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000725 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.098442 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.017934 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.004330 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.023452 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002061 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.084363 \n",
- "\n",
- " 2006 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000725 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.099530 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.018254 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.004330 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.024887 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002089 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.083776 \n",
- "\n",
- " 2007 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000688 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.103210 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.018291 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.004330 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.028227 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002136 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.082994 \n",
- "\n",
- " 2008 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000626 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.108532 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.018583 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.004330 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.030650 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002136 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.084816 \n",
- "\n",
- " 2009 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000626 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.113571 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.019379 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.004330 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.032522 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002136 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.087523 \n",
- "\n",
- " 2010 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000626 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.114161 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.020052 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.004771 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.034413 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002136 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.087156 \n",
- "\n",
- " 2011 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000655 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.113096 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.020303 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.005573 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.037644 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002137 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.087135 \n",
- "\n",
- " 2012 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000704 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.116885 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.020501 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.005687 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.041575 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002139 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.089239 \n",
- "\n",
- " 2013 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000704 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.120688 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.021099 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.005687 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.048268 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002139 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.088468 \n",
- "\n",
- " 2014 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.000704 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.125068 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.021732 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.005677 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 0.057504 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.002139 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.000000 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.087969 \n",
- "\n",
- " ... \\\n",
- "model scenario region variable unit ... \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr ... \n",
- "\n",
- " 2061 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.640144 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.853833 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.393090 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.458206 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.070650 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.888570 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.092825 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.013473 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.687098 \n",
- "\n",
- " 2062 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.611040 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.820184 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.372561 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.424978 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.043190 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.748170 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.088376 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.012885 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.657721 \n",
- "\n",
- " 2063 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.587707 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.852033 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.401736 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.440630 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.044780 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.765670 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.085639 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.012455 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.630744 \n",
- "\n",
- " 2064 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.566017 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.818461 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.388353 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.427114 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.047020 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.931880 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.082554 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.011983 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.660829 \n",
- "\n",
- " 2065 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.701597 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.849846 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.373291 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.445782 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.053170 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.881490 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.079163 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.011486 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.636016 \n",
- "\n",
- " 2066 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.665704 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.813574 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.389484 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.414364 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.005780 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.743370 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.107793 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.010958 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.668544 \n",
- "\n",
- " 2067 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.640081 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.834648 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.375624 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.426094 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.027230 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.839330 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.104399 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.010568 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.641752 \n",
- "\n",
- " 2068 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.617566 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.802674 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.364750 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.467019 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.025420 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.784380 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.101185 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.010126 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.667759 \n",
- "\n",
- " 2069 \\\n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.589881 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.831823 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.387195 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.445350 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 1.009230 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.764510 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.096227 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.014696 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.642032 \n",
- "\n",
- " 2070 \n",
- "model scenario region variable unit \n",
- "WILIAM Baseline no policies no CO2tax China Secondary Energy|Electricity|Geothermal EJ/yr 0.561562 \n",
- " East Asia and Oceania Secondary Energy|Electricity|Geothermal EJ/yr 0.795460 \n",
- " European Union (27 member countries) Secondary Energy|Electricity|Geothermal EJ/yr 0.370103 \n",
- " India Secondary Energy|Electricity|Geothermal EJ/yr 0.416520 \n",
- " Latin America Secondary Energy|Electricity|Geothermal EJ/yr 0.976543 \n",
- " Rest of the World Secondary Energy|Electricity|Geothermal EJ/yr 1.683820 \n",
- " Russia Secondary Energy|Electricity|Geothermal EJ/yr 0.091961 \n",
- " United Kingdom Secondary Energy|Electricity|Geothermal EJ/yr 0.014009 \n",
- " United States, Mexico and Canada Secondary Energy|Electricity|Geothermal EJ/yr 0.648005 \n",
- "\n",
- "[9 rows x 66 columns]"
+ "