Skip to content

Latest commit

 

History

History
52 lines (36 loc) · 6.49 KB

README.md

File metadata and controls

52 lines (36 loc) · 6.49 KB

Project: Knapsack problem solved with Gate-based Game-like VQE and Annealing-based DQM.

Team: Hybrid Demons (Advanced Hybrid Division) Ziwei Qiu, Ilan Mitnikov, Yusheng Zhao, Nakul Aggarwal , Victor Onofre

To represent the effect of any decision by numerical values, the outcome of the decision can be measured by a single value representing gain, profit, loss, cost, or another data category. The comparison of these values gives a total order on the set of all options for a decision. Finding the option with the highest or lowest value can be difficult because the set of available options may be extensive or not explicitly known. The knapsack problem is one of this decision process.

The knapsack problem can be formally defined as follows: We are given an item set N, consisting of n items j with profit Pj and weight Wj, and the capacity value c. The objective is to select a subset of N such that the total profit of the selected items is maximized and the total weight does not exceed c. (see more details here: https://en.wikipedia.org/wiki/Knapsack_problem)

In this project, we work on solving the Knapsack problem with both gate-based game running on IonQ hardware and annealing-based DQM/BQM methods running on D-Wave hardware, and to compare between the two methods. We further show using the DQM solver to implement the bounded Knapsack problem.

Annealing: Implement the bounded Knapsack problem with the DQM solver

We demonstrated solving the Bounded Knapsack Problem with the D-wave Ocean Discrete Quadratic Model (DQM) solver, where we are allowed to take multiple pieces for each item so the variable can take discrete values 0,1,2,... up to b. This extended Knapsack problem has a direct application in stock portofolio optimization where we show a proof-of-concept demonstration in the notebook 'Knapsack_DQM.ipynb'.

Knapsack problems appear in many real-world decision-making processes, including home energy management, cognitive radio networks, resource management in software, power allocation management, relay selection in secure cooperative wireless communication, etc.

Future works on this project include:

  1. Study in more detail and quantitatively the actual quantum advantage of solving this NP-hard problem on large dataset over classical methods by running on real quantum computers.
  2. Implement different variants of the Knapsack problem, e.g. by adding more constraints, adding m knapsacks with different capacities or optimizing the Unbounded Knapsack Problem where an unlimited amount of each item is available.
  3. Use Knapsack problem as a subroutine and combine it with other NP-hard problems to solve complicated tasks challenging to classical computers.
  4. In the stock selection application, we can better quantify the profits instead of just using earnings as the metric, and have more realistic assumptions.

Annealing: Implement the Balanced Assignment Problem as BQM and Unbalanced Assignment Problem as DQM

We first started with the idea of the balanced assignment problem which has paramount importance in operations research and industries. We solved it using D-wave Ocean Binary Quadratic Model (BQM) solver where we allot n agents to n tasks such that each agent is alloted to one task and vice-versa. The central objeective is to maximize the efficiency of this model where each agent has a certain efficiency to solve every given task (implemented randomly as a 2-D matrix). We compare our performance with the classical 'Hungarian Algorithm' by comparing the Hamming Distances between the two as a function of the Lagrange multiplier used in annealing based problems. We try to calculate an optimal number of steps if the Hamming distance becomes zero.

We then begin with the unbalanced assignment problem where the size of the number of agents A is not equal to number of tasks T. Here, we take the case where A<T. In addition, each task has to be completed a certain number of times which is chosen randoml. Thus, we have a 1-D task array of length T which has the values as to how many times that specific task has to be completed. This is an equality constraint. Thus each agent can either do a certain number of tasks modelled as the discrete variables in DQM. There is also an upper bound 𝑈 on the number of tasks that each agent can do. We validate against the fulfillment of the constraints in our solution.

Future works on this project include:

  1. More detailed survey of the constraints that can be implemented in the DQM framework. Try to look for simulated annealing based solutions as well and compare the performances of the two.
  2. We can model the preferences of the agents as to how many tasks they want to perform and allot a schedule comfortable to everyone's needs.
  3. This model can work as a sub-module in nurse-scheduling with complicated constraints and far more steps.

Gate-based VQE Game

Here we designed a game with the goal of finding the solution of the knapsack problem. As we know, different optimization problems could be solved by optimizing a VQE like ansazt circuit. Usually the optimization of the circuit parameters is done by a classical optimization routine. However, in our game the user can take the optimization part into their own hands.
The solution using the annealing machine is used to evaluate how far the user is from the goal - the minimum energy point.

Game outline:

  • The user starts from a random point in the parameter space (the parameters describe the ansatz circuit)
  • Then, because we are trying to optimize a high-dimensional problem, we cannot easily visualize the entire landscape of the cost. Even if we can, it will take up huge amount of resources to try and compute a high-dimensional grid around the starting point to see the landscape of the cost around it.
  • To overcome that, we show the player multiple 3D views of the surrounding cost of different pairs of parameters they choose.
  • Then the challenge is, given the view of different projection of the local cost choose a step in the direction that minimizes the total cost.
  • This is basically a multidimensional navigation puzzle!!!
  • The user wins if they arrive within a distance from the minimal target point.
  • The user will be punished if he goes to a point in the parameter space with lower cost to the place with a higher cost
  • This game is inspired by the masochistic game "Getting Over It with Bennett Foddy". Hopefully, by blindly and hopelessly traversing through the high-dimensional parameter space with the help of few projections, the player will understand why a VQE is in general a hard task to accomplish.