python

Оптимизация многоступенчатых компрессоров по энергозатратам на адиабатическое сжатие газа

  • суббота, 27 января 2018 г. в 03:13:45
https://habrahabr.ru/post/347624/
  • Разработка под Windows
  • Математика
  • Анализ и проектирование систем
  • Python




Введение


В 1934 году швейцарская фирма «БроунБовери» (Brown-Boveri) на основе теоретических работ Стодолы впервые создала многоступенчатый осевой компрессор с КПД 84 %. Вскоре, осевые компрессоры стали успешно использоваться этой фирмой для газотурбинных установок.

Многоступенчатые осевые компрессоры [1]

Принципиальная схема осевого многоступенчатого компрессора приведена на рисунке:



Осевой многоступенчатый компрессор состоит из ряда последовательно расположенных направляющих лопаток 6, закрепленных в корпусе 7, и рабочих лопаток 5, расположенных на барабанном роторе 11. По мере сжатия, объем воздуха уменьшается и, следовательно, уменьшаются высоты лопаток.

Вращаясь, рабочие лопатки ротора сообщают газу кинетическую энергию. При движении по расширяющимся каналам рабочих лопаток относительная скорость воздуха падает, происходит уменьшение кинетической энергии потока с соответствующим повышением давления в нем.

Изменение относительной скорости потока в канале рабочих лопаток связано с расходом энергии, подводимой к компрессору.

В расширяющихся каналах направляющих лопаток наблюдается дальнейшее повышение давления воздуха и уменьшение скорости его движения. В проточную часть компрессора воздух поступает через входной патрубок 1 и направляющий аппарат 4, откуда, пройдя каналы рабочих лопаток 5 и направляющих лопаток 6, попадает в спрямляющий аппарат 8.

Направляющий аппарат обеспечивает необходимое направление воздушному потоку перед входом в первую ступень, а спрямляющий аппарат обеспечивает осевой выход в диффузор 9 и далее в выходной патрубок 10.

Число ступеней сжатия в такой конструкции количеством рабочих лопаток 5, расположенных на барабанном роторе 11.

Многоступенчатые поршневые компрессоры [2]

Для получения сжатого газа более высокого давления (0,1-2 МПа и выше) применяются многоступенчатые компрессоры с промежуточным охлаждением газа после каждой ступени.

Сущность многоступенчатого сжатия может быть пояснена на примере двухступенчатого компрессора, схема которого и идеальная (при Vo = 0) индикаторная диаграмма представлена на рисунке:



В первой ступени 1 газ сжимается по политропе 1–2 до давления Р2, а затем он поступает в промежуточный холодильник 3, где охлаждается до начальной температуры T1. Гидравлическое сопротивление холодильника по воздушному тракту делают небольшим. Это позволяет считать процесс охлаждения 2–3 изобарным.

