-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathcoef_shp.mod
94 lines (90 loc) · 6.15 KB
/
coef_shp.mod
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
* Copyright (C) 2000-2024 Energy Technology Systems Analysis Programme (ETSAP)
* This file is part of the IEA-ETSAP TIMES model generator, licensed
* under the GNU General Public License v3.0 (see file NOTICE-GPLv3.txt).
*=============================================================================*
* COEF_SHP prepares the shapes for COEF_PTR and COEF_CPT
*=============================================================================*
* Shaping of COEF_PTRANS
*------------------------------------------------------------------------------
PARAMETER RTP_FFCX(REG,ALLYEAR,ALLYEAR,PRC,CG,CG) //;
SET AGEJ(J,AGE) / 1.1 /;
Z=SMAX(T,MAX(IPD(T),D(T))); OPYEAR(LIFE,AGE)$((ORD(AGE)<=ORD(LIFE))$(ORD(LIFE)<=Z)) = YES;
RTP_CGC(RTP(R,V,P),CG,CG2)$((FLO_FUNCX(RTP,CG,CG2)<=0)$FLO_FUNCX(RTP,CG,CG2))=PRC_VINT(R,P);
* Remove FLO_FUNCX indexes that won't have any effect
Z=CARD(J)/2+1;
FLO_FUNCX(RTP,CG,CG2)$(ABS(FLO_FUNCX(RTP,CG,CG2)-Z)>Z-1.5-INF$ACTCG(CG)) = 0;
OPTION RP_GRP <= FLO_FUNCX,PRC_YMIN < RP_GRP,CLEAR=PRC_YMAX;
TRACKP(RP)$PRC_YMIN(RP) $= PRC_VINT(RP)+RP_GRP(RP,'CAPFLO');
RTP_CAPYR(RTP_CPTYR(R,V,T,P)) $= TRACKP(R,P);
LOOP(AGEJ(J,AGE)$CARD(TRACKP),
LOOP(V,
* Set the starting and ending years taking into account NCAP_ILED:
PRC_YMIN(TRACKP(R,P)) = B(V)+ROUND(NCAP_ILED(R,V,P));
PRC_YMAX(TRACKP(R,P)) = PRC_YMIN(R,P)+ROUND(NCAP_TLIFE(R,V,P))-1;
* Calculate average SHAPE for plants still operating in each period:
RTP_FFCX(RTP_CAPYR(R,V,T,P),CG1,CG2)$FLO_FUNCX(R,V,P,CG1,CG2) =
SUM(PERIODYR(T,EOHYEARS)$(YEARVAL(EOHYEARS) LE MAX(B(T),PRC_YMAX(R,P))),
SHAPE(J+(FLO_FUNCX(R,V,P,CG1,CG2)-1),AGE+(MIN(YEARVAL(EOHYEARS),PRC_YMAX(R,P))-PRC_YMIN(R,P))))
/ (MAX(1,MIN(E(T),PRC_YMAX(R,P))-MAX(B(T),PRC_YMIN(R,P))+1)) -1;
);
* For repeated investments, use the average SHAPE over lifetime:
RVPRL(RTP(R,T,P))$((COEF_RPTI(RTP)>1)$TRACKP(R,P)) = ROUND(NCAP_TLIFE(RTP)-1)+EPS;
RTP_FFCX(RTP_CAPYR(R,TT,T,P),CG1,CG2)$(RVPRL(R,TT,P)$FLO_FUNCX(R,TT,P,CG1,CG2)) =
SUM(OPYEAR(AGE+RVPRL(R,TT,P),LIFE),SHAPE(J+(FLO_FUNCX(R,TT,P,CG1,CG2)-1),LIFE)) / (RVPRL(R,TT,P)+1) -1;
);
* Shapes for capacity-related commodity flows
COEF_CIO(RTP_CAPYR(R,V,T,P),C,IO)$NCAP_COM(R,V,P,C,IO) $= RTP_FFCX(R,V,T,P,'CAPFLO',C);
COEF_CIO(RTP_CPTYR(R,V,T,P),C,IO)$NCAP_CLAG(R,V,P,C,IO) = SIGN(NCAP_CLAG(R,V,P,C,IO)) *
(MAX(0, E(T)+1-MAX(B(V)+NCAP_ILED(R,V,P)+ABS(NCAP_CLAG(R,V,P,C,IO)),B(T))) /
MAX(.1,E(T)+1-MAX(B(V)+NCAP_ILED(R,V,P),B(T)))-1)-1$(NCAP_CLAG(R,V,P,C,IO)<0);
RTP_FFCX(RTP_CAPYR,'CAPFLO',CG) = 0;
* Option for non-vintaged FLO_FUNC multipliers
RTP_FFCX(RTP_VINTYR(R,V,T,P),CG,CG2)$((FLO_FUNC(R,V,P,CG,CG2,'ANNUAL')>0)$RTP_CGC(R,V,P,CG,CG2))=FLO_FUNC(R,T,P,CG,CG2,'ANNUAL')/FLO_FUNC(R,V,P,CG,CG2,'ANNUAL')-1;
OPTION CLEAR=TRACKP,CLEAR=RVPRL,CLEAR=RP_GRP;
*------------------------------------------------------------------------------
* Shaping of COEF_CPT
*------------------------------------------------------------------------------
* Remove NCAP_CPX indexes that won't have any effect
Z=CARD(J)/2+1;
NCAP_CPX(RTP)$(ABS(NCAP_CPX(RTP)-Z)>Z-1.5) = 0;
OPTION PRC_YMIN < NCAP_CPX,CLEAR=PRC_YMAX;
LOOP(AGEJ(J,AGE)$CARD(NCAP_CPX),
TRACKP(RP) $= PRC_YMIN(RP);
LOOP(V,
* Set the starting and ending years taking into account NCAP_ILED:
PRC_YMIN(TRACKP(R,P)) = B(V)+ROUND(NCAP_ILED(R,V,P));
PRC_YMAX(TRACKP(R,P)) = PRC_YMIN(R,P)+NCAP_TLIFE(R,V,P);
* Calculate weighted average SHAPE for plants still operating in each period:
LOOP(G_RCUR(R,CUR),
COEF_CAP(RTP_CPTYR(R,V,T,P))$NCAP_CPX(R,V,P) =
SUM(PERIODYR(T,Y_EOH)$(YEARVAL(Y_EOH)<PRC_YMAX(R,P)),MIN(1,PRC_YMAX(R,P)-YEARVAL(Y_EOH))*OBJ_DISC(R,Y_EOH,CUR)*
SHAPE(J+(NCAP_CPX(R,V,P)-1),AGE+(YEARVAL(Y_EOH)-PRC_YMIN(R,P)))) / COEF_PVT(R,T)
));
* For repeated investments, use the average SHAPE over lifetime:
RVPRL(RTP)$((COEF_RPTI(RTP)>1)$NCAP_CPX(RTP)) = ROUND(NCAP_TLIFE(RTP)-1)+EPS;
COEF_CAP(RTP_CPTYR(R,V(TT),T,P))$RVPRL(R,V,P) =
SUM(OPYEAR(AGE+RVPRL(R,V,P),LIFE),SHAPE(J+(NCAP_CPX(R,V,P)-1),LIFE)) / (RVPRL(R,V,P)+1);
COEF_CAP(RTP_CPTYR(R,V,T,P))$NCAP_CPX(R,V,P) = (1/MAX(1,COEF_CPT(R,V,T,P)/COEF_CAP(R,V,T,P)))$COEF_CAP(R,V,T,P)-1;
);
COEF_CPT(R,V,T,P)$COEF_CAP(R,V,T,P) = COEF_CPT(R,V,T,P)*(COEF_CAP(R,V,T,P)+1);
OPTION CLEAR=PRC_YMIN,CLEAR=PRC_YMAX,CLEAR=TRACKP,CLEAR=RTP_CGC, RTP_CPX <= COEF_CAP, CLEAR=COEF_CAP;
* Override COEF_OCOM if conditions met for using capacity transfer
RTP_CGC(RTP(R,V,P),CG('CAPFLO'),C)$((FLO_FUNCX(R,'0',P,CG,C)=3)$NCAP_OCOM(RTP,C))=YES;
LOOP(AGEJ(J,AGE)$CARD(RTP_CGC),
OPTION RVPRL < RTP_CGC;
PASTSUM(RTP(R,V,P))$RVPRL(RTP) = B(V)+ROUND(NCAP_ILED(RTP))+ROUND(NCAP_DLAG(RTP)+NCAP_DLIFE(RTP)/2);
RVPRL(RTP)$RVPRL(RTP) = PASTSUM(RTP)+ROUND(COEF_RPTI(RTP)*NCAP_TLIFE(RTP));
LOOP(G_RCUR(R,CUR),
FIL2(T)=COEF_PVT(R,T)*D(T)/SUM(PERIODYR(T,Y_EOH),(YEARVAL(Y_EOH)-B(T)+1)*OBJ_DISC(R,Y_EOH,CUR));
*.... Calculate remaining levelized capacity levels
COEF_CAP(R,VNT(V,T),P)$((MIN(M(T)+1,E(T))<RVPRL(R,V,P))$RVPRL(R,V,P)) = 1/COEF_RPTI(R,V,P) *
MAX(POWER(SHAPE(J+(NCAP_CPX(R,V,P)-1),AGE+(B(T)-PASTSUM(R,V,P)-1)),B(T)-PASTSUM(R,V,P)-1>=0)*(1-FIL2(T)) +
SUM(PERIODYR(T,Y_EOH)$(YEARVAL(Y_EOH)<RVPRL(R,V,P)),OBJ_DISC(R,Y_EOH,CUR)*POWER(SHAPE(J+(NCAP_CPX(R,V,P)-1),AGE+MOD(YEARVAL(Y_EOH)-PASTSUM(R,V,P),ROUND(NCAP_TLIFE(R,V,P)))),YEARVAL(Y_EOH)-PASTSUM(R,V,P)>=0))/COEF_PVT(R,T)*FIL2(T),
SHAPE(J+(NCAP_CPX(R,V,P)-1),AGE+MAX(0,E(T)-PASTSUM(R,V,P)))$(E(T)<RVPRL(R,V,P))));
*...Derive overriding COEF_OCOM coefficients
COEF_OCOM(R,VNT(V,T),P,C)$RTP_CGC(R,V,P,'CAPFLO',C) = COEF_RPTI(R,V,P) *
(MAX(0,POWER(SHAPE(J+(NCAP_CPX(R,V,P)-1),AGE+(B(T)-PASTSUM(R,V,P)-1)),B(T)-PASTSUM(R,V,P)-1>=0)-COEF_CAP(R,V,T,P))*NCAP_OCOM(R,V,P,C)/FPD(T))$(B(T)<RVPRL(R,V,P));
COEF_OCOM(R,V,T(TT+1),P,C)$((B(T)>PASTSUM(R,V,P))$VNT(V,TT)$RTP_CGC(R,V,P,'CAPFLO',C)) = COEF_RPTI(R,V,P) * MAX(0,COEF_CAP(R,V,TT,P)-COEF_CAP(R,V,T,P))*NCAP_OCOM(R,V,P,C)/FPD(T);
);
OPTION CLEAR=RTP_CGC,CLEAR=COEF_CAP,CLEAR=PASTSUM,CLEAR=RVPRL;