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.
- inewave/__init__.py +1 -1
- inewave/newave/__init__.py +16 -7
- inewave/newave/avl_cortesfpha_nwv.py +10 -0
- inewave/newave/avl_desvfpha_s.py +7 -0
- inewave/newave/avl_desvfpha_v_q.py +7 -0
- inewave/newave/eco_fpha.py +10 -0
- inewave/newave/evap_avl_desv.py +33 -0
- inewave/newave/evap_cortes.py +34 -0
- inewave/newave/evap_eco.py +34 -0
- inewave/newave/fpha_avl_desv_s.py +59 -0
- inewave/newave/fpha_avl_desv_v_q.py +58 -0
- inewave/newave/fpha_cortes.py +40 -0
- inewave/newave/fpha_eco.py +41 -0
- inewave/newave/modelos/pmo.py +40 -0
- inewave/newave/nwv_avl_evap.py +10 -0
- inewave/newave/nwv_cortes_evap.py +10 -0
- inewave/newave/nwv_eco_evap.py +10 -0
- inewave/newave/pmo.py +17 -0
- inewave/nwlistop/__init__.py +65 -30
- inewave/nwlistop/c_v_rhq.py +10 -0
- inewave/nwlistop/c_v_rhq_s.py +10 -0
- inewave/nwlistop/c_v_rhv_s.py +10 -0
- inewave/nwlistop/celetricas.py +10 -0
- inewave/nwlistop/cviol_eletricasin.py +19 -0
- inewave/nwlistop/cviol_rhq.py +21 -0
- inewave/nwlistop/cviol_rhq_sin.py +19 -0
- inewave/nwlistop/cviol_rhv.py +21 -0
- inewave/nwlistop/cviol_rhv_sin.py +19 -0
- inewave/nwlistop/deletricas.py +10 -0
- inewave/nwlistop/depminuh.py +10 -0
- inewave/nwlistop/desvuh.py +10 -0
- inewave/nwlistop/dtbmax.py +10 -0
- inewave/nwlistop/dtbmin.py +10 -0
- inewave/nwlistop/dvazmax.py +10 -0
- inewave/nwlistop/modelos/cviol_eletricasin.py +28 -0
- inewave/nwlistop/modelos/cviol_rhq.py +28 -0
- inewave/nwlistop/modelos/cviol_rhq_sin.py +28 -0
- inewave/nwlistop/modelos/cviol_rhv.py +26 -0
- inewave/nwlistop/modelos/cviol_rhv_sin.py +26 -0
- inewave/nwlistop/modelos/pivarm.py +20 -0
- inewave/nwlistop/modelos/pivarmincr.py +20 -0
- inewave/nwlistop/modelos/qbomb.py +28 -0
- inewave/nwlistop/modelos/qdesviouh.py +28 -0
- inewave/nwlistop/modelos/qturuh.py +28 -0
- inewave/nwlistop/modelos/qvertuh.py +28 -0
- inewave/nwlistop/modelos/valor_agua.py +24 -0
- inewave/nwlistop/modelos/viol_eletricasin.py +28 -0
- inewave/nwlistop/modelos/viol_evmin.py +23 -0
- inewave/nwlistop/modelos/viol_evminm.py +23 -0
- inewave/nwlistop/modelos/viol_evminsin.py +23 -0
- inewave/nwlistop/modelos/viol_fpha.py +31 -0
- inewave/nwlistop/modelos/viol_ghmin.py +29 -0
- inewave/nwlistop/modelos/viol_ghminm.py +29 -0
- inewave/nwlistop/modelos/viol_ghminsin.py +29 -0
- inewave/nwlistop/modelos/viol_ghminuh.py +28 -0
- inewave/nwlistop/modelos/viol_lpp_dfmax.py +29 -0
- inewave/nwlistop/modelos/viol_lpp_dfmaxm.py +29 -0
- inewave/nwlistop/modelos/viol_lpp_dfmaxsin.py +29 -0
- inewave/nwlistop/modelos/viol_lpp_tbmax.py +29 -0
- inewave/nwlistop/modelos/viol_lpp_tbmaxm.py +29 -0
- inewave/nwlistop/modelos/viol_lpp_tbmaxsin.py +29 -0
- inewave/nwlistop/modelos/viol_neg_evap.py +26 -0
- inewave/nwlistop/modelos/viol_pos_evap.py +26 -0
- inewave/nwlistop/modelos/viol_turbmax.py +28 -0
- inewave/nwlistop/modelos/viol_turbmin.py +28 -0
- inewave/nwlistop/modelos/viol_vazmax.py +28 -0
- inewave/nwlistop/modelos/viol_vazmin.py +28 -0
- inewave/nwlistop/modelos/vretiradauh.py +26 -0
- inewave/nwlistop/pivarm.py +13 -2
- inewave/nwlistop/pivarmincr.py +13 -2
- inewave/nwlistop/qbomb.py +23 -0
- inewave/nwlistop/qdesviouh.py +21 -0
- inewave/nwlistop/qturuh.py +21 -0
- inewave/nwlistop/qvertuh.py +21 -0
- inewave/nwlistop/vagua.py +10 -0
- inewave/nwlistop/valor_agua.py +21 -0
- inewave/nwlistop/vertuh.py +10 -0
- inewave/nwlistop/vevmin.py +10 -0
- inewave/nwlistop/vevminm.py +10 -0
- inewave/nwlistop/vevminsin.py +10 -0
- inewave/nwlistop/vghmin.py +10 -0
- inewave/nwlistop/vghminm.py +10 -0
- inewave/nwlistop/vghminsin.py +10 -0
- inewave/nwlistop/viol_eletricasin.py +19 -0
- inewave/nwlistop/viol_evmin.py +20 -0
- inewave/nwlistop/viol_evminm.py +22 -0
- inewave/nwlistop/viol_evminsin.py +19 -0
- inewave/nwlistop/viol_fpha.py +22 -0
- inewave/nwlistop/viol_ghmin.py +22 -0
- inewave/nwlistop/viol_ghminm.py +22 -0
- inewave/nwlistop/viol_ghminsin.py +19 -0
- inewave/nwlistop/viol_ghminuh.py +22 -0
- inewave/nwlistop/viol_lpp_dfmax.py +22 -0
- inewave/nwlistop/viol_lpp_dfmaxm.py +22 -0
- inewave/nwlistop/viol_lpp_dfmaxsin.py +18 -0
- inewave/nwlistop/viol_lpp_tbmax.py +22 -0
- inewave/nwlistop/viol_lpp_tbmaxm.py +22 -0
- inewave/nwlistop/viol_lpp_tbmaxsin.py +18 -0
- inewave/nwlistop/viol_neg_evap.py +22 -0
- inewave/nwlistop/viol_pos_evap.py +22 -0
- inewave/nwlistop/viol_turbmax.py +22 -0
- inewave/nwlistop/viol_turbmin.py +22 -0
- inewave/nwlistop/viol_vazmax.py +22 -0
- inewave/nwlistop/viol_vazmin.py +22 -0
- inewave/nwlistop/vretiradauh.py +21 -0
- inewave/nwlistop/vturuh.py +10 -0
- {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/METADATA +1 -1
- {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/RECORD +155 -46
- tests/libs/test_restricoes.py +0 -3
- tests/libs/test_usinas_hidreletricas.py +0 -2
- tests/mocks/arquivos/pivarm.py +22 -0
- tests/mocks/arquivos/pivarmincr.py +22 -0
- tests/mocks/arquivos/pmo.py +6 -1
- tests/mocks/arquivos/viol_fpha.py +29 -0
- tests/newave/test_evap_avl_desv.py +40 -0
- tests/newave/test_evap_cortes.py +41 -0
- tests/newave/test_evap_eco.py +41 -0
- tests/newave/test_fpha_avl_desv_s.py +39 -0
- tests/newave/test_fpha_avl_desv_v_q.py +38 -0
- tests/newave/test_fpha_cortes.py +48 -0
- tests/newave/test_fpha_eco.py +47 -0
- tests/newave/test_pmo.py +14 -0
- tests/nwlistop/test_cviol_eletricasin.py +37 -0
- tests/nwlistop/test_cviol_rhq_sin.py +37 -0
- tests/nwlistop/test_cviol_rhv_sin.py +37 -0
- tests/nwlistop/test_qbomb.py +40 -0
- tests/nwlistop/test_qdesviouh.py +40 -0
- tests/nwlistop/test_qturuh.py +40 -0
- tests/nwlistop/test_qvertuh.py +40 -0
- tests/nwlistop/test_valor_agua.py +40 -0
- tests/nwlistop/test_viol_eletricasin.py +37 -0
- tests/nwlistop/test_viol_evmin.py +40 -0
- tests/nwlistop/test_viol_evminm.py +40 -0
- tests/nwlistop/test_viol_evminsin.py +37 -0
- tests/nwlistop/test_viol_fpha.py +40 -0
- tests/nwlistop/test_viol_ghmin.py +40 -0
- tests/nwlistop/test_viol_ghminm.py +40 -0
- tests/nwlistop/test_viol_ghminsin.py +37 -0
- tests/nwlistop/test_viol_ghminuh.py +40 -0
- tests/nwlistop/test_viol_lpp_dfmax.py +40 -0
- tests/nwlistop/test_viol_lpp_dfmaxm.py +40 -0
- tests/nwlistop/test_viol_lpp_dfmaxsin.py +37 -0
- tests/nwlistop/test_viol_lpp_tbmax.py +40 -0
- tests/nwlistop/test_viol_lpp_tbmaxm.py +40 -0
- tests/nwlistop/test_viol_lpp_tbmaxsin.py +37 -0
- tests/nwlistop/test_viol_neg_evap.py +41 -0
- tests/nwlistop/test_viol_pos_evap.py +40 -0
- tests/nwlistop/test_viol_turbmax.py +40 -0
- tests/nwlistop/test_viol_turbmin.py +40 -0
- tests/nwlistop/test_viol_vazmax.py +40 -0
- tests/nwlistop/test_viol_vazmin.py +40 -0
- tests/nwlistop/test_vretiradauh.py +40 -0
- {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/LICENSE.md +0 -0
- {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/WHEEL +0 -0
- {inewave-1.7.5.dist-info → inewave-1.8.0.dist-info}/top_level.txt +0 -0
inewave/__init__.py
CHANGED
inewave/newave/__init__.py
CHANGED
|
@@ -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 .
|
|
50
|
-
from .
|
|
51
|
-
from .
|
|
52
|
-
from .
|
|
53
|
-
from .
|
|
54
|
-
from .
|
|
55
|
-
from .
|
|
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)
|
inewave/newave/avl_desvfpha_s.py
CHANGED
|
@@ -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
|
|
inewave/newave/eco_fpha.py
CHANGED
|
@@ -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()
|
inewave/newave/modelos/pmo.py
CHANGED
|
@@ -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
|
inewave/newave/nwv_avl_evap.py
CHANGED
|
@@ -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)
|
inewave/newave/nwv_eco_evap.py
CHANGED
|
@@ -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
|
"""
|