Summing two binary vectors
이전 댓글 표시
How can I add two binary vector say a= 1 0 1, b= 1 1 0?
Using simply '+' gives decimal output. I want the summation in binary.
채택된 답변
추가 답변 (1개)
y = sumbin(a,b) adds two binary values a and b represented by boolean row vectors (1/0, true/false) and returns the results y as a boolean row vector.
log2dec(v) is a helper function called by sumbin() and converts the boolean vectors to binary strings and then to the decimal representation.
Demo:
a = [1 0 1]; % = 5
b = [1 1 0]; % = 6
log2dec = @(v)bin2dec(num2str(v));
sumbin = @(a,b)dec2bin(sum([log2dec(a), log2dec(b)]))-'0';
sumbin(a,b) % = 11
If you want to add more than 2 binary numbers in the form of boolean vectors,
y = sumbin(a,b,...,n) receives any number of boolean row vectors (1/0, true/false) and returns the results y as a boolean row vector.
a = [1 0 1]; % = 5
b = [1 1 0]; % = 6
c = [1]; % = 1
d = [1 1 1]; % = 7
log2dec = @(v)bin2dec(num2str(v));
sumbin = @(varargin)dec2bin(sum(cellfun(log2dec, varargin)))-'0';
sumbin(a,b,c,d) % = 19
댓글 수: 2
Neeraj Chimwal
2021년 3월 25일
@Neeraj Chimwal just FYI, the first part of my answer and Fangjun Jiang's answer are practically the same, there's very little difference.
The second part of my answer shows how to extend the summation to more than 2 binary vectors.
All vectors are arrays but not all arrays are vectors. A vector is 2D with one dimention equal to 1.
These are vectors
A = [1 0 1];
size(A)
B = [1;0;1];
size(B)
These are arrays that are not vectors
C = rand(2,3);
size(C)
D = rand(2,3,4);
size(D)
카테고리
도움말 센터 및 File Exchange에서 Logical에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!