-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrankine_cycle.py
129 lines (117 loc) · 4.45 KB
/
rankine_cycle.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
# -*- coding: utf-8 -*-
from src.two_phase_fluid_cycle import TwoPhaseCycle
from CoolProp.CoolProp import PropsSI
from src.fluid import Fluid
def main():
# general paramemeters
fluid = Fluid("IF97::Water")
ph = 30 * 1e5
pm = 10 * 1e5
pl = 1.5 * 1e5
t_max = PropsSI(
'T', 'P', ph, 'S', PropsSI(
'S', 'P', pm, 'Q', 1, fluid.name
), fluid.name
)
s1 = PropsSI('S', 'P', pl, 'Q', 0, fluid.name)
p1 = pl
t1 = PropsSI('T', 'P', pl, 'Q', 0, fluid.name)
x1 = 0
h1 = PropsSI('H', 'P', pl, 'Q', 0, fluid.name)
initial_state = {
"pi": p1,
"si": s1,
"ti": t1,
"xi": x1,
"hi": h1,
}
# SIMPLE RANKINE CYCLE
processes_rankine_simple = [
{"prcs_name": '1--2', "prcs_type": "dq",
"pf": ph, "eta_isentropic": 1.0},
{"prcs_name": '2--3', "prcs_type": "dp",
"xf": 0, "eta_isentropic": 0},
{"prcs_name": '3--4', "prcs_type": "dp",
"xf": 1, "eta_isentropic": 0},
{"prcs_name": '4--5', "prcs_type": "dp",
"tf": t_max, "eta_isentropic": 0},
{"prcs_name": '5--6', "prcs_type": "dq",
"pf": pl, "eta_isentropic": 0.9},
{"prcs_name": '6--1', "prcs_type": "dp",
"xf": 0, "eta_isentropic": 0}
]
rankine_simple = TwoPhaseCycle(
fluid,
initial_state,
processes_rankine_simple,
)
[print(process, "\n") for process in rankine_simple.solved_processes]
rankine_simple.states_values_to_csv('rankine_simple')
rankine_simple.processes_values_to_csv('rankine_simple')
# simple.plot_T_s_diagram('simple_rankine')
# simple.plot_h_s_diagram('simple_rankine')
# REHEATED RANKINE CYCLE
processes_rankine_reheated = [
{"prcs_name": '1--2', "prcs_type": "dq",
"pf": ph, "eta_isentropic": 1.0},
{"prcs_name": '2--3', "prcs_type": "dp",
"xf": 0, "eta_isentropic": 0},
{"prcs_name": '3--4', "prcs_type": "dp",
"xf": 1, "eta_isentropic": 0},
{"prcs_name": '4--5', "prcs_type": "dp",
"tf": t_max, "eta_isentropic": 0},
{"prcs_name": '5--6', "prcs_type": "dq",
"pf": pm, "eta_isentropic": 0.9},
{"prcs_name": '6--7', "prcs_type": "dp",
"tf": t_max, "eta_isentropic": 0},
{"prcs_name": '7--8', "prcs_type": "dq",
"pf": pl, "eta_isentropic": 0.87},
{"prcs_name": '8--1', "prcs_type": "dp",
"xf": 0, "eta_isentropic": 0}
]
rankine_reheated = TwoPhaseCycle(
fluid,
initial_state,
processes_rankine_reheated,
)
[print(process, "\n") for process in rankine_reheated.solved_processes]
rankine_reheated.states_values_to_csv('rankine_reheated')
rankine_reheated.processes_values_to_csv('rankine_reheated')
# rankine_reheated.plot_T_s_diagram('reheated_rankine')
# rankine_reheated.plot_h_s_diagram('reheated_rankine')
# REGENERATIVE AND REHEATED RANKINE CYCLE
processes_rankine_regenerative = [
{"prcs_name": '1--a', "prcs_type": "dq",
"pf": pm, "eta_isentropic": 1.0},
{"prcs_name": 'a--b', "prcs_type": "dp",
"xf": 0, "eta_isentropic": None},
{"prcs_name": 'b--c', "prcs_type": "dq",
"pf": ph, "eta_isentropic": 1.0},
{"prcs_name": 'c--3', "prcs_type": "dp",
"xf": 0, "eta_isentropic": None},
{"prcs_name": '3--4', "prcs_type": "dp",
"xf": 1, "eta_isentropic": None},
{"prcs_name": '4--5', "prcs_type": "dp",
"tf": t_max, "eta_isentropic": None},
{"prcs_name": '5--6', "prcs_type": "dq",
"pf": pm, "eta_isentropic": 0.9},
{"prcs_name": '6--7', "prcs_type": "dp",
"tf": t_max, "eta_isentropic": None},
{"prcs_name": '7--8', "prcs_type": "dq",
"pf": pl, "eta_isentropic": 0.87},
{"prcs_name": '8--1', "prcs_type": "dp",
"xf": 0, "eta_isentropic": None}
]
rankine_regenerative = TwoPhaseCycle(
fluid,
initial_state,
processes_rankine_regenerative,
)
[print(process, "\n") for process in rankine_regenerative.solved_processes]
# m_extruded = rankine_regenerative.m_extruded()
rankine_regenerative.states_values_to_csv('rankine_regenerative')
rankine_regenerative.processes_values_to_csv('rankine_regenerative')
# rankine_regenerative.plot_T_s_diagram('regenerative_rankine')
# rankine_regenerative.plot_h_s_diagram('regenerative_rankine')
if __name__ == "__main__":
main()