2  Model

Pdf version of the model mathematical framework can be found here.

2.1 Sets

The model sets
Name Alias Description
comm c,cp,ce,cn commodity
region r,rp,re,rn region
year y,yp,ye,yn year
slice s,sp,se,sn time slices
sup s1,s1p,s1e,s1n supply
dem d,dp,de,dn demand
tech t,tp,te,tn technology
stg st1,st1p,st1e,st1n storage
trade t1,t1p,t1e,t1n trade between regions
expp e,ep,ee,en export to the rest of the world (ROW)
imp i,ip,ie,in import from the ROW
group g,gp,ge,gn group of input or output commodities in technology
weather wth1,wth1p,wth1e,wth1n weather

2.2 Parameters

The model parameters
Name Alias Description
pYearFraction(year) pYearFractiony fraction of sum of sampled slices in year – experimental
pTechOlife(tech, region) pTechOlifet,r Operational life of technologies
pTechCinp2ginp(tech, comm, region, year, slice) pTechCinp2ginpt,c,r,y,s Commodity input to group input
pTechGinp2use(tech, group, region, year, slice) pTechGinp2uset,g,r,y,s Group input into use
pTechCinp2use(tech, comm, region, year, slice) pTechCinp2uset,c,r,y,s Commodity input to use
pTechUse2cact(tech, comm, region, year, slice) pTechUse2cactt,c,r,y,s Use to commodity activity
pTechCact2cout(tech, comm, region, year, slice) pTechCact2coutt,c,r,y,s Commodity activity to commodity output
pTechEmisComm(tech, comm) pTechEmisCommt,c Combustion factor for input commodity (from 0 to 1)
pTechAct2AInp(tech, comm, region, year, slice) pTechAct2AInpt,c,r,y,s Activity to aux-commodity input
pTechCap2AInp(tech, comm, region, year, slice) pTechCap2AInpt,c,r,y,s Capacity to aux-commodity input
pTechNCap2AInp(tech, comm, region, year, slice) pTechNCap2AInpt,c,r,y,s New capacity to aux-commodity input
pTechCinp2AInp(tech, comm, comm, region, year, slice) pTechCinp2AInpt,c,c,r,y,s Commodity input to aux-commodity input
pTechCout2AInp(tech, comm, comm, region, year, slice) pTechCout2AInpt,c,c,r,y,s Commodity output to aux-commodity input
pTechAct2AOut(tech, comm, region, year, slice) pTechAct2AOutt,c,r,y,s Activity to aux-commodity output
pTechCap2AOut(tech, comm, region, year, slice) pTechCap2AOutt,c,r,y,s Capacity to aux-commodity output
pTechNCap2AOut(tech, comm, region, year, slice) pTechNCap2AOutt,c,r,y,s New capacity to aux-commodity output
pTechCinp2AOut(tech, comm, comm, region, year, slice) pTechCinp2AOutt,c,c,r,y,s Commodity to aux-commodity output
pTechCout2AOut(tech, comm, comm, region, year, slice) pTechCout2AOutt,c,c,r,y,s Commodity-output to aux-commodity input
pTechFixom(tech, region, year) pTechFixomt,r,y Fixed Operating and maintenance (O\
pTechVarom(tech, region, year, slice) pTechVaromt,r,y,s Variable O\
pTechInvcost(tech, region, year) pTechInvcostt,r,y Investment costs (per unit of capacity)
pTechEac(tech, region, year) pTechEact,r,y Equivalent annual (investment) cost
pTechRetCost(tech, region, year) pTechRetCostt,r,y Early retirement costs
pTechShareLo(tech, comm, region, year, slice) pTechShareLot,c,r,y,s Lower bound of the share of the commodity in total group input or output
pTechShareUp(tech, comm, region, year, slice) pTechShareUpt,c,r,y,s Upper bound of the share of the commodity in total group input or output
pTechAfLo(tech, region, year, slice) pTechAfLot,r,y,s Lower bound on availability factor by slices
pTechAfUp(tech, region, year, slice) pTechAfUpt,r,y,s Upper bound on availability factor by slices
pTechRampUp(tech, region, year, slice) pTechRampUpt,r,y,s Ramp Up on availability factor
pTechRampDown(tech, region, year, slice) pTechRampDownt,r,y,s Ramp Down on availability
pTechAfsLo(tech, region, year, slice) pTechAfsLot,r,y,s Lower bound on availability factor by groups of slices
pTechAfsUp(tech, region, year, slice) pTechAfsUpt,r,y,s Upper bound on availability factor by groups of slices
pTechAfcLo(tech, comm, region, year, slice) pTechAfcLot,c,r,y,s Lower bound for commodity output
pTechAfcUp(tech, comm, region, year, slice) pTechAfcUpt,c,r,y,s Upper bound for commodity output
pTechStock(tech, region, year) pTechStockt,r,y Technology capacity stock
pTechCapUp(tech, region, year) pTechCapUpt,r,y Upper bound on technology capacity
pTechCapLo(tech, region, year) pTechCapLot,r,y Lower bound on technology capacity
pTechNewCapUp(tech, region, year) pTechNewCapUpt,r,y Upper bound on new technology capacity
pTechNewCapLo(tech, region, year) pTechNewCapLot,r,y Lower bound on new technology capacity
pTechRetUp(tech, region, year) pTechRetUpt,r,y Upper bound on early retirement
pTechRetLo(tech, region, year) pTechRetLot,r,y Lower bound on early retirement
pTechCap2act(tech) pTechCap2actt Technology capacity units to activity units conversion factor
pTechCvarom(tech, comm, region, year, slice) pTechCvaromt,c,r,y,s Commodity-specific variable costs (per unit of commodity input or output)
pTechAvarom(tech, comm, region, year, slice) pTechAvaromt,c,r,y,s Auxilary Commodity-specific variable costs (per unit of commodity input or output)
pDiscount(region, year) pDiscountr,y Discount rate (can be region and year specific)
pDiscountFactor(region, year) pDiscountFactorr,y Discount factor (cumulative)
pDiscountFactorMileStone(region, year) pDiscountFactorMileStoner,y Discount factor (cumulative) sum for MileStone
pSupCost(sup, comm, region, year, slice) pSupCosts1,c,r,y,s Costs of supply (price per unit)
pSupAvaUp(sup, comm, region, year, slice) pSupAvaUps1,c,r,y,s Upper bound for supply
pSupAvaLo(sup, comm, region, year, slice) pSupAvaLos1,c,r,y,s Lower bound for supply
pSupReserveUp(sup, comm, region) pSupReserveUps1,c,r Upper constraint on cumulative supply
pSupReserveLo(sup, comm, region) pSupReserveLos1,c,r Lower constraint on cumulative supply
pDemand(dem, comm, region, year, slice) pDemandd,c,r,y,s Exogenous demand
pEmissionFactor(comm, comm) pEmissionFactorc,c Emission factor
pDummyImportCost(comm, region, year, slice) pDummyImportCostc,r,y,s Dummy costs parameters (for debugging)
pDummyExportCost(comm, region, year, slice) pDummyExportCostc,r,y,s Dummy costs parameters (for debuging)
pTaxCostInp(comm, region, year, slice) pTaxCostInpc,r,y,s Commodity taxes for input
pTaxCostOut(comm, region, year, slice) pTaxCostOutc,r,y,s Commodity taxes for output
pTaxCostBal(comm, region, year, slice) pTaxCostBalc,r,y,s Commodity taxes for balance
pSubCostInp(comm, region, year, slice) pSubCostInpc,r,y,s Commodity subsidies for input
pSubCostOut(comm, region, year, slice) pSubCostOutc,r,y,s Commodity subsidies for output
pSubCostBal(comm, region, year, slice) pSubCostBalc,r,y,s Commodity subsidies for balance
pAggregateFactor(comm, comm) pAggregateFactorc,c Aggregation factor of commodities
pPeriodLen(year) pPeriodLeny Length of milestone-year-period
pSliceShare(slice) pSliceShares Slice share in year
pSliceWeight(slice) pSliceWeights Slice weight
ordYear(year) ordYeary ord year (used in GLPK-MathProg)
cardYear(year) cardYeary card year (used in GLPK-MathProg)
pStorageInpEff(stg, comm, region, year, slice) pStorageInpEffst1,c,r,y,s Storage input efficiency
pStorageOutEff(stg, comm, region, year, slice) pStorageOutEffst1,c,r,y,s Storage output efficiency
pStorageStgEff(stg, comm, region, year, slice) pStorageStgEffst1,c,r,y,s Storage time-efficiency (annual)
pStorageStock(stg, region, year) pStorageStockst1,r,y Storage capacity stock
pStorageCapUp(stg, region, year) pStorageCapUpst1,r,y Upper bound on storage capacity
pStorageCapLo(stg, region, year) pStorageCapLost1,r,y Lower bound on storage capacity
pStorageNewCapUp(stg, region, year) pStorageNewCapUpst1,r,y Upper bound on new storage capacity
pStorageNewCapLo(stg, region, year) pStorageNewCapLost1,r,y Lower bound on new storage capacity
pStorageRetUp(stg, region, year) pStorageRetUpst1,r,y Upper bound on early retirement
pStorageRetLo(stg, region, year) pStorageRetLost1,r,y Lower bound on early retirement
pStorageOlife(stg, region) pStorageOlifest1,r Storage operational life
pStorageCostStore(stg, region, year, slice) pStorageCostStorest1,r,y,s Storing costs per stored amount (annual)
pStorageCostInp(stg, region, year, slice) pStorageCostInpst1,r,y,s Storage input costs
pStorageCostOut(stg, region, year, slice) pStorageCostOutst1,r,y,s Storage output costs
pStorageFixom(stg, region, year) pStorageFixomst1,r,y Storage fixed O\
pStorageInvcost(stg, region, year) pStorageInvcostst1,r,y Storage investment costs
pStorageEac(stg, region, year) pStorageEacst1,r,y Storage equivalent annual costs
pStorageRetCost(stg, region, year) pStorageRetCostst1,r,y Storage early retirement costs
pStorageCap2stg(stg) pStorageCap2stgst1 Storage (dis)charging capacity to accumulating capacity (to be renamed to duration)
pStorageAfLo(stg, region, year, slice) pStorageAfLost1,r,y,s Storage availability factor lower bound (minimum charging level)
pStorageAfUp(stg, region, year, slice) pStorageAfUpst1,r,y,s Storage availability factor upper bound (maximum charging level)
pStorageCinpUp(stg, comm, region, year, slice) pStorageCinpUpst1,c,r,y,s Storage input upper bound
pStorageCinpLo(stg, comm, region, year, slice) pStorageCinpLost1,c,r,y,s Storage input lower bound
pStorageCoutUp(stg, comm, region, year, slice) pStorageCoutUpst1,c,r,y,s Storage output upper bound
pStorageCoutLo(stg, comm, region, year, slice) pStorageCoutLost1,c,r,y,s Storage output lower bound
pStorageNCap2Stg(stg, comm, region, year, slice) pStorageNCap2Stgst1,c,r,y,s Initial storage charge level for new investment
pStorageCharge(stg, comm, region, year, slice) pStorageChargest1,c,r,y,s Initial storage charge level for stock
pStorageStg2AInp(stg, comm, region, year, slice) pStorageStg2AInpst1,c,r,y,s Storage level to auxilary input
pStorageStg2AOut(stg, comm, region, year, slice) pStorageStg2AOutst1,c,r,y,s Storage level output
pStorageCinp2AInp(stg, comm, region, year, slice) pStorageCinp2AInpst1,c,r,y,s Storage input to auxilary input
pStorageCinp2AOut(stg, comm, region, year, slice) pStorageCinp2AOutst1,c,r,y,s Storage input to auxilary output
pStorageCout2AInp(stg, comm, region, year, slice) pStorageCout2AInpst1,c,r,y,s Storage output to auxilary input
pStorageCout2AOut(stg, comm, region, year, slice) pStorageCout2AOutst1,c,r,y,s Storage output to auxilary output
pStorageCap2AInp(stg, comm, region, year, slice) pStorageCap2AInpst1,c,r,y,s Storage capacity to auxilary input
pStorageCap2AOut(stg, comm, region, year, slice) pStorageCap2AOutst1,c,r,y,s Storage capacity to auxilary output
pStorageNCap2AInp(stg, comm, region, year, slice) pStorageNCap2AInpst1,c,r,y,s Storage new capacity to auxilary input
pStorageNCap2AOut(stg, comm, region, year, slice) pStorageNCap2AOutst1,c,r,y,s Storage new capacity to auxilary output
pTradeIrEff(trade, region, region, year, slice) pTradeIrEfft1,r,r,y,s Inter-regional trade efficiency
pTradeIrUp(trade, region, region, year, slice) pTradeIrUpt1,r,r,y,s Upper bound on trade flow
pTradeIrLo(trade, region, region, year, slice) pTradeIrLot1,r,r,y,s Lower bound on trade flow
pTradeIrCost(trade, region, region, year, slice) pTradeIrCostt1,r,r,y,s Costs of trade flow
pTradeIrMarkup(trade, region, region, year, slice) pTradeIrMarkupt1,r,r,y,s Markup of trade flow
pTradeIrCsrc2Ainp(trade, comm, region, region, year, slice) pTradeIrCsrc2Ainpt1,c,r,r,y,s Auxiliary input commodity in source region
pTradeIrCsrc2Aout(trade, comm, region, region, year, slice) pTradeIrCsrc2Aoutt1,c,r,r,y,s Auxiliary output commodity in source region
pTradeIrCdst2Ainp(trade, comm, region, region, year, slice) pTradeIrCdst2Ainpt1,c,r,r,y,s Auxiliary input commodity in destination region
pTradeIrCdst2Aout(trade, comm, region, region, year, slice) pTradeIrCdst2Aoutt1,c,r,r,y,s Auxiliary output commodity in destination region
pExportRowRes(expp) pExportRowRese Upper bound on cumulative export to ROW
pExportRowUp(expp, region, year, slice) pExportRowUpe,r,y,s Upper bound on export to ROW
pExportRowLo(expp, region, year, slice) pExportRowLoe,r,y,s Lower bound on export to ROW
pExportRowPrice(expp, region, year, slice) pExportRowPricee,r,y,s Export prices to ROW
pImportRowRes(imp) pImportRowResi Upper bound on cumulative import to ROW
pImportRowUp(imp, region, year, slice) pImportRowUpi,r,y,s Upper bount on import from ROW
pImportRowLo(imp, region, year, slice) pImportRowLoi,r,y,s Lower bound on import from ROW
pImportRowPrice(imp, region, year, slice) pImportRowPricei,r,y,s Import prices from ROW
pTradeStock(trade, year) pTradeStockt1,y Existing capacity
pTradeCapUp(trade, year) pTradeCapUpt1,y Upper bound on trade capacity
pTradeCapLo(trade, year) pTradeCapLot1,y Lower bound on trade capacity
pTradeNewCapUp(trade, year) pTradeNewCapUpt1,y Upper bound on new trade capacity
pTradeNewCapLo(trade, year) pTradeNewCapLot1,y Lower bound on new trade capacity
pTradeRetUp(trade, year) pTradeRetUpt1,y Upper bound on early retirement
pTradeRetLo(trade, year) pTradeRetLot1,y Lower bound on early retirement
pTradeOlife(trade) pTradeOlifet1 Operational life
pTradeInvcost(trade, region, year) pTradeInvcostt1,r,y Overnight investment costs
pTradeEac(trade, region, year) pTradeEact1,r,y Equivalent annual costs
pTradeRetCost(trade, region, year) pTradeRetCostt1,r,y Early retirement costs
pTradeFixom(trade, year) pTradeFixomt1,y Fixed O\
pTradeVarom(trade, region, region, year, slice) pTradeVaromt1,r,r,y,s Variable O\
pTradeCap2Act(trade) pTradeCap2Actt1 Capacity to activity factor
pWeather(weather, region, year, slice) pWeatherwth1,r,y,s weather factors
pSupWeatherUp(weather, sup) pSupWeatherUpwth1,s1 weather factor for supply upper value (ava.up)
pSupWeatherLo(weather, sup) pSupWeatherLowth1,s1 weather factor for supply lower value (ava.lo)
pTechWeatherAfLo(weather, tech) pTechWeatherAfLowth1,t weather factor for technology availability lower value (af.lo)
pTechWeatherAfUp(weather, tech) pTechWeatherAfUpwth1,t weather factor for technology availability upper value (af.up)
pTechWeatherAfsLo(weather, tech) pTechWeatherAfsLowth1,t weather factor for technology availability lower value (af.lo)
pTechWeatherAfsUp(weather, tech) pTechWeatherAfsUpwth1,t weather factor for technology availability upper value (afs.lo)
pTechWeatherAfcLo(weather, tech, comm) pTechWeatherAfcLowth1,t,c weather factor for technology availability lower value (afs.lo)
pTechWeatherAfcUp(weather, tech, comm) pTechWeatherAfcUpwth1,t,c weather factor for commodity availability upper value (afc.lo)
pStorageWeatherAfLo(weather, stg) pStorageWeatherAfLowth1,st1 weather factor for storage availability lower value (af.lo)
pStorageWeatherAfUp(weather, stg) pStorageWeatherAfUpwth1,st1 weather factor for storage availability upper value (af.up)
pStorageWeatherCinpUp(weather, stg) pStorageWeatherCinpUpwth1,st1 weather factor for storage commodity input upper value (cinp.up)
pStorageWeatherCinpLo(weather, stg) pStorageWeatherCinpLowth1,st1 weather factor for storage commodity input lower value (cinp.lo)
pStorageWeatherCoutUp(weather, stg) pStorageWeatherCoutUpwth1,st1 weather factor for storage commodity output upper value (cout.up)
pStorageWeatherCoutLo(weather, stg) pStorageWeatherCoutLowth1,st1 weather factor for storage commodity output lower value (cout.lo)
pLECLoACT(region) pLECLoACTr levelized costs interim parameter

2.3 Variables

The model variables [Inf,+Inf]
Name Alias Description
vTechInv(tech, region, year) vTechInvt,r,y Overnight investment costs
vTechEac(tech, region, year) vTechEact,r,y Annualized investment costs
vTechOMCost(tech, region, year) vTechOMCostt,r,y Sum of all operational costs is equal vTechFixom + vTechVarom (AVarom + CVarom + ActVarom)
vSupCost(sup, region, year) vSupCosts1,r,y Supply costs (weighted)
vEmsFuelTot(comm, region, year, slice) vEmsFuelTotc,r,y,s Total emissions from fuels combustion (technologies) (weighted)
vBalance(comm, region, year, slice) vBalancec,r,y,s Net commodity balance (all sources) (weighted)
vTotalCost(region, year) vTotalCostr,y Regional annual total costs (weighted)
vObjective vObjective Objective costs
vTaxCost(comm, region, year) vTaxCostc,r,y Total tax levies (tax costs)
vSubsCost(comm, region, year) vSubsCostc,r,y Total subsidies (substracted from costs)
vAggOutTot(comm, region, year, slice) vAggOutTotc,r,y,s Aggregated commodity output (weighted)
vStorageOMCost(stg, region, year) vStorageOMCostst1,r,y Storage O\
vTradeCost(region, year) vTradeCostr,y Total trade costs (weighted)
vTradeRowCost(region, year) vTradeRowCostr,y Trade with ROW costs (weighted)
vTradeIrCost(region, year) vTradeIrCostr,y Interregional trade costs (weighted)
The model positive variables [0,+Inf]
Name Alias Description
vTechNewCap(tech, region, year) vTechNewCapt,r,y New capacity
vTechRetiredStockCum(tech, region, year) vTechRetiredStockCumt,r,y Early retired stock
vTechRetiredStock(tech, region, year) vTechRetiredStockt,r,y Early retired stock
vTechRetiredNewCap(tech, region, year, year) vTechRetiredNewCapt,r,y,y Early retired new capacity
vTechCap(tech, region, year) vTechCapt,r,y Total capacity of the technology
vTechAct(tech, region, year, slice) vTechActt,r,y,s Activity level of technology
vTechInp(tech, comm, region, year, slice) vTechInpt,c,r,y,s Input level
vTechOut(tech, comm, region, year, slice) vTechOutt,c,r,y,s Commodity output from technology - tech timeframe
vTechAInp(tech, comm, region, year, slice) vTechAInpt,c,r,y,s Auxiliary commodity input
vTechAOut(tech, comm, region, year, slice) vTechAOutt,c,r,y,s Auxiliary commodity output
vSupOut(sup, comm, region, year, slice) vSupOuts1,c,r,y,s Output of supply
vSupReserve(sup, comm, region) vSupReserves1,c,r Cumulative supply (weighted)
vDemInp(comm, region, year, slice) vDemInpc,r,y,s Input to demand
vOutTot(comm, region, year, slice) vOutTotc,r,y,s Total commodity output (all processes) (weighted)
vInpTot(comm, region, year, slice) vInpTotc,r,y,s Total commodity input (all processes) (weighted)
vInp2Lo(comm, region, year, slice, slice) vInp2Loc,r,y,s,s Desagregation of slices for input parent to (grand)child
vOut2Lo(comm, region, year, slice, slice) vOut2Loc,r,y,s,s Desagregation of slices for output parent to (grand)child
vSupOutTot(comm, region, year, slice) vSupOutTotc,r,y,s Total commodity supply (weighted)
vTechInpTot(comm, region, year, slice) vTechInpTotc,r,y,s Total commodity (main \
vTechOutTot(comm, region, year, slice) vTechOutTotc,r,y,s Total commodity (main \
vStorageInpTot(comm, region, year, slice) vStorageInpTotc,r,y,s Total commodity (main \
vStorageOutTot(comm, region, year, slice) vStorageOutTotc,r,y,s Total commodity (main \
vStorageAInp(stg, comm, region, year, slice) vStorageAInpst1,c,r,y,s Aux-commodity input to storage
vStorageAOut(stg, comm, region, year, slice) vStorageAOutst1,c,r,y,s Aux-commodity input from storage
vDummyImport(comm, region, year, slice) vDummyImportc,r,y,s Dummy import (for debugging)
vDummyExport(comm, region, year, slice) vDummyExportc,r,y,s Dummy export (for debugging)
vStorageInp(stg, comm, region, year, slice) vStorageInpst1,c,r,y,s Storage input
vStorageOut(stg, comm, region, year, slice) vStorageOutst1,c,r,y,s Storage output
vStorageStore(stg, comm, region, year, slice) vStorageStorest1,c,r,y,s Storage level
vStorageInv(stg, region, year) vStorageInvst1,r,y Storage investments
vStorageEac(stg, region, year) vStorageEacst1,r,y Storage EAC investments
vStorageCap(stg, region, year) vStorageCapst1,r,y Storage capacity
vStorageNewCap(stg, region, year) vStorageNewCapst1,r,y Storage new capacity
vImportTot(comm, region, year, slice) vImportTotc,r,y,s Total regional import (Ir + ROW) (weighted)
vExportTot(comm, region, year, slice) vExportTotc,r,y,s Total regional export (Ir + ROW) (weighted)
vTradeIr(trade, comm, region, region, year, slice) vTradeIrt1,c,r,r,y,s Total physical trade flows between regions
vTradeIrAInp(trade, comm, region, year, slice) vTradeIrAInpt1,c,r,y,s Trade auxilari input
vTradeIrAInpTot(comm, region, year, slice) vTradeIrAInpTotc,r,y,s Trade total auxilari input (weighted)
vTradeIrAOut(trade, comm, region, year, slice) vTradeIrAOutt1,c,r,y,s Trade auxilari output
vTradeIrAOutTot(comm, region, year, slice) vTradeIrAOutTotc,r,y,s Trade auxilari output total (weighted)
vExportRowCum(expp, comm) vExportRowCume,c Cumulative export to ROW
vExportRow(expp, comm, region, year, slice) vExportRowe,c,r,y,s Export to ROW
vImportRowCum(imp, comm) vImportRowCumi,c Cumulative import from ROW
vImportRow(imp, comm, region, year, slice) vImportRowi,c,r,y,s Import from ROW
vTradeCap(trade, year) vTradeCapt1,y Trade capacity
vTradeInv(trade, region, year) vTradeInvt1,r,y Investment in trade capacity (overnight)
vTradeEac(trade, region, year) vTradeEact1,r,y Investment in trade capacity (EAC)
vTradeNewCap(trade, year) vTradeNewCapt1,y New trade capacity
vTotalUserCosts(region, year) vTotalUserCostsr,y Total additional costs (set by user)

2.4 Equations

2.4.0.1 eqTechSng2Sng: Technology input to output

vTechInpt,c,r,y,spTechCinp2uset,c,r,y,s=vTechOutt,cp,r,y,spTechUse2cactt,cp,r,y,spTechCact2coutt,cp,r,y,s

2.4.0.2 eqTechGrp2Sng: Technology group input to output

pTechGinp2uset,g,r,y,sc(vTechInpt,c,r,y,spTechCinp2ginpt,c,r,y,s)=vTechOutt,cp,r,y,spTechUse2cactt,cp,r,y,spTechCact2coutt,cp,r,y,s

2.4.0.3 eqTechSng2Grp: Technology input to group output

vTechInpt,c,r,y,spTechCinp2uset,c,r,y,s=cp(vTechOutt,cp,r,y,spTechUse2cactt,cp,r,y,spTechCact2coutt,cp,r,y,s)

2.4.0.4 eqTechGrp2Grp: Technology group input to group output

pTechGinp2uset,g,r,y,sc(vTechInpt,c,r,y,spTechCinp2ginpt,c,r,y,s)=cp(vTechOutt,cp,r,y,spTechUse2cactt,cp,r,y,spTechCact2coutt,cp,r,y,s)

2.4.0.5 eqTechShareInpLo: Technology lower bound on input share

vTechInpt,c,r,y,spTechShareLot,c,r,y,scp(vTechInpt,cp,r,y,s)

2.4.0.6 eqTechShareInpUp: Technology upper bound on input share

vTechInpt,c,r,y,spTechShareUpt,c,r,y,scp(vTechInpt,cp,r,y,s)

2.4.0.7 eqTechShareOutLo: Technology lower bound on output share

vTechOutt,c,r,y,spTechShareLot,c,r,y,scp(vTechOutt,cp,r,y,s)

2.4.0.8 eqTechShareOutUp: Technology upper bound on output share

vTechOutt,c,r,y,spTechShareUpt,c,r,y,scp(vTechOutt,cp,r,y,s)

2.4.0.9 eqTechAInp: Technology auxiliary commodity input

vTechAInpt,c,r,y,s=(vTechActt,r,y,spTechAct2AInpt,c,r,y,s)+(vTechCapt,r,ypTechCap2AInpt,c,r,y,spTechCap2actt)+(vTechNewCapt,r,ypTechNCap2AInpt,c,r,y,s)+cp(pTechCinp2AInpt,c,cp,r,y,svTechInpt,cp,r,y,s)+cp(pTechCout2AInpt,c,cp,r,y,svTechOutt,cp,r,y,s)

2.4.0.10 eqTechAOut: Technology auxiliary commodity output

vTechAOutt,c,r,y,s=(vTechActt,r,y,spTechAct2AOutt,c,r,y,s)+(vTechCapt,r,ypTechCap2AOutt,c,r,y,spTechCap2actt)+(vTechNewCapt,r,ypTechNCap2AOutt,c,r,y,s)+cp(pTechCinp2AOutt,c,cp,r,y,svTechInpt,cp,r,y,s)+cp(pTechCout2AOutt,c,cp,r,y,svTechOutt,cp,r,y,s)

2.4.0.11 eqTechAfLo: Technology availability factor lower bound

pTechAfLot,r,y,spTechCap2acttvTechCapt,r,ypSliceShareswth1(pTechWeatherAfLowth1,tpWeatherwth1,r,y,s)vTechActt,r,y,s

2.4.0.12 eqTechAfUp: Technology availability factor upper bound

vTechActt,r,y,spTechAfUpt,r,y,spTechCap2acttvTechCapt,r,ypSliceShareswth1(pTechWeatherAfUpwth1,tpWeatherwth1,r,y,s)

2.4.0.13 eqTechAfsLo: Technology availability factor for sum of slices lower bound

pTechAfsLot,r,y,spTechCap2acttvTechCapt,r,ypSliceShareswth1(pTechWeatherAfsLowth1,tpWeatherwth1,r,y,s)sp(vTechActt,r,y,sp)

2.4.0.14 eqTechAfsUp: Technology availability factor for sum of slices upper bound

sp(vTechActt,r,y,sp)pTechAfsUpt,r,y,spTechCap2acttvTechCapt,r,ypSliceShareswth1(pTechWeatherAfsUpwth1,tpWeatherwth1,r,y,s)

2.4.0.15 eqTechRampUp: Technology ramp up

vTechActt,r,y,spSliceSharesvTechActt,r,y,sppSliceSharesppSliceSharespTechCap2acttpTechCap2acttvTechCapt,r,ypTechRampUpt,r,y,s

2.4.0.16 eqTechRampDown: Technology ramp down

vTechActt,r,y,sppSliceSharespvTechActt,r,y,spSliceSharespSliceSharespTechCap2acttpTechCap2acttvTechCapt,r,ypTechRampDownt,r,y,s

2.4.0.17 eqTechActSng: Technology activity to commodity output

vTechActt,r,y,s=vTechOutt,c,r,y,spTechCact2coutt,c,r,y,s

2.4.0.18 eqTechActGrp: Technology activity to group output

vTechActt,r,y,s=c(vTechOutt,c,r,y,spTechCact2coutt,c,r,y,s)

2.4.0.19 eqTechAfcOutLo: Technology commodity availability factor lower bound

pTechCact2coutt,c,r,y,spTechAfcLot,c,r,y,spTechCap2acttvTechCapt,r,ypSliceShareswth1(pTechWeatherAfcLowth1,t,cpWeatherwth1,r,y,s)vTechOutt,c,r,y,s

2.4.0.20 eqTechAfcOutUp: Technology commodity availability factor upper bound

vTechOutt,c,r,y,spTechCact2coutt,c,r,y,spTechAfcUpt,c,r,y,spTechCap2acttvTechCapt,r,ywth1(pTechWeatherAfcUpwth1,t,cpWeatherwth1,r,y,s)

2.4.0.21 eqTechAfcInpLo: Technology commodity availability factor lower bound

pTechAfcLot,c,r,y,spTechCap2acttvTechCapt,r,ypSliceShareswth1(pTechWeatherAfcLowth1,t,cpWeatherwth1,r,y,s)vTechInpt,c,r,y,s

2.4.0.22 eqTechAfcInpUp: Technology commodity availability factor upper bound

vTechInpt,c,r,y,spTechAfcUpt,c,r,y,spTechCap2acttvTechCapt,r,ypSliceShareswth1(pTechWeatherAfcUpwth1,t,cpWeatherwth1,r,y,s)

2.4.0.23 eqTechCap: Technology capacity

vTechCapt,r,y=pTechStockt,r,yvTechRetiredStockCumt,r,y+yp(pPeriodLenyp(vTechNewCapt,r,ypye(vTechRetiredNewCapt,r,yp,ye)))

2.4.0.24 eqTechCapLo: Technology capacity lower bound

vTechCapt,r,ypTechCapLot,r,y

2.4.0.25 eqTechCapUp: Technology capacity upper bound

vTechCapt,r,ypTechCapUpt,r,y

2.4.0.26 eqTechNewCapLo: __

vTechNewCapt,r,ypTechNewCapLot,r,y

2.4.0.27 eqTechNewCapUp: __

vTechNewCapt,r,ypTechNewCapUpt,r,y

2.4.0.28 eqTechRetiredNewCap: Retirement of new capacity

yp(vTechRetiredNewCapt,r,y,yp)vTechNewCapt,r,y

2.4.0.29 eqTechRetiredStockCum: Retirement of stock cumulative

vTechRetiredStockCumt,r,ypTechStockt,r,y

2.4.0.30 eqTechRetiredStock: Retirement of stock

vTechRetiredStockt,r,y=vTechRetiredStockCumt,r,yyp(vTechRetiredStockCumt,r,yp)

2.4.0.31 eqTechEac: Technology Equivalent Annual Cost (EAC)

vTechEact,r,y=yp(pTechEact,r,yppPeriodLenyp(vTechNewCapt,r,ypye(vTechRetiredNewCapt,r,yp,ye)))

2.4.0.32 eqTechInv: Technology overnight investment costs

vTechInvt,r,y=pTechInvcostt,r,yvTechNewCapt,r,y

2.4.0.33 eqTechOMCost: Technology O&M costs (weighted)

vTechOMCostt,r,y=pTechFixomt,r,yvTechCapt,r,y+s(pTechVaromt,r,y,spSliceWeightsvTechActt,r,y,s)+s(c(pTechCvaromt,c,r,y,spSliceWeightsvTechInpt,c,r,y,s))+s(c(pTechCvaromt,c,r,y,spSliceWeightsvTechOutt,c,r,y,s))+s(c(pTechAvaromt,c,r,y,spSliceWeightsvTechAOutt,c,r,y,s))+s(c(pTechAvaromt,c,r,y,spSliceWeightsvTechAInpt,c,r,y,s))

2.4.0.34 eqSupAvaUp: Supply availability upper bound

vSupOuts1,c,r,y,spSupAvaUps1,c,r,y,swth1(pSupWeatherUpwth1,s1pWeatherwth1,r,y,s)

2.4.0.35 eqSupAvaLo: Supply availability lower bound

vSupOuts1,c,r,y,spSupAvaLos1,c,r,y,swth1(pSupWeatherLowth1,s1pWeatherwth1,r,y,s)

2.4.0.36 eqSupReserve: Cumulative supply (use of reserve)

vSupReserves1,c,r=y,s(pPeriodLenypSliceWeightsvSupOuts1,c,r,y,s)

2.4.0.37 eqSupReserveUp: Cumulative supply upper constraint

vSupReserves1,c,rpSupReserveUps1,c,r

2.4.0.38 eqSupReserveLo: Cumulative supply lower constraint

vSupReserves1,c,rpSupReserveLos1,c,r

2.4.0.39 eqSupCost: Supply costs

vSupCosts1,r,y=c,s(pSupCosts1,c,r,y,spSliceWeightsvSupOuts1,c,r,y,s)

2.4.0.40 eqDemInp: Demand equation

vDemInpc,r,y,s=d(pDemandd,c,r,y,s)

2.4.0.41 eqAggOutTot: Aggregating-commodity output (weighted)

vAggOutTotc,r,y,s=cp(pAggregateFactorc,cpsp(vOutTotcp,r,y,sp))

2.4.0.42 eqEmsFuelTot: Total emissions from commodity consumption (weighted)

vEmsFuelTotc,r,y,s=cp(pEmissionFactorc,cpt(pTechEmisCommt,cpsp(vTechInpt,cp,r,y,sp)))pSliceWeights

2.4.0.43 eqStorageAInp: Storage level

vStorageAInpst1,c,r,y,s=cp(pStorageStg2AInpst1,c,r,y,svStorageStorest1,cp,r,y,s)+cp(pStorageCinp2AInpst1,c,r,y,svStorageInpst1,cp,r,y,s)+cp(pStorageCout2AInpst1,c,r,y,svStorageOutst1,cp,r,y,s)+cp(pStorageCap2AInpst1,c,r,y,svStorageCapst1,r,y)+cp(pStorageNCap2AInpst1,c,r,y,svStorageNewCapst1,r,y)

2.4.0.44 eqStorageAOut: Storage availability factor lower

vStorageAOutst1,c,r,y,s=cp(pStorageStg2AOutst1,c,r,y,svStorageStorest1,cp,r,y,s)+cp(pStorageCinp2AOutst1,c,r,y,svStorageInpst1,cp,r,y,s)+cp(pStorageCout2AOutst1,c,r,y,svStorageOutst1,cp,r,y,s)+cp(pStorageCap2AOutst1,c,r,y,svStorageCapst1,r,y)+cp(pStorageNCap2AOutst1,c,r,y,svStorageNewCapst1,r,y)

2.4.0.45 eqStorageStore: Storage availability factor upper

vStorageStorest1,c,r,y,s=pStorageChargest1,c,r,y,s+(pStorageNCap2Stgst1,c,r,y,svStorageNewCapst1,r,y)+pStorageInpEffst1,c,r,y,spvStorageInpst1,c,r,y,sp+(pStorageStgEffst1,c,r,y,spSliceShares)vStorageStorest1,c,r,y,spvStorageOutst1,c,r,y,sppStorageOutEffst1,c,r,y,sp

2.4.0.46 eqStorageAfLo: Storage output vs level

vStorageStorest1,c,r,y,spStorageAfLost1,r,y,spStorageCap2stgst1vStorageCapst1,r,ywth1(pStorageWeatherAfLowth1,st1pWeatherwth1,r,y,s)

2.4.0.47 eqStorageAfUp: Storage aux-commodity input

vStorageStorest1,c,r,y,spStorageAfUpst1,r,y,spStorageCap2stgst1vStorageCapst1,r,ywth1(pStorageWeatherAfUpwth1,st1pWeatherwth1,r,y,s)

2.4.0.48 eqStorageClear: Storage aux-commodity output

vStorageOutst1,c,r,y,spStorageOutEffst1,c,r,y,svStorageStorest1,c,r,y,s

2.4.0.49 eqStorageInpUp: Storage input upper constraint

vStorageInpst1,c,r,y,svStorageCapst1,r,ypStorageCinpUpst1,c,r,y,swth1(pStorageWeatherCinpUpwth1,st1pWeatherwth1,r,y,s)

2.4.0.50 eqStorageInpLo: Storage input lower constraint

vStorageInpst1,c,r,y,svStorageCapst1,r,ypStorageCinpLost1,c,r,y,swth1(pStorageWeatherCinpLowth1,st1pWeatherwth1,r,y,s)

2.4.0.51 eqStorageOutUp: Storage output upper constraint

vStorageOutst1,c,r,y,svStorageCapst1,r,ypStorageCoutUpst1,c,r,y,swth1(pStorageWeatherCoutUpwth1,st1pWeatherwth1,r,y,s)

2.4.0.52 eqStorageOutLo: Storage output lower constraint

vStorageOutst1,c,r,y,svStorageCapst1,r,ypStorageCoutLost1,c,r,y,swth1(pStorageWeatherCoutLowth1,st1pWeatherwth1,r,y,s)

2.4.0.53 eqStorageCap: Storage capacity

vStorageCapst1,r,y=pStorageStockst1,r,y+yp(pPeriodLenypvStorageNewCapst1,r,yp)

2.4.0.54 eqStorageCapLo: Storage capacity lower bound

vStorageCapst1,r,ypStorageCapLost1,r,y

2.4.0.55 eqStorageCapUp: Storage capacity upper bound

vStorageCapst1,r,ypStorageCapUpst1,r,y

2.4.0.56 eqStorageNewCapLo: Storage new capacity lower bound

vStorageNewCapst1,r,ypStorageNewCapLost1,r,y

2.4.0.57 eqStorageNewCapUp: Storage new capacity upper bound

vStorageNewCapst1,r,ypStorageNewCapUpst1,r,y

2.4.0.58 eqStorageInv: Storage overnight investment costs

vStorageInvst1,r,y=pStorageInvcostst1,r,yvStorageNewCapst1,r,y

2.4.0.59 eqStorageEac: Storage equivalent annual cost

vStorageEacst1,r,y=yp(pStorageEacst1,r,yppPeriodLenypvStorageNewCapst1,r,yp)

2.4.0.60 eqStorageCost: Storage total costs

vStorageOMCostst1,r,y=pStorageFixomst1,r,yvStorageCapst1,r,y+c(s(pStorageCostInpst1,r,y,spSliceWeightsvStorageInpst1,c,r,y,s)+s(pStorageCostOutst1,r,y,spSliceWeightsvStorageOutst1,c,r,y,s)+s(pStorageCostStorest1,r,y,spSliceWeightsvStorageStorest1,c,r,y,s))

2.4.0.61 eqImportTot: Import equation (Ir & ROW)

vImportTotc,dst,y,s=t1(src(pTradeIrEfft1,src,dst,y,svTradeIrt1,c,src,dst,y,s))pSliceWeights+i(vImportRowi,c,dst,y,s)pSliceWeights

2.4.0.62 eqExportTot: Export equation (Ir & ROW)

vExportTotc,src,y,s=t1(dst(vTradeIrt1,c,src,dst,y,s))pSliceWeights+e(vExportRowe,c,src,y,s)pSliceWeights

2.4.0.63 eqTradeFlowUp: Trade upper bound

vTradeIrt1,c,src,dst,y,spTradeIrUpt1,src,dst,y,s

2.4.0.64 eqTradeFlowLo: Trade lower bound

vTradeIrt1,c,src,dst,y,spTradeIrLot1,src,dst,y,s

2.4.0.65 eqCostTrade: Total trade costs

vTradeCostr,y=vTradeRowCostr,y+vTradeIrCostr,y

2.4.0.66 eqCostRowTrade: Costs of trade with the Rest of the World (ROW)

vTradeRowCostr,y=i,c,s(pImportRowPricei,r,y,spSliceWeightsvImportRowi,c,r,y,s)e,c,s(pExportRowPricee,r,y,spSliceWeightsvExportRowe,c,r,y,s)

2.4.0.67 eqCostIrTrade: Costs of import

vTradeIrCostr,y=t1(pTradeFixomt1,ypTradeStockt1,y)+t1(pTradeFixomt1,y(vTradeCapt1,ypTradeStockt1,y))+t1(vTradeEact1,r,y)+t1,src(c(s((pTradeIrCostt1,src,r,y,s+pTradeIrMarkupt1,src,r,y,s)vTradeIrt1,c,src,r,y,spSliceWeights)))t1,dst(c(s((pTradeIrCostt1,r,dst,y,s+pTradeIrMarkupt1,r,dst,y,s)vTradeIrt1,c,r,dst,y,spSliceWeights)))

2.4.0.68 eqExportRowUp: Export to ROW upper constraint

vExportRowe,c,r,y,spExportRowUpe,r,y,s

2.4.0.69 eqExportRowLo: Export to ROW lower constraint

vExportRowe,c,r,y,spExportRowLoe,r,y,s

2.4.0.70 eqExportRowCum: Cumulative export to ROW

vExportRowCume,c=r,y,s(pPeriodLenypSliceWeightsvExportRowe,c,r,y,s)

2.4.0.71 eqExportRowResUp: Cumulative export to ROW upper constraint

vExportRowCume,cpExportRowRese

2.4.0.72 eqImportRowUp: Import from ROW upper constraint

vImportRowi,c,r,y,spImportRowUpi,r,y,s

2.4.0.73 eqImportRowLo: Import of ROW lower constraint

vImportRowi,c,r,y,spImportRowLoi,r,y,s

2.4.0.74 eqImportRowCum: Cumulative import from ROW

vImportRowCumi,c=r,y,s(pPeriodLenypSliceWeightsvImportRowi,c,r,y,s)

2.4.0.75 eqImportRowResUp: Cumulative import from ROW upper constraint

vImportRowCumi,cpImportRowResi

2.4.0.76 eqTradeCapFlow: Trade capacity

pSliceSharespTradeCap2Actt1vTradeCapt1,ysrc,dst(vTradeIrt1,c,src,dst,y,s)

2.4.0.77 eqTradeCap: Trade capacity lower bound

vTradeCapt1,y=pTradeStockt1,y+yp(pPeriodLenypvTradeNewCapt1,yp)

2.4.0.78 eqTradeCapLo: Trade capacity upper bound

vTradeCapt1,ypTradeCapLot1,y

2.4.0.79 eqTradeCapUp: Trade new capacity lower bound

vTradeCapt1,ypTradeCapUpt1,y

2.4.0.80 eqTradeNewCapLo: Trade new capacity upper bound

vTradeNewCapt1,ypTradeNewCapLot1,y

2.4.0.81 eqTradeNewCapUp: Trade overnight investment costs

vTradeNewCapt1,ypTradeNewCapUpt1,y

2.4.0.82 eqTradeInv: Trade equivalent annual costs

vTradeInvt1,r,y=pTradeInvcostt1,r,yvTradeNewCapt1,y

2.4.0.83 eqTradeEac: Trade capacity to activity

vTradeEact1,r,y=yp(pTradeEact1,r,yppPeriodLenypvTradeNewCapt1,yp)

2.4.0.84 eqTradeIrAInp: Trade auxiliary commodity input

vTradeIrAInpt1,c,r,y,s=dst(pTradeIrCsrc2Ainpt1,c,r,dst,y,scp(vTradeIrt1,cp,r,dst,y,s))+src(pTradeIrCdst2Ainpt1,c,src,r,y,scp(vTradeIrt1,cp,src,r,y,s))

2.4.0.85 eqTradeIrAOut: Trade auxiliary commodity output

vTradeIrAOutt1,c,r,y,s=dst(pTradeIrCsrc2Aoutt1,c,r,dst,y,scp(vTradeIrt1,cp,r,dst,y,s))+src(pTradeIrCdst2Aoutt1,c,src,r,y,scp(vTradeIrt1,cp,src,r,y,s))

2.4.0.86 eqTradeIrAInpTot: Trade auxiliary commodity input

vTradeIrAInpTotc,r,y,s=pSliceWeightst1,sp(vTradeIrAInpt1,c,r,y,sp)

2.4.0.87 eqTradeIrAOutTot: Trade auxiliary commodity output

vTradeIrAOutTotc,r,y,s=pSliceWeightst1,sp(vTradeIrAOutt1,c,r,y,sp)

2.4.0.88 eqBalLo: commodity balance <= 0 (e.g. upper limit - deficit is allowed)

vBalancec,r,y,s0

2.4.0.89 eqBalUp: commodity balance >= 0 (e.g. lower limit - excess is allower)

vBalancec,r,y,s0

2.4.0.90 eqBalFx: commodity balance >= 0 (no excess nor deficit is allowed)

vBalancec,r,y,s=0

2.4.0.91 eqBal: Commodity balance definition

vBalancec,r,y,s=vOutTotc,r,y,svInpTotc,r,y,s

2.4.0.92 eqOutTot: Total commodity output

vOutTotc,r,y,s=pSliceWeightsvDummyImportc,r,y,s+vSupOutTotc,r,y,s+vEmsFuelTotc,r,y,s+vAggOutTotc,r,y,s+vTechOutTotc,r,y,s+vStorageOutTotc,r,y,s+vImportTotc,r,y,s+vTradeIrAOutTotc,r,y,s+pSliceWeightssp(vOut2Loc,r,y,sp,s)

2.4.0.93 eqOut2Lo: Total commodity input

sp(vOut2Loc,r,y,s,sp)=vSupOutTotc,r,y,s+vEmsFuelTotc,r,y,s+vAggOutTotc,r,y,s+vTechOutTotc,r,y,s+vStorageOutTotc,r,y,s+vImportTotc,r,y,s+vTradeIrAOutTotc,r,y,s

2.4.0.94 eqInpTot: From commodity slice to lo level

vInpTotc,r,y,s=pSliceWeightsvDemInpc,r,y,s+pSliceWeightsvDummyExportc,r,y,s+vTechInpTotc,r,y,s+vStorageInpTotc,r,y,s+vExportTotc,r,y,s+vTradeIrAInpTotc,r,y,s+pSliceWeightssp(vInp2Loc,r,y,sp,s)

2.4.0.95 eqInp2Lo: From commodity slice to lo level

sp(vInp2Loc,r,y,s,sp)=vTechInpTotc,r,y,s+vStorageInpTotc,r,y,s+vExportTotc,r,y,s+vTradeIrAInpTotc,r,y,s

2.4.0.96 eqSupOutTot: Supply total output

vSupOutTotc,r,y,s=pSliceWeightss1(vSupOuts1,c,r,y,s)

2.4.0.97 eqTechInpTot: Technology total input

vTechInpTotc,r,y,s=pSliceWeightst(vTechInpt,c,r,y,s)+pSliceWeightst(sp(vTechInpt,c,r,y,sp))+pSliceWeightst(vTechAInpt,c,r,y,s)+pSliceWeightst(sp(vTechAInpt,c,r,y,sp))

2.4.0.98 eqTechOutTot: Technology total output

vTechOutTotc,r,y,s=pSliceWeightst(vTechOutt,c,r,y,s)+pSliceWeightst(sp(vTechOutt,c,r,y,sp))+pSliceWeightst(vTechAOutt,c,r,y,s)+pSliceWeightst(sp(vTechAOutt,c,r,y,sp))

2.4.0.99 eqStorageInpTot: Storage total input

vStorageInpTotc,r,y,s=pSliceWeightsst1(vStorageInpst1,c,r,y,s)+pSliceWeightsst1(vStorageAInpst1,c,r,y,s)

2.4.0.100 eqStorageOutTot: Storage total output

vStorageOutTotc,r,y,s=pSliceWeightsst1(vStorageOutst1,c,r,y,s)+pSliceWeightsst1(vStorageAOutst1,c,r,y,s)

2.4.0.101 eqCost: Total costs (weighted)

vTotalCostr,y=t(vTechEact,r,y)+t(pTechRetCostt,r,y(vTechRetiredStockt,r,y+yp(vTechRetiredNewCapt,r,yp,y)))+t,yp(pTechRetCostt,r,yvTechRetiredNewCapt,r,yp,y)+t(vTechOMCostt,r,y)+s1(vSupCosts1,r,y)+c,s(pDummyImportCostc,r,y,spSliceWeightsvDummyImportc,r,y,s)+c,s(pDummyExportCostc,r,y,spSliceWeightsvDummyExportc,r,y,s)+c(vTaxCostc,r,y)c(vSubsCostc,r,y)+st1(vStorageOMCostst1,r,y)+st1(vStorageEacst1,r,y)+vTradeCostr,y+vTotalUserCostsr,y

2.4.0.102 eqTaxCost: Commodity taxes (weighted)

vTaxCostc,r,y=s(pTaxCostOutc,r,y,svOutTotc,r,y,s)+s(pTaxCostInpc,r,y,svInpTotc,r,y,s)+s(pTaxCostBalc,r,y,svBalancec,r,y,s)

2.4.0.103 eqSubsCost: Commodity subsidy (weighted)

vSubsCostc,r,y=s(pSubCostOutc,r,y,svOutTotc,r,y,s)+s(pSubCostInpc,r,y,svInpTotc,r,y,s)+s(pSubCostBalc,r,y,svBalancec,r,y,s)

2.4.0.104 eqObjective: Objective equation NPV of total costs

vObjective=r,y(pDiscountFactorMileStoner,yvTotalCostr,y)

2.4.0.105 eqLECActivity: levelized costs (auxiliary equation)

s(vTechActt,r,y,s)pLECLoACTr