inewave 1.7.5__py3-none-any.whl → 1.8.0__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 (155) 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/pmo.py +40 -0
  15. inewave/newave/nwv_avl_evap.py +10 -0
  16. inewave/newave/nwv_cortes_evap.py +10 -0
  17. inewave/newave/nwv_eco_evap.py +10 -0
  18. inewave/newave/pmo.py +17 -0
  19. inewave/nwlistop/__init__.py +65 -30
  20. inewave/nwlistop/c_v_rhq.py +10 -0
  21. inewave/nwlistop/c_v_rhq_s.py +10 -0
  22. inewave/nwlistop/c_v_rhv_s.py +10 -0
  23. inewave/nwlistop/celetricas.py +10 -0
  24. inewave/nwlistop/cviol_eletricasin.py +19 -0
  25. inewave/nwlistop/cviol_rhq.py +21 -0
  26. inewave/nwlistop/cviol_rhq_sin.py +19 -0
  27. inewave/nwlistop/cviol_rhv.py +21 -0
  28. inewave/nwlistop/cviol_rhv_sin.py +19 -0
  29. inewave/nwlistop/deletricas.py +10 -0
  30. inewave/nwlistop/depminuh.py +10 -0
  31. inewave/nwlistop/desvuh.py +10 -0
  32. inewave/nwlistop/dtbmax.py +10 -0
  33. inewave/nwlistop/dtbmin.py +10 -0
  34. inewave/nwlistop/dvazmax.py +10 -0
  35. inewave/nwlistop/modelos/cviol_eletricasin.py +28 -0
  36. inewave/nwlistop/modelos/cviol_rhq.py +28 -0
  37. inewave/nwlistop/modelos/cviol_rhq_sin.py +28 -0
  38. inewave/nwlistop/modelos/cviol_rhv.py +26 -0
  39. inewave/nwlistop/modelos/cviol_rhv_sin.py +26 -0
  40. inewave/nwlistop/modelos/pivarm.py +20 -0
  41. inewave/nwlistop/modelos/pivarmincr.py +20 -0
  42. inewave/nwlistop/modelos/qbomb.py +28 -0
  43. inewave/nwlistop/modelos/qdesviouh.py +28 -0
  44. inewave/nwlistop/modelos/qturuh.py +28 -0
  45. inewave/nwlistop/modelos/qvertuh.py +28 -0
  46. inewave/nwlistop/modelos/valor_agua.py +24 -0
  47. inewave/nwlistop/modelos/viol_eletricasin.py +28 -0
  48. inewave/nwlistop/modelos/viol_evmin.py +23 -0
  49. inewave/nwlistop/modelos/viol_evminm.py +23 -0
  50. inewave/nwlistop/modelos/viol_evminsin.py +23 -0
  51. inewave/nwlistop/modelos/viol_fpha.py +31 -0
  52. inewave/nwlistop/modelos/viol_ghmin.py +29 -0
  53. inewave/nwlistop/modelos/viol_ghminm.py +29 -0
  54. inewave/nwlistop/modelos/viol_ghminsin.py +29 -0
  55. inewave/nwlistop/modelos/viol_ghminuh.py +28 -0
  56. inewave/nwlistop/modelos/viol_lpp_dfmax.py +29 -0
  57. inewave/nwlistop/modelos/viol_lpp_dfmaxm.py +29 -0
  58. inewave/nwlistop/modelos/viol_lpp_dfmaxsin.py +29 -0
  59. inewave/nwlistop/modelos/viol_lpp_tbmax.py +29 -0
  60. inewave/nwlistop/modelos/viol_lpp_tbmaxm.py +29 -0
  61. inewave/nwlistop/modelos/viol_lpp_tbmaxsin.py +29 -0
  62. inewave/nwlistop/modelos/viol_neg_evap.py +26 -0
  63. inewave/nwlistop/modelos/viol_pos_evap.py +26 -0
  64. inewave/nwlistop/modelos/viol_turbmax.py +28 -0
  65. inewave/nwlistop/modelos/viol_turbmin.py +28 -0
  66. inewave/nwlistop/modelos/viol_vazmax.py +28 -0
  67. inewave/nwlistop/modelos/viol_vazmin.py +28 -0
  68. inewave/nwlistop/modelos/vretiradauh.py +26 -0
  69. inewave/nwlistop/pivarm.py +13 -2
  70. inewave/nwlistop/pivarmincr.py +13 -2
  71. inewave/nwlistop/qbomb.py +23 -0
  72. inewave/nwlistop/qdesviouh.py +21 -0
  73. inewave/nwlistop/qturuh.py +21 -0
  74. inewave/nwlistop/qvertuh.py +21 -0
  75. inewave/nwlistop/vagua.py +10 -0
  76. inewave/nwlistop/valor_agua.py +21 -0
  77. inewave/nwlistop/vertuh.py +10 -0
  78. inewave/nwlistop/vevmin.py +10 -0
  79. inewave/nwlistop/vevminm.py +10 -0
  80. inewave/nwlistop/vevminsin.py +10 -0
  81. inewave/nwlistop/vghmin.py +10 -0
  82. inewave/nwlistop/vghminm.py +10 -0
  83. inewave/nwlistop/vghminsin.py +10 -0
  84. inewave/nwlistop/viol_eletricasin.py +19 -0
  85. inewave/nwlistop/viol_evmin.py +20 -0
  86. inewave/nwlistop/viol_evminm.py +22 -0
  87. inewave/nwlistop/viol_evminsin.py +19 -0
  88. inewave/nwlistop/viol_fpha.py +22 -0
  89. inewave/nwlistop/viol_ghmin.py +22 -0
  90. inewave/nwlistop/viol_ghminm.py +22 -0
  91. inewave/nwlistop/viol_ghminsin.py +19 -0
  92. inewave/nwlistop/viol_ghminuh.py +22 -0
  93. inewave/nwlistop/viol_lpp_dfmax.py +22 -0
  94. inewave/nwlistop/viol_lpp_dfmaxm.py +22 -0
  95. inewave/nwlistop/viol_lpp_dfmaxsin.py +18 -0
  96. inewave/nwlistop/viol_lpp_tbmax.py +22 -0
  97. inewave/nwlistop/viol_lpp_tbmaxm.py +22 -0
  98. inewave/nwlistop/viol_lpp_tbmaxsin.py +18 -0
  99. inewave/nwlistop/viol_neg_evap.py +22 -0
  100. inewave/nwlistop/viol_pos_evap.py +22 -0
  101. inewave/nwlistop/viol_turbmax.py +22 -0
  102. inewave/nwlistop/viol_turbmin.py +22 -0
  103. inewave/nwlistop/viol_vazmax.py +22 -0
  104. inewave/nwlistop/viol_vazmin.py +22 -0
  105. inewave/nwlistop/vretiradauh.py +21 -0
  106. inewave/nwlistop/vturuh.py +10 -0
  107. {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/METADATA +1 -1
  108. {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/RECORD +155 -46
  109. tests/libs/test_restricoes.py +0 -3
  110. tests/libs/test_usinas_hidreletricas.py +0 -2
  111. tests/mocks/arquivos/pivarm.py +22 -0
  112. tests/mocks/arquivos/pivarmincr.py +22 -0
  113. tests/mocks/arquivos/pmo.py +6 -1
  114. tests/mocks/arquivos/viol_fpha.py +29 -0
  115. tests/newave/test_evap_avl_desv.py +40 -0
  116. tests/newave/test_evap_cortes.py +41 -0
  117. tests/newave/test_evap_eco.py +41 -0
  118. tests/newave/test_fpha_avl_desv_s.py +39 -0
  119. tests/newave/test_fpha_avl_desv_v_q.py +38 -0
  120. tests/newave/test_fpha_cortes.py +48 -0
  121. tests/newave/test_fpha_eco.py +47 -0
  122. tests/newave/test_pmo.py +14 -0
  123. tests/nwlistop/test_cviol_eletricasin.py +37 -0
  124. tests/nwlistop/test_cviol_rhq_sin.py +37 -0
  125. tests/nwlistop/test_cviol_rhv_sin.py +37 -0
  126. tests/nwlistop/test_qbomb.py +40 -0
  127. tests/nwlistop/test_qdesviouh.py +40 -0
  128. tests/nwlistop/test_qturuh.py +40 -0
  129. tests/nwlistop/test_qvertuh.py +40 -0
  130. tests/nwlistop/test_valor_agua.py +40 -0
  131. tests/nwlistop/test_viol_eletricasin.py +37 -0
  132. tests/nwlistop/test_viol_evmin.py +40 -0
  133. tests/nwlistop/test_viol_evminm.py +40 -0
  134. tests/nwlistop/test_viol_evminsin.py +37 -0
  135. tests/nwlistop/test_viol_fpha.py +40 -0
  136. tests/nwlistop/test_viol_ghmin.py +40 -0
  137. tests/nwlistop/test_viol_ghminm.py +40 -0
  138. tests/nwlistop/test_viol_ghminsin.py +37 -0
  139. tests/nwlistop/test_viol_ghminuh.py +40 -0
  140. tests/nwlistop/test_viol_lpp_dfmax.py +40 -0
  141. tests/nwlistop/test_viol_lpp_dfmaxm.py +40 -0
  142. tests/nwlistop/test_viol_lpp_dfmaxsin.py +37 -0
  143. tests/nwlistop/test_viol_lpp_tbmax.py +40 -0
  144. tests/nwlistop/test_viol_lpp_tbmaxm.py +40 -0
  145. tests/nwlistop/test_viol_lpp_tbmaxsin.py +37 -0
  146. tests/nwlistop/test_viol_neg_evap.py +41 -0
  147. tests/nwlistop/test_viol_pos_evap.py +40 -0
  148. tests/nwlistop/test_viol_turbmax.py +40 -0
  149. tests/nwlistop/test_viol_turbmin.py +40 -0
  150. tests/nwlistop/test_viol_vazmax.py +40 -0
  151. tests/nwlistop/test_viol_vazmin.py +40 -0
  152. tests/nwlistop/test_vretiradauh.py +40 -0
  153. {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/LICENSE.md +0 -0
  154. {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/WHEEL +0 -0
  155. {inewave-1.7.5.dist-info → inewave-1.8.0.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.0"
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()
@@ -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
@@ -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)
@@ -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 NwvEcoEvap(ArquivoCSV):
10
12
  """
@@ -32,3 +34,11 @@ class NwvEcoEvap(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 EvapEco no lugar.",
42
+ DeprecationWarning,
43
+ )
44
+ super().__init__(data)
inewave/newave/pmo.py CHANGED
@@ -1,3 +1,4 @@
1
+ from inewave.newave.modelos.pmo import BlocoVersaoModeloPMO
1
2
  from inewave.newave.modelos.pmo import BlocoEafPastTendenciaHidrolPMO
2
3
  from inewave.newave.modelos.pmo import BlocoEafPastCfugaMedioPMO
3
4
  from inewave.newave.modelos.pmo import BlocoConvergenciaPMO
@@ -48,6 +49,7 @@ class Pmo(BlockFile):
48
49
  T = TypeVar("T")
49
50
 
50
51
  BLOCKS = [
52
+ BlocoVersaoModeloPMO,
51
53
  BlocoEafPastTendenciaHidrolPMO,
52
54
  BlocoEafPastCfugaMedioPMO,
53
55
  BlocoConvergenciaPMO,
@@ -71,6 +73,21 @@ class Pmo(BlockFile):
71
73
  BlocoGeracaoMaximaUsinasTermicasPMO,
72
74
  ]
73
75
 
76
+ @property
77
+ def versao_modelo(self) -> Optional[str]:
78
+ """
79
+ A versão do modelo que produziu o arquivo.
80
+
81
+ :return: A string de versão do modelo.
82
+ :rtype: str | None
83
+ """
84
+ b = self.data.get_blocks_of_type(BlocoVersaoModeloPMO)
85
+ if isinstance(b, BlocoVersaoModeloPMO):
86
+ return b.data
87
+ elif isinstance(b, list):
88
+ return b[0].data
89
+ return None
90
+
74
91
  @property
75
92
  def eafpast_tendencia_hidrologica(self) -> Optional[pd.DataFrame]:
76
93
  """