Truncating Y values during integration to integrate only the "peaks" or delete CERTAIN elements from a matrix
2 ビュー (過去 30 日間)
古いコメントを表示
I have a load of data from a force transducer output. The data is in the form of time vs volts.
TEXT=fopen('Test 5.txt','rt');
texta=textscan(TEXT,'%f%f','CommentStyle','"');
A=texta{1};
B=texta{2};
C=[A,B];
D=C;
plot(D)
data:image/s3,"s3://crabby-images/eb991/eb991cf549e227e76e6bd4e405e9a38beee2b992" alt=""
The first part of my script removes the -ve values, as this relates to the compression wave recoiling in the force transducer and doesn't actually relate to compressive forces at all.
C(C<0)=0;
plot(C)
data:image/s3,"s3://crabby-images/9046c/9046c95294ea405f51b4415e6ec238d8149ff24f" alt=""
So far so good.
I am measuring the peak impulse above a certain range — impulse being the integral of force*time (or volts*time in this instance as the transducer outputs a voltage and I haven't included the conversion yet).
To measure the peak impulse I only need the values above a certain range, say 1.
data:image/s3,"s3://crabby-images/961b1/961b1413fc463a3e7d590e07d979574c01da197b" alt=""
I have tried to simply make a conditional statement to remove all data less than 1:
E=C;
E(E<1)=0;
plot(E)
data:image/s3,"s3://crabby-images/007ec/007ec90720dae234ee8fd7971b81e5036853bbb8" alt=""
However, this is not correct as what I am after is more like this (edited on MS paint):
data:image/s3,"s3://crabby-images/b9c4f/b9c4f56bcd0ecff0d639521070124c4260d4850c" alt=""
Does anyone have any ideas on how I can, either:
- Limit the Y values used to numerically integrate the data i.e ymin=1
- Remove the data in such a fashion as to resemble the final image above?
Any help would be appreciated!!! Mark.
EDIT:
Please note that I cannot simply state that E(E<1)=1 as this would artificially inflate the integral. I need all the data below that point to basically disappear.
0 件のコメント
回答 (1 件)
Azzi Abdelmalek
2013 年 11 月 18 日
findpeaks(y,'minpeakheight',1)
3 件のコメント
Azzi Abdelmalek
2013 年 11 月 18 日
編集済み: Azzi Abdelmalek
2013 年 11 月 18 日
[x_peak,x_location]=findpeaks(y,'minpeakheight',1)
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!