How to integrate dataset over a certain domain ?
조회 수: 2 (최근 30일)
이전 댓글 표시

clear all
close all
clc
load data.txt
S_v = data(:,2);
T = data (:,1);
I_H = trapz(S_v); %Spectral_Intensity
Here it integrates over the whole domain. But how can I integrate within the specified range ?
댓글 수: 0
채택된 답변
Star Strider
2021년 4월 22일
Perhaps:
load data.txt
S_v = data(:,2);
T = data (:,1);
Trange = (T >= 0.1) & (T <= 2.5);
I_H = trapz(T(Trange), S_v(Trange)); %Spectral_Intensity
will do what you want. (Not able to test it without ‘data.txt’.)
Do not use clear or clc. It is simply inefficient.
댓글 수: 2
Star Strider
2021년 4월 23일
As always, my pleasure!
With vectors or arrays, the trapz funciton is the only option. The other integration functions require function handle arguments, and integrate the functions themselves between specific limits.
추가 답변 (0개)
참고 항목
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!