Skip to content

Commit

Permalink
add repr of QNS, add TODOs, add broken job iteration test
Browse files Browse the repository at this point in the history
  • Loading branch information
ModischFabrications committed Apr 11, 2024
1 parent e7b6aa1 commit b6c6f0e
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 4 deletions.
13 changes: 10 additions & 3 deletions app/solver/data/Job.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,11 @@ class QNS(NS):
def __str__(self):
return f"{self.name}: l={self.length}, n={self.quantity}"

def __repr__(self):
if self.name:
return f"QNS(length={self.length}, name={self.name}, quantity={self.quantity})"
return f"QNS(length={self.length}, quantity={self.quantity})"

def as_base(self) -> NS:
return NS(length=self.length, name=self.name)

Expand All @@ -52,7 +57,7 @@ class INS(NS):
"""
"(infinite) quantity + named size", adds optional quantity (can be infinite)
"""
quantity: Optional[int] = -1 # more or less equal to infinite
quantity: Optional[PositiveInt] = None # more or less equal to infinite

def as_base(self) -> NS:
return NS(length=self.length, name=self.name)
Expand Down Expand Up @@ -91,13 +96,15 @@ def iterate_stocks(self) -> Iterator[NS]:

# if this overflows your solution is probably shit
# TODO this could be limited even further, see iterations of test_big_small
iterations = target.quantity if target.quantity != -1 else math.ceil(
# TODO also too small, see test_infinite_count
iterations = target.quantity if target.quantity else math.ceil(
self.sum_of_required() / target.length)
for _ in range(iterations):
yield target.as_base()

def sum_of_required(self):
return sum([target.length * target.quantity for target in self.required])
# TODO won't account for everything! easy to trick
return sum([(target.length + self.cut_width) * target.quantity for target in self.required])

def n_targets(self) -> int:
"""
Expand Down
12 changes: 11 additions & 1 deletion tests/solver/data/test_Job.py
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,17 @@ def test_solver_skip_too_short():
job = Job(stocks=(INS(length=100, quantity=10), INS(length=1000)), cut_width=10,
required=(QNS(length=500, quantity=2), QNS(length=1000, quantity=2)))

assert list(job.iterate_stocks()) == [NS(length=1000), NS(length=1000), NS(length=1000)]
assert list(job.iterate_stocks()) == [NS(length=1000)] * 4


def test_infinite_count():
job = Job(
stocks=(INS(length=100),),
cut_width=1,
required=(QNS(length=50, quantity=6),)
)

assert list(job.iterate_stocks()) == [NS(length=100)] * 6


def test_to_json():
Expand Down

0 comments on commit b6c6f0e

Please sign in to comment.