通过Python + Pygame实现频谱谐波图

pygame是跨平台python模块,专为电子游戏设计,包括图像、声音。建立在SDL基础上,允许实时电子游戏研发而无需被低级语言束缚, 开发者可以把精力放在游戏的架构上。

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 & frequenciesprint("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://shuyeidc.com/wp/209972.html<

(0)
管理的头像管理
上一篇2025-04-09 17:27
下一篇 2025-04-09 17:29

相关推荐

  • 骨干网络体系结构能干什么?骨干网络体系结构的作用

    骨干网络体系结构是现代信息社会的“超级高速公路网”,它通过分层设计、冗余备份和智能调度,确保海量数据在全球范围内高速、稳定、安全地传输,是支撑云计算、物联网及人工智能应用的底层基石,想象一下,如果你把互联网比作一个巨大的城市交通系统,那么骨干网络就是连接各个城市的主干道和立交桥,没有它,你的每一次微信发送、每一……

    2026-06-18
    0
  • 高io数据库可以干什么用?高io数据库适合什么场景

    高IO数据库的核心价值在于通过极高的读写吞吐量,解决海量数据场景下的性能瓶颈,是支撑高并发交易、实时分析及大规模内容分发的关键基础设施,在数字化转型的深水区,数据不再仅仅是静态的记录,而是流动的资产,传统的机械硬盘或普通SSD早已无法满足现代应用对速度的极致追求,高IO(Input/Output)数据库,就是那……

    2026-06-18
    0
  • 高io服务器性能如何?高io服务器适合什么场景

    高IO服务器并非单纯指代某种硬件,而是指在随机读写、高并发连接及小文件处理场景下,具备极致IOPS(每秒输入输出操作次数)和低延迟特性的计算资源,它是支撑现代高并发应用稳定运行的核心基石,在2026年的数字化浪潮中,业务负载早已从简单的静态页面展示演变为复杂的实时数据处理,许多开发者在排查系统瓶颈时,往往忽略了……

    2026-06-18
    0
  • 隔离网络空间哪里便宜?国内隔离网络空间价格

    隔离网络空间并没有统一的“便宜”标准,其成本高度取决于物理隔离等级、带宽需求及安全合规要求,通常物理网闸方案初期投入较高但长期运维成本低,而逻辑隔离方案虽初期便宜但存在潜在安全风险,建议根据业务敏感度选择混合隔离架构以平衡成本与安全,在数字化时代,企业构建独立网络环境的需求日益增长,但“隔离网络空间哪里便宜”这……

    2026-06-18
    0
  • 骨干网络体系结构设备为何故障?常见原因有哪些

    骨干网络体系结构设备故障的核心原因通常归结为硬件老化、配置错误、物理链路中断及外部攻击四大类,其中电源模块失效与光模块性能衰减是占比最高的隐性故障源,骨干网作为数字经济的“大动脉”,其稳定性直接关乎国计民生,当核心路由器或交换机出现丢包、震荡甚至宕机时,运维人员往往面临巨大的压力,很多人第一反应是检查软件配置……

    2026-06-18
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注