Script for CSV processing

3 vues (au cours des 30 derniers jours)
Antonio Jayena
Antonio Jayena le 23 Mar 2015
Commenté : dpb le 23 Mar 2015
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.
  1 commentaire
Antonio Jayena
Antonio Jayena le 23 Mar 2015
Im trying to go in other way, but I'm faling in the sintax
j=1
i=1
for i=1:30
s=csvread('scope_0_1.csv',2,0);
if (r2==0) % when signal cross zero
j=j+1
else
if (j==25) % finding the 25th zero crossing
disp('s');
j=0;
i=i+1;
end
Any help plis?

Connectez-vous pour commenter.

Réponses (2)

dpb
dpb le 23 Mar 2015
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.

Antonio Jayena
Antonio Jayena le 23 Mar 2015
Im trying to go in other way, but I'm faling in the sintax
j=1
i=1
for i=1:30
s=csvread('scope_0_1.csv',2,0);
if (r2==0) % when signal cross zero
j=j+1
else
if (j==25) % finding the 25th zero crossing
disp('s');
j=0;
i=i+1;
end
Any help plis?
  3 commentaires
Antonio Jayena
Antonio Jayena le 23 Mar 2015
I´m trying but I get errors.
Error using horzcat
Dimensions of matrices being concatenated are not
consistent.
Error in Matlab (line 2)
ix=find([0 diff(s>0)==1,25]);
Mi CSV has 2 colums (voltage and time)...is here my error? I make a loop because I have a lot of CSV files, and Im triying to get the value of each one printing in each iteration with
disp('s')
Thank you for your effort.
dpb
dpb le 23 Mar 2015
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>

Connectez-vous pour commenter.

Catégories

En savoir plus sur Matrix Indexing dans Help Center et File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by