###前提・実現したいこと
MATLABで大きさの異なる複数の円を重ならないように描画しようとしています。
以下の参考サイトから画像を取ってきたのですが、以下のような実行結果が得たいです。
参考サイトでFunctionsの欄にあるコードを試しに実行してみたのですが、関数だけなので、動かないようです。
参考サイト
###該当のソースコード
現状では、Matlabでは1つの円を描画するコードとして以下
Matlab
1% 等間隔ベクトルの作成 2t = linspace(0,2*pi,100); 3 4figure 5cx = 600; cy = 600; % 中心 6r = 0; % 半径 7 8 9for i =0:20 10 fill(r*sin(t)+cx,r*cos(t)+cy, 'k') 11 r = r+1; 12end 13i=i+1; 14 15axis([0,1200,0,1200]) 16axis square
Processingでは以下のコードで近いものを実装することはできました。
コードの参考にした記事
processing
1//配列準備 2 ArrayList <PVector> circles; 3 4 void setup() { 5 background(0); 6 size(600, 600); 7 8 //色相・彩度・明度で指定 9 smooth(); 10 noLoop(); 11 } 12 13 void draw() { 14 background(255); 15 circles = new ArrayList <PVector>(); 16 17 addCircle(); 18 19 for (int i=0; i<circles.size(); i++) { 20 PVector p = circles.get(i); 21 noStroke(); 22 fill(0); 23 ellipse(p.x, p.y, p.z, p.z); 24 } 25 26 } 27 28 29 void addCircle() { 30 //10は個数 31 while (circles.size() < 10) { 32 //大きさが10から100の間 33 float diameter = random(10, 100); 34 PVector c = new PVector(random(width), random(height), diameter); 35 boolean overlapping = false; 36 37 for (PVector p : circles) { 38 39 /* 40 distは2点間の距離を出す dist(x1, y1, x2, y2) 41 この場合は、cとpの2点間の距離 > cの半径+pの半径の場合に描画される 42 cとpの2点間の距離 < cの半径+pの半径の場合は重なってしまう 43 */ 44 45 if (dist(c.x, c.y, p.x, p.y) < (c.z + p.z)) { 46 overlapping = true; 47 break; 48 } 49 } 50 51 if (!overlapping) { 52 //配列の要素を追加 53 circles.add(c); 54 } 55 56 57 } 58 } 59 60 //マウスを押すと再描画 61 void mousePressed() { 62 redraw(); 63 }
###試してみたこと
参考サイトでFunctionsの欄にあるコードを試しに実行してみたのですが、関数だけなので、動かないようです。
参考サイト
例えば、参考サイトのFunction欄5つ目に紹介されている「GENERATE SYNTHETIC MICROSTRUCTURE」を実行すると
matlab
1%% GENERATE SYNTHETIC MICROSTRUCTURE 2% This code was modified so that the user can hard input the aspect 3//長すぎるため割愛
関数または変数 'image_ellipse' が未定義です。 エラー: trial12_30 (line 44) I_ellipse = image_ellipse(a0, b0, 0);
と表示されます。
###補足情報(言語/FW/ツール等のバージョンなど)
MatlabR2017b
Processing3.3
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。