inewave 1.7.5__py3-none-any.whl → 1.8.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. inewave/__init__.py +1 -1
  2. inewave/newave/__init__.py +16 -7
  3. inewave/newave/avl_cortesfpha_nwv.py +10 -0
  4. inewave/newave/avl_desvfpha_s.py +7 -0
  5. inewave/newave/avl_desvfpha_v_q.py +7 -0
  6. inewave/newave/eco_fpha.py +10 -0
  7. inewave/newave/evap_avl_desv.py +33 -0
  8. inewave/newave/evap_cortes.py +34 -0
  9. inewave/newave/evap_eco.py +34 -0
  10. inewave/newave/fpha_avl_desv_s.py +59 -0
  11. inewave/newave/fpha_avl_desv_v_q.py +58 -0
  12. inewave/newave/fpha_cortes.py +40 -0
  13. inewave/newave/fpha_eco.py +41 -0
  14. inewave/newave/modelos/blocos/tabelacsv.py +1 -1
  15. inewave/newave/modelos/blocos/versaomodelo.py +3 -3
  16. inewave/newave/modelos/forwarh.py +1 -1
  17. inewave/newave/modelos/hidr.py +1 -1
  18. inewave/newave/modelos/modif.py +9 -9
  19. inewave/newave/modelos/pmo.py +40 -0
  20. inewave/newave/modelos/vazoes.py +1 -1
  21. inewave/newave/modif.py +1 -1
  22. inewave/newave/nwv_avl_evap.py +10 -0
  23. inewave/newave/nwv_cortes_evap.py +10 -0
  24. inewave/newave/nwv_eco_evap.py +10 -0
  25. inewave/newave/pmo.py +17 -0
  26. inewave/nwlistop/__init__.py +65 -30
  27. inewave/nwlistop/c_v_rhq.py +10 -0
  28. inewave/nwlistop/c_v_rhq_s.py +10 -0
  29. inewave/nwlistop/c_v_rhv_s.py +10 -0
  30. inewave/nwlistop/celetricas.py +10 -0
  31. inewave/nwlistop/cviol_eletricasin.py +19 -0
  32. inewave/nwlistop/cviol_rhq.py +21 -0
  33. inewave/nwlistop/cviol_rhq_sin.py +19 -0
  34. inewave/nwlistop/cviol_rhv.py +21 -0
  35. inewave/nwlistop/cviol_rhv_sin.py +19 -0
  36. inewave/nwlistop/deletricas.py +10 -0
  37. inewave/nwlistop/depminuh.py +10 -0
  38. inewave/nwlistop/desvuh.py +10 -0
  39. inewave/nwlistop/dtbmax.py +10 -0
  40. inewave/nwlistop/dtbmin.py +10 -0
  41. inewave/nwlistop/dvazmax.py +10 -0
  42. inewave/nwlistop/modelos/blocos/valoresserie.py +1 -1
  43. inewave/nwlistop/modelos/cviol_eletricasin.py +28 -0
  44. inewave/nwlistop/modelos/cviol_rhq.py +28 -0
  45. inewave/nwlistop/modelos/cviol_rhq_sin.py +28 -0
  46. inewave/nwlistop/modelos/cviol_rhv.py +26 -0
  47. inewave/nwlistop/modelos/cviol_rhv_sin.py +26 -0
  48. inewave/nwlistop/modelos/pivarm.py +20 -0
  49. inewave/nwlistop/modelos/pivarmincr.py +20 -0
  50. inewave/nwlistop/modelos/qbomb.py +28 -0
  51. inewave/nwlistop/modelos/qdesviouh.py +28 -0
  52. inewave/nwlistop/modelos/qturuh.py +28 -0
  53. inewave/nwlistop/modelos/qvertuh.py +28 -0
  54. inewave/nwlistop/modelos/valor_agua.py +24 -0
  55. inewave/nwlistop/modelos/viol_eletricasin.py +28 -0
  56. inewave/nwlistop/modelos/viol_evmin.py +23 -0
  57. inewave/nwlistop/modelos/viol_evminm.py +23 -0
  58. inewave/nwlistop/modelos/viol_evminsin.py +23 -0
  59. inewave/nwlistop/modelos/viol_fpha.py +31 -0
  60. inewave/nwlistop/modelos/viol_ghmin.py +29 -0
  61. inewave/nwlistop/modelos/viol_ghminm.py +29 -0
  62. inewave/nwlistop/modelos/viol_ghminsin.py +29 -0
  63. inewave/nwlistop/modelos/viol_ghminuh.py +28 -0
  64. inewave/nwlistop/modelos/viol_lpp_dfmax.py +29 -0
  65. inewave/nwlistop/modelos/viol_lpp_dfmaxm.py +29 -0
  66. inewave/nwlistop/modelos/viol_lpp_dfmaxsin.py +29 -0
  67. inewave/nwlistop/modelos/viol_lpp_tbmax.py +29 -0
  68. inewave/nwlistop/modelos/viol_lpp_tbmaxm.py +29 -0
  69. inewave/nwlistop/modelos/viol_lpp_tbmaxsin.py +29 -0
  70. inewave/nwlistop/modelos/viol_neg_evap.py +26 -0
  71. inewave/nwlistop/modelos/viol_pos_evap.py +26 -0
  72. inewave/nwlistop/modelos/viol_turbmax.py +28 -0
  73. inewave/nwlistop/modelos/viol_turbmin.py +28 -0
  74. inewave/nwlistop/modelos/viol_vazmax.py +28 -0
  75. inewave/nwlistop/modelos/viol_vazmin.py +28 -0
  76. inewave/nwlistop/modelos/vretiradauh.py +26 -0
  77. inewave/nwlistop/pivarm.py +13 -2
  78. inewave/nwlistop/pivarmincr.py +13 -2
  79. inewave/nwlistop/qbomb.py +23 -0
  80. inewave/nwlistop/qdesviouh.py +21 -0
  81. inewave/nwlistop/qturuh.py +21 -0
  82. inewave/nwlistop/qvertuh.py +21 -0
  83. inewave/nwlistop/vagua.py +10 -0
  84. inewave/nwlistop/valor_agua.py +21 -0
  85. inewave/nwlistop/vertuh.py +10 -0
  86. inewave/nwlistop/vevmin.py +10 -0
  87. inewave/nwlistop/vevminm.py +10 -0
  88. inewave/nwlistop/vevminsin.py +10 -0
  89. inewave/nwlistop/vghmin.py +10 -0
  90. inewave/nwlistop/vghminm.py +10 -0
  91. inewave/nwlistop/vghminsin.py +10 -0
  92. inewave/nwlistop/viol_eletricasin.py +19 -0
  93. inewave/nwlistop/viol_evmin.py +20 -0
  94. inewave/nwlistop/viol_evminm.py +22 -0
  95. inewave/nwlistop/viol_evminsin.py +19 -0
  96. inewave/nwlistop/viol_fpha.py +22 -0
  97. inewave/nwlistop/viol_ghmin.py +22 -0
  98. inewave/nwlistop/viol_ghminm.py +22 -0
  99. inewave/nwlistop/viol_ghminsin.py +19 -0
  100. inewave/nwlistop/viol_ghminuh.py +22 -0
  101. inewave/nwlistop/viol_lpp_dfmax.py +22 -0
  102. inewave/nwlistop/viol_lpp_dfmaxm.py +22 -0
  103. inewave/nwlistop/viol_lpp_dfmaxsin.py +18 -0
  104. inewave/nwlistop/viol_lpp_tbmax.py +22 -0
  105. inewave/nwlistop/viol_lpp_tbmaxm.py +22 -0
  106. inewave/nwlistop/viol_lpp_tbmaxsin.py +18 -0
  107. inewave/nwlistop/viol_neg_evap.py +22 -0
  108. inewave/nwlistop/viol_pos_evap.py +22 -0
  109. inewave/nwlistop/viol_turbmax.py +22 -0
  110. inewave/nwlistop/viol_turbmin.py +22 -0
  111. inewave/nwlistop/viol_vazmax.py +22 -0
  112. inewave/nwlistop/viol_vazmin.py +22 -0
  113. inewave/nwlistop/vretiradauh.py +21 -0
  114. inewave/nwlistop/vturuh.py +10 -0
  115. {inewave-1.7.5.dist-info → inewave-1.8.1.dist-info}/METADATA +1 -1
  116. {inewave-1.7.5.dist-info → inewave-1.8.1.dist-info}/RECORD +165 -56
  117. tests/libs/test_restricoes.py +0 -3
  118. tests/libs/test_usinas_hidreletricas.py +0 -2
  119. tests/mocks/arquivos/pivarm.py +22 -0
  120. tests/mocks/arquivos/pivarmincr.py +22 -0
  121. tests/mocks/arquivos/pmo.py +6 -1
  122. tests/mocks/arquivos/viol_fpha.py +29 -0
  123. tests/newave/test_evap_avl_desv.py +40 -0
  124. tests/newave/test_evap_cortes.py +41 -0
  125. tests/newave/test_evap_eco.py +41 -0
  126. tests/newave/test_fpha_avl_desv_s.py +39 -0
  127. tests/newave/test_fpha_avl_desv_v_q.py +38 -0
  128. tests/newave/test_fpha_cortes.py +48 -0
  129. tests/newave/test_fpha_eco.py +47 -0
  130. tests/newave/test_pmo.py +14 -0
  131. tests/nwlistop/test_cviol_eletricasin.py +37 -0
  132. tests/nwlistop/test_cviol_rhq_sin.py +37 -0
  133. tests/nwlistop/test_cviol_rhv_sin.py +37 -0
  134. tests/nwlistop/test_pivarm.py +15 -1
  135. tests/nwlistop/test_pivarmincr.py +18 -1
  136. tests/nwlistop/test_qbomb.py +40 -0
  137. tests/nwlistop/test_qdesviouh.py +40 -0
  138. tests/nwlistop/test_qturuh.py +40 -0
  139. tests/nwlistop/test_qvertuh.py +40 -0
  140. tests/nwlistop/test_valor_agua.py +40 -0
  141. tests/nwlistop/test_viol_eletricasin.py +37 -0
  142. tests/nwlistop/test_viol_evmin.py +40 -0
  143. tests/nwlistop/test_viol_evminm.py +40 -0
  144. tests/nwlistop/test_viol_evminsin.py +37 -0
  145. tests/nwlistop/test_viol_fpha.py +40 -0
  146. tests/nwlistop/test_viol_ghmin.py +40 -0
  147. tests/nwlistop/test_viol_ghminm.py +40 -0
  148. tests/nwlistop/test_viol_ghminsin.py +37 -0
  149. tests/nwlistop/test_viol_ghminuh.py +40 -0
  150. tests/nwlistop/test_viol_lpp_dfmax.py +40 -0
  151. tests/nwlistop/test_viol_lpp_dfmaxm.py +40 -0
  152. tests/nwlistop/test_viol_lpp_dfmaxsin.py +37 -0
  153. tests/nwlistop/test_viol_lpp_tbmax.py +40 -0
  154. tests/nwlistop/test_viol_lpp_tbmaxm.py +40 -0
  155. tests/nwlistop/test_viol_lpp_tbmaxsin.py +37 -0
  156. tests/nwlistop/test_viol_neg_evap.py +41 -0
  157. tests/nwlistop/test_viol_pos_evap.py +40 -0
  158. tests/nwlistop/test_viol_turbmax.py +40 -0
  159. tests/nwlistop/test_viol_turbmin.py +40 -0
  160. tests/nwlistop/test_viol_vazmax.py +40 -0
  161. tests/nwlistop/test_viol_vazmin.py +40 -0
  162. tests/nwlistop/test_vretiradauh.py +40 -0
  163. {inewave-1.7.5.dist-info → inewave-1.8.1.dist-info}/LICENSE.md +0 -0
  164. {inewave-1.7.5.dist-info → inewave-1.8.1.dist-info}/WHEEL +0 -0
  165. {inewave-1.7.5.dist-info → inewave-1.8.1.dist-info}/top_level.txt +0 -0
