mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2024-12-15 04:30:33 +00:00
Addign some useful matlab binary file reading functions
This commit is contained in:
parent
a5d65f3424
commit
114121ef51
57
src/utils/matlab/libs/read_complex_binary.m
Normal file
57
src/utils/matlab/libs/read_complex_binary.m
Normal file
@ -0,0 +1,57 @@
|
||||
%
|
||||
% Copyright 2001 Free Software Foundation, Inc.
|
||||
%
|
||||
% This file is part of GNU Radio
|
||||
%
|
||||
% GNU Radio is free software; you can redistribute it and/or modify
|
||||
% it under the terms of the GNU General Public License as published by
|
||||
% the Free Software Foundation; either version 3, or (at your option)
|
||||
% any later version.
|
||||
%
|
||||
% GNU Radio is distributed in the hope that it will be useful,
|
||||
% but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
% GNU General Public License for more details.
|
||||
%
|
||||
% You should have received a copy of the GNU General Public License
|
||||
% along with GNU Radio; see the file COPYING. If not, write to
|
||||
% the Free Software Foundation, Inc., 51 Franklin Street,
|
||||
% Boston, MA 02110-1301, USA.
|
||||
%
|
||||
|
||||
function v = read_complex_binary (filename, count, start_sample)
|
||||
|
||||
%% usage: read_complex_binary (filename, [count], [start_sample])
|
||||
%%
|
||||
%% open filename and return the contents as a column vector,
|
||||
%% treating them as 32 bit complex numbers
|
||||
%%
|
||||
|
||||
m = nargchk (1,2,nargin);
|
||||
if (m)
|
||||
%usage (m);
|
||||
end
|
||||
|
||||
if (nargin < 2)
|
||||
count = Inf;
|
||||
start_sample=0;
|
||||
end
|
||||
|
||||
if (nargin < 3)
|
||||
start_sample=0;
|
||||
end
|
||||
|
||||
f = fopen (filename, 'rb');
|
||||
if (f < 0)
|
||||
v = 0;
|
||||
else
|
||||
if (start_sample>0)
|
||||
bytes_per_sample=4;
|
||||
fseek(f,start_sample*bytes_per_sample,'bof');
|
||||
end
|
||||
t = fread (f, [2, count], 'float');
|
||||
fclose (f);
|
||||
v = t(1,:) + t(2,:)*i;
|
||||
[r, c] = size (v);
|
||||
v = reshape (v, c, r);
|
||||
end
|
48
src/utils/matlab/libs/read_complex_char_binary.m
Normal file
48
src/utils/matlab/libs/read_complex_char_binary.m
Normal file
@ -0,0 +1,48 @@
|
||||
%
|
||||
% Copyright 2001 Free Software Foundation, Inc.
|
||||
%
|
||||
% This file is part of GNU Radio
|
||||
%
|
||||
% GNU Radio is free software; you can redistribute it and/or modify
|
||||
% it under the terms of the GNU General Public License as published by
|
||||
% the Free Software Foundation; either version 3, or (at your option)
|
||||
% any later version.
|
||||
%
|
||||
% GNU Radio is distributed in the hope that it will be useful,
|
||||
% but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
% GNU General Public License for more details.
|
||||
%
|
||||
% You should have received a copy of the GNU General Public License
|
||||
% along with GNU Radio; see the file COPYING. If not, write to
|
||||
% the Free Software Foundation, Inc., 51 Franklin Street,
|
||||
% Boston, MA 02110-1301, USA.
|
||||
%
|
||||
|
||||
function v = read_complex_char_binary (filename, count)
|
||||
|
||||
%% usage: read_complex_binary (filename, [count])
|
||||
%%
|
||||
%% open filename and return the contents as a column vector,
|
||||
%% treating them as 32 bit complex numbers
|
||||
%%
|
||||
|
||||
m = nargchk (1,2,nargin);
|
||||
if (m)
|
||||
usage (m);
|
||||
end
|
||||
|
||||
if (nargin < 2)
|
||||
count = Inf;
|
||||
end
|
||||
|
||||
f = fopen (filename, 'rb');
|
||||
if (f < 0)
|
||||
v = 0;
|
||||
else
|
||||
t = fread (f, [2, count], 'int8');
|
||||
fclose (f);
|
||||
v = t(1,:) + t(2,:)*i;
|
||||
[r, c] = size (v);
|
||||
v = reshape (v, c, r);
|
||||
end
|
48
src/utils/matlab/libs/read_complex_short_binary.m
Normal file
48
src/utils/matlab/libs/read_complex_short_binary.m
Normal file
@ -0,0 +1,48 @@
|
||||
%
|
||||
% Copyright 2001 Free Software Foundation, Inc.
|
||||
%
|
||||
% This file is part of GNU Radio
|
||||
%
|
||||
% GNU Radio is free software; you can redistribute it and/or modify
|
||||
% it under the terms of the GNU General Public License as published by
|
||||
% the Free Software Foundation; either version 3, or (at your option)
|
||||
% any later version.
|
||||
%
|
||||
% GNU Radio is distributed in the hope that it will be useful,
|
||||
% but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
% GNU General Public License for more details.
|
||||
%
|
||||
% You should have received a copy of the GNU General Public License
|
||||
% along with GNU Radio; see the file COPYING. If not, write to
|
||||
% the Free Software Foundation, Inc., 51 Franklin Street,
|
||||
% Boston, MA 02110-1301, USA.
|
||||
%
|
||||
|
||||
function v = read_complex_short_binary (filename, count)
|
||||
|
||||
%% usage: read_complex_binary (filename, [count])
|
||||
%%
|
||||
%% open filename and return the contents as a column vector,
|
||||
%% treating them as 32 bit complex numbers
|
||||
%%
|
||||
|
||||
m = nargchk (1,2,nargin);
|
||||
if (m)
|
||||
usage (m);
|
||||
end
|
||||
|
||||
if (nargin < 2)
|
||||
count = Inf;
|
||||
end
|
||||
|
||||
f = fopen (filename, 'rb');
|
||||
if (f < 0)
|
||||
v = 0;
|
||||
else
|
||||
t = fread (f, [2, count], 'short');
|
||||
fclose (f);
|
||||
v = t(1,:) + t(2,:)*i;
|
||||
[r, c] = size (v);
|
||||
v = reshape (v, c, r);
|
||||
end
|
Loading…
Reference in New Issue
Block a user