Example #1
0
from maxrect_pack.maxrect import MaxRect
from maxrect_pack.recthelper import random_rects


WIDTH = 20
HEIGHT = 20

if __name__ == '__main__':
    m = MaxRect(WIDTH, HEIGHT)

    rects_cut = random_rects(WIDTH, HEIGHT, 4, 4, 2)
    for r in rects_cut:
        m.cut_off(r)

    print("{} free rects".format(len(m.free_rects)))
    m.plot()
Example #2
0
from maxrect_pack import rect
from maxrect_pack.maxrect import MaxRect
from maxrect_pack.rect import COOR
from maxrect_pack.rect_chosers import simple_smallest_x_fit
from maxrect_pack.recthelper import random_rects

WIDTH = 20
HEIGHT = 20

if __name__ == '__main__':
    m = MaxRect(WIDTH, HEIGHT)

    rects_cut = random_rects(WIDTH, HEIGHT, 4, 4, 30)

    for r in rects_cut:
        container_rect = simple_smallest_x_fit(r, m.free_rects)
        r = rect.set_position(r, container_rect[COOR][0][0],
                              container_rect[COOR][1][0])
        m.cut_off(r)

    m.plot()
from maxrect_pack.maxrect_solver import MaxRectSolver
from maxrect_pack.orienter import Orienter
from maxrect_pack.recthelper import random_rects
from maxrect_pack.scorer import scorerBSSF


WIDTH = 1000
HEIGHT = 1000

if __name__ == '__main__':
    rects_to_place = random_rects(WIDTH, HEIGHT, 200, 200, 100)
    solver = MaxRectSolver(WIDTH, HEIGHT)
    solver.solve(Orienter.orient_all(rects_to_place), scorerBSSF, priority_pick=80)
    solver.plot()