The Munkres module provides an O(n³) implementation of the Munkres algorithm (also called the Hungarian algorithm or the Kuhn-Munkres algorithm). The algorithm models an assignment problem as an N×M cost matrix, where each element represents the cost of assigning the ith worker to the jth job, and it figures out the least-cost solution, choosing a single item from each row and column in the matrix, such that no row and no column are used more than once.
The example uses the fetch API to load json, so we must serve our html through a web server.
The package.json can be used to install http-server
for this purpose:
npm install
npm run start-server
Navigate to http://localhost:8080/index.html
var munkres = require('munkres-js');
munkres([
[400, 150, 400],
[400, 450, 600],
[300, 225, 300]
])
// => [ [ 0, 1 ], [ 1, 0 ], [ 2, 2 ] ]
Returns the list of matrix indices corresponding to the optimal assignment.
When used in the browser, the global computeMunkres
function is exposed.
See the docs in munkres.js for more details.
This module is a translation of a Python implementation by Brian Clapper.
The original implementation is based on http://csclab.murraystate.edu/~bob.pilgrim/445/munkres.html.
It is available via bower
and npm
as munkres-js
.
© 2014 Anna Henningsen (Conversion to JS)
© 2008 Brian M. Clapper
Apache License 2.0. See accompanying LICENSE file.