用Python代碼來繪制彭羅斯點(diǎn)陣的教程
這里是顯示彭羅斯點(diǎn)陣的Python的腳本。是的,這是可以運(yùn)行的有效Phython代碼。
譯注:彭羅斯點(diǎn)陣,物理學(xué)術(shù)語。上世紀(jì)70年代英國數(shù)學(xué)家彭羅斯第一次提出了這個概念,稱為彭羅斯點(diǎn)陣(Pen-rose tiles)。
_ =\
"""if!
1:"e,V=100
0,(0j-1)**-.2;
v,S=.5/ V.real,
[(0,0,4 *e,4*e*
V)];w=1 -v"def!
E(T,A, B,C):P
,Q,R=B*w+ A*v,B*w+C
*v,A*w+B*v;retur n[(1,Q,C,A),(1,P
,Q,B),(0,Q,P,A)]*T+[(0,C ,R,B),(1,R,C,A)]*(1-T)"f
or!i!in!_[:11]:S =sum([E (*x)for !x!in!S],[])"imp
ort!cair o!as!O; s=O.Ima geSurfac
e(1,e,e) ;c=O.Con text(s); M,L,G=c.
move_to ,c.line_to,c.s et_sour
ce_rgb a"def!z(f,a) :f(-a.
imag,a. real-e-e)"for!T,A,B,C!in[i !for!i!
in!S!if!i[""";exec(reduce(lambda x,i:x.replace(chr
(i),"\n "[34-i:]), range( 35),_+"""0]]:z(M,A
);z(L,B);z (L,C); c.close_pa
th()"G (.4,.3 ,1);c.
paint( );G(.7 ,.7,1)
;c.fil l()"fo r!i!in
!range (9):"! g=1-i/
8;d=i/ 4*g;G(d,d,d, 1-g*.8
)"!def !y(f,a):z(f,a+(1+2j)*( 1j**(i
/2.))*g)"!for!T,A,B,C!in!S:y(M,C);y(L,A);y(M
,A);y(L,B)"!c.st roke()"s.write_t
o_png('pen rose.png')
""" ))
當(dāng)這個程序運(yùn)行時,它輸出了一個1000×1000的圖像文件,包含大約2212個由3D立體效應(yīng)渲染的彭羅斯點(diǎn)陣。這里是該圖像的一部分(點(diǎn)擊放大)。

運(yùn)行該腳本需要Pycairo。它只在Python它是標(biāo)準(zhǔn)的Python腳本,但我努力想把它變得更簡潔,于是我又從中刪減了一些。
編注:Pycairo是一組Python版本的Cario圖形庫。
彭羅斯點(diǎn)陣很酷,因?yàn)樗鼈兎侵芷谛缘馗采w了整個平面——圖片的轉(zhuǎn)換副本與原型從來不會一致。它們是由Roger Penrose先生通過將五邊形的平面平鋪在一起的一系列嘗試而發(fā)明的。
與C或Perl相比,Python并不是讓人迷惑的編程語言。這種比較似乎也從未發(fā)生,而且在網(wǎng)上也沒有多少讓人費(fèi)解的Python的例子:你可以在官方的Python常見問題中或各種網(wǎng)頁如這里和這里找到一些例子。在2011年的PyCon對此還有專題討論。
我相信輸出一個高分辨率的圖像是第一個讓人費(fèi)解的Python程序。如果你知道其它的例子,可以在評論中告訴我。
相關(guān)文章
Django中使用Celery執(zhí)行定時任務(wù)問題
這篇文章主要介紹了Django中使用Celery執(zhí)行定時任務(wù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
react+django清除瀏覽器緩存的幾種方法小結(jié)
今天小編就為大家分享一篇react+django清除瀏覽器緩存的幾種方法小結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
Python 通過requests實(shí)現(xiàn)騰訊新聞抓取爬蟲的方法
今天小編就為大家分享一篇Python 通過requests實(shí)現(xiàn)騰訊新聞抓取爬蟲的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-02-02
Python中關(guān)鍵字is與==的區(qū)別簡述
這篇文章主要介紹了Python中關(guān)鍵字is與==的區(qū)別,對于Python初學(xué)者有一定的借鑒學(xué)習(xí)價值,需要的朋友可以參考下2014-07-07
基于Python開發(fā)圖像數(shù)據(jù)清洗&圖像質(zhì)量檢查工具
隨著目前采集的數(shù)據(jù)集中的圖像越來越多,出現(xiàn)了數(shù)據(jù)格式十分雜亂、質(zhì)量不統(tǒng)一等問題,下面小編就來用Python制作一個圖像數(shù)據(jù)清洗&圖像質(zhì)量檢查工具吧2025-03-03
Anaconda下Python中h5py與netCDF4模塊下載與安裝的教程詳解
這篇文章主要為大家詳細(xì)介紹了基于Anaconda,下載并安裝Python中h5py與netCDF4這兩個模塊的方法,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01

