# INPUT solutionFile = 'Paiva3lim3.sol' sufixo = 'paiva' info = 'Vale do Sousa (90 x 1ano)' pSaveFig = 1 # -1/0/1 - gravação das figuras no disco ################################ # Ficheiro com vertices file = open('ValeSousaVert.txt') nlin = -1 Units = {} xmin = 100000000000 xmax = -100000000000 ymin = 100000000000 ymax = -100000000000 NamUx = '000' LVert = [] for line in file: nlin += 1 if nlin == 0: continue lex = line.split() #if nlin < 5 or nlin > 90475: #print(lex if NamUx == lex[0]: x = float(lex[2]) y = float(lex[3]) LVert.append((x,y)) if xmin > x : xmin = x if xmax < x : xmax = x if ymin > y : ymin = y if ymax < y : ymax = y elif line[:3] == '###': Units[NamUx] = LVert break else: if NamUx != '000': Units[NamUx] = LVert NamUx = lex[0] LVert = [] x = float(lex[2]) y = float(lex[3]) LVert.append((x,y)) if xmin > x : xmin = x if xmax < x : xmax = x if ymin > y : ymin = y if ymax < y : ymax = y file.close() #print('Numero das linhas no ficheiro: nlin=',nlin) #print('xmin=', xmin, 'xmax=', xmax) #print('ymin=', ymin, 'ymax=', ymax) #print(len(Units)) ################################################# # Áreas das unidades de gestão (m2) file = open('UnitAreasVSousa.txt') nlin = -1 Areas = {} for line in file: nlin += 1 if nlin == 0: continue lex = line.split() #if nlin < 5 or nlin > 90475: #print(lex) Ar = float(lex[1]) Areas[lex[0]] = Ar file.close() #print(nlin, len(Areas)) ################################################## # Concelhos das unidades file = open('ug_concelhos.csv') nlin = -1 Concel4Unid = {} UnPaivaNorte = [] UnPaivaSul = [] UnPenafiel = [] UnParedes = [] for line in file: nlin += 1 if nlin == 0: continue lex = line.split(',') #if nlin < 5 or nlin > 1310: #print(lex) Concel4Unid[lex[0]] = lex[1] if lex[1] == "PaivaNorte": UnPaivaNorte.append(lex[0]) elif lex[1] == "PaivaSul": UnPaivaSul.append(lex[0]) elif lex[1] == "Penafiel": UnPenafiel.append(lex[0]) elif lex[1] == "Paredes": UnParedes.append(lex[0]) #else: #print('Unknown: ', line) file.close() #print(nlin, len(Concel4Unid)) #print(UnPaivaNorte) #print(UnPaivaSul) #print(UnParedes) #print(UnPenafiel) #print(Concel4Unid) ################################################ #%matplotlib notebook import matplotlib.pyplot as plt Cores = {'PaivaNorte':'fuchsia','PaivaSul':'salmon', 'Penafiel':'lime', 'Paredes':'royalblue'} fig = plt.figure(figsize=(10,10)) ax = plt.gca() ax.set_facecolor('lightgray') K = sorted(list(Units.keys())) for key in K: xx = [] yy = [] for v in Units[key]: xx.append(v[0]) yy.append(v[1]) if int(key) >= 4000: clr = 'yellow' else: clr = Cores[Concel4Unid[key]] plt.fill(xx, yy, facecolor=clr, edgecolor='black', linewidth=1) #ax.xlim=(-25000, -15000) #ax.ylim=(150000, 1800000) plt.plot([-25000, -25010], [165000, 165010], lw=15, c=Cores['Paredes'], label='Paredes') plt.plot([-25000, -25010], [165000, 165010], lw=15, c=Cores['Penafiel'], label='Penafiel') plt.plot([-25000, -25010], [165000, 165010], lw=15, c=Cores['PaivaNorte'],label='PaivaNorte') plt.plot([-25000, -25010], [165000, 165010], lw=15, c=Cores['PaivaSul'], label='PaivaSul') plt.plot([-25000, -25010], [165000, 165010], lw=17, c='lightgray') plt.legend() plt.tight_layout() #plt.savefig('VSousaBlocos.svg',dpi=100) #plt.show(plt) ############################################## # Ficheiro das Prescrições - VS3 file = open('PrescVS_1.txt') nlin = -1 TabPreVS = {} Parx = 'xxx' Prex = 'xxx' for line in file: nlin += 1 if nlin == 0: #print(line) continue lex = line.split() if nlin < 5 or nlin > 143940: #print(nlin,'lex=',lex) continue if lex[0] != Parx: Parx = lex[0] TabPreVS[Parx] = {} Prex = 'xxx' if lex[1] != Prex: Prex = lex[1] TabPreVS[Parx][Prex] = [] for i in range(2,6): lex[i] = float(lex[i]) lex[6] = int(lex[6]) TabPreVS[Parx][Prex].append(lex[2:]) file.close() #print('Número das linhas no ficheiro: nlin=',nlin) Un = sorted(list(TabPreVS.keys())) #print(Un) #print('Número das Unidades na Tabela=', len(Un)) ############################################### Sol = [] def sol_input(fname): print('File=', fname) file = open(fname) nlin = 0 pr = 0 for line in file: nlin += 1 if pr==0 and line[:13]=="Variable Name": pr = 1 continue if pr==1 and line[:19]=="All other variables": pr = 2 break if pr==0: continue if line[:5] != 'Presc': continue if line[:8] == 'Presc800': continue lex = line.split() lexp = lex[0].split('_') if int(lexp[1][2:]) < 4000: buf = [lexp[1][2:], lexp[0][5:], lexp[2], lexp[3], lex[0], nlin] Sol.append(buf) file.close() print('Número das linhas no ficheiro: nlin=',nlin) print('Número das variáveias não nulas=', len(Sol)) ############################################## # Solution input Sol = [] sol_input(solutionFile) Sol[:5], Sol[-5:] ############################################# # Solução + Prescrições = Madeira import numpy as np MAD = [] for k in range(90): # para 90 periodos de 1 anos Ctt = ['Ctt',0,'X'] # V_thin, Parcelas... Cth = ['Cth',0,'X'] # V_harv, Parcelas... Ect = ['Ect',0,'X'] # V_thin, Parcelas... Ech = ['Ech',0,'X'] # V_harv, Parcelas... Pbt = ['Pbt',0,'X'] # V_thin, Parcelas... Pbh = ['Pbh',0,'X'] # V_harv, Parcelas... Qrt = ['Qrt',0,'X'] # V_thin, Parcelas... Qrh = ['Qrh',0,'X'] # V_harv, Parcelas... Sbt = ['Sbt',0,'X'] # V_thin, Parcelas... Sbx = ['Sbx',0,'X'] # V_thin+cork, Parcelas... Sbc = ['Sbc',0,'X'] # V_cork, Parcelas... period = [Ctt, Cth, Ect, Ech, Pbt, Pbh, Qrt, Qrh, Sbt, Sbx, Sbc] MAD.append(period) eps = 0.000001 for lin in Sol: ##print(lin) try: Q = TabPreVS[lin[0]][lin[1]] # Parc Pres except KeyError: print('KeyError: ', 'Pa=', lin[0], 'Presc=', lin[1], 'var=', lin[4]) continue for st in Q: ##print('st:', st, st[5],st[4]) if st[5] == 'Ct': if st[0] > eps and st[1] < eps: MAD[st[4]-1][0].append(lin[0]) MAD[st[4]-1][0][1] += st[0] elif st[0] < eps and st[1] > eps: MAD[st[4]-1][1].append(lin[0]) MAD[st[4]-1][1][1] += st[1] elif st[0] > eps and st[1] > eps: MAD[st[4]-1][1].append(lin[0]) MAD[st[4]-1][0][1] += st[0] MAD[st[4]-1][1][1] += st[1] else: print('Aviso 11', st, lin[0], lin[1]) elif st[5] == 'Ec': if st[0] > eps and st[1] < eps: MAD[st[4]-1][2].append(lin[0]) MAD[st[4]-1][2][1] += st[0] elif st[0] < eps and st[1] > eps: MAD[st[4]-1][3].append(lin[0]) MAD[st[4]-1][3][1] += st[1] elif st[0] < eps and st[1] < eps: pass else: print('Aviso 12', st, lin[0], lin[1]) elif st[5] == 'Pb': if st[0] > eps and st[1] < eps: MAD[st[4]-1][4].append(lin[0]) MAD[st[4]-1][4][1] += st[0] elif st[0] < eps and st[1] > eps: MAD[st[4]-1][5].append(lin[0]) MAD[st[4]-1][5][1] += st[1] elif st[0] > eps and st[1] > eps: MAD[st[4]-1][5].append(lin[0]) MAD[st[4]-1][4][1] += st[0] MAD[st[4]-1][5][1] += st[1] else: print('Aviso 13', st, lin[0], lin[1]) elif st[5] == 'Qr': if st[0] > eps and st[1] < eps: MAD[st[4]-1][6].append(lin[0]) MAD[st[4]-1][6][1] += st[0] elif st[0] < eps and st[1] > eps: MAD[st[4]-1][7].append(lin[0]) MAD[st[4]-1][7][1] += st[1] else: print('Aviso 14', st, lin[0], lin[1]) elif st[5] == 'Sb': if st[0] > eps and st[3] < eps: MAD[st[4]-1][8].append(lin[0]) MAD[st[4]-1][8][1] += st[0] elif st[0] < eps and st[3] > eps: MAD[st[4]-1][10].append(lin[0]) MAD[st[4]-1][10][1] += st[3] elif st[0] > eps and st[3] > eps: MAD[st[4]-1][9].append(lin[0]) MAD[st[4]-1][8][1] += st[0] MAD[st[4]-1][10][1] += st[3] else: print('Aviso 15', st, lin[0], lin[1]) else: print('Aviso 10: ', st[5], st, lin[0], lin[1]) break #print('Ready') ####################################################### import matplotlib.pyplot as plt Clrs = ['gold', 'darkgoldenrod', 'lightcoral', 'red', 'lightgreen', 'green', 'cornflowerblue', 'blue', 'magenta', 'purple', 'indigo'] K = sorted(list(Units.keys())) for period in range(0,30): # [2, 6, 20, 29]: if pSaveFig < 0: break fig = plt.figure(figsize=(10,10)) ax = plt.gca() ax.set_facecolor('lightgray') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[0], label='Ct-thin') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[1], label='Ct-harv') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[3], label='Ec-harv') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[4], label='Pb-thin') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[5], label='Pb-harv') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[6], label='Qr-thin') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[7], label='Qr-harv') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[8], label='Sb-thin') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[9], label='Sb-thco') plt.plot([-25000, -25001], [165000, 165001], lw=15, c=Clrs[10], label='Sb-cork') plt.plot([-25000, -25001], [165000, 165001], lw=17, c='lightgray') plt.legend() for key in K: xx = [] yy = [] for v in Units[key]: xx.append(v[0]) yy.append(v[1]) ax.fill(xx, yy, facecolor='white', edgecolor='black', linewidth=1) MADp = MAD[period] nclr = 0 for esp in MADp: for key in esp[3:] : xx = [] yy = [] for v in Units[key]: xx.append(v[0]) yy.append(v[1]) ax.fill(xx, yy, facecolor=Clrs[nclr], edgecolor='black', linewidth=1) # thin nclr += 1 plt.text(-26000, 143000, info, fontsize=12) st = str(period+1) buf = 'Period = '+st plt.text(-26000, 166000, buf, fontsize=12) print(buf) #ax.xlim=((-20000, -15000)) #ax.ylim=((150000, 170000)) plt.tight_layout() if pSaveFig == 1: plt.savefig('VSousa-'+sufixo+'-'+st+'.png', dpi=100) #plt.show(plt) print('Ready')