2
0
mirror of https://github.com/m-labs/artiq.git synced 2025-01-08 01:53:34 +08:00
artiq/examples/mandelbrot.py

48 lines
1.1 KiB
Python
Raw Normal View History

2014-09-16 23:12:03 +08:00
import sys
2014-09-30 17:38:02 +08:00
from artiq import *
2014-10-19 23:51:49 +08:00
from artiq.coredevice import comm_serial, core
2014-09-16 23:12:03 +08:00
2014-09-30 17:38:02 +08:00
2014-09-16 23:12:03 +08:00
class Mandelbrot(AutoContext):
def col(self, i):
sys.stdout.write(" .,-:;i+hHM$*#@ "[i])
def row(self):
print("")
# based on: http://warp.povusers.org/MandScripts/python.html
@kernel
def run(self):
minX = -2.0
maxX = 1.0
width = 78
height = 36
aspectRatio = 2
yScale = (maxX-minX)*(height/width)*aspectRatio
for y in range(height):
for x in range(width):
c_r = minX+x*(maxX-minX)/width
c_i = y*yScale/height-yScale/2
z_r = c_r
z_i = c_i
for i in range(16):
if z_r*z_r + z_i*z_i > 4:
break
new_z_r = (z_r*z_r)-(z_i*z_i) + c_r
z_i = 2*z_r*z_i + c_i
z_r = new_z_r
self.col(i)
self.row()
2014-09-30 17:38:02 +08:00
2014-10-05 16:24:21 +08:00
def main():
2014-10-19 23:51:49 +08:00
with comm_serial.Comm() as comm:
exp = Mandelbrot(core=core.Core(comm))
2014-09-16 23:12:03 +08:00
exp.run()
2014-10-05 16:24:21 +08:00
if __name__ == "__main__":
main()