Script for CSV processing
조회 수: 1 (최근 30일)
이전 댓글 표시
Hi friends.
First of all I apologize for my bad English.
I tell you my problem. I was working with an osciloscope and I take around 500 measures (Voltage/Time) in CSV files. The signal is a pulse train with only the 1% of the period crossing the zero.I want to measure with matlab, for each csv, which is the value of x axis (time) for exactly 25 pulses of the whole train.
Doing this with cursors is a very hard work. I'm trying to build a Script. My main idea (because of the small time that the signal cross the zero) is to make a FOR loop, with a IF loop inside that, when Y axis have crossed the zero 25 times, the script catchs the value of the X axis in a new variable. This operation, with the bucle, for all the CSV files.
This is my idea, but Im new in Matlab and is costing me a lot.
Anyone can help me? Thank you very much.
답변 (2개)
dpb
2015년 3월 23일
s=csvread('yourfile.csv'); % read the signal
ix=find([0 diff(s>0)==1,25); % locate first 25 zero crossings
The above works by turning the input signal into a 0/1 pulse train, then looks for the positive crossing locations (where the 0 turns to 1 is a +1 difference).
The ix index vector is the position in the original vector of those crossings, specifically it will be the index of the first positive location after the zero-crossing.
댓글 수: 0
Antonio Jayena
2015년 3월 23일
댓글 수: 3
dpb
2015년 3월 23일
OK, I presumed a row vector in s; for a Nx2 array then for the voltage column it would be
ix=find([0; diff(s(:,1)>0)==1,25]);
again assuming the data array is s; obviously use whatever you use in your script.
For processing multiple files, you might look at the File Exchange function filefun that applies a function "automagically" to each function. It's at <Apply a function to files>
참고 항목
카테고리
Help Center 및 File Exchange에서 Matrix Indexing에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!