Your task is to implement the Unbounded Knapsack algorithm (also known as the Complete Knapsack problem) and verify its correctness in Dafny. You are given a sequence of weights and a sequence of values for n items, and a maximum weight capacity W. The goal is to determine the maximum total value of items that can be included in the knapsack such that the total weight does not exceed W. Unlike 0/1 Knapsack, each item can be selected multiple times (unlimited supply). In the incomplete code, the specification defines what constitutes a valid selection strategy (a sequence of non-negative integers indicating the count of each item chosen) and how to calculate the total weight and value. Your task is to implement the algorithm and verify that it returns the optimal value. Specifically, you must prove: (1) Upper Bound: Any valid selection yields a total value less than or equal to the returned result. (2) Existence: There exists a valid selection whose total value is exactly equal to the returned result. Note that because Dafny integers are signed, explicit preconditions are added to ensure weights (specifically strictly positive to prevent infinite inclusion), values, and capacity are non-negative.