PySimpleGUI/DemoPrograms/Demo_Graph_FourierTransform.py

72 lines
2.0 KiB
Python

import math
import numpy as np
import PySimpleGUI as sg
import time
"""
Fourier Transform Animated Graph
A fun demonstration of the Graph Element and the drawing primitive draw_lines
Written by Jason Yang, by an innovative PySimpleGUI user that has created a number
of impressive animations using PySimpleGUI.
Copyright 2020 Jason Yang
"""
def push(v):
if len(buffer)==size:
del buffer[-1]
buffer[0:0] = [v]
def update(i):
draw.Erase()
x1 = x0 + r1*math.cos(v1*i*rad)
y1 = y0 + r1*math.sin(v1*i*rad)
x2 = x1 + r2*math.cos(v2*i*rad)
y2 = y1 + r2*math.sin(v2*i*rad)
x3 = x2 + r3*math.cos(v3*i*rad)
y3 = y2 + r3*math.sin(v3*i*rad)
push(y3)
draw.DrawCircle((x0, y0), r1, line_color='blue')
draw.DrawCircle((x1, y1), r2, line_color='yellow')
draw.DrawCircle((x2, y2), r3, line_color='red')
draw.DrawLine((x0, y0), (x1, y1), color='magenta')
draw.DrawLine((x1, y1), (x2, y2), color='white')
draw.DrawLine((x2, y2), (x3, y3), color='white')
draw.DrawLine((x3, y3), (x[0]+xx, buffer[0]), color='ivory')
draw.DrawPoint((x3, y3), size=10, color='red')
lines = ((x[i]+xx, y) for i, y in enumerate(buffer))
draw.DrawLines(lines, color='green1')
size = 720
distance = 100
r0, r1, r2, r3 = 90, 90, 30, 18
rad = math.pi/180
v1, v2, v3 = 1, 3, 5
x = np.array(list(range(size)))
x0 = y0 = r1+r2+r3
xx = x0*2 + distance
buffer = []
win_size = (xx+size, 2*x0)
layout = [[sg.Graph(canvas_size=win_size, graph_bottom_left=(0, 0),
graph_top_right=win_size, key='-GRAPH-')]]
window = sg.Window('Fourier', layout=layout, finalize=True)
draw = window['-GRAPH-']
i = 0
timeout = refresh_interval = 10 # Target refresh interval = 10 milliseconds
while True:
start_time = time.time()
event, values = window.read(timeout=timeout)
if event == None:
break
update(i)
i = i+1 if i<359 else 0
timeout = max(0, (refresh_interval - (time.time()-start_time)*1000))
window.close()