特定限度内的曲线循环伏安法下面积

时间:2019-05-28 10:33:48

标签: matlab

我想计算I> 0和V <0.4时曲线下的积分面积,我不能用trapz函数来做到这一点,请帮忙!

我尝试了积分和陷阱函数,但没有用!我无法附加该文本文件,因此,如果您需要调试该文本文件,请告诉我该怎么做。

close all
clear all
clc
c=Constants;
F = dir('*.txt');  
nF = length(F) ;
count = 0 ;
for ii = 1:nF
fname = F(ii).name ;
end
filename = fullfile(fname);
fileID = fopen(filename);
formatSpec = '%s';
N = 1;
c_text = textscan(fileID,formatSpec,N,'Delimiter',' ');
c_data = textscan(fileID,'%f %f');
v=c_data{1};
i=c_data{2};

idi = i>0;
idv=v<0.4;
v_pos = v(idv);
i_pos= i(idi); 
% v_limit=v_pos(idv)

inty = trapz(v_pos, i_pos)


setvalue = 0.06;
[~,closestIndex] = min(abs(setvalue-v_pos));
vm= v_pos(closestIndex)

setvalue = 0.4;
[~,closestIndex] = min(abs(setvalue-v_pos));
vf= v_pos(closestIndex)
ifinal=i_pos(closestIndex)

figure(1)
plot(v,i)
hold on
hold off
grid
area=inty-[(vf-vm)*ifinal]
yline(0);

cvarea=area/1000;
qh=cvarea/c.cvscanrate;
active_area=qh/(c.qpt*c.A);
fprintf('Active surface area of catalyst %g cm^2 Pt/ cm^2 electrode \n', active_area);

使用trapz时出错(第66行) 点间距必须是指定均匀间距的标量或每个数据点的x坐标向量。

1 个答案:

答案 0 :(得分:0)

有几种计算离散积分的方法。

这是黎曼和近似值

enter image description here

这是trapz

使用的梯形规则

enter image description here

黎曼和是最容易计算的。

您只需要每个矩形的宽度和高度(以便我们可以计算面积)。

%Dummy data:
x = 0:0.1:10;
y = x.^2;  
%Width
X = diff(x)
%Height
Y = conv(y,ones(2,1),'valid')/2
%Integral:
I = sum(X.*Y)

即使点间距不均匀,此方法仍然有效。