matlab拟合NRTL方程
时间: 2023-07-13 13:10:38 浏览: 263
NRTL.rar_NRTL_NRTL matlab_groupruv_matlab nrtl_气液平衡
5星 · 资源好评率100%
要使用Matlab拟合NRTL方程,需要先准备好实验数据。NRTL方程的拟合需要知道每个组分的摩尔分数、温度和压力等参数,以及每个组分的相对挥发度(或者其它类似的参数)。然后可以使用Matlab中的拟合函数,如fit、lsqcurvefit等,来进行拟合。
下面是一个简单的例子,假设我们有一组二元混合物的实验数据,包括组分1和组分2的摩尔分数、温度和压力等参数,以及二者的相对挥发度。我们想用NRTL方程拟合这组数据,求出NRTL方程中的τij和kij参数,并用拟合后的方程预测组分的活度系数。
首先,需要定义NRTL方程。可以将其定义为一个函数,如下所示:
```
function gamma = nrtl(tau,kij,x)
% tau: NRTL方程中的τij参数
% kij: NRTL方程中的kij参数
% x: 混合物中各组分的摩尔分数
n = length(x);
gamma = zeros(n,1);
for i = 1:n
sum1 = 0;
sum2 = 0;
for j = 1:n
if j ~= i
sum1 = sum1 + x(j)*tau(i,j)/(1+kij(i,j)*x(j));
sum2 = sum2 + x(j)*kij(i,j)*tau(i,j)/(1+kij(i,j)*x(j));
end
end
gamma(i) = exp(sum1 + sum2);
end
end
```
接下来,可以使用Matlab中的拟合函数,如lsqcurvefit,来拟合NRTL方程。假设我们已经将实验数据存储在一个名为data的结构体中,包括x1、x2、T、P和alpha等变量。可以使用如下代码进行拟合:
```
% 定义拟合函数
fun = @(x,xdata) nrtl(x(1:4),x(5:8),xdata(:,1:2));
% 初始化参数
x0 = [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1];
% 拟合数据
x = lsqcurvefit(fun,x0,data(:,1:2),log(data.alpha));
% 输出拟合结果
disp(x(1:4)); % 输出tauij参数
disp(x(5:8)); % 输出kij参数
```
最后,可以使用拟合后的NRTL方程来预测组分的活度系数。假设我们要预测组分1和组分2在给定条件下的活度系数,可以使用如下代码:
```
% 给定摩尔分数、温度和压力等参数
x = [0.3 0.7];
T = 298; % K
P = 1e5; % Pa
% 计算相应的tauij和kij参数
tau = x(1)*x(2)*[0.1 0.2; 0.2 0.1];
kij = x(1)*x(2)*[0.2 0.3; 0.3 0.2];
% 计算活度系数
gamma = nrtl(tau,kij,x);
% 输出结果
disp(gamma);
```
这样就可以使用Matlab拟合NRTL方程,并预测混合物中各组分的活度系数了。需要注意的是,NRTL方程的拟合需要根据具体的实验数据,选择合适的参数个数和初始值,并进行适当的调整,以获得较好的拟合效果。
阅读全文