inewave/__init__.py CHANGED
@@ -6,7 +6,7 @@ inewave é um módulo em Python para manipulação dos arquivos de entrada
6
6
  e saída do NEWAVE.
7
7
  """
8
8
 
9
- __version__ = "1.7.5"
9
+ __version__ = "1.8.1"
10
10
 
11
11
  from . import newave # noqa
12
12
  from . import nwlistcf # noqa
@@ -1,5 +1,14 @@
1
1
  # Inclui os membros
2
2
 
3
+ # Deprecated
4
+ from .avl_cortesfpha_nwv import AvlCortesFpha # noqa
5
+ from .avl_desvfpha_s import AvlDesvFphaS # noqa
6
+ from .avl_desvfpha_v_q import AvlDesvFphaVQ # noqa
7
+ from .eco_fpha import EcoFpha # noqa
8
+ from .nwv_avl_evap import NwvAvlEvap # noqa
9
+ from .nwv_cortes_evap import NwvCortesEvap # noqa
10
+ from .nwv_eco_evap import NwvEcoEvap # noqa
11
+
3
12
  from .abertura import Abertura # noqa
4
13
  from .adterm import Adterm # noqa
5
14
  from .agrint import Agrint # noqa
@@ -46,13 +55,13 @@ from .term import Term # noqa
46
55
  from .vazoes import Vazoes # noqa
47
56
  from .vazpast import Vazpast # noqa
48
57
  from .volref_saz import VolrefSaz # noqa
49
- from .avl_cortesfpha_nwv import AvlCortesFpha # noqa
50
- from .avl_desvfpha_s import AvlDesvFphaS # noqa
51
- from .avl_desvfpha_v_q import AvlDesvFphaVQ # noqa
52
- from .eco_fpha import EcoFpha # noqa
53
- from .nwv_avl_evap import NwvAvlEvap # noqa
54
- from .nwv_cortes_evap import NwvCortesEvap # noqa
55
- from .nwv_eco_evap import NwvEcoEvap # noqa
58
+ from .fpha_cortes import FphaCortes # noqa
59
+ from .fpha_avl_desv_s import FphaAvlDesvS # noqa
60
+ from .fpha_avl_desv_v_q import FphaAvlDesvVQ # noqa
61
+ from .fpha_eco import FphaEco # noqa
62
+ from .evap_avl_desv import EvapAvlDesv # noqa
63
+ from .evap_cortes import EvapCortes # noqa
64
+ from .evap_eco import EvapEco # noqa
56
65
  from .energiaf import Energiaf # noqa
57
66
  from .energiab import Energiab # noqa
58
67
  from .energias import Energias # noqa
@@ -11,6 +11,8 @@ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
11
11
  from typing import Optional
12
12
  import pandas as pd # type: ignore
13
13
 
14
+ from warnings import warn
15
+
14
16
 
15
17
  class AvlCortesFpha(ArquivoCSV):
16
18
  """
