You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.
multirow/infinity/benchmark/scripts/render.sage

42 lines
1.3 KiB

import sys
import math
M=3
ZERO=1e-10
def angle_cmp(v):
return math.atan2(v[0], v[1])
for fname in sys.argv[1:]:
load(fname)
nrays = len(pi)
frat = f.apply_map(lambda x : x.nearby_rational(max_denominator=1000))
vertices = [(f+R[i]/pi[i]).apply_map(lambda x: x.nearby_rational(max_denominator=1000)) for i in range(nrays)]
poly = Polyhedron(vertices=vertices)
print "Writing %s.tex..." % fname
texfile = open("%s.tex" % fname, "w")
texfile.write("\\draw[fill,fill opacity=0.1] ")
for v in sorted(poly.vertices(), key=angle_cmp):
texfile.write("(%s, %s) -- " % (v[0], v[1]))
texfile.write("cycle;\n")
#texfile.write("\\draw (%s, %s) circle [radius=1.5pt];\n" % (frat[0], frat[1]))
for v in vertices:
texfile.write("\\draw[dashed] (%s,%s) -- (%s,%s);\n" % (frat[0], frat[1], v[0], v[1]))
texfile.close()
print "Writing %s.png..." % fname
p0 = sum([arrow(f, f + R[i] / pi[i], color='blue') for i in range(nrays)])
pf = list_plot([f], color='red', pointsize=30, zorder=-1)
p1 = poly.plot(color='blue', alpha=0.2)
p3 = list_plot(
[(x,y) for x in range(-M,M+1) for y in range(-M,M+1)],
color='black', figsize=20, pointsize=30, zorder=1)
output = "%s.png" % fname
save(p0+pf+p3+p1, output, xmin=-M, ymin=-M, xmax=M, ymax=M)