フィルターのクリア

How to similuate a coin flip with probablility p

97 ビュー (過去 30 日間)
Zach
Zach 2011 年 11 月 9 日
コメント済み: ali fadi 2022 年 4 月 11 日
How do I simulate getting a result, either 0 or 1, with probability p. So if p=0.5 I should get an output of 0 half of the time, and 1 half of the time.
  1 件のコメント
ali fadi
ali fadi 2022 年 4 月 11 日
probability and statics the probability function flipping 3 coins in matlab

サインインしてコメントする。

採用された回答

Wayne King
Wayne King 2011 年 11 月 9 日
100 tosses with p=0.5.
x = round(rand(100,1));
If you want a probability other than p=0.5, then realize that rand() is uniform random number generator between [0,1], so you can assign the output of rand() accordingly. For example, for p=0.25:
y = zeros(100,1);
x = rand(100,1);
y(x<0.25) = 1;
Or if you just want to simulate the number of 0's or 1's in a certain number of trials. Say 100 for example. Here is a simulation of ten such experiments. Requires Statistics Toolbox.
R = binornd(100,0.5,10,1);

その他の回答 (3 件)

Nick
Nick 2011 年 11 月 9 日
Alternatively you could use the randi function in MATLAB which generates random integers.
100 tosses with 0=heads, 1=tails
coin=randi([0:1], [100,1])
It should more or less give you 50 0's and 50 1's.
If there is more than 2 possible outcomes and they all occur with the same probability then just increase the integer range of the randi function.
  4 件のコメント
Image Analyst
Image Analyst 2021 年 11 月 13 日
編集済み: Image Analyst 2021 年 11 月 13 日
@Evangelia Lo, if you have the Image Processing Toolbox you can use bwareafilt() to extract runs of only the length you want and then bwlabel() or regionprops() to count them. If you want to find the index where each run starts, use regionprops():
coins = logical(randi([0, 1], 1, 30000)); % 30,000 coins
patternLength = 10; % Whatever you want
% Throw out all regions that don't match the length we want using bwareafilt(). Need to invert.
coins2 = bwareafilt(~coins, [patternLength, patternLength]);
% Count them
props = regionprops(coins2, 'PixelIdxList');
numPatternOccurrences = numel(props)
% For fun, find out where they occur.
indexes = vertcat(props.PixelIdxList); % All 10 indexes in a run
startingIndex = indexes(1 : patternLength : end) % Just the starting index.
Evangelia Lo
Evangelia Lo 2021 年 11 月 13 日
How can i do it without the Image Processing Toolbox ?

サインインしてコメントする。


Cory London
Cory London 2018 年 11 月 15 日
This code is easily minupulated and works pretty well
Ntoss = 100;
x = rand(1, Ntoss); % what is the resulting size of x?
toss = (x < 0.5);
  1 件のコメント
Umar Abdulhamid
Umar Abdulhamid 2021 年 10 月 6 日
Can you briefly explain this for me please?

サインインしてコメントする。


SARATHRAJ V
SARATHRAJ V 2021 年 2 月 20 日
Ntoss = 100; x = rand(1, Ntoss); % what is the resulting size of x? toss = (x < 0.5);

カテゴリ

Help Center および File ExchangeLinear Algebra についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by