@@ -44,3 +46,11 @@ class AvlCortesFpha(ArquivoCSV):
44
46
  :rtype: pd.DataFrame | None
45
47
  """
46
48
  return self._tabela()
49
+
50
+ def __init__(self, data=...) -> None:
51
+ warn(
52
+ "Esta classe é relativa a um arquivo que não é mais suportado."
53
+ + " Utilize a classe FphaCortes no lugar.",
54
+ DeprecationWarning,
55
+ )
56
+ super().__init__(data)
@@ -5,6 +5,8 @@ from cfinterface.files.blockfile import BlockFile
5
5
  from typing import Optional, TypeVar
6
6
  import pandas as pd # type: ignore
7
7
 
8
+ from warnings import warn
9
+
8
10
 
9
11
  class AvlDesvFphaS(BlockFile):
10
12
  """
@@ -18,6 +20,11 @@ class AvlDesvFphaS(BlockFile):
18
20
  T = TypeVar("T")
19
21
 
20
22
  def __init__(self, data=...) -> None:
23
+ warn(
24
+ "Esta classe é relativa a um arquivo que não é mais suportado."
25
+ + " Utilize a classe FphaAvlDesvS no lugar.",
26
+ DeprecationWarning,
27
+ )
21
28
  super().__init__(data)
