漂亮的頻譜諧波圖必備 Python + Pygame
這個Python + Pygame程式繪製了4條衰減正弦波的軌跡,每條軸2條,彩虹色。 它會生成一系列隨機諧波圖(harmonographs)。 |
harmonograph是通常在科學博物館中看到的機械裝置,它有兩個或多個帶有筆的擺錘,可以在一張紙上畫畫。 擺筆運動,筆在紙上畫出漂亮的圖案。 通過繪製一起作用在繪圖點上的正交正弦波,可以在計算機程式中輕鬆模擬這一點。 這會生成利薩如圖形(Lissajous-Figure),這些圖形會被衰減以形成令人愉悅的“平行”線巢狀,就像您在鈔票上看到的那樣。
它的速度很快,並且可以根據需要將其設定為更快(或更慢)。 提示:將顯示視窗設定為全屏。 MIT許可證; 從GitHub下載
#!/usr/bin/python ''' Spectral Harmonographs Copyright 2014 Alan Richmond (Tuxar.uk) ''' print("Quit: q key, Screenshot: spacebar") import pygame, sys, random as r from pygame.locals import * from math import pi, sin, cos, exp # EDIT THESE: width,height=1280,720 # YouTube HD width,height=1920,1080 # my left monitor width,height=1280,1024 # my right monitor width,height=1680,1050 # Lucy's monitor width,height=1200,800 #width,height=2560,1440 # YT channel art dd=0.99995 # decay factor dt=0.02 # time increment speed=200 # yes, speed hui=57*2 # Hue increment hue,sat,val,aaa=0,100,100,0 sd=0.005 # frequency spread (from integer) mx=4 # max range for amplitudes & frequencies print("Hit SPACE to save") def check_event(): global save for event in pygame.event.get(): if event.type == QUIT: sys.exit() elif event.type == KEYDOWN and event.key == K_q: sys.exit() elif event.type == KEYDOWN and event.key == K_SPACE: save=True print("Saving when finished...") def scale(length): while True: a1,a2=r.randint(-mx,mx),r.randint(-mx,mx) max=abs(a1)+abs(a2) if max>0: break return a1,a2,length/(2*max) steps=0 pygame.init() pygame.event.set_allowed([QUIT, KEYDOWN]) screen = pygame.display.set_mode((width,height),DOUBLEBUF) screen.set_alpha(None) #fg=pygame.Color(0,0,0,0) #fg=(0,0,0) fg=(255,255,255) save=False while True: # Amplitudes & scales ax1,ax2,xscale=scale(width) ay1,ay2,yscale=scale(height) fx1, fx2 = r.randint(1,mx) + r.gauss(0,sd), r.randint(1,mx) + r.gauss(0,sd) fy1, fy2 = r.randint(1,mx) + r.gauss(0,sd), r.randint(1,mx) + r.gauss(0,sd) px1, px2 = r.uniform(0,2*pi), r.uniform(0,2*pi) py1, py2 = r.uniform(0,2*pi), r.uniform(0,2*pi) print(ax1,ax2,ay1,ay2) print(fx1,fx2,fy1,fy2) print(px1,px2,py1,py2) dec=1.0 t=0.0 # angle for sin first=True while dec>0.015: # calculate next x,y point along line x = xscale * dec * (ax1*sin(t * fx1 + px1) + ax2*sin(t * fx2 + px2)) + width/2 y = yscale * dec * (ay1*sin(t * fy1 + py1) + ay2*sin(t * fy2 + py2)) + height/2 dec*=dd # decay if not first: # ignore any complaint about prev_x,y being undefined # fg.hsva=(hue,sat,val,aaa) # hue = (hue + dt*hui) % 360 # cycle hue pygame.draw.aaline(screen, fg, (x, y), (prev_x, prev_y), 1) else: first=False prev_x = x # save x,y for next line segment start prev_y = y if steps%speed==0: pygame.display.update() steps+=1 t+=dt # increment angle for sin check_event() if save: # parameters are encoded into filename pars='shg-{0}_{1}-{2}_{3}-{4}_{5}'.format(ax1,ax2,fx1,fx2,px1,px2) pygame.image.save(screen, pars+'.jpg') print("Saved as "+pars+'.jpg') save=False screen.fill((0,0,0)) # screen.fill((255,255,255))
例如在Ubuntu/Debian版的 Linux上,你可能需要安裝python和/或pygame:
sudo apt-get install pygame sudo apt-get install python
進入你儲存它的目錄,讓它可執行,然後執行它:
chmod +x harmonograph.py ./harmonograph.py
效果圖:
原文地址: https://www.linuxprobe.com/python-pygame.html
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2674029/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 頻率響度、靈敏度、總諧波失真(THD)和訊雜比(SNR)
- 前端切圖必備技能前端
- 用Flutter的Canvas來自己繪製柱狀頻譜圖FlutterCanvas
- Python 機器學習的必備技巧Python機器學習
- 從苦逼到牛逼!2019年最全最新Linux運維工程師必備技能圖譜……Linux運維工程師
- Python面試必備的7大問題Python面試
- Python操作Excel的36個必備函式PythonExcel函式
- python如何檢測pygame中的碰撞PythonGAM
- matlab求影像頻譜Matlab
- Ofcom 分享頻譜的未來思考
- 為手機筆電而生的諧波點膠機——歐力克斯
- Python為什麼成為了必備的技能?Python
- 【收藏】Python語言中必備的20個字串方法!Python字串
- 安卓音樂頻譜安卓
- 面向前端開發的python入門圖譜前端Python
- pygame 教學 匯入圖片GAM
- c#WinFrom自定義圖表儀表控制元件-頻譜C#控制元件
- 必備!iShot 1.7.6 中文版 (支援長截圖的截圖工具)
- python爬蟲進階必備之代理Python爬蟲
- python-docx處理Word必備工具Python
- python-pygame學習筆記PythonGAM筆記
- Making Games with Python & Pygame 中文翻譯GAMPython
- 學習Python必須具備的五大技能!Python
- 雲原生時代,分散式系統設計必備知識圖譜(內含22個知識點)分散式
- 知識圖譜01:知識圖譜的定義
- 知識圖譜|知識圖譜的典型應用
- 頻率域濾波基本操作
- 前端必備 PS三種切圖方法 Cutterman最好用的切圖工具前端
- GSMA:2022年亞太地區5G頻譜路線圖
- 程式設計師必備畫圖技能之——時序圖程式設計師時序圖
- Java程式設計師必備的一些流程圖Java程式設計師流程圖
- 教程 | 用AI生成貓的圖片,擼貓人士必備AI
- pygame 教學 2 —— 匯入圖片GAM
- 在Vue中使用WebSocket+HighCharts+Canvas實現高效能的頻譜瀑布圖VueWebCanvas
- Python入門必備知識點總結Python
- Python 基礎(一):入門必備知識Python
- Python 必備面試基礎知識-3Python面試
- Python 面試必備基礎知識-1Python面試