MATLAB中如何将离散加速度积分求得速度

方法一:

E=load('C:\Users\Administrator\Desktop\in.txt');
D=E-sum(E(:,1))/length(E);
figure(1)
plot(D)
 title('滤波前加速度')
%%%%%%%%%%%%%%%%%%%%%%%%%%%


% 积分%%%%%%%%%%%%
dt=0.1;
Sx=0;
for i=1:1:length(D)
Sx=D(i,1)*dt+Sx ;%从最值位置叠加加速度
Vx(i,1)=Sx; %速度矩阵
end
figure(2)
subplot(2,1,1)
plot(Vx)
ylabel('速度')
%%% 直流分量确定和积分基线的标定 %%%%%%%%%%%%%%%%%%%%%
Vx=Vx-sum(Vx(:,1))/length(Vx);
% Sx2=dt*cumtrapz(Vx-0.04) %X方向位移矩阵,其中0.04为通过整周期积分得出的直流分量值。
Sx2=dt*cumtrapz(Vx); %X方向位移矩阵,其中Vx为通过标定后的速度矩阵。
subplot(2,1,2)
plot(Sx2)
ylabel('位移')



方法二:

将下面内容保存为Simpson.m
function y= Simpson(f,a,b,M)
% f被积函数;a积分下限;b积分上限;M子区间个数(将x分为多少个区间)
if M==0
    y=0;
else
h=(b-a)/(2*M);
s1=0;
s2=0;
for i=1:M
    x=a+(2*i-1)*h;
    s1=s1+feval(f,x);
end
for j=1:(

你可能感兴趣的:(MATLAB)