22
29
  self.__df_completo: Optional[pd.DataFrame] = None
23
30
 
@@ -5,6 +5,8 @@ from cfinterface.files.blockfile import BlockFile
5
5
  from typing import Optional, TypeVar
6
6
  import pandas as pd # type: ignore
7
7
 
8
+ from warnings import warn
9
+
8
10
 
9
11
  class AvlDesvFphaVQ(BlockFile):
10
12
  """
@@ -18,6 +20,11 @@ class AvlDesvFphaVQ(BlockFile):
18
20
  T = TypeVar("T")
19
21
 
20
22
  def __init__(self, data=...) -> None:
23
+ warn(
24
+ "Esta classe é relativa a um arquivo que não é mais suportado."
25
+ + " Utilize a classe FphaAvlDesvVQ no lugar.",
26
+ DeprecationWarning,
27
+ )
21
28
  super().__init__(data)
22
29
  self.__df_completo: Optional[pd.DataFrame] = None
23
30
 
@@ -5,6 +5,8 @@ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
5
5
  from typing import Optional
6
6
  import pandas as pd # type: ignore
7
7
 
8
+ from warnings import warn
9
+
8
10
 
9
11
  class EcoFpha(ArquivoCSV):
10
12
  """
@@ -39,3 +41,11 @@ class EcoFpha(ArquivoCSV):
39
41
  :rtype: pd.DataFrame | None
