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.
- 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/blocos/tabelacsv.py +1 -1
- inewave/newave/modelos/blocos/versaomodelo.py +3 -3
- inewave/newave/modelos/forwarh.py +1 -1
- inewave/newave/modelos/hidr.py +1 -1
- inewave/newave/modelos/modif.py +9 -9
- inewave/newave/modelos/pmo.py +40 -0
- inewave/newave/modelos/vazoes.py +1 -1
- inewave/newave/modif.py +1 -1
- 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/blocos/valoresserie.py +1 -1
- 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.1.dist-info}/METADATA +1 -1
- {inewave-1.7.5.dist-info → inewave-1.8.1.dist-info}/RECORD +165 -56
- 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_pivarm.py +15 -1
- tests/nwlistop/test_pivarmincr.py +18 -1
- 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.1.dist-info}/LICENSE.md +0 -0
- {inewave-1.7.5.dist-info → inewave-1.8.1.dist-info}/WHEEL +0 -0
- {inewave-1.7.5.dist-info → inewave-1.8.1.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()
|
|
@@ -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 = ""
|
inewave/newave/modelos/hidr.py
CHANGED
inewave/newave/modelos/modif.py
CHANGED
|
@@ -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
|
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/modelos/vazoes.py
CHANGED
inewave/newave/modif.py
CHANGED
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)
|