目次
ジュリア集合とは?
ジュリア集合は、複素平面上の特定の点の集合であり、フラクタルの一種です。フラクタルとは、どんなに拡大しても同じようなパターンが現れる図形のことです。
ジュリア集合の生成
ジュリア集合は、特定の複素数 cを用いて次の反復操作を行うことによって生成されます。
- 初期値として複素数z0を選びます。
- 次の式を反復的に適用する。この漸化式はマンデルブロ集合と同じです。
data:image/s3,"s3://crabby-images/ac283/ac28326abc32e318449b9dff0958bdcb9d39d0df" alt=""
- 反復操作を無限に続けたときに、znが発散(無限大に近づく)かどうかを調べます。発散するならその点はジュリア集合に含まれません。発散しないなら、その点はジュリア集合に含まれます。
- この反復操作をすべての初期値z0に対して行い、結果として得られる集合がジュリア集合となります。(マンデルブロ集合は、初期値をz0=0と固定し、複素数cを変動させますが、ジュリア集合はその逆で、複素数cを固定し、初期値z0を動かします。そのため、ジュリア集合はcによって形が変わるという点が魅力的です。)
ジュリア集合の特徴
- 複雑な形状:ジュリア集合は非常に複雑な形状を持ちます。拡大しても同じようなパターンが現れる自己相似性が特徴的。
- パラメータ c:複素数 cの値によってジュリア集合の形状は大きく変わります。特定の cの値では、ジュリア集合が連結な形状を持つ場合もあれば、離散的な形状になる場合もあります。
ジュリア集合の例
data:image/s3,"s3://crabby-images/f4760/f47606124525aa394087722afb773c84c1e28cc3" alt=""
data:image/s3,"s3://crabby-images/60d63/60d630ab70726204a3d4d9631dd5c62eb19a6a58" alt=""
data:image/s3,"s3://crabby-images/71333/7133397d8a5cc76f8e4438fb66020829556edf99" alt=""
data:image/s3,"s3://crabby-images/02570/02570d32b84e6c90c05fb7d252fbbf5ee41c692a" alt=""
data:image/s3,"s3://crabby-images/b4395/b4395583f24f4f2c6b129b05f6eb99a4e3a76a94" alt=""
data:image/s3,"s3://crabby-images/c9bb1/c9bb1d18d6cfb37861d7d9d5c7b15bbc6549e5e4" alt=""
data:image/s3,"s3://crabby-images/5929c/5929cb2c23daf092d89c5129b965b83f39cc4e3f" alt=""
data:image/s3,"s3://crabby-images/e66e9/e66e9be892674dbeec166f44fb723ba754b9708d" alt=""
data:image/s3,"s3://crabby-images/9f166/9f166f7510d2bc6b492e3164b2e52af3f0a7d330" alt=""
このように、ジュリア集合は非常に美しいパターンを持つため、芸術作品としても楽しまれています。
参考コード(Python)
import numpy as np
import matplotlib.pyplot as plt
def julia_set(c, width, height, x_min, x_max, y_min, y_max, max_iter):
x = np.linspace(x_min, x_max, width)
y = np.linspace(y_min, y_max, height)
X, Y = np.meshgrid(x, y)
Z = X + 1j * Y
iterations = np.zeros(Z.shape, dtype=int)
for i in range(max_iter):
mask = np.abs(Z) < 2
iterations[mask] = i
Z[mask] = Z[mask] ** 2 + c
return iterations
def plot_julia_set(julia, x_min, x_max, y_min, y_max):
plt.imshow(julia, extent=(x_min, x_max, y_min, y_max), cmap='hot')
plt.colorbar()
plt.title('Julia Set')
plt.xlabel('Re')
plt.ylabel('Im')
plt.show()
if __name__ == "__main__":
c = complex(0.4, 0.4) # The complex parameter for the Julia set
width, height = 800, 800 # Resolution of the image
x_min, x_max = -1.5, 1.5 # x-axis range
y_min, y_max = -1.5, 1.5 # y-axis range
max_iter = 300 # Maximum number of iterations
julia = julia_set(c, width, height, x_min, x_max, y_min, y_max, max_iter)
plot_julia_set(julia, x_min, x_max, y_min, y_max)
複素数cのパラメータを入れ替えると、図形が変化します。