40
42
  """
41
43
  return self._tabela()
44
+
45
+ def __init__(self, data=...) -> None:
46
+ warn(
47
+ "Esta classe é relativa a um arquivo que não é mais suportado."
48
+ + " Utilize a classe FphaEco no lugar.",
49
+ DeprecationWarning,
50
+ )
51
+ super().__init__(data)
@@ -0,0 +1,33 @@
1
+ from inewave.newave.modelos.blocos.versaomodelo import VersaoModelo
2
+ from inewave.newave.modelos.nwv_avl_evap import TabelaAvlEvap
3
+
4
+ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
5
+ from typing import Optional
6
+ import pandas as pd # type: ignore
7
+
8
+
9
+ class EvapAvlDesv(ArquivoCSV):
10
+ """
11
+ Arquivo com a avaliação da evaporação linear do NEWAVE.
12
+ """
13
+
14
+ BLOCKS = [VersaoModelo, TabelaAvlEvap]
15
+
16
+ @property
17
+ def tabela(self) -> Optional[pd.DataFrame]:
18
+ """
19
+ A tabela de dados que está contida no arquivo.
20
+
21
+ - periodo (`int`)
22
+ - codigo_usina (`int`)
23
+ - nome_usina (`str`)
24
+ - volume_armazenado_hm3 (`float`)
25
+ - evaporacao_calculada_hm3 (`float`)
26
+ - evaporacao_modelo_hm3 (`float`)
27
+ - desvio_absoluto_hm3 (`float`)
28
+ - desvio_percentual (`float`)
29
+
30
+ :return: A tabela como um dataframe
31
+ :rtype: pd.DataFrame | None
32
+ """
33
+ return self._tabela()
@@ -0,0 +1,34 @@
1
+ from inewave.newave.modelos.blocos.versaomodelo import VersaoModelo
2
+ from inewave.newave.modelos.nwv_cortes_evap import TabelaCortesEvap
3
+
4
+ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
5
+ from typing import Optional
6
+ import pandas as pd # type: ignore
7
+
8
+
9
+ class EvapCortes(ArquivoCSV):
10
+ """
11
+ Arquivo com os cortes da evaporação linear do NEWAVE.
12
+ """
13
+
14
+ BLOCKS = [VersaoModelo, TabelaCortesEvap]
15
+
16
+ @property
17
+ def tabela(self) -> Optional[pd.DataFrame]:
18
+ """
19
+ A tabela de dados que está contida no arquivo.
20
+
21
+ - periodo (`int`)
22
+ - indice_usina (`int`)
23
+ - nome_usina (`str`)
24
+ - derivada_cota_area (`float`)
25
+ - derivada_volume_cota (`float`)
26
+ - volume_referencia_hm3 (`float`)
27
+ - evaporacao_referencia_hm3 (`float`)
28
+ - coeficiente_volume (`float`)
29
+ - rhs_volume (`float`)
30
+
31
+ :return: A tabela como um dataframe
32
+ :rtype: pd.DataFrame | None
33
+ """
34
+ return self._tabela()
@@ -0,0 +1,34 @@
1
+ from inewave.newave.modelos.blocos.versaomodelo import VersaoModelo
2
+ from inewave.newave.modelos.nwv_eco_evap import TabelaEcoEvap
3
+
4
+ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
5
+ from typing import Optional
6
+ import pandas as pd # type: ignore
7
+
8
+
9
+ class EvapEco(ArquivoCSV):
10
+ """
11
+ Arquivo com o eco dos dados da evaporação linear do NEWAVE.
12
+ """
13
+
14
+ BLOCKS = [VersaoModelo, TabelaEcoEvap]
15
+
16
+ @property
17
+ def tabela(self) -> Optional[pd.DataFrame]:
18
+ """
19
+ A tabela de dados que está contida no arquivo.
20
+
21
+ - periodo (`int`)
22
+ - codigo_usina (`int`)
23
+ - nome_usina (`str`)
24
+ - volume_referencia_hm3 (`float`)
25
+ - evaporacao_referencia_hm3 (`float`)
26
+ - coeficiente_evaporacao_mm_mes (`int`)
27
+ - flag_evaporacao (`int`)
28
+ - evaporacao_linear (`int`)
29
+ - tipo_volume_referencia (`int`)
30
+
31
+ :return: A tabela como um dataframe
32
+ :rtype: pd.DataFrame | None
33
+ """
34
+ return self._tabela()
@@ -0,0 +1,59 @@
1
+ from inewave.newave.modelos.blocos.versaomodelo import VersaoModelo
2
+ from inewave.newave.modelos.avl_desvfpha_s import TabelaAvlDesvFphaS
3
+
4
+ from cfinterface.files.blockfile import BlockFile
5
+ from typing import Optional, TypeVar
6
+ import pandas as pd # type: ignore
7
+
8
+
9
+ class FphaAvlDesvS(BlockFile):
10
+ """
11
+ Arquivo com os desvios da função de produção no plano de
12
+ vazão vertida (S).
13
+ """
14
+
15
+ BLOCKS = [VersaoModelo, TabelaAvlDesvFphaS]
16
+ ENCODING = "iso-8859-1"
17
+
18
+ T = TypeVar("T")
19
+
20
+ def __init__(self, data=...) -> None:
21
+ super().__init__(data)
22
+ self.__df_completo: Optional[pd.DataFrame] = None
23
+
24
+ @property
25
+ def tabela(self) -> Optional[pd.DataFrame]:
26
+ """
27
+ A tabela de dados que está contida no arquivo.
28
+
29
+ - codigo_usina (`int`)
30
+ - nome_usina (`str`)
31
+ - volume_armazenado_percentual (`float`)
32
+ - vazao_turbinada_m3s (`float`)
33
+ - vazao_vertida_m3s (`float`)
34
+ - desvio_percentual (`float`)
35
+
36
+ :return: A tabela como um dataframe
37
+ :rtype: pd.DataFrame | None
38
+ """
39
+ if self.__df_completo is None:
40
+ tabelas = self.data.of_type(TabelaAvlDesvFphaS)
41
+ self.__df_completo = pd.DataFrame()
42
+ for t in tabelas:
43
+ self.__df_completo = pd.concat(
44
+ [self.__df_completo, t.data], ignore_index=True
45
+ )
46
+ return self.__df_completo
47
+
48
+ @property
49
+ def versao(self) -> Optional[str]:
50
+ """
51
+ A versão do modelo utilizada para executar o caso.
52
+
53
+ :return: A versão do modelo
54
+ :rtype: str | None
55
+ """
56
+ b = self.data.get_blocks_of_type(VersaoModelo)
57
+ if isinstance(b, VersaoModelo):
58
+ return b.data
59
+ return None
@@ -0,0 +1,58 @@
1
+ from inewave.newave.modelos.blocos.versaomodelo import VersaoModelo
2
+ from inewave.newave.modelos.avl_desvfpha_v_q import TabelaAvlDesvFphaVQ
3
+
4
+ from cfinterface.files.blockfile import BlockFile
5
+ from typing import Optional, TypeVar
6
+ import pandas as pd # type: ignore
7
+
8
+
9
+ class FphaAvlDesvVQ(BlockFile):
10
+ """
11
+ Arquivo com os desvios da função de produção nos planos de
12
+ volume armazenado e vazão turbinada (V-Q).
13
+ """
14
+
15
+ BLOCKS = [VersaoModelo, TabelaAvlDesvFphaVQ]
16
+ ENCODING = "iso-8859-1"
17
+
18
+ T = TypeVar("T")
19
+
20
+ def __init__(self, data=...) -> None:
21
+ super().__init__(data)
22
+ self.__df_completo: Optional[pd.DataFrame] = None
23
+
24
+ @property
25
+ def tabela(self) -> Optional[pd.DataFrame]:
26
+ """
27
+ A tabela de dados que está contida no arquivo.
28
+
29
+ - codigo_usina (`int`)
30
+ - nome_usina (`str`)
31
+ - volume_armazenado_percentual (`float`)
32
+ - vazao_turbinada_m3s (`float`)
33
+ - desvio_percentual (`float`)
34
+
35
+ :return: A tabela como um dataframe
36
+ :rtype: pd.DataFrame | None
37
+ """
38
+ if self.__df_completo is None:
39
+ tabelas = self.data.of_type(TabelaAvlDesvFphaVQ)
40
+ tabelas_validas = [t.data for t in tabelas if t is not None]
41
+ self.__df_completo = pd.concat(
42
+ [t for t in tabelas_validas if isinstance(t, pd.DataFrame)],
43
+ ignore_index=True,
44
+ )
45
+ return self.__df_completo
46
+
47
+ @property
48
+ def versao(self) -> Optional[str]:
49
+ """
50
+ A versão do modelo utilizada para executar o caso.
51
+
52
+ :return: A versão do modelo
53
+ :rtype: str | None
54
+ """
55
+ b = self.data.get_blocks_of_type(VersaoModelo)
56
+ if isinstance(b, VersaoModelo):
57
+ return b.data
58
+ return None
@@ -0,0 +1,40 @@
1
+ from inewave.newave.modelos.blocos.versaomodelo import (
2
+ VersaoModeloLibs,
3
+ )
4
+ from inewave.newave.modelos.avl_cortesfpha_nwv import (
5
+ TabelaAvlCortesFpha,
6
+ )
7
+
8
+ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
9
+ from typing import Optional
10
+ import pandas as pd # type: ignore
11
+
12
+
13
+ class FphaCortes(ArquivoCSV):
14
+ """
15
+ Arquivo com os cortes da função de produção para as UHEs
16
+ do NEWAVE.
17
+ """
18
+
19
+ BLOCKS = [VersaoModeloLibs, TabelaAvlCortesFpha]
20
+
21
+ @property
22
+ def tabela(self) -> Optional[pd.DataFrame]:
23
+ """
24
+ A tabela de dados que está contida no arquivo.
25
+
26
+ - codigo_usina (`int`)
27
+ - periodo (`int`)
28
+ - nome_usina (`str`)
29
+ - indice_corte (`int`)
30
+ - fator_correcao (`float`)
31
+ - rhs_energia (`float`)
32
+ - coeficiente_volume_util_MW_hm3 (`float`)
33
+ - coeficiente_vazao_turbinada_MW_m3s (`float`)
34
+ - coeficiente_vazao_vertida_MW_m3s (`float`)
35
+ - coeficiente_vazao_lateral_MW_m3s (`float`)
36
+
37
+ :return: A tabela como um dataframe
38
+ :rtype: pd.DataFrame | None
39
+ """
40
+ return self._tabela()
@@ -0,0 +1,41 @@
1
+ from inewave.newave.modelos.blocos.versaomodelo import VersaoModelo
2
+ from inewave.newave.modelos.eco_fpha import TabelaEcoFpha
3
+
4
+ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
5
+ from typing import Optional
6
+ import pandas as pd # type: ignore
7
+
8
+
9
+ class FphaEco(ArquivoCSV):
10
+ """
11
+ Arquivo com o eco da função de produção para as UHEs
12
+ do NEWAVE.
13
+ """
14
+
15
+ BLOCKS = [VersaoModelo, TabelaEcoFpha]
16
+
17
+ @property
18
+ def tabela(self) -> Optional[pd.DataFrame]:
19
+ """
20
+ A tabela de dados que está contida no arquivo.
21
+
22
+ - codigo_usina (`int`)
23
+ - periodo (`int`)
24
+ - nome_usina (`str`)
25
+ - tipo (`int`)
26
+ - conv (`int`)
27
+ - alfa (`int`)
28
+ - rems (`int`)
29
+ - numero_pontos_vazao_turbinada (`int`)
30
+ - vazao_turbinada_minima (`float`)
31
+ - vazao_turbinada_maxima (`float`)
32
+ - numero_pontos_volume_armazenado (`int`)
33
+ - volume_armazenado_minimo (`float`)
34
+ - volume_armazenado_maximo (`float`)
35
+ - geracao_minima (`float`)
36
+ - geracao_maxima (`float`)
37
+
38
+ :return: A tabela como um dataframe
39
+ :rtype: pd.DataFrame | None
40
+ """
41
+ return self._tabela()
@@ -11,7 +11,7 @@ class TabelaCSV(Block):
11
11
  a partir de um modelo de linha, para arquivos de saída do NEWAVE.
12
12
  """
