#!/usr/bin/env python3
-
pc = [(4, 2), (4, 2), (4, 2)]
rc = [(9, 7), (12, 6), (10, 7), (18, 5), (20, 4), (10, 6), (8, 6), (10, 8)]
mx = 29
print("(c{:02d}h Int)".format(i))
print(")")
-# Preamble2
print(":formula")
print("(and")
for i, (w, h) in enumerate(pc+rc, 1):
# Print the width and height
print((
- '\t(or '
+ '(or '
'(and (= c{0:02d}w {1}) (= c{0:02d}h {2})) '
- '(and (= c{0:02d}w {2}) (= c{0:02d}h {1}))'
- ')').format(i, w-1, h-1))
+ '(and (= c{0:02d}w {2}) (= c{0:02d}h {1})))').format(i, w-1, h-1))
- # Print the bounds of the coordinates
+ # Print the bounds of the coordinates
print((
- '\t(> c{0:02d}x 0) (> c{0:02d}y 0)\n'
- '\t(<= (+ c{0:02d}x c{0:02d}w) {1}) (<= (+ c{0:02d}y c{0:02d}h) {2})\n'
- ).format(i, mx, my))
+ '(> c{0:02d}x 0) (> c{0:02d}y 0)'
+ '(<= (+ c{0:02d}x c{0:02d}w) {1}) (<= (+ c{0:02d}y c{0:02d}h) {2})'
+ ).format(i, mx, my))
- # Print the non overlap with others
+ # Print the non overlap with others
for j in range(1, 1+len(pc+rc)):
if i != j:
print((
- '\t(or \n'
- '\t\t(> c{0:02d}x (+ c{1:02d}x c{1:02d}w)) '
- '(< (+ c{0:02d}x c{0:02d}w) c{1:02d}x)\n'
- '\t\t(> c{0:02d}y (+ c{1:02d}y c{1:02d}h)) '
- '(< (+ c{0:02d}y c{0:02d}h) c{1:02d}y)'
- ')').format(i, j))
+ '(or '
+ '(> c{0:02d}x (+ c{1:02d}x c{1:02d}w)) (< (+ c{0:02d}x c{0:02d}w) c{1:02d}x) '
+ '(> c{0:02d}y (+ c{1:02d}y c{1:02d}h)) (< (+ c{0:02d}y c{0:02d}h) c{1:02d}y)'
+ ')').format(i, j))
-# Print the PC distance to eachother
+ # Print the PC distance to eachother
for i, _ in enumerate(pc, 1):
for j, _ in enumerate(pc, 1):
if i != j:
print((
- '\t(or \n'
- '\t\t(> \n'
- '\t\t\t(- \n'
- '\t\t\t\t(+ \n'
- '\t\t\t\t\tc{0:02d}x \n'
- '\t\t\t\t\t(/ c{0:02d}w 2) \n'
- '\t\t\t\t) \n'
- '\t\t\t\t(+ \n'
- '\t\t\t\t\tc{1:02d}x \n'
- '\t\t\t\t\t(/ c{1:02d}w 2) \n'
- '\t\t\t\t) \n'
- '\t\t\t) \n'
- '\t\t\t{2} \n'
- '\t\t)\n'
- '\t\t(> (- (+ c{1:02d}x (/ c{1:02d}w 2)) '
- '(+ c{0:02d}x (/ c{0:02d}w 2))) {2})\n'
- '\t\t(> (- (+ c{0:02d}y (/ c{0:02d}h 2)) '
- '(+ c{1:02d}y (/ c{1:02d}h 2))) {2})\n'
- '\t\t(> (- (+ c{1:02d}y (/ c{1:02d}h 2)) '
- '(+ c{0:02d}y (/ c{0:02d}h 2))) {2})'
+ '(or '
+ '(> (- (+ c{0:02d}x (/ c{0:02d}w 2) ) (+ c{1:02d}x (/ c{1:02d}w 2) ) ) {2} ) '
+ '(> (- (+ c{1:02d}x (/ c{1:02d}w 2)) (+ c{0:02d}x (/ c{0:02d}w 2))) {2}) '
+ '(> (- (+ c{0:02d}y (/ c{0:02d}h 2)) (+ c{1:02d}y (/ c{1:02d}h 2))) {2}) '
+ '(> (- (+ c{1:02d}y (/ c{1:02d}h 2)) (+ c{0:02d}y (/ c{0:02d}h 2))) {2})'
')').format(i, j, pd))
-# Print the constraint that they have to be connected to a ps
+ # Print the constraint that they have to be connected to a ps
for i, _ in enumerate(rc, 1+len(pc)):
- print('\t(or')
+ print('(or')
for j, _ in enumerate(pc, 1):
print((
- '\t(not (or \n'
- '\t\t(> c{0:02d}x (+ c{1:02d}x 1 c{1:02d}w)) '
- '(< (+ c{0:02d}x c{0:02d}w) (- c{1:02d}x 1))\n'
- '\t\t(> c{0:02d}y (+ c{1:02d}y 1 c{1:02d}h)) '
- '(< (+ c{0:02d}y c{0:02d}h) (- c{1:02d}y 1))'
+ '(not (or '
+ '(> c{0:02d}x (+ c{1:02d}x 1 c{1:02d}w)) (< (+ c{0:02d}x c{0:02d}w) (- c{1:02d}x 1)) '
+ '(> c{0:02d}y (+ c{1:02d}y 1 c{1:02d}h)) (< (+ c{0:02d}y c{0:02d}h) (- c{1:02d}y 1))'
'))').format(i, j))
- print('\t)')
+ print(')')
# Close the and,benchmark parenthesis
print("))")