Google ColabのJulia言語でマンデルブロ集合、仏様のようなブッダブロ、燃える船・バーニングシップフラクタルを描いてみる。どれも計算が速い。
今回はいろいろなフラクタル。以前、Pythonでやったものをそのまま移植しただけだが、とにかく速いし何も考えなくてもプロットできる。
まずはマンデルブロ集合。
#マンデルブロ集合
using Plots
function mandelcalc(img, Nx, Ny, xmin, xmax, ymin, ymax, max_iteration)
for i in 1:Nx
for j in 1:Ny
iteration = 0
c = x[i] + im * y[j]
z = 0.0 + 0.0im
while abs2(z) < 4 && iteration < max_iteration
z = z^2 + c
iteration += 1
end
img[j, i] = log(iteration)
end
end
end
Nx = 1200
Ny = 1200
xmax = 1.0
xmin = -2.5
ymax = 1.5
ymin = -1.5
max_iteration = 1000
img = zeros(Float64, Nx, Ny)
x = range(xmin, xmax, Nx)
y = range(ymin, ymax, Ny)
mandelcalc(img, Nx, Ny, xmin, xmax, ymin, ymax, max_iteration)
heatmap(x, y, img, fillcolor = cgrad(:hot), size=(800, 600))
|
次はブッダブロ。
#ブッダブロ
using Plots
using Random
function buddhacalc(img, Nx, Ny, xmin, xmax, ymin, ymax, max_repeat, max_iteration)
dx = (xmax - xmin) / Float64(Nx)
dy = (ymax - ymin) / Float64(Ny)
for n in 1:max_iteration
cx = rand() * (xmax - xmin) + xmin
cy = rand() * (ymax - ymin) + ymin
c = cx + im*cy
zpath = []
z = 0.0 + 0.0im
iteration = 0
while abs2(z)<4 && iteration < max_repeat
z = z^2 + c
push!(zpath, z)
iteration += 1
end
if iteration < max_repeat
for k in 1:length(zpath)
i = round(Int64, (real(zpath[k])-xmin)/dx)
j = round(Int64, (imag(zpath[k])-ymin)/dy)
if i <= Nx && i >= 1 && j <= Ny && j >= 1
img[Nx + 1 - i, j] += 1
end
end
end
end
end
Random.seed!(1)
Nx=1200
Ny=1200
max_iteration=10000000
max_repeat=1000
img = zeros(Int64, Nx, Ny)
xmax=2.0
xmin=-2.0
ymax=2.0
ymin=-2.0
x = range(xmin, xmax, Nx)
y = range(ymin, ymax, Ny)
buddhacalc(img, Nx, Ny, xmin, xmax, ymin, ymax, max_repeat, max_iteration)
heatmap(x, y, img, fillcolor = cgrad(:hot), size=(800, 600))
|
最後はバーニングシップフラクタル。
#バーニングシップフラクタル
using Plots
function burningship(img, Nx, Ny, xmin, xmax, ymin, ymax, max_iteration)
for i in 1:Nx
for j in 1:Ny
iteration = 0
c = x[i] + im * y[j]
z = 0 + 0im
while abs2(z) < 4 && iteration < max_iteration
z = (abs(real(z)) + im * abs(imag(z)))^2 + c
iteration += 1
end
img[Nx + 1 - j, i] = log(iteration)
end
end
end
Nx = 2000
Ny = 2000
max_iteration = 1000
xmax = -1.7
xmin = -1.8
ymax = 0.02
ymin = -0.1
img = zeros(Float64, Nx, Ny)
x = range(xmin, xmax, Nx)
y = range(ymin, ymax, Ny)
burningship(img, Nx, Ny, xmin, xmax, ymin, ymax, max_iteration)
heatmap(x, y, img, fillcolor = cgrad(:hot), size=(800, 600))
|
« 高周波・RFニュース 2025年4月3日 SEMCOが48V電源サーバー向けに100V MLCCを発表、AmphenolとSemtechが1.6T アクディブ銅ケーブル発表、 NordicがnPM2100 PMIC評価ボード、Lightmatterが256Tbpsを1パッケージのCPOで、Fractal Antenna Systemsが対ドローン指向性音響エネルギー | トップページ | Apple Intelligenceのビジュアルインテリジェンスにグランフロント大阪に来ている1/1ガンプラヘッドのガンダムとジークアクスについて聞いてみた。ガンダムは正解、ジークアクスはなぜかキャリバーン(水星の魔女)と答えた。謎だ… »
「パソコン・インターネット」カテゴリの記事
「学問・資格」カテゴリの記事
- 高周波・RFニュース 2025年12月13日 5G Americasが米国の5G普及率99%と発表、ZTEが800G Metro Transport Network (MTN) 標準化主導、NordicのnRF9151モジュールがSkylo認証取得、不完全なViaの電気特性解説、QualcommがRISC-VのVentana Micro Systems買収など(2025.12.13)
- 高周波・RFニュース 2025年12月12日 iFixitが水冷スマホRedMagic 11 Proを分解、Qorvoがロボット向けの技術を紹介、SamsungとKTが6Gに向けAI-RANを実証、NordicがnRF9151向けソフトと開発キット発表、Taoglasが6G向けアンテナ設計解説など(2025.12.12)
- 高周波・RFニュース 2025年12月11日 Qualcommが6Gに向けたOBBB法解説、GSMAが欧州のスペクトラム価格についての報告、Menlo Microが防衛向けに高スタンドオフ保護ミリ波スイッチ発表、京セラとローデ&シュワルツがCES2026でミリ波PAAMデモ、iFIxitのスマホアプリ(2025.12.11)
- 高周波・RFニュース 2025年12月10日 Sivers semiconductorとDigiKeyがパートナーシップ締結、u-bloxが車載Bluetothモジュール発表、TDKが車載パワーインダクタ発表、世界の6GHz Wi-Fi普及状況解説(2025.12.10)
「日記・コラム・つぶやき」カテゴリの記事
- 高周波・RFニュース 2025年12月13日 5G Americasが米国の5G普及率99%と発表、ZTEが800G Metro Transport Network (MTN) 標準化主導、NordicのnRF9151モジュールがSkylo認証取得、不完全なViaの電気特性解説、QualcommがRISC-VのVentana Micro Systems買収など(2025.12.13)
- 高周波・RFニュース 2025年12月12日 iFixitが水冷スマホRedMagic 11 Proを分解、Qorvoがロボット向けの技術を紹介、SamsungとKTが6Gに向けAI-RANを実証、NordicがnRF9151向けソフトと開発キット発表、Taoglasが6G向けアンテナ設計解説など(2025.12.12)
- 高周波・RFニュース 2025年12月11日 Qualcommが6Gに向けたOBBB法解説、GSMAが欧州のスペクトラム価格についての報告、Menlo Microが防衛向けに高スタンドオフ保護ミリ波スイッチ発表、京セラとローデ&シュワルツがCES2026でミリ波PAAMデモ、iFIxitのスマホアプリ(2025.12.11)
- Google ColabでAPIキーなしにAIモデル(Gemini 2.5 flashなど)が使えるようになっていた。早速電子レンジの動作原理について聞いてみる。正しく2.45GHzは水分子の共振周波数ではない、と答えられた。(2025.12.10)
- 高周波・RFニュース 2025年12月10日 Sivers semiconductorとDigiKeyがパートナーシップ締結、u-bloxが車載Bluetothモジュール発表、TDKが車載パワーインダクタ発表、世界の6GHz Wi-Fi普及状況解説(2025.12.10)
« 高周波・RFニュース 2025年4月3日 SEMCOが48V電源サーバー向けに100V MLCCを発表、AmphenolとSemtechが1.6T アクディブ銅ケーブル発表、 NordicがnPM2100 PMIC評価ボード、Lightmatterが256Tbpsを1パッケージのCPOで、Fractal Antenna Systemsが対ドローン指向性音響エネルギー | トップページ | Apple Intelligenceのビジュアルインテリジェンスにグランフロント大阪に来ている1/1ガンプラヘッドのガンダムとジークアクスについて聞いてみた。ガンダムは正解、ジークアクスはなぜかキャリバーン(水星の魔女)と答えた。謎だ… »








コメント