13
13
 
14
- __slots__ = []
14
+ __slots__: List[str] = []
15
15
 
16
16
  BEGIN_PATTERN = "-----;------;"
17
17
  LINE_MODEL = Line([])
@@ -2,7 +2,7 @@ from cfinterface.components.block import Block
2
2
  from cfinterface.components.literalfield import LiteralField
3
3
  from cfinterface.components.line import Line
4
4
 
5
- from typing import IO
5
+ from typing import IO, List
6
6
 
7
7
 
8
8
  class VersaoModelo(Block):
@@ -11,7 +11,7 @@ class VersaoModelo(Block):
11
11
  título do arquivo.
12
12
  """
13
13
 
14
- __slots__ = []
14
+ __slots__: List[str] = []
15
15
 
16
16
  BEGIN_PATTERN = r"CEPEL: NEWAVE"
17
17
  END_PATTERN = ""
@@ -36,7 +36,7 @@ class VersaoModeloLibs(Block):
36
36
  título do arquivo.
37
37
  """
38
38
 
39
- __slots__ = []
39
+ __slots__: List[str] = []
40
40
 
41
41
  BEGIN_PATTERN = r"NEWAVE -"
42
42
  END_PATTERN = ""
@@ -10,7 +10,7 @@ class SecaoDadosForwarh(Section):
10
10
  arquivo forwarh.dat
