Skip to content
Permalink
ff8326de7b
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Go to file
 
 
Cannot retrieve contributors at this time
203 lines (177 sloc) 5.49 KB
function b = de2bi(varargin)
%DE2BI Convert decimal numbers to binary numbers.
% B = DE2BI(D) converts a nonnegative integer decimal vector D to a
% binary matrix B. Each row of the binary matrix B corresponds to one
% element of D. The default orientation of the binary output is
% Right-MSB; the first element in B represents the lowest bit.
%
% In addition to the vector input, three optional parameters can be
% given:
%
% B = DE2BI(...,N) uses N to define how many digits (columns) are output.
%
% B = DE2BI(...,N,P) uses P to define which base to convert the decimal
% elements to.
%
% B = DE2BI(...,MSBFLAG) uses MSBFLAG to determine the output
% orientation. MSBFLAG has two possible values, 'right-msb' and
% 'left-msb'. Giving a 'right-msb' MSBFLAG does not change the
% function's default behavior. Giving a 'left-msb' MSBFLAG flips the
% output orientation to display the MSB to the left.
%
% Examples:
% E = [12; 5];
%
% A = de2bi(E)
% B = de2bi(E,5)
% C = de2bi(E,[],3)
% D = de2bi(E,5,'left-msb')
%
% See also BI2DE.
% Copyright 1996-2008 The MathWorks, Inc.
% $Revision: 1.19.4.5 $ $Date: 2010/04/05 22:13:25 $
% Typical error checking.
error(nargchk(1,4,nargin,'struct'));
% --- Placeholder for the signature string.
sigStr = '';
msbFlag = '';
p = [];
n = [];
% --- Identify string and numeric arguments
for i=1:nargin
if(i>1)
sigStr(size(sigStr,2)+1) = '/';
end;
% --- Assign the string and numeric flags
if(ischar(varargin{i}))
sigStr(size(sigStr,2)+1) = 's';
elseif(isnumeric(varargin{i}))
sigStr(size(sigStr,2)+1) = 'n';
else
error('comm:de2bi:InvalidArg','Only string and numeric arguments are accepted.');
end;
end;
% --- Identify parameter signitures and assign values to variables
switch sigStr
% --- de2bi(d)
case 'n'
d = varargin{1};
% --- de2bi(d, n)
case 'n/n'
d = varargin{1};
n = varargin{2};
% --- de2bi(d, msbFlag)
case 'n/s'
d = varargin{1};
msbFlag = varargin{2};
% --- de2bi(d, n, msbFlag)
case 'n/n/s'
d = varargin{1};
n = varargin{2};
msbFlag = varargin{3};
% --- de2bi(d, msbFlag, n)
case 'n/s/n'
d = varargin{1};
msbFlag = varargin{2};
n = varargin{3};
% --- de2bi(d, n, p)
case 'n/n/n'
d = varargin{1};
n = varargin{2};
p = varargin{3};
% --- de2bi(d, n, p, msbFlag)
case 'n/n/n/s'
d = varargin{1};
n = varargin{2};
p = varargin{3};
msbFlag = varargin{4};
% --- de2bi(d, n, msbFlag, p)
case 'n/n/s/n'
d = varargin{1};
n = varargin{2};
msbFlag = varargin{3};
p = varargin{4};
% --- de2bi(d, msbFlag, n, p)
case 'n/s/n/n'
d = varargin{1};
msbFlag = varargin{2};
n = varargin{3};
p = varargin{4};
% --- If the parameter list does not match one of these signatures.
otherwise
error('comm:de2bi:InvalidArgSeq','Syntax error.');
end;
if isempty(d)
error('comm:de2bi:NoInput','Required parameter empty.');
end
inType = class(d);
d = double(d(:));
len_d = length(d);
if any(d(:) < 0) || any(~isfinite(d(:))) || ~isreal(d) || ~isequal(floor(d),d)
error('comm:de2bi:InvalidInput','Input must contain only finite real nonnegative integers.');
end
% Assign the base to convert to.
if isempty(p)
p = 2;
elseif max(size(p) ~= 1)
error('comm:de2bi:NonScalarBase','Destination base must be scalar.');
elseif (~isfinite(p)) || (~isreal(p)) || (floor(p) ~= p)
error('comm:de2bi:InvalidBase','Destination base must be a finite real integer.');
elseif p < 2
error('comm:de2bi:BaseLessThan2','Cannot convert to a base of less than two.');
end;
% Determine minimum length required.
tmp = max(d);
if tmp ~= 0 % Want base-p log of tmp.
ntmp = floor( log(tmp) / log(p) ) + 1;
else % Since you can't take log(0).
ntmp = 1;
end
% This takes care of any round off error that occurs for really big inputs.
if ~( (p^ntmp) > tmp )
ntmp = ntmp + 1;
end
% Assign number of columns in output matrix.
if isempty(n)
n = ntmp;
elseif max(size(n) ~= 1)
error('comm:de2bi:NonScalarN','Specified number of columns must be scalar.');
elseif (~isfinite(n)) || (~isreal(n)) || (floor(n) ~= n)
error('comm:de2bi:InvalidN','Specified number of columns must be a finite real integer.');
elseif n < ntmp
error('comm:de2bi:SmallN','Specified number of columns in output matrix is too small.');
end
% Check if the string msbFlag is valid.
if isempty(msbFlag)
msbFlag = 'right-msb';
elseif ~(strcmp(msbFlag, 'right-msb') || strcmp(msbFlag, 'left-msb'))
error('comm:de2bi:InvalidMsbFlag','Invalid string msbFlag.');
end
% Initial value.
b = zeros(len_d, n);
% Perform conversion.
%Vectorized conversion for P=2 case
if(p==2)
[~,e]=log2(max(d)); % How many digits do we need to represent the numbers?
b=rem(floor(d*pow2(1-max(n,e):0)),p);
if strcmp(msbFlag, 'right-msb')
b = fliplr(b);
end;
else
for i = 1 : len_d % Cycle through each element of the input vector/matrix.
j = 1;
tmp = d(i);
while (j <= n) && (tmp > 0) % Cycle through each digit.
b(i, j) = rem(tmp, p); % Determine current digit.
tmp = floor(tmp/p);
j = j + 1;
end;
end;
% If a msbFlag is specified to flip the output such that the MSB is to the left.
if strcmp(msbFlag, 'left-msb')
b2 = b;
b = b2(:,n:-1:1);
end;
end;
b = feval(inType, b); % data type conversion
% [EOF]