combinatorics with itertools

main
villares 2019-05-19 22:32:39 -03:00
rodzic 7960387759
commit d85ad6a03a
2 zmienionych plików z 50 dodań i 1 usunięć

Wyświetl plik

@ -20,7 +20,7 @@ def setup():
x, y, w = 0, 0, (width - 20) / 10
textSize(10)
i = 0
while (combinations.hasMore()):
while combinations.hasMore():
combination = combinations.next()
txt = ""
for n in combination:

Wyświetl plik

@ -0,0 +1,49 @@
from itertools import product, combinations, permutations, combinations_with_replacement
space = 30
def setup():
global line_combos, W, H, position
size(600, 600)
frameRate(5)
rectMode(CENTER)
strokeWeight(2)
grid = list(product(range(-1, 2), repeat=2))
lines = list(combinations(grid, 2))
short_lines = []
for l in lines:
(x0, y0), (x1, y1) = l[0], l[1]
if dist(x0, y0, x1, y1) <= sqrt(2):
short_lines.append(l)
print(len(short_lines))
line_combos = list(combinations(short_lines, 4))
print len(line_combos)
W, H = (width - space) / space, (height - space) / space
position = 0
print(W, H)
def draw():
global position
colorMode(RGB)
background(0)
i = position
for y in range(H):
for x in range(W):
if i < len(line_combos):
pushMatrix()
translate(space + space * x, space + space * y)
draw_combo(i)
popMatrix()
i += 1
if i < len(line_combos):
position += W
def draw_combo(i):
colorMode(RGB)
siz = space / 4
for i, sl in enumerate(line_combos[i]):
colorMode(HSB)
stroke(i * 32, 200, 200)
(x0, y0), (x1, y1) = sl[0], sl[1]
line(x0 * siz, y0 * siz, x1 * siz, y1 * siz)