Реферат: Синтез химико- технологической системы
Название: Синтез химико- технологической системы Раздел: Рефераты по химии Тип: реферат | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Санкт-Петербургский государственный технологический институт (Технический университет) Физико-математическое отделение Факультет_______6 ________ Кафедра математического моделирования Курс_________4 __________ и оптимизации химико-технологических процессов Группа_______665 ________ Учебная дисциплина СИСТЕМНЫЙ АНАЛИЗ ХИМИЧЕСКИХ ТЕХНОЛОГИЙ КУРСОВОЙ ПРОЕКТ Тема СИНТЕЗ ХИМИКО-ТЕХНОЛОГИЧЕСКОЙ СИСТЕМЫ Студентка Дворникова Анастасия Руководитель Гайков А.В. Оценка за курсовой проект___________ _____________________ (подпись руководителя) Дата защиты проекта______________ Санкт-Петербург, 2009 год Тема: синтез химико-технологической системы. Номер варианта: 4. Цель: синтезировать ХТС, работающую по нижеописанной технологии. Исходные данные: m=4 n =1 Все реакторы идеального вытеснения t0 =50 0 С, t1 =4150 С, t2 =4850 С, t3 =4100 С, t4 =4250 С, t5 =4050 С ta 1 =1800 С, ta 2 = 1950 С Расход смеси на входе в систему: 132000 м3 /час Концентрация компонентов: А=0,085 об.доли В=0,08 об.доли С=0,0001 об.доли Объемы реакторов, м3 V1 =79, V2 =65, V3 =40, V4 =55, V5 =35 Объемы абсорберов, м3 v1 =25, v2 =28 Плотность орошения в 1ом абсорбере: 18 м3 /м2 Плотность орошения в 2ом абсорбере: 19 м3 /м2 Для получения значений k0 и Е в уравнении Аррениуса использовать данные Приложение 1 и метод наименьших квадратов. Для нахождения значений Kp(t) использовать данные Приложение 2 и метод наименьших квадратов. Для получения статистической модели абсорбера использовать данные Приложения 3 и метод Брандона. ОГЛАВЛЕНИЕ 1.1 Описание объекта исследования. 6 1.2 Постановка задачи оптимизации. 6 1.3 Описание метода наименьших квадратов. 7 1.4 Описание метода Брандона. 9 1.5 Реактор идеального вытеснения. 12 1.6 Синтез оптимальных систем теплообмена. 13 2.1 Расчет k0 и E в уравнении Аррениуса с использованием метода наименьших квадратов. 17 2.2 Расчет зависимости kр (t) с использованием метода наименьших квадратов 20 2.3 Расчет статистической модели абсорбера с использованием метода Брандона 23 2.4 Расчет реакторов идеального вытеснения. 33 2.6 Синтез оптимальных систем теплообмена. 36 В нашем мире наблюдается стремительное развитие химической промышленности. Создаются и внедряются новые технологии и новая техника, большое внимание уделяется созданию безотходных и малоотходных производств, а также экономному расходованию сырья и всех видов энергии. Промышленные процессы протекают в сложных химико-технологических системах (ХТС), каждая из которых представляет собой совокупность аппаратов и машин, объединенных в единый производственный комплекс для выпуска продукции. Основным методом исследования ХТС не случайно считается математическое моделирование, так как этот метод позволяет открыть новые возможности при разработке математических химико-технологических процессов, в том числе по их применению их для расчета и оптимизации ХТС. Методы анализа, синтеза и оптимизации ХТС, реализованные в виде алгоритмов и программ, применяются в системах автоматизированного проектирования химических производств (САПР). Эти системы существенно повышают производительность труда проектировщиков и позволяют значительно улучшить качество проектов. Благодаря САПР ускоряется внедрение в производство технологических разработок. В процессе своей деятельности конструкторам и технологам постоянно приходится принимать технические решения путем выбора оптимальных вариантов. Должен быть выбран тот предпочтительный вариант конструкции изделия или технологического процесса, который затем будет разрабатываться для осуществления в производстве. При создании современных химических и нефтехимических производств большое значение имеет рациональное использование вторичных энергоресурсов, образующихся при проведении химико-технологических процессов. Проектирование оптимальных тепловых систем представляет сложную комбинаторную задачу, причем количество альтернативных вариантов резко возрастает при увеличении числа технологических потоков. Существуют различные методы синтеза оптимальных ТС. Основные – комбинаторные и эвристические. Комбинаторные методы (например, метод ветвей и границ) позволяют получить точное решение. С помощью эвристических методов находят близкие к оптимальным структуры ТС, при этом из рассмотрения исключается большая часть альтернативных вариантов. 1.1 Описание объекта исследования Химико-технологическая система (Х'ГС) представляет собой совокупность взаимосвязанных технологическими потоками и действующих как одно целое аппаратов в которых осуществляется определённая последовательность технологических операций -' подготовка сырья к химическим превращениям, химические превращения. выделение и очистка целевых продуктов. Каждая технологическая операция протекает в отдельных аппаратах, которые являются элементами ХТС. Для исследования ХТС характерно. что при этом не изучаются внутренние свойства и структура элементов, а анализируются только такие свойства элементов. которые определяют его взаимосвязь с другими элементами Х'ГС и влияют на свойства системы в целом. Состояние системы зависит от конструкционных параметров ХТС и технологического режима. Конструкционные параметры ХТС - геометрические характеристики элементов системы – объём, диаметр, высота и т. д. Параметры технологического режима ХТС - совокупность параметров внутри элемента, влияющих на скорость технологического процесса, выход и качество продукции. К ним относится концентрации реагентов, температура, давление, активность катализатора, гидродинамика потока. От параметров ХТС зависит качество функционирования ХТС, которое определяют по показателям эффективности - количеству реализованной продукции, качеству продукции, эксплуатационным и капитальным затратам. При этом следует отметить, что на показатели ХТС, несомненно. оказывают влияние показатели работы отдельных элементов, в которых одновременно протекают физические и химические процессы. Последовательное описание или изображение процессов и соответствующих им аппаратов называется технологической схемой ХТС. 1.2 Постановка задачи оптимизации Оптимизация – это целенаправленная деятельность, заключающаяся в получении наилучших результатов при соответствующих условиях. Любая инженерная деятельность, связанная с разработкой новых технологических систем и управлением ими, сопровождается поиском оптимальных решений. Для осуществления такого поиска необходим объект оптимизации и критерий оптимальности, который также называют целевой функцией. Для решения задач оптимизации широко используются математические описания ХТС. При формулировании критерия оптимальности ХТС принимаются во внимание технико-экономические показатели, безопасность технологических режимов оборудования, обеспечение защиты окружающей среды. Критерий оптимальности обычно является скалярной функцией нескольких переменных. Задача оптимизации сводится к поиску экстремума этой функции, то есть f (e, a, u, z, t, r, α, d) → Extremum где e – вектор входных переменных; a – вектор выходных переменных; u – вектор управляющих переменных; z – вектор возмущений; t – время; r – вектор режимных параметров; α – вектор структурных параметров; в – вектор конструктивных параметров. Входными и выходными параметрами являются обычно состав, расход и температуры отдельных потоков. Управляющими воздействиями могут быть расход сырья на входе в химический реактор или расход пара в теплообменнике. Примеры возмущений – изменения температуры окружающей среды и состава исходного сырья за счет примесей, а также изменение активности катализатора за счет его закоксовывания. Под режимными параметрами понимаются температуры и давления в аппаратах, скорости вращения рабочих органов машин. Структурные параметры характеризуют топологию ХТС. В частности, они определяют число аппаратов в системе и связи между ними. Конструктивные параметры характеризуют габаритные размеры отдельных аппаратов, толщины их стенок и т.п. Конструктивными параметрами ректификационной колонны являются, например, число тарелок, размеры элементов тарелок. ХТС как объект оптимизации описывается математической моделью в виде системы уравнений: = 0; j = 1, . . . , p. Эту систему уравнений можно рассматривать кА первый вид ограничений на независимые переменные при поиске экстремума. Второй вид ограничений представляет собой система неравенств: ≥ 0; i = 1, . . . , m. Эти неравенства характеризуют ограничения на допустимые интервалы изменения независимых переменных, обусловленные нормами расхода сырья и энергии, безопасностью работы оборудования и т.п. Таким образом, общей задачей оптимизации ХТС является нахождение экстремума функции с учетом указанных ограничений путем изменения числа независимых переменных. 1.3 Описание метода наименьших квадратов Пусть имеется некоторая выборка экспериментальных данных объемом m опытов, содержащая независимые переменные x1, x2,..., xk и зависимую переменную (отклик) y. В общем случае зависимых переменных может быть несколько, и их выбор часто зависит от целей исследования. Наиболее общий тип линейной модели записывается в виде y=b0+b1z1+b2z2+...+bkzk), где каждая из переменных zj называемая в дальнейшем фактором, представляет собой функциональную зависимость произвольного вида от независимых переменных zj=zj(x1, x2, ..., xn). Параметр k определяет количество факторов в эмпирическом уравнении. Задача определения коэффициентов уравнения регрессии по МНК сводится практически к определению минимума функции многих переменных: требуется выбрать b0, b1,..., bk так, чтобы сумма квадратов отклонений, рассчитанных по уравнению, и экспериментальных значений функции отклика была минимальной
(4) Если функция дифференцируема, то необходимым условием минимума Ф b0, b1,..., bk является выполнение равенств:
(5) При линейном характере зависимости
система уравнений принимает вид Раскрывая скобки и перенося направо слагаемые, не содержащие неизвестных коэффициентов bJ, j=0,…,k, получим систему линейных алгебраических уравнений Таким образом, задача оценки неизвестных коэффициентов уравнения линейной регрессии сводится к решению системы линейных алгебраических уравнений относительно коэффициентов bi,,i=0,1,...,k что легко выполнить, например, численными методами на ЭВМ. Статистические модели создают на основании имеющихся экспериментальных данных, снятых на действующем объекте. Задачу формулируют следующим образом: по данной выборке объемом n (т.е. по заданному числу опытов) построить модель и оценить адекватность ее реальному объекту. В общем случае современный технологический процесс представляется в виде многомерного объекта. На объект действуют вектор входных параметров Х, составляющие которого {х1 ,х2 ,…,хl }, и вектор управления Z, составляющие которого {z1, z2, …zk }. Выходные параметры {y1 ,y2 ,…,yp } составляют вектор выходных параметров Y. Общий вид статистической модели многомерного технологического объекта можно записать в виде системы алгебраических уравнений или в векторной форме: y1 = F1 {x1 ,x2 ,…xm } y2 = F2 {x1 ,x2 ,…xm } …………………… yp = Fp {x1 ,x2 ,…xm } Y=F(X), где X,Y – векторы входных и выходных параметров объекта. В данной курсовой работе для построения модели многомерного технологического объекта используется метод Брандона. Сущность метода заключается в следующем. Предполагается, что функция F1 {x1, x2 ,…,xm } в предыдущей системе является произведением функций от входных параметров, то есть ŷ = yf1 (x1 )f2 (x2 )…fm (xm ) или в более удобной форме: ŷ = yПfk (xk ) где ŷ – расчетное значение i-го выходного параметра; y = Σ(y0i /n) – средняя величина экспериментальных значений i-го выходного параметра; n – количество опытов в исходной выборке. При использовании метода Брандона большое значение имеет порядок следования функций в уравнении. Чем больше влияние оказывает фактор на выходной параметр, тем меньшим должен быть его порядковый номер в указанном уравнении. Оценить степень влияния к-го фактора на выходной параметр можно по величине частного коэффициента множественной корреляции: где rxy/x1 ,x2 ,…,xm - величина частного коэффициента корреляции, учитывающая влияние К-го фактора на выходной параметр у при условии, что влияние всех прочих факторов исключено; в – определитель матрицы, построенной из парных коэффициентов корреляции. Матрица имеет вид: , k=1,2,3. Dm +1, m +1 – определитель матрицы с вычеркнутыми m+1-ой строкой и m+1-м столбцом; Dm +1, k – определитель матрицы с вычеркнутыми m+1-ой строкой и k-м столбцом; Dk , k – определитель матрицы с вычеркнутыми k-ой строкой и k-м столбцом; rxy – парные коэффициенты корреляции определяемые по формуле: Коэффициенты корреляции по абсолютной величине не превышает единицы. (-1 ≤ rxy ≤ 1). Чем ближе абсолютное значение коэффициента | rxy | к единице, тем сильнее линейная связь между величинами. Следует отметить, что коэффициент корреляции одинаково отмечает долю случайности и криволинейность связи между х и у. Зависимость х и у может быть близкой к функциональной, но существенно не линейной; коэффициент корреляции при этом будет значительно меньше единицы. Объективное определение тесноты связи может быть проведено в результате совместного анализа качественной и количественной оценок. Порядок расположения влияющих факторов определяют в соответствии с убыванием величины частных коэффициентов корреляции. Следует иметь в виду, что коэффициент корреляции – чисто статистический показатель и не содержит предположения, что изучаемые величины находятся в причинно-следственной связи. Прежде чем определять вид первой зависимости, следует представить исходные экспериментальные значения выходного параметра в каждом опыте yэj в безразмерной форме yэ0j где у – средняя величина выходного параметра. Таким образом, исходными данными для поиска первой зависимости будут нормированные значения вектора выходных параметров ỹ0 и опытные значения первого влияющего фактора. Выбрав зависимость ỹ = f1 (x1 ) с помощью метода наименьших квадратов, определяют остаточный показатель Yэ для каждого наблюдения. Предполагая, что уэ1 не зависит от х1 , а зависит от х2, …, хm , выбирают зависимость от второго фактора. Получив расчетную зависимость находят остаточный показатель уэ2 для каждого наблюдения: Выполнив аналогичные действия для каждого К-го влияющего фактора получают регрессионную зависимость для рассмотренного выходного параметра. Порядок расположения факторов для этой зависимости определен на этапе ранжирования и отличается от порядка в общем уравнении. Для оценки точности аппроксимации найденной функции вычисляют корреляционное отношение: и среднюю относительную ошибку: Совокупность зависимостей по каждому выходному параметру представляет собой статистическую модель, многомерно технологического объекта. 1.5 Реактор идеального вытеснения Модель идеального вытеснения предполагает, что в реакторе реализуется так называемый поршневой режим движения потока, все частицы двигаются в одном заданном направлении, в реакторе отсутствует осевое перемешивание, но разрешено радиальное, в связи, с чем значения всех параметров технологического процесса изменяются плавно от начального до конечного состояния. Время пребывания всех частиц в аппаратах идеального вытеснения одинаково, т.е. временной характеристикой реакторов идеального вытеснения служит уравнение: , где τ’ – время пребывания в реакторе любого элементарного объема; τ – среднее время пребывания; Vc – расход смеси; υ – объем реактора. Математическая модель – это система уравнений, которая устанавливает связь входных и выходных параметров реактора. aA + bB → cC v=K*CA a *CB b В нашем случае скорость реакции в реакторе описывается уравнением: Для определения скорости реакции по каждому веществу для многоступенчатых химических реакций составляется стехиометрическая матрица размером m на n, где m – число стадий, n – число компонентов. Элементы матрицы соответствуют стехиометрическим коэффициентам, причем коэффициент будет отрицательным, если вещество расходуется и положительным, если вещество образуется.
Скорость по i-му компоненту будет представлять собой сумму компонентов i – го столбца. vA = -2wI vB = -wI vC = 2wI vD = wII Математическое описание: К этой системе необходимо добавить уравнение теплового баланса: , где λ1 =q/Cp – коэффициенты адиабатического разогрева. Модель вытеснения можно применять для технических реагентов при проектировании жидкофазных трубчатых реакторов с большим отношением, длины трубы к его диаметру. Такие реакторы широко применяются в производствах органических веществ. К режиму вытеснения относят по газовой фазе полочные контактные аппараты с фильтрующими слоями катализатора, шахтные печи и конверторы. Значительная часть применяемых в промышленности насадочных башен для взаимодействия газов с жидкостями работает при небольших скоростях газового потока и малых плотностях орошения. 1.6 Синтез оптимальных систем теплообмена В наиболее традиционной постановке задача синтеза тепловых систем (ТС) формулируется следующим образом: имеются m горячих и n холодных технологических потоков, которые называют основными технологическими потоками. Для каждого из этих потоков заданы начальные температуры и , конечные температуры , и значения водяных эквивалентов (произведение расхода на удельную теплоемкость) ,. Здесь . Индексы "г" и "х" относят соответствующую величину к горячему и холодному потокам. Необходимо определить структуру технологических связей между теплообменными аппаратами заданного типа, а также же площади поверхностей теплообмена каждого аппарата, которые обеспечивали бы заданные начальные и конечные температуры основных технологических потоков при минимально возможном значении приведенных технологических затрат 3пр, связанных с эксплуатацией синтезируемой ТС. Для решения задачи синтезируемую ТС разделяют на две подсистемы: внутреннюю (рекуперативную), где в теплообмене участвуют только основные технологические потоки; и внешнюю, где при теплообмене используется вспомогательные теплоносители (вспомогательные технологические потоки) и вспомогательные теплообменники, осуществляющие теплообмен между основными и вспомогательными технологическими потоками. При этом внешняя подсистема используется только тогда, когда во внутренней подсистеме не удается получить заданные конечные температуры. Приведенные технологические затраты, связанные с эксплуатацией синтезируемой ТС, могут быть выражены следующим образом: - затраты на рекуперативные теплообменники, руб; - затраты на вспомогательные теплообменники, руб; - затраты на вспомогательные теплоносители, руб; - нормативный коэффициент эффективности (= 0,12). Если во внутренней подсистеме используются К1 теплообменных аппаратов, а во внешней – , то: При расчете стоимости i - го теплообменника любой подсистемы в данной работе используется зависимость где F - площадь поверхности теплообмена соответствующего i- го теплообменника, м2 а - стоимостной коэффициент, зависящий от типа теплообменника. Затраты на вспомогательные теплоносители определяются по формуле: Где - продолжительность годовой эксплуатации системы ч/год; - стоимость i - го вспомогательного теплоносителя, - расход p- го вспомогательного теплоносителя в 1- м вспомогательном теплообменнике, кг/ч. При синтезе ТС используются формулы: где Q - тепловая нагрузка теплообменника; k- соответствующий коэффициент теплопередачи. Средняя разность температур для теплообменника: где и - разности температур на концах теплообменника. Тепловая нагрузка теплообменника, или количество тепла, переданное в одном аппарате, определяется на основе концепции передачи максимально возможного тепла при минимально допустимой разности температур на концах теплообменника Если ()<0, то теплообмен невозможен.
; Задача синтеза решается путем формирования множества возможных комбинаций исходных горячих и холодных потоков для проведения физически реализуемых операций теплообмена в теплообменном аппарате. для этой цели строят таблицу пар взаимодействующих потоков исходя из условия Qmax. Из таблицы пар выбирается пара потоков, вступающих во взаимный теплообмен. Если в результате теплообмена данные потоки достигли заданных конечных температур, то они исключаются из рассмотрения. Иначе, начальным температурам этих потоков присваиваются значения конечных температур результирующих потоков, после чего таблица пар перестраивается, и выбирается новая пара потоков. Данная операция производится до тех пор, пока не останется потоков, способных вступать во взаимный теплообмен, или все потоки достигнут требуемых конечных температур. При необходимости для достижения заданных конечных температур в теплообменных системах используются вспомогательные тепло - и хладагенты. Таким образом, задача синтеза является многоэтапной задачей, в которой на каждом этапе осуществляется выбор пары потоков, вступающих во взаимный теплообмен. 2.1 Расчет k0 и E в уравнении Аррениуса с использованием метода наименьших квадратов Расчет проводился на основе данных из Приложения 1 в программе, написанной в Visual Basic. Код программы : Option Explicit Dim z As Integer Dim i As Integer Dim s1 As Single Dim s2 As Single Dim s3 As Single Dim s4 As Single Dim a As Single Dim b As Single Dim k0 As Single Dim e As Single Dim t() As Single Dim k() As Single Dim kr() As Single Dim eps() As Single Dim x() As Single Dim y() As Single Private Sub Command1_Click() z = InputBox("Введите количество опытов", "Ввод экспериментальных данных") MSFlexGrid1.Rows = z + 1 ReDim t(z) As Single ReDim k(z) As Single ReDim kr(z) As Single ReDim eps(z) As Single For i = 1 To z MSFlexGrid1.Row = i MSFlexGrid1.Col = 1 t(i) = Val(InputBox("Введите параметр T 'C", "Ввод экспериментальных данных")) MSFlexGrid1.Text = CStr(t(i)) MSFlexGrid1.Col = 2 k(i) = Val(InputBox("Введите параметр K", "Ввод экспериментальных данных")) MSFlexGrid1.Text = CStr(k(i)) Next i Command2.Enabled = True Command2.Visible = True End Sub Private Sub Command2_Click() ReDim x(z) As Single ReDim y(z) As Single For i = 1 To z x(i) = 1 / (t(i) + 273) y(i) = Log(k(i)) Next i s1 = 0 s2 = 0 s3 = 0 s4 = 0 For i = 1 To z s1 = s1 + x(i) s2 = s2 + x(i) * x(i) s3 = s3 + x(i) * y(i) s4 = s4 + y(i) Next i a = (z * s3 - s1 * s4) / (z * s2 - s1 * s1) b = (s2 * s4 - s1 * s3) / (z * s2 - s1 * s1) e = -8.315 * a Text1.Text = CStr(e) k0 = Exp(b) Text2.Text = CStr(k0) For i = 1 To z kr(i) = k0 * Exp(-e / (8.315 * (t(i) + 273))) eps(i) = Abs(k(i) - kr(i)) / Abs(k(i)) MSFlexGrid1.Row = i MSFlexGrid1.Col = 3 MSFlexGrid1.Text = CStr(kr(i)) MSFlexGrid1.Col = 4 MSFlexGrid1.Text = CStr(eps(i)) Next i End Sub Private Sub Command4_Click() End End Sub Private Sub Form_Load() MSFlexGrid1.Col = 0 MSFlexGrid1.Row = 0 MSFlexGrid1.Text = "№ п.п." For i = 1 To 13 MSFlexGrid1.Row = i MSFlexGrid1.Text = CStr(i) Next i MSFlexGrid1.Row = 0 MSFlexGrid1.Col = 1 MSFlexGrid1.Text = "t 'C" MSFlexGrid1.Col = 2 MSFlexGrid1.Text = "Kr, 1/c" MSFlexGrid1.Col = 3 MSFlexGrid1.Text = "Krr, 1/c" MSFlexGrid1.Col = 4 MSFlexGrid1.Text = "eps, %" End Sub
Результат расчета: Итак, получили: E=60457.93 и k0 =18525.68. 2.2 Расчет зависимости kр (t) с использованием метода наименьших квадратов Расчет проводился на основе данных из Приложения 2 в программе, написанной в Visual Basic. Код программы : Option Explicit Dim z As Integer Dim i As Integer Dim s1 As Single Dim s2 As Single Dim s3 As Single Dim s4 As Single Dim a As Single Dim b As Single Dim k0 As Single Dim e As Single Dim t() As Single Dim k() As Single Dim kr() As Single Dim eps() As Single Dim x() As Single Dim y() As Single Private Sub Command1_Click() z = InputBox("Введите количество опытов", "Ввод экспериментальных данных") MSFlexGrid1.Rows = z + 1 ReDim t(z) As Single ReDim k(z) As Single ReDim kr(z) As Single ReDim eps(z) As Single For i = 1 To z MSFlexGrid1.Row = i MSFlexGrid1.Col = 1 t(i) = Val(InputBox("Введите параметр T 'C", "Ввод экспериментальных данных")) MSFlexGrid1.Text = CStr(t(i)) MSFlexGrid1.Col = 2 k(i) = Val(InputBox("Введите параметр K", "Ввод экспериментальных данных")) MSFlexGrid1.Text = CStr(k(i)) Next i Command2.Enabled = True Command2.Visible = True End Sub Private Sub Command2_Click() ReDim x(z) As Single ReDim y(z) As Single For i = 1 To z x(i) = 1 / (t(i) + 273) y(i) = Log(k(i)) / 2.3025 Next i s1 = 0 s2 = 0 s3 = 0 s4 = 0 For i = 1 To z s1 = s1 + x(i) s2 = s2 + x(i) * x(i) s3 = s3 + x(i) * y(i) s4 = s4 + y(i) Next i a = (z * s3 - s1 * s4) / (z * s2 - s1 * s1) b = (s2 * s4 - s1 * s3) / (z * s2 - s1 * s1) Text1.Text = CStr(a) b = -b Text2.Text = CStr(b) For i = 1 To z kr(i) = 10 ^ (a / (t(i) + 273) - b) eps(i) = Abs(k(i) - kr(i)) / Abs(k(i)) MSFlexGrid1.Row = i MSFlexGrid1.Col = 3 MSFlexGrid1.Text = CStr(kr(i)) MSFlexGrid1.Col = 4 MSFlexGrid1.Text = CStr(eps(i)) Next i End Sub Private Sub Command4_Click() End End Sub Private Sub Form_Load() MSFlexGrid1.Col = 0 MSFlexGrid1.Row = 0 MSFlexGrid1.Text = "№ п.п." For i = 1 To 13 MSFlexGrid1.Row = i MSFlexGrid1.Text = CStr(i) Next i MSFlexGrid1.Row = 0 MSFlexGrid1.Col = 1 MSFlexGrid1.Text = "t 'C" MSFlexGrid1.Col = 2 MSFlexGrid1.Text = "Kr" MSFlexGrid1.Col = 3 MSFlexGrid1.Text = "Krr" MSFlexGrid1.Col = 4 MSFlexGrid1.Text = "eps, %" End Sub Результат расчета: Итак, получили А=4789.031 и В=4.519998, следовательно: 2.3 Расчет статистической модели абсорбера с использованием метода Брандона Расчет проводился на основе данных из Приложения 3 в программе, написанной в Visual Basic. Код программы : Dim a() As Single Dim n As Integer, m As Integer Sub mnk6(ftr As Integer, n1 As Integer, masX() As Single, masY() As Single, masYR() As Single, formula As String) Dim matrYR() As Single, x() As Single, y() As Single, skwOtkl() As Single, i As Integer Dim ka As Single, kb As Single, AB() As Single, minS As Single, indMin As Integer ReDim matrYR(1 To n1, 1 To 6) As Single, x(1 To n1) As Single, y(1 To n1) As Single, skwOtkl(1 To 6) As Single ReDim AB(1 To 6, 1 To 2) As Single '1 --- Уравнение y=a*x+b For i = 1 To n1 x(i) = masX(i): y(i) = masY(i) Next i Call KoefAB(n1, x(), y(), ka, kb) AB(1, 1) = ka: AB(1, 2) = kb skwOtkl(1) = 0 For i = 1 To n1 matrYR(i, 1) = ka * masX(i) + kb skwOtkl(1) = skwOtkl(1) + (masY(i) - matrYR(i, 1)) ^ 2 Next i '2 --- Уравнение y=1/(a*x+b) For i = 1 To n1 x(i) = masX(i): y(i) = 1 / masY(i) Next i Call KoefAB(n1, x(), y(), ka, kb) AB(2, 1) = ka: AB(2, 2) = kb skwOtkl(2) = 0 For i = 1 To n1 matrYR(i, 2) = 1 / (ka * masX(i) + kb) skwOtkl(2) = skwOtkl(2) + (masY(i) - matrYR(i, 2)) ^ 2 Next i '3 --- Уравнение y=a/x+b For i = 1 To n1 x(i) = 1 / masX(i): y(i) = masY(i) Next i Call KoefAB(n1, x(), y(), ka, kb) AB(3, 1) = ka: AB(3, 2) = kb skwOtkl(3) = 0 For i = 1 To n1 matrYR(i, 3) = ka / masX(i) + kb skwOtkl(3) = skwOtkl(3) + (masY(i) - matrYR(i, 3)) ^ 2 Next i '4 --- Уравнение y=b*x^a For i = 1 To n1 x(i) = Log(masX(i)): y(i) = Log(masY(i)) Next i Call KoefAB(n1, x(), y(), ka, kb) AB(4, 1) = ka: AB(4, 2) = Exp(kb) skwOtkl(4) = 0 For i = 1 To n1 matrYR(i, 4) = Exp(kb) * masX(i) ^ ka skwOtkl(4) = skwOtkl(4) + (masY(i) - matrYR(i, 4)) ^ 2 Next i '5 --- Уравнение y=b*exp(a*x) For i = 1 To n1 y(i) = Log(masY(i)): x(i) = masX(i) Next i Call KoefAB(n1, x(), y(), ka, kb) AB(5, 1) = ka: AB(5, 2) = Exp(kb) skwOtkl(5) = 0 For i = 1 To n1 matrYR(i, 5) = Exp(kb) * Exp(ka * masX(i)) skwOtkl(5) = skwOtkl(5) + (y(i) - matrYR(i, 5)) ^ 2 Next i '6 --- Уравнение y=a*log(x)+b For i = 1 To n1 y(i) = masY(i): x(i) = Log(masX(i)) Next i Call KoefAB(n1, x(), y(), ka, kb) AB(6, 1) = ka: AB(6, 2) = kb skwOtkl(6) = 0 For i = 1 To n1 matrYR(i, 6) = ka * Log(masX(i)) + kb skwOtkl(6) = skwOtkl(6) + (y(i) - matrYR(i, 6)) ^ 2 Next i indMin = 1 minS = skwOtkl(1) For i = 2 To 6 If minS > skwOtkl(i) Then indMin = i minS = skwOtkl(i) End If Next i If indMin = 1 Then formula = CStr(AB(1, 1)) + "*x" + CStr(ftr) + "+" + CStr(AB(1, 2)) For i = 1 To n1 masYR(i) = matrYR(i, 1) Next i End If If indMin = 2 Then formula = "1/(" + CStr(AB(2, 1)) + "*x" + CStr(ftr) + "+" + CStr(AB(2, 2)) + ")" For i = 1 To n1 masYR(i) = matrYR(i, 2) Next i End If If indMin = 3 Then formula = CStr(AB(3, 1)) + "/x" + CStr(ftr) + "+" + CStr(AB(3, 2)) For i = 1 To n1 masYR(i) = matrYR(i, 3) Next i End If If indMin = 4 Then formula = CStr(AB(4, 2)) + "*x" + CStr(ftr) + "^" + CStr(AB(4, 1)) For i = 1 To n1 masYR(i) = matrYR(i, 4) Next i End If If indMin = 5 Then formula = CStr(AB(5, 2)) + "*exp(" + CStr(AB(5, 1)) + "*x" + CStr(ftr) + ")" For i = 1 To n1 masYR(i) = matrYR(i, 5) Next i End If If indMin = 6 Then formula = CStr(AB(6, 1)) + "*ln(x" + CStr(ftr) + ")+" + CStr(AB(6, 2)) For i = 1 To n1 masYR(i) = matrYR(i, 6) Next i End If End Sub Private Sub mnuComp_Click() Dim stroka As String, i As Integer, ind() As Integer, rabA() As Single, eta As Single, eps As Single Dim SrZnachY As Single, NormY() As Single, msX() As Single, msY() As Single, formul() As String Dim j As Integer, YRASCH() As Single, formulka As String, s1 As Single, s2 As Single, s3 As Single ReDim ind(1 To m) As Integer, rabA(1 To n, 1 To m + 1) As Single, NormY(1 To n, 1 To m) As Single ReDim msX(1 To n) As Single, msY(1 To n) As Single, msyr(1 To n) As Single, formul(1 To m) As String ReDim YRASCH(1 To n) As Single For i = 1 To m List1.ListIndex = i - 1 stroka = Mid(List1.Text, 2, 7): ind(i) = CInt(stroka) Next i For j = 1 To m For i = 1 To n rabA(i, j) = a(i, ind(j)) rabA(i, m + 1) = a(i, m + 1) Next i Next j SrZnach = 0 For i = 1 To n SrZnachY = SrZnachY + rabA(i, m + 1) Next i SrZnachY = SrZnachY / n formulka = "y=" + CStr(SrZnachY) For i = 1 To n YRASCH(i) = SrZnachY NormY(i, 1) = a(i, m + 1) / SrZnachY Next i For j = 1 To m For i = 1 To n msX(i) = rabA(i, j) msY(i) = NormY(i, j) Next i Call mnk6(ind(j), n, msX(), msY(), msyr(), formul(j)) For i = 1 To n YRASCH(i) = YRASCH(i) * msyr(i) Next i If j < m Then For i = 1 To n NormY(i, j + 1) = NormY(i, j) / msyr(i) Next i End If formulka = formulka + "*(" + formul(j) + ")" Next j Label1.Caption = "РЕЗУЛЬТАТЫ РАСЧЕТА:" Label5.Caption = "ПОДОБРАНА МОДЕЛЬ: " + vbCrLf Label5.Caption = Label5.Caption + formulka Label5.Visible = True With MSFlexGrid1 .Cols = .Cols + 1: .Col = .Cols - 1: .Row = 0: .Text = "YR" For i = 1 To n .Row = i: .Text = CStr(YRASCH(i)) Next i End With s1 = 0: s2 = 0: s3 = 0 For i = 1 To n s1 = s1 + (a(i, m + 1) - YRASCH(i)) ^ 2 s2 = s2 + (a(i, m + 1) - SrZnachY) ^ 2 s3 = s3 + Abs(a(i, m + 1) - YRASCH(i)) / Abs(a(i, m + 1)) Next i eps = 100 / n * s3 eta = Sqr(1 - s1 / s2) Text1.Text = CStr(eta) Text2.Text = CStr(eps) End Sub 'm- кол-во факторов, N - колво опытов Private Sub mnuExit_Click() End End Sub Sub KoefAB(n As Integer, x() As Single, y() As Single, ka As Single, kb As Single) Dim s1 As Single, s2 As Single, s3 As Single, s4 As Single s1 = 0: s2 = 0: s3 = 0: s4 = 0 For i = 1 To n s1 = s1 + x(i) s2 = s2 + x(i) * x(i) s3 = s3 + x(i) * y(i) s4 = s4 + y(i) Next i ka = (n * s3 - s1 * s4) / (n * s2 - s1 * s1) kb = (s2 * s4 - s1 * s3) / (n * s2 - s1 * s1) End Sub Private Function Opred(n1 As Integer, x1() As Single) As Single Dim i As Integer, j As Integer, в As Single Dim e As Single, k As Integer, b1 As Integer, c As Integer Dim a As Single, s As Single, g As Single, z As Integer ReDim x(1 To n1, 1 To n1) As Single z = 1 d = 1 For i = 1 To n1 For j = 1 To n1 x(i, j) = x1(i, j) Next j Next i For k = 1 To n1 - 1 e = 0 For i = k To n1 For j = k To n1 If Abs(e) >= Abs(x(i, j)) Then GoTo m90 e = x(i, j): b1 = i: c = j m90: Next j Next i If k = b1 Then GoTo m120 For j = k To n1 s = x(k, j) x(k, j) = x(b1, j) x(b1, j) = s Next j z = -z m120: If k = c Then GoTo m150 For i = k To n1 s = x(i, k) x(i, k) = x(i, c) x(i, c) = s Next i z = -z m150: For i = k + 1 To n1 g = x(i, k) / x(k, k) For j = k To n1 x(i, j) = x(i, j) - g * x(k, j) Next j Next i Next k For i = 1 To n1 d = в * x(i, i) Next i d = в * z Opred = d End Function Function Rxy(n As Integer, x() As Single, y() As Single) As Single Dim i As Integer, s1 As Single, s2 As Single, s3 As Single Dim s4 As Single, s5 As Single s1 = 0: s2 = 0: s3 = 0: s4 = 0: s5 = 0 For i = 1 To n s1 = s1 + x(i) s2 = s2 + x(i) ^ 2 s3 = s3 + x(i) * y(i) s4 = s4 + y(i) s5 = s5 + y(i) ^ 2 Next i Rxy = (n * s3 - s1 * s4) / Sqr((n * s2 - s1 * s1) * (n * s5 - s4 * s4)) End Function Private Sub mnuOpen_Click() Dim s As String, i As Integer CommonDialog1.Action = 1 s = CommonDialog1.FileName Open s For Input As #1 Input #1, m, n With MSFlexGrid1 .Cols = m + 2: .Rows = n + 1 .Col = 0: .Row = 0: .Text = "№" For i = 1 To m .Col = i: .Text = "X" + CStr(i) Next i .Col = m + 1: .Text = "Y" ReDim a(1 To n, 1 To m + 1) As Single For i = 1 To n .Col = 0: .Row = i: .Text = CStr(i) For j = 1 To m + 1 Input #1, a(i, j) .Col = j: .Text = CStr(a(i, j)) Next j Next i Close #1 End With End Sub Private Sub mnuRangir_Click() Dim d() As Single, x1() As Single, y1() As Single Dim dm1 As Single, dmk() As Single, dkk() As Single, KRxy() As Single Dim i As Integer, j As Integer, a1() As Single, sz As String ReDim d(1 To m + 1, 1 To m + 1) As Single, x1(1 To n) As Single, y1(1 To n) As Single ReDim dmk(1 To m) As Single, dkk(1 To m) As Single, KRxy(1 To m) As Single ReDim a1(1 To m, 1 To m) As Single, smassiv(1 To m) As String For i = 1 To m smassiv(i) = "X" + CStr(i) Next i For i = 1 To m + 1 d(i, i) = 1 Next i For j = 1 To m For k = j + 1 To m + 1 For i = 1 To n x1(i) = a(i, j): y1(i) = a(i, k) Next i d(j, k) = Rxy(n, x1(), y1()) 'транспонирование матрицы d(k, j) = d(j, k) Next k Next j 'вывод матрицы D With MSFlexGrid2 .Cols = m + 1: .Rows = m + 1 For i = 1 To m + 1 For j = 1 To m + 1 .Col = j - 1: .ColWidth(.Col) = 1500: .Row = i - 1: .Text = CStr(d(i, j)) Next j Next i End With 'частн коэфф множ коррел For i = 1 To m For j = 1 To m a1(i, j) = d(i, j) Next j Next i dm1 = Opred(m, a1()) For k = 1 To m For i = 1 To m k1 = 0 For j = 1 To m + 1 If j <> k Then k1 = k1 + 1 a1(i, k1) = d(i, j) End If Next j Next i dmk(k) = Opred(m, a1()) Next k For k = 1 To m k1 = 0 For i = 1 To m + 1 If i <> k Then k1 = k1 + 1: k2 = 0 For j = 1 To m + 1 If j <> k Then k2 = k2 + 1 a1(k1, k2) = d(i, j) End If Next j End If Next i dkk(k) = Opred(m, a1()) Next k With MSFlexGrid3 .Rows = m: .Cols = 2: .FixedRows = 0: .FixedCols = 0 For i = 1 To m .Row = i - 1 .Col = 0: .Text = "Ryx" + CStr(i) + "=" KRxy(i) = dmk(i) / Sqr(dm1 * dkk(i)) .Col = 1: .ColWidth(.Col) = 1500: .Text = CStr(KRxy(i)) Next i End With 'сортировка List1.Clear For i = 1 To m - 1 k = i For j = i To m If Abs(KRxy(k)) > Abs(KRxy(j)) Then k = j Next j sz = smassiv(k) smassiv(k) = smassiv(i) smassiv(i) = sz Next i For i = m To 1 Step -1 List1.AddItem (smassiv(i)) Next i End Sub Результаты расчета: 1) для степени абсорбции: В данных обозначениях Х1-начальная температура, Х2-плотность орошения, Х3-объем абсорбера, Y-степень абсорбции данная, YR-степень абсорбции рассчитанная. 2) для температуры: В данных обозначениях Х1-начальная температура, Х2-плотность орошения, Х3-объем абсорбера, Y-данная конечная температура, YR- рассчитанная конечная температура. 2.4 Расчет реакторов идеального вытеснения По заданию в схеме все реакторы идеального вытеснения, причем четыре реактора до первого абсорбера, а пятый реактор между первым и вторым абсорберами. Расчет проводится в одной и той же программе с использованием исходных данных и получаемых результатов. Необходимо учесть, что: данные, которые мы получили на выходе из 4го реактора, являются входными параметрами для 1го абсорбера; данные, которые мы получили на выходе из 1го абсорбера, являются входными параметрами для 5го реактора; данные, которые мы получили на выходе из 5го реактора, являются входными параметрами для 2го абсорбера.
Код программы : Option Explicit Dim tn As Single Dim ca0 As Single Dim cb0 As Single Dim cc0 As Single Dim vr As Single Dim g As Single Dim n As Integer Dim q As Single Dim cp As Single Dim k0 As Single Dim ea As Single Dim a0 As Single Dim b0 As Single Dim tau As Single Dim dtau As Single Dim ca As Single Dim cb As Single Dim cc As Single Dim tk As Single Dim i As Integer Dim x As Single Dim a As Single Dim в As Single Dim c As Single Dim l As Single Dim k As Single Dim kr As Single Dim f2 As Single Dim r As Single Private Sub Command1_Click() End End Sub Private Sub Command2_Click() tn = Val(Text1.Text) ca0 = Val(Text2.Text) cb0 = Val(Text3.Text) cc0 = Val(Text4.Text) vr = Val(Text5.Text) g = Val(Text6.Text) n = Val(Text13.Text) q = Val(Text7.Text) cp = Val(Text8.Text) k0 = Val(Text10.Text) ea = Val(Text9.Text) a0 = Val(Text11.Text) b0 = Val(Text12.Text) tau = vr * 3600 / g dtau = tau / n ca = ca0 tk = tn For i = 1 To n x = (ca0 - ca) / ca0 ca = ca0 * (1 - x) cb = cb0 - ca0 * x cc = cc0 + ca0 * x k = k0 * Exp(-ea / 8.31 / (tk + 273.15)) kr = 10 ^ (a0 / (tk + 273.15) - b0) a = ca + 0.8 * cc d = kr * ca * Sqr(cb) c = (cc / d) ^ 2 l = 1 - c r = k * ca * cb / a * l ca = ca - r * dtau f2 = q * r / cp tk = tk + f2 * dtau Next i Text14.Text = CStr(tk) Text15.Text = CStr(ca) Text16.Text = CStr(cb) Text17.Text = CStr(cc) Text18.Text = CStr(tau) End Sub
Результаты расчета: Из полученных результатов нам важны концентрации компонентов, чтобы ввести их в следующий реактор или абсорбер, а так же температуры на выходе (Тi ): Т1 =577.06 Т2 =514.18 Т3 =414.34 Т4 =430.73 Т5 =411.87 По заданию необходимо провести расчет двух абсорберов. Для этого используется программа, написанная в Visual Basic, исходные данные, данные полученные при расчете реакторов и зависимости, полученные по методу Брандона в пункте 3.3.
Код программы : Private Sub Command1_Click() tn = Val(Text13.Text) ro = Val(Text14.Text) vabs = Val(Text15.Text) tk = 47.44545 * (-0.05320523 * ro + 1.889979) * (-0.03595265 * vabs + 1.890018) * (0.004502005 * tn + 0.1782164) Text12.Text = CStr(tk) eta = 83.19818 * (0.03020197 * vabs + 0.2518149) * (0.03027636 * ro + 0.4635413) * (1 / (0.002109864 * tn + 0.6166517)) eta = eta / 100 Text5.Text = CStr(eta) g0 = Val(Text1.Text) ca0 = Val(Text2.Text) cb0 = Val(Text3.Text) cc0 = Val(Text4.Text) dltg = g0 * cc0 * eta g = g0 - dltg ca = g0 * ca0 / g cb = g0 * cb0 / g cc = g0 * (1 - eta) * cc0 / g w0 = g0 * 0.33 w = g * 0.33 prc = (g0 - g) / g0 * 100 Text6.Text = CStr(ca) Text7.Text = CStr(cb) Text8.Text = CStr(cc) Text9.Text = CStr(g) Text10.Text = CStr(w0) Text11.Text = CStr(w) End Sub Private Sub Command2_Click() Unload Me End Sub Результаты расчета: Из результатов расчета первого абсорбера нам необходимо значение расхода на выходе (G) для ввода его в пятый реактор и второй абсорбер, значения водяных эквивалентов на входе (Wн ) и на выходе (Wк ). Из результатов расчета обоих реакторов нам необходимы значения температур на выходе (Та1 и Та2 ). G=124146.814 м3 /час Wн =43.56 Wк =40.97 Та1 =43.34 Та2 =38.91 2.6 Синтез оптимальных систем теплообмена Для расчета используется программа, написанная в Visual Basic, исходные данные, приведенные в таблице ниже. Исходные данные для проектирования тепловой системы:
Код программы : Dim nx As Integer, ng As Integer, n As Integer, n0 As Integer Dim k As Single, c As Single, dt As Single, k0 As Single Dim tn() As Single, tk() As Single, w() As Single Dim tx() As Single, tg() As Single, nomx() As Integer Dim nomg() As Integer, r() As Single, ne() As Single Dim st() As Single Private Sub Command1_Click() st0 = 0 k = 0 m1: With MSFlexGrid1 .Cols = 9: .Col = 0: .Row = 0: .Text = "L": .Col = 1: .Text = "х": .Col = 2: .Text = "Tнх" .Col = 3: .Text = "Tхк": .Col = 4: .Text = "г": .Col = 5: .Text = "Tнг" .Col = 6: .Text = "Tгк": .Col = 7: .Text = "Q": .Col = 8: .Text = "Стоимость" l = 0 k = k + 1 For i = 1 To n If tn(i) < tk(i) Then GoTo m2 For j = 1 To n If tn(j) > tk(j) Then GoTo m3 tg0 = tn(i): tg1 = tk(i) tx0 = tn(j): tx1 = tk(j) a = tg0 - tx0 - dt If a < 0 Then GoTo m3 If (tg1 - tx0) < dt Then tg1 = tx0 + dt If (tg0 - tx1) < dt Then tx1 = tg0 - dt qx = (tx1 - tx0) * w(j) qg = (tg0 - tg1) * w(i) q = qx If qx > qg Then q = qg If q < 1 Then GoTo m3 tx1 = tx0 + q / w(j) tg1 = tg0 - q / w(i) dt1 = tg0 - tx1 dt2 = tg1 - tx0 r0 = Log(dt1 / dt2) dlt = (dt1 + dt2) / 2 If Abs(r0) > 0.639 Then dlt = (dt1 - dt2) / r0 f = q / k0 / dlt l = l + 1 st(l) = c * f ^ 0.6 st0 = st0 + st(l) nomg(l) = i: nomx(l) = j: tg(l) = tg1: tx(l) = tx1 .Rows = l + 1 .Col = 0: .Row = l: .Text = CStr(l) .Col = 1: .Text = CStr(j): .Col = 2: .Text = CStr(tx0) .Col = 3: .Text = CStr(tx1): .Col = 4: .Text = CStr(i): .Col = 5: .Text = CStr(tg0) .Col = 6: .Text = CStr(tg1): .Col = 7: .Text = CStr(q): .Col = 8: .Text = CStr(st(l)) m3: Next j m2: Next i End With If l = 0 Then GoTo m4 If ne(k) = 1 Then Label5.Caption = "Выберите вариант теплообмена между потоками i и j для которых начальные температуры максимальны" If ne(k) = 2 Then Label5.Caption = "Выберите вариант теплообмена между потоками, который обеспечивает максимальное количество передаваемого тепла" If ne(k) = 3 Then Label5.Caption = "Выберите для теплообмена горячий поток с наиболее высокой температурой на входе и холодный поток с наиболее высокой температурой на выходе из теплообменника" If ne(k) = 4 Then Label5.Caption = "Выберите для теплообмена холодный поток с наиболее низкой температурой на входе и горячий поток с наиболее низкой температурой на выходе из теплообменника" If ne(k) = 5 Then Label5.Caption = "Выберите для теплообмена пару потоков произвольным образом" l = CInt(InputBox("Введите номер варианта теплообмена:")) i = nomg(l): j = nomx(l): tn(i) = tg(l): tn(j) = tx(l) MSFlexGrid1.Clear GoTo m1 m4: Label7.Visible = True: Text4.Text = CStr(st0): Text4.Visible = True End Sub Private Sub Form_Load() Dim S As String, i As Integer CommonDialog1.Action = 1 S = CommonDialog1.FileName Open S For Input As #1 Input #1, nx, ng n = nx + ng Text1.Text = CStr(nx) Text2.Text = CStr(ng) n0 = nx * ng Input #1, k0, c, dt ReDim tn(1 To n) As Single, tk(1 To n) As Single, w(1 To n) As Single ReDim tx(1 To n0) As Single, tg(1 To n0) As Single, nomx(1 To n0) As Integer ReDim nomg(1 To n0) As Integer, r(1 To n0 + 2) As Single, ne(1 To n0 + 2) As Single ReDim st(1 To n0) As Single For i = 1 To n Input #1, tn(i), tk(i), w(i) Next i Close #1 r0 = -100 dr0 = CInt(InputBox("Введите любое число из интервала 1-33:")) For i = 1 To n0 + 2 r0 = r0 + dr0 r(i) = Rnd(r0) Next i Label4.Caption = "" For i = 1 To n0 + 2 If r(i) >= 0 And r(i) < 0.2 Then ne(i) = 1 If r(i) >= 0.2 And r(i) < 0.4 Then ne(i) = 2 If r(i) >= 0.4 And r(i) < 0.6 Then ne(i) = 3 If r(i) >= 0.6 And r(i) < 0.8 Then ne(i) = 4 If r(i) >= 0.8 And r(i) < 1 Then ne(i) = 5 Label4.Caption = Label4.Caption + CStr(ne(i)) + " " Next i End Sub Результаты расчета: Таблица 1 Таблица пар исходных потоков ( I этап синтеза) На основании таблицы 1 для теплообмена выбран 8 поток, так как необходимо было выбрать для теплообмена холодный поток с наиболее низкой температурой на входе и горячий поток с наиболее низкой температурой на выходе из теплообменника. Таблица 2 Таблица пар результирующих и исходных потоков (II этап синтеза) На основании таблицы 2 для теплообмена выбран 7 поток, так как необходимо было выбрать вариант теплообмена между потоками, который обеспечивает максимальное количество передаваемого тепла. Таблица 3 – Таблица пар результирующих и исходных потоков (III этап синтеза) На основании таблицы 3 для теплообмена выбран 2 поток, так как необходимо было выбрать вариант теплообмена между потоками i и j, для которых начальные температуры максимальны. Таблица 4 – Таблица пар результирующих и исходных потоков (IV этап синтеза) На основании таблицы 4 для теплообмена выбран 2 поток, так как необходимо было выбрать для теплообмена горячий поток с наиболее высокой температурой на входе и холодный поток с наиболее высокой температурой на выходе из теплообменника. Таблица 5 – Таблица пар результирующих и исходных потоков (V этап синтеза) На основании таблицы 5 для теплообмена выбран 2 поток, так как необходимо было выбрать поток произвольным образом. В результате синтеза системы теплообмена все потоки, кроме 1го холодного, достигли заданной температуры. Следовательно, его необходимо нагреть до нужной температуры, используя нагреватель. Для расчета используется программа, написанная в Visual Basic.
Код программы: Private Sub Command1_Click() Dim c As Single, dt As Single, qx As Single Dim tx1 As Single, tx0 As Single, tg0 As Single Dim tg1 As Single, Wx As Single, Wr As Single Dim qg As Single, q As Single, dlt As Single, k0 As Single Dim st As Single c = 483: dt = 20: k0 = 0.01745 tg0 = CSng(Text3.Text) tx0 = CSng(Text1.Text) tx1 = CSng(Text2.Text) Wx = CSng(Text6.Text) Wr = CSng(Text7.Text) tg1 = tx1 + dt qx = (tx1 - tx0) * Wx qg = (tg0 - tg1) * Wr q = qx If qx > qg Then q = qg tx1 = tx0 + q / Wx tg1 = tg0 - q / Wr: dtl = tg0 - tx1: dt2 = tg1 - tx0 dlt = (dt1 + dt2) / 2 f = q / k0 / dlt st = c * f ^ 0.6 Text5.Text = CStr(st) Text4.Text = CStr(tg1) End Sub Результаты расчета: Тепловая схема будет иметь следующий вид:
577,06 414,34 425
430,73 566,4 514,18 43,34 309,92 396,47 405
411,87 506,15 435 180 485 50 253,98 350,129 415 460 195 410 Общая стоимость данной технологической схемы составляет 1192555.42, которая была получена в результате расчета оптимальных технологических схем (1154145), а также учитывает стоимость нагревателя (38410.42). В данной курсовой работе были произведены следующие процессы оптимизации: 1. С помощью метода наименьших квадратов получили минимальные отклонения экспериментальных значений константы скорости химической реакции от расчетных для нахождения предэкспоненциального множителя k0 и энергии активации химической реакции Е. 2. С помощью метода наименьших квадратов получили минимальные отклонения экспериментальных значений константы равновесия от расчетных значений. 3. С помощью метода Брандона получили статическую модель абсорбера, а также рассчитали все потоки на входе и выходе из реакторов. Выбранная схема теплообмена, состоящая из 5 реакторов и 1 нагревателя, позволяет достичь заданных начальных и конечных температур основных технологических потоков наиболее оптимальным из рассмотренных вариантов. Таким образом, рассчитанная в данной курсовой работе химико-технологическая система обеспечивает эффективную реализацию заданной технологии. 1. Методы и средства автоматизированного расчета химико-технологических систем / Кузичкин Н. В., Саутин С. Н., Пунин А. Е., Холоднов В.А., Шибаев В. А. – Л.: Химия, 1987. – 152с 2. Химико-технологические системы. Синтез, оптимизация и управление / Д. Бальцер, В. Вайсс, В. К. Викторов и др. / Под ред. И. П. Мухленова. – Л.: Химия, 1986. -424 с. 3. Синтез оптимальных тепловых систем. Метод. указания / ЛТИ им. Ленсовета. Л.,1985 Зависимость константы скорости от температуры
Зависимость константы равновесия от температуры
Экспериментальные данные по работе абсорберов
|