data:image/s3,"s3://crabby-images/1d829/1d829657e8509ae4d2f5c16e5c24deef399ff365" alt="見出し画像"
フォトギャラリー用画像#26
パスカルの三角形の二項係数を偶奇で塗り分けると現れる模様が、所謂”シェルピンスキーの ギャスケット”でした。
今回はパスカルの三角形を「2の倍数とそれ以外」、「4の倍数とそれ以外」、「8の倍数とそれ以外」、「16の倍数とそれ以外」といった規則で塗り分けた図です。
data:image/s3,"s3://crabby-images/851df/851df2b14a5b76db25171f437ed43d89c8826f77" alt=""
data:image/s3,"s3://crabby-images/78276/78276f78caecde6c3c9d9745be0830d7c9009650" alt=""
data:image/s3,"s3://crabby-images/72caf/72caf337f6290b18c9f1ac6a0e725d4ef279324f" alt=""
data:image/s3,"s3://crabby-images/3952b/3952bd1ebc3cfbdcd962a698acf88ac1679ae669" alt=""
data:image/s3,"s3://crabby-images/f26b4/f26b4e6762d559a27716dfa0d2efe9a2aaf1132d" alt=""
data:image/s3,"s3://crabby-images/62f93/62f93d71096027c1e9b024d5961f9e05b5e75f4d" alt=""
data:image/s3,"s3://crabby-images/3b6d4/3b6d4e4c087ef673bb8dd65e6f708c9b73a68b18" alt=""
data:image/s3,"s3://crabby-images/9e36f/9e36f7a3c2b12b9b73a67cf2d2dbe80afe34150c" alt=""
ソースコード
Google Collaboratoryの共有リンク
# -*- coding: utf-8 -*-
import matplotlib.pyplot as plt
import numpy as np
width = 1280; height = 670 # みんなのフォトギャラリー用にサイズを指定
im = np.ones((height, width))
# 二項係数をpで割った余りを計算
p = 4
h = 10 ; w = 10
mat = np.zeros((h,w))
mat[0][0]=1
for i in range (1,h):
mat[0][i] = 1
for j in range (1,i+1):
mat[j][i-j] = (mat[j-1][i-j]+mat[j][i-j-1] )%p
print(mat)
for k0 in range(8):
k = k0+1
# 二項係数をpで割った余りを計算
p = 2 ** k
n = height + width
mat = np.zeros((n,n))
mat[0][0]=1
for i in range (1,n-1):
mat[0][i] = 1
for j in range (1,i+1):
mat[j][i-j] = (mat[j-1][i-j]+mat[j][i-j-1])%p
# 余りが 0 の所は黒、それ以外は白を格納
for i in range (height):
for j in range (width):
im[i][j]= 0 if mat[i][j] == 0 else 255
#画像の表示と保存
plt.imshow(im, cmap='gray')
plt.axis('off')
plt.show()
plt.imsave('no+e_photo_gallery_026_'+str(k)+'.png', im, cmap='gray',dpi=1000 )