11
11
  """
12
12
 
13
- __slots__ = []
13
+ __slots__: List[str] = []
14
14
 
15
15
  ZVAZ = 100
16
16
 
@@ -12,7 +12,7 @@ class RegistroUHEHidr(Register):
12
12
  arquivo HIDR.
13
13
  """
14
14
 
15
- __slots__ = []
15
+ __slots__: List[str] = []
16
16
 
17
17
  LINE = Line(
18
18
  [
@@ -7,7 +7,7 @@ from cfinterface.components.floatfield import FloatField
7
7
  from cfinterface.adapters.components.repository import factory
8
8
  from copy import deepcopy
9
9
  from datetime import datetime
10
- from typing import Optional, IO
10
+ from typing import Optional, IO, List
11
11
 
12
12
 
13
13
  class ModifRegister(Register):
@@ -73,7 +73,7 @@ class USINA(Register):
73
73
  Registro que contém a usina modificada.
74
74
  """
75
75
 
76
- __slots__ = []
76
+ __slots__: List[str] = []
77
77
 
78
78
  IDENTIFIER = " USINA"
79
79
  IDENTIFIER_DIGITS = 8
@@ -376,7 +376,7 @@ class VMAXT(Register):
376
376
  com data.
377
377
  """
378
378
 
379
- __slots__ = []
379
+ __slots__: List[str] = []
380
380
 
381
381
  IDENTIFIER = " VMAXT"
382
382
  IDENTIFIER_DIGITS = 8
@@ -439,7 +439,7 @@ class VMINT(Register):
439
439
  com data.
440
440
  """
441
441
 
442
- __slots__ = []
442
+ __slots__: List[str] = []
443
443
 
444
444
  IDENTIFIER = " VMINT"
445
445
  IDENTIFIER_DIGITS = 8
@@ -502,7 +502,7 @@ class VMINP(Register):
502
502
  com data para adoção de penalidade.
503
503
  """
504
504
 
505
- __slots__ = []
505
+ __slots__: List[str] = []
506
506
 
507
507
  IDENTIFIER = " VMINP"
508
508
  IDENTIFIER_DIGITS = 8
@@ -565,7 +565,7 @@ class VAZMINT(Register):
565
565
  com data.
566
566
  """
567
567
 
568
- __slots__ = []
568
+ __slots__: List[str] = []
569
569
 
570
570
  IDENTIFIER = " VAZMINT"
571
571
  IDENTIFIER_DIGITS = 8
@@ -613,7 +613,7 @@ class VAZMAXT(Register):
613
613
  com data.
614
614
  """
615
615
 
616
- __slots__ = []
616
+ __slots__: List[str] = []
617
617
 
618
618
  IDENTIFIER = " VAZMAXT"
619
619
  IDENTIFIER_DIGITS = 8
@@ -661,7 +661,7 @@ class TURBMAXT(Register):
661
661
  com data.
662
662
  """
663
663
 
664
- __slots__ = []
664
+ __slots__: List[str] = []
665
665
 
666
666
  IDENTIFIER = " TURBMAXT"
667
667
  IDENTIFIER_DIGITS = 9
@@ -709,7 +709,7 @@ class TURBMINT(Register):
709
709
  com data.
710
710
  """
711
711
 
712
- __slots__ = []
712
+ __slots__: List[str] = []
713
713
 
714
714
  IDENTIFIER = " TURBMINT"
715
715
  IDENTIFIER_DIGITS = 9
@@ -21,6 +21,46 @@ from inewave._utils.formatacao import (
21
21
  )
22
22
 
23
23
 
24
+ class BlocoVersaoModeloPMO(Block):
25
+ """
26
+ Bloco com a versão do modelo localizado no arquivo `pmo.dat`.
27
+ """
28
+
29
+ __slots__ = ["__line"]
30
+
31
+ BEGIN_PATTERN = (
32
+ " CEPEL MODELO ESTRATEGICO DE"
33
+ + " GERACAO HIDROTERMICA A SUBSISTEMAS VERSAO"
34
+ )
35
+ END_PATTERN = ""
36
+
37
+ def __init__(self, previous=None, next=None, data=None) -> None:
38
+ super().__init__(previous, next, data)
39
+
40
+ self.__line = Line([LiteralField(18, 109)])
41
+
42
+ def __eq__(self, o: object) -> bool:
43
+ if not isinstance(o, BlocoVersaoModeloPMO):
44
+ return False
45
+ bloco: BlocoVersaoModeloPMO = o
46
+ if not all(
47
+ [
48
+ isinstance(self.data, str),
49
+ isinstance(o.data, str),
50
+ ]
51
+ ):
52
+ return False
53
+ else:
54
+ return self.data == bloco.data
55
+
56
+ # Override
57
+ def read(self, file: IO, *args, **kwargs):
58
+
59
+ linha = file.readline()
60
+ dados: List[str] = self.__line.read(linha)
61
+ self.data = dados[0].strip()
62
+
63
+
24
64
  class BlocoEafPastTendenciaHidrolPMO(Block):
25
65
  """
26
66
  Bloco de informações de afluências passadas para
@@ -9,7 +9,7 @@ class RegistroVazoesPostos(Register):
9
9
  Registro com os dados associados às vazões dos postos.
10
10
  """
11
11
 
12
- __slots__ = []
12
+ __slots__: List[str] = []
13
13
 
14
14
  POSTOS = 320
15
15
 
inewave/newave/modif.py CHANGED
@@ -29,7 +29,7 @@ class Modif(RegisterFile):
29
29
  configurações das usinas hidroelétricas.
30
30
  """
31
31
 
32
- __slots__ = []
32
+ __slots__: List[str] = []
33
33
 
34
34
  T = TypeVar("T")
35
35
 
@@ -5,6 +5,8 @@ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
5
5
  from typing import Optional
6
6
  import pandas as pd # type: ignore
7
7
 
8
+ from warnings import warn
9
+
8
10
 
9
11
  class NwvAvlEvap(ArquivoCSV):
10
12
  """
@@ -31,3 +33,11 @@ class NwvAvlEvap(ArquivoCSV):
31
33
  :rtype: pd.DataFrame | None
32
34
  """
33
35
  return self._tabela()
36
+
37
+ def __init__(self, data=...) -> None:
38
+ warn(
39
+ "Esta classe é relativa a um arquivo que não é mais suportado."
40
+ + " Utilize a classe EvapAvlDesv no lugar.",
41
+ DeprecationWarning,
42
+ )
43
+ super().__init__(data)
@@ -5,6 +5,8 @@ from inewave.newave.modelos.arquivoscsv.arquivocsv import ArquivoCSV
5
5
  from typing import Optional
6
6
  import pandas as pd # type: ignore
7
7
 
8
+ from warnings import warn
9
+
8
10
 
9
11
  class NwvCortesEvap(ArquivoCSV):
10
12
  """
@@ -32,3 +34,11 @@ class NwvCortesEvap(ArquivoCSV):
32
34
  :rtype: pd.DataFrame | None
33
35
  """
34
36
  return self._tabela()
37
+
38
+ def __init__(self, data=...) -> None:
39
+ warn(
40
+ "Esta classe é relativa a um arquivo que não é mais suportado."
41
+ + " Utilize a classe EvapCortes no lugar.",
42
+ DeprecationWarning,
43
+ )
44
+ super().__init__(data)