После холодильника газ поступает во вторую ступень 2, где сжимается по политропе 3–4 до давления Р3. Если бы сжатие до давления Р3 осуществлялось в идеальном одноступенчатом компрессоре (линия 1–2'), то величина затраченной за цикл работы определялась бы площадью 012'b0.

При двухступенчатом сжатии с промежуточным охлаждением, эта работа численно равна площади 01234b0. Заштрихованная площадь соответствует экономии работы за цикл при двухступенчатом сжатии.

Многоступенчатое сжатие газа [3]

При многоступенчатом изоэнтропическом сжатии газа от начального давления Po до конечного давления Pn, желательно, установить такие промежуточные давления, при которых суммарная энергия, израсходованная на сжатие, была бы минимальной.

Газ охлаждается изобарический до своей начальной температуры T, после каждого адиабатического сжатия. Затраты энергии на n- ступени определяются из уравнения:



где: m- число кмолей сжимаемого газа;R-универсальная газовая постоянная,;
T — начальная температура газа, K; γ — отношение удельных теплоемкостей газа при постоянном давлении и постоянном объеме, в работе принято γ=1,4; xn- давление газа после сжатия на n ступени.

Постановка задачи


1. Найти такое распределение давлений на выходе ступеней адиабатического сжатия при котором затраченная на сжатие энергия , будет минимальна;
2. Определить влияние числа степеней сжатия на минимальную энергию сжатия при одинаковых значениях начального и конечного давлений.

Решение задачи средствами библиотеки scipy. optimize


Сначала рассмотрим пять степеней сжатия в соответствии с расчётной схемой, приведенной на рисунке:



Листинг программы
#!/usr/bin/env python
#coding=utf8
import numpy as np# модуль для создания списков
from scipy.optimize import minimize# модуль оптимизации
import matplotlib.pyplot as plt# модуль для графиков
import time# модуль для контроля времени
Po=1#начальное давление газа
Pzad=64#конечное давление газа
g=1.4#отношение удельных теплоемкостей газа
m=10# число кило моль газа
R=8.314# универсальная газовая постоянная
a=(g-1)/g
T=293# температура газа
a=0.286
"Распределение энергии по ступеням сжатия:"
def E1(x1):
                return m*R*T*a*((x1/Po)**2-1)
def E2(x1,x2):
                return m*R*T*a*((x2/x1)**2-1)
def E3(x2,x3):
                return m*R*T*a*((x3/x2)**2-1)
def E4(x3,x4):
                return m*R*T*a*((x4/x3)**2-1)
def E5(x4):
                return m*R*T*a*((Pzad/x4)**2-1)        
start = time.time()
def E(x1,x2,x3,x4):#
         return E1(x1)+E2(x1,x2)+E3(x2,x3)+E4(x3,x4)+E5(x4)
def fun2(x):
   return E(*x)
x0 =[4,15,24,40] #точка начала поиска экстремума
res = minimize(fun2, x0)# распределение давления при минимуме энергии
stop = time.time()
print ("Время работы оптимизатора:",round(stop-start,3))
x1=round(res['x'][0],3)#давление на выходе I ступени
x2=round(res['x'][1],3)#давление на выходе II ступени
x3=round(res['x'][2],3)#давление на выходе III ступени
x4=round(res['x'][3],3)#давление на выходе IV ступени
x5=Pzad
"Формирование списка давлений:"
x=[]
x.append(x1)
x.append(x2)
x.append(x3)
x.append(x4)
x.append(x5)
z1=E1(x1)# затраты энергии I ступени
z2=E2(x1,x2)+z1# общие затраты энергии I+II ступени
z3=E3(x2,x3)+z2#общие затраты энергии I+II +III ступени
z4=E4(x3,x4)+z3#общие затраты энергии I+II +III +IV ступени
z5=E5(x4)+z4#общие затраты энергии I+II +III +IV+V ступени
"Формирование списка затрат энергии:"
y=[]
y.append(z1)
y.append(z2)
y.append(z3)
y.append(z4)
y.append(z5)
plt.title('Затраты энергии - %s кДж на  %s ступенчатое  \n\
адиабатическое сжатие газа с  %s до  %s ати '%(int(z5),len(y),Po,Pzad))
plt.ylabel('Затраты энергии')
plt.xlabel('Давление газа')
plt.plot(x[0],y[0],'o', label='I ступень, давление - %s'%x1)
plt.plot(x[1],y[1],'o', label='II ступень, давление - %s'%x2)
plt.plot(x[2],y[2],'o', label='III ступень, давление - %s'%x3)
plt.plot(x[3],y[3],'o', label='IV ступень, давление - %s'%x4)
plt.plot(x[4],y[4],'o', label='V ступень, давление - %s'%x5)
plt.plot(x,y,'r')
plt.legend(loc='best')
plt.grid(True)
plt.show()


Получим:
Время работы оптимизатора: 0.0



Увеличим количество ступеней сжатия на одну согласно следующего листинга:

Листинг программы
#!/usr/bin/env python
#coding=utf8
import numpy as np# модуль для создания списков
from scipy.optimize import minimize#модуль оптимизации
import matplotlib.pyplot as plt#модуль для графиков
import time# модуль для контроля времени
Po=1#начальное давление газа
Pzad=64#конечное давление газа
g=1.4#отношение удельных теплоемкостей газа
m=10# число кило моль газа
R=8.314# универсальная газовая постоянная
a=(g-1)/g
T=293# температура газа
a=0.286
"Распределение энергии по ступеням сжатия:"
def E1(x1):
                return m*R*T*a*((x1/Po)**2-1)
def E2(x1,x2):
                return m*R*T*a*((x2/x1)**2-1)
def E3(x2,x3):
                return m*R*T*a*((x3/x2)**2-1)
def E4(x3,x4):
                return m*R*T*a*((x4/x3)**2-1)
def E5(x4,x5):
                return m*R*T*a*((x5/x4)**2-1)        
def E6(x5):
                return m*R*T*a*((Pzad/x5)**2-1)  
start = time.time()
def E(x1,x2,x3,x4,x5):
         return E1(x1)+E2(x1,x2)+E3(x2,x3)+E4(x3,x4)+E5(x4,x5)+E6(x5)
def fun2(x):
   return E(*x)
x0 =[4,15,20,30,40]#точка начала поиска экстремума
res = minimize(fun2, x0)# распределение давления при минимуме энергии
stop = time.time()
print ("Время работы оптимизатора :",round(stop-start,3))
x1=round(res['x'][0],3)#давление на выходе I ступени
x2=round(res['x'][1],3)#давление на выходе II ступени
x3=round(res['x'][2],3)#давление на выходе III ступени
x4=round(res['x'][3],3)#давление на выходе IV ступени
x5=round(res['x'][4],3)#давление на выходе V ступени
x6=Pzad# давление на выходе VI ступени
"Формирование списка давлений:"
x=[]
x.append(x1)
x.append(x2)
x.append(x3)
x.append(x4)
x.append(x5)
x.append(x6)
z1=E1(x1)# затраты энергии I ступени
z2=E2(x1,x2)+z1# общие затраты энергии I+II ступени
z3=E3(x2,x3)+z2# общие затраты энергии I+II+III ступени
z4=E4(x3,x4)+z3# общие затраты энергии I+II+III+IV ступени
z5=E5(x4,x5)+z4# общие затраты энергии I+II+III+IV+V ступени
z6=E6(x5)+z5# общие затраты энергии I+II+III+IV+V +VI ступени
"Формирование списка затрат энергии:"
y=[]
y.append(z1)
y.append(z2)
y.append(z3)
y.append(z4)
y.append(z5)
y.append(z6)
plt.title('Затраты энергии - %s кДж на  %s ступенчатое  \n\
адиабатическое сжатие газа с  %s до  %s ати '%(int(z6),len(y),Po,Pzad))
plt.ylabel('Затраты энергии')
plt.xlabel('Давление газа')
plt.plot(x[0],y[0],'o', label='I ступень, давление - %s'%x1)
plt.plot(x[1],y[1],'o', label='II ступень, давление - %s'%x2)
plt.plot(x[2],y[2],'o', label='III ступень, давление - %s'%x3)
plt.plot(x[3],y[3],'o', label='IV ступень, давление - %s'%x4)
plt.plot(x[4],y[4],'o', label='V ступень, давление - %s'%x5)
plt.plot(x[5],y[5],'o', label='VI ступень, давление - %s'%x6)
plt.plot(x,y,'r')
plt.legend(loc='best')
plt.grid(True)
plt.show()


Получим:
Время работы оптимизатора: 0.005



Сравнивая приведенные графики, можно определить снижение энергозатрат на адиабатическое сжатие газа:

(149024 -125405)*100/149024=15, 85%

Вывод: увеличение числа ступеней сжатия только на единицу позволяет сэкономить почти 16 % энергии, затраченной на адиабатическое сжатие газа в многоступенчатом компрессоре.

Однако, это только один вид затрачиваемой энергии. Понятно, что введение дополнительной ступени приведёт не только к дополнительным затратам при изготовлении, но и к дополнительным эксплуатационным затратам, за счёт увеличения мощности двигателя и секции системы охлаждения.

Оптимальный вариант нужно выбирать с учётом всех видов затрат, но это уже совсем другая задача.

Выводы:


1. Найдено распределение давлений на выходе ступеней адиабатического сжатия при котором затраченная на адиабатическое сжатие энергия , минимальна;

2. Увеличение числа ступеней сжатия только на единицу позволяет сэкономить почти 16 % энергии, затраченной на адиабатическое сжатие газа в многоступенчатом компрессоре.

Ссылки:


1. Компрессоры газотурбинных установок (ГТУ).
2. Многоступенчатый компрессор.
3. Фан — Лянь — Цэнь, Ван, Чу – Сен. Дискретный принцип максимума. — М, «Мир»,1967.-176 с.