How to generate a random number of n bits length?

26 vues (au cours des 30 derniers jours)
Mohsin Shah
Mohsin Shah le 6 Sep 2018
Commenté : John D'Errico le 18 Nov 2020
Let's say a function takes input n as the bit length and outputs a random number. For example, for n = 4, the output range is [0 - 15] which also includes the range for n = 3 i.e. [0 - 7]. The function should generate the number in the range [8 - 15] and not in the range [0 - 15]. How to do this and how to generalize it for any n?
  3 commentaires
Mohsin Shah
Mohsin Shah le 6 Sep 2018
For n = 3 then the output range is [0-7] which includes the range [0-3] which is for n = 2
KALYAN ACHARJYA
KALYAN ACHARJYA le 6 Sep 2018
Modifié(e) : KALYAN ACHARJYA le 6 Sep 2018
@Mohsin Check my answer, as per your requirement? If any modification required, let me know.

Connectez-vous pour commenter.

Réponse acceptée

Guillaume
Guillaume le 6 Sep 2018
For n = 4 it should generate a number in the range [8-15]
If I understand correctly, you want a 4 bit random number with the MSB always set to 1. That sounds like a strange requirement, probably not thought properly, but this is simply equivalent to generating a 3 bit random number and tacking 1 as the MSB. The generic version of that (generating a n-1 bit number + MSB of 1) is:
n = 4
number = randi([1, 2^(n-1)]) + 2^(n-1) - 1
  3 commentaires
ANz Eisenheim
ANz Eisenheim le 18 Nov 2020
I want generate a random large sequence of bits and block the sequence. each block of data consisting of 4 bits. Can Anyone help?
John D'Errico
John D'Errico le 18 Nov 2020
@ANz Eisenheim - please don't revive dead questions with a new question. If you have a new question, then ask it separately.
Regardless, what is the problem? Generate random bits as a vector. rand can do it. randi can do it. As long as the sequence is of a length that is a multiple of 4, you are done. So WTP?

Connectez-vous pour commenter.

Plus de réponses (1)

KALYAN ACHARJYA
KALYAN ACHARJYA le 6 Sep 2018
Modifié(e) : KALYAN ACHARJYA le 6 Sep 2018
function bit_result=rand_bits(n)
result=randi([2^(n-1), 2^n]);
bit_result=de2bi(result,n)
end
  3 commentaires
KALYAN ACHARJYA
KALYAN ACHARJYA le 6 Sep 2018
Modifié(e) : KALYAN ACHARJYA le 6 Sep 2018
@Mohsin I have edited the answer, can you verify it?
Mohsin Shah
Mohsin Shah le 6 Sep 2018
I appreciate your efforts but the edited function still doesn't work. Check the answer of Guillaume which worked for me.

Connectez-vous pour commenter.

Community Treasure Hunt

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

Start Hunting!

Translated by