1
0
mirror of https://github.com/gnss-sdr/gnss-sdr synced 2024-11-15 14:25:00 +00:00
gnss-sdr/utils/matlab/libs/read_complex_binary.m

48 lines
1.1 KiB
Matlab

% Usage: read_complex_binary (filename, [count], [start_sample])
%
% Opens filename and returns the contents as a column vector,
% treating them as 32 bit complex numbers
%
% -------------------------------------------------------------------------
%
% GNSS-SDR is a Global Navigation Satellite System software-defined receiver.
% This file is part of GNSS-SDR.
%
% Copyright (C) 2010-2019 (see AUTHORS file for a list of contributors)
% SPDX-License-Identifier: GPL-3.0-or-later
%
% -------------------------------------------------------------------------
%
function v = read_complex_binary (filename, count, start_sample)
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