![](https://www.mathworks.com/matlabcentral/answers/uploaded_files/495273/image.png)
generating random , non uniform fiber distribution of circle in square
10 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
DIVAKAR RAJU P V
le 20 Jan 2021
Modifié(e) : Adam Danz
le 26 Jan 2021
I wanted to generate the square filled with circles of equal radius. Distribution should be random, non uniform and geomtrically periodic(meaning cut out portion of the circles on boundaries of square should be on the opposite side of the square). Though many people posted this question, no answer so far. can someone help me in it.
on esuggestion got to follow the Random sequential expansion(RSE) algorithm.
![](https://www.mathworks.com/matlabcentral/answers/uploaded_files/494509/image.png)
0 commentaires
Réponse acceptée
Adam Danz
le 20 Jan 2021
Modifié(e) : Adam Danz
le 20 Jan 2021
figure('Color','w')
ax = axes();
axis off
S.axisHandle = ax;
S.frameSize = [100,100]; % axis size, centered at (0,0)
S.circSize = 2; % circle radius
S.nSizes = NaN;
S.edgeType = 2; % Frame should cut off circle edges
S.supressWarning = true;
S.drawFrame = true; % show the black axis frame
[circData, circHandles] = bubblebath(S);
% View the first 5 rows of circle (x,y) coordinates and radii
circData(1:5,:)
% ans =
% 29.88 -32.97 2
% 13.043 -30.441 2
% -45.91 1.8186 2
% 33.429 45.709 2
% 35.57 -19.943 2
![](https://www.mathworks.com/matlabcentral/answers/uploaded_files/495273/image.png)
5 commentaires
Adam Danz
le 22 Jan 2021
Modifié(e) : Adam Danz
le 22 Jan 2021
@DIVAKAR RAJU P V download vs 2.3.0 of bubblebath(). This version supports edge wrapping. The section of circles that expand beyond an axis border are wrapped to the other side. If a circle expands beyond two axis borders at a corner, both its x and y components are wrapped. Note that this function relies on random processes and intentionally uses a low-level, unsophisticated algorithm which is different from circle-packing and its wrapping feature may differ from the algorithm in the paper you shared.
Example:
rng('default') % for reproducibility
S = struct();
S.frameSize = [30 30];
S.circSize = 4;
S.nSizes = NaN;
S.edgeType = 3; % <-- flag to wrap edges
S.supressWarning = true;
bubblebath(S)
![](https://www.mathworks.com/matlabcentral/answers/uploaded_files/497018/image.png)
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Creating and Concatenating Matrices dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!