Maikou's picture
all files first commit
9c3a994
raw
history blame
1.29 kB
import numpy as np
import matplotlib.pyplot as plt
# Helper functions
def get_colors(inp, colormap="viridis", normalize=True, vmin=None, vmax=None):
colormap = plt.cm.get_cmap(colormap)
if normalize:
vmin = np.min(inp)
vmax = np.max(inp)
norm = plt.Normalize(vmin, vmax)
return colormap(norm(inp))[:, :3]
def gen_checkers(n_checkers_x, n_checkers_y, width=256, height=256):
# tex dims need to be power of two.
array = np.ones((width, height, 3), dtype='float32')
# width in texels of each checker
checker_w = width / n_checkers_x
checker_h = height / n_checkers_y
for y in range(height):
for x in range(width):
color_key = int(x / checker_w) + int(y / checker_h)
if color_key % 2 == 0:
array[x, y, :] = [1., 0.874, 0.0]
else:
array[x, y, :] = [0., 0., 0.]
return array
def gen_circle(width=256, height=256):
xx, yy = np.mgrid[:width, :height]
circle = (xx - width / 2 + 0.5) ** 2 + (yy - height / 2 + 0.5) ** 2
array = np.ones((width, height, 4), dtype='float32')
array[:, :, 0] = (circle <= width)
array[:, :, 1] = (circle <= width)
array[:, :, 2] = (circle <= width)
array[:, :, 3] = circle <= width
return array