blob: 6ca267ffc8c33f81e30d3543c6b9d6686a299642 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!-- NewPage -->
<html lang="en">
<head>
<!-- Generated by javadoc -->
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>MunkresAssignment (Apache HBase 3.0.0-alpha-2-SNAPSHOT API)</title>
<link rel="stylesheet" type="text/css" href="../../../../../stylesheet.css" title="Style">
<script type="text/javascript" src="../../../../../script.js"></script>
</head>
<body>
<script type="text/javascript"><!--
try {
if (location.href.indexOf('is-external=true') == -1) {
parent.document.title="MunkresAssignment (Apache HBase 3.0.0-alpha-2-SNAPSHOT API)";
}
}
catch(err) {
}
//-->
var methods = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":10,"i5":10,"i6":10,"i7":10,"i8":10,"i9":10,"i10":10};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
var tableTab = "tableTab";
var activeTableTab = "activeTableTab";
</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a name="navbar.top">
<!-- -->
</a>
<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
<a name="navbar.top.firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="class-use/MunkresAssignment.html">Use</a></li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../../../index-all.html">Index</a></li>
<li><a href="../../../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../../org/apache/hadoop/hbase/util/MovingAverage.html" title="class in org.apache.hadoop.hbase.util"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
<li><a href="../../../../../org/apache/hadoop/hbase/util/MurmurHash.html" title="class in org.apache.hadoop.hbase.util"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../index.html?org/apache/hadoop/hbase/util/MunkresAssignment.html" target="_top">Frames</a></li>
<li><a href="MunkresAssignment.html" target="_top">No&nbsp;Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_top">
<li><a href="../../../../../allclasses-noframe.html">All&nbsp;Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
allClassesLink = document.getElementById("allclasses_navbar_top");
if(window==top) {
allClassesLink.style.display = "block";
}
else {
allClassesLink.style.display = "none";
}
//-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li><a href="#field.summary">Field</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li><a href="#field.detail">Field</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a name="skip.navbar.top">
<!-- -->
</a></div>
<!-- ========= END OF TOP NAVBAR ========= -->
<!-- ======== START OF CLASS DATA ======== -->
<div class="header">
<div class="subTitle">org.apache.hadoop.hbase.util</div>
<h2 title="Class MunkresAssignment" class="title">Class MunkresAssignment</h2>
</div>
<div class="contentContainer">
<ul class="inheritance">
<li><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">java.lang.Object</a></li>
<li>
<ul class="inheritance">
<li>org.apache.hadoop.hbase.util.MunkresAssignment</li>
</ul>
</li>
</ul>
<div class="description">
<ul class="blockList">
<li class="blockList">
<hr>
<br>
<pre>@InterfaceAudience.Private
public class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.38">MunkresAssignment</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></pre>
<div class="block">Computes the optimal (minimal cost) assignment of jobs to workers (or other
analogous) concepts given a cost matrix of each pair of job and worker, using
the algorithm by James Munkres in "Algorithms for the Assignment and
Transportation Problems", with additional optimizations as described by Jin
Kue Wong in "A New Implementation of an Algorithm for the Optimal Assignment
Problem: An Improved Version of Munkres' Algorithm". The algorithm runs in
O(n^3) time and need O(n^2) auxiliary space where n is the number of jobs or
workers, whichever is greater.</div>
</li>
</ul>
</div>
<div class="summary">
<ul class="blockList">
<li class="blockList">
<!-- =========== FIELD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="field.summary">
<!-- -->
</a>
<h3>Field Summary</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Field Summary table, listing fields, and an explanation">
<caption><span>Fields</span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colLast" scope="col">Field and Description</th>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private int[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#assignments">assignments</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private float[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#colAdjust">colAdjust</a></span></code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private int</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#cols">cols</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private boolean[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#colsCovered">colsCovered</a></span></code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private float[][]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#cost">cost</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private float[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#leastInRow">leastInRow</a></span></code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private int[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#leastInRowIndex">leastInRowIndex</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private byte[][]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#mask">mask</a></span></code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private static byte</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#NONE">NONE</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Deque.html?is-external=true" title="class or interface in java.util">Deque</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#path">path</a></span></code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private static byte</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#PRIME">PRIME</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private float[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#rowAdjust">rowAdjust</a></span></code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private int</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#rows">rows</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private boolean[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#rowsCovered">rowsCovered</a></span></code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private static byte</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#STAR">STAR</a></span></code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private boolean</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#transposed">transposed</a></span></code>&nbsp;</td>
</tr>
</table>
</li>
</ul>
<!-- ======== CONSTRUCTOR SUMMARY ======== -->
<ul class="blockList">
<li class="blockList"><a name="constructor.summary">
<!-- -->
</a>
<h3>Constructor Summary</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Constructor Summary table, listing constructors, and an explanation">
<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colOne" scope="col">Constructor and Description</th>
</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#MunkresAssignment-float:A:A-">MunkresAssignment</a></span>(float[][]&nbsp;costMatrix)</code>
<div class="block">Construct a new problem instance with the specified cost matrix.</div>
</td>
</tr>
</table>
</li>
</ul>
<!-- ========== METHOD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="method.summary">
<!-- -->
</a>
<h3>Method Summary</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Method Summary table, listing methods, and an explanation">
<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">Instance Methods</a></span><span class="tabEnd">&nbsp;</span></span><span id="t4" class="tableTab"><span><a href="javascript:show(8);">Concrete Methods</a></span><span class="tabEnd">&nbsp;</span></span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colLast" scope="col">Method and Description</th>
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#findUncoveredZero--">findUncoveredZero</a></span>()</code>
<div class="block">Find a zero cost assignment which is not covered.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#preliminaries--">preliminaries</a></span>()</code>
<div class="block">Corresponds to the "preliminaries" step of the original algorithm.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#primeInRow-int-">primeInRow</a></span>(int&nbsp;r)</code>
<div class="block">Find a primed zero in the specified row.</div>
</td>
</tr>
<tr id="i3" class="rowColor">
<td class="colFirst"><code>int[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#solve--">solve</a></span>()</code>
<div class="block">Get the optimal assignments.</div>
</td>
</tr>
<tr id="i4" class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#starInCol-int-">starInCol</a></span>(int&nbsp;c)</code>
<div class="block">Find a starred zero in the specified column.</div>
</td>
</tr>
<tr id="i5" class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#starInRow-int-">starInRow</a></span>(int&nbsp;r)</code>
<div class="block">Find a starred zero in a specified row.</div>
</td>
</tr>
<tr id="i6" class="altColor">
<td class="colFirst"><code>private boolean</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#stepOne--">stepOne</a></span>()</code>
<div class="block">Corresponds to step 1 of the original algorithm.</div>
</td>
</tr>
<tr id="i7" class="rowColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#stepThree--">stepThree</a></span>()</code>
<div class="block">Corresponds to step 3 of the original algorithm.</div>
</td>
</tr>
<tr id="i8" class="altColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#stepTwo--">stepTwo</a></span>()</code>
<div class="block">Corresponds to step 2 of the original algorithm.</div>
</td>
</tr>
<tr id="i9" class="rowColor">
<td class="colFirst"><code>private boolean</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#testIsDone--">testIsDone</a></span>()</code>
<div class="block">Test whether the algorithm is done, i.e.</div>
</td>
</tr>
<tr id="i10" class="altColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/util/MunkresAssignment.html#updateMin-int-int-">updateMin</a></span>(int&nbsp;row,
int&nbsp;col)</code>
<div class="block">A specified row has become covered, and a specified column has become
uncovered.</div>
</td>
</tr>
</table>
<ul class="blockList">
<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
<!-- -->
</a>
<h3>Methods inherited from class&nbsp;java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></h3>
<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#clone--" title="class or interface in java.lang">clone</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#equals-java.lang.Object-" title="class or interface in java.lang">equals</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#finalize--" title="class or interface in java.lang">finalize</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#getClass--" title="class or interface in java.lang">getClass</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#hashCode--" title="class or interface in java.lang">hashCode</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#notify--" title="class or interface in java.lang">notify</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#notifyAll--" title="class or interface in java.lang">notifyAll</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#toString--" title="class or interface in java.lang">toString</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait--" title="class or interface in java.lang">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-" title="class or interface in java.lang">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-int-" title="class or interface in java.lang">wait</a></code></li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
<div class="details">
<ul class="blockList">
<li class="blockList">
<!-- ============ FIELD DETAIL =========== -->
<ul class="blockList">
<li class="blockList"><a name="field.detail">
<!-- -->
</a>
<h3>Field Detail</h3>
<a name="NONE">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>NONE</h4>
<pre>private static final&nbsp;byte <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.44">NONE</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.util.MunkresAssignment.NONE">Constant Field Values</a></dd>
</dl>
</li>
</ul>
<a name="STAR">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>STAR</h4>
<pre>private static final&nbsp;byte <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.45">STAR</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.util.MunkresAssignment.STAR">Constant Field Values</a></dd>
</dl>
</li>
</ul>
<a name="PRIME">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>PRIME</h4>
<pre>private static final&nbsp;byte <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.46">PRIME</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.util.MunkresAssignment.PRIME">Constant Field Values</a></dd>
</dl>
</li>
</ul>
<a name="transposed">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>transposed</h4>
<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.52">transposed</a></pre>
</li>
</ul>
<a name="rows">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>rows</h4>
<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.55">rows</a></pre>
</li>
</ul>
<a name="cols">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>cols</h4>
<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.58">cols</a></pre>
</li>
</ul>
<a name="cost">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>cost</h4>
<pre>private&nbsp;float[][] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.61">cost</a></pre>
</li>
</ul>
<a name="mask">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>mask</h4>
<pre>private&nbsp;byte[][] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.64">mask</a></pre>
</li>
</ul>
<a name="rowsCovered">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>rowsCovered</h4>
<pre>private&nbsp;boolean[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.67">rowsCovered</a></pre>
</li>
</ul>
<a name="colsCovered">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>colsCovered</h4>
<pre>private&nbsp;boolean[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.70">colsCovered</a></pre>
</li>
</ul>
<a name="path">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>path</h4>
<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Deque.html?is-external=true" title="class or interface in java.util">Deque</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.73">path</a></pre>
</li>
</ul>
<a name="assignments">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>assignments</h4>
<pre>private&nbsp;int[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.80">assignments</a></pre>
</li>
</ul>
<a name="leastInRow">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>leastInRow</h4>
<pre>private&nbsp;float[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.85">leastInRow</a></pre>
</li>
</ul>
<a name="leastInRowIndex">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>leastInRowIndex</h4>
<pre>private&nbsp;int[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.86">leastInRowIndex</a></pre>
</li>
</ul>
<a name="rowAdjust">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>rowAdjust</h4>
<pre>private&nbsp;float[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.87">rowAdjust</a></pre>
</li>
</ul>
<a name="colAdjust">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>colAdjust</h4>
<pre>private&nbsp;float[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.88">colAdjust</a></pre>
</li>
</ul>
</li>
</ul>
<!-- ========= CONSTRUCTOR DETAIL ======== -->
<ul class="blockList">
<li class="blockList"><a name="constructor.detail">
<!-- -->
</a>
<h3>Constructor Detail</h3>
<a name="MunkresAssignment-float:A:A-">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>MunkresAssignment</h4>
<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.97">MunkresAssignment</a>(float[][]&nbsp;costMatrix)</pre>
<div class="block">Construct a new problem instance with the specified cost matrix. The cost
matrix must be rectangular, though not necessarily square. If one dimension
is greater than the other, some elements in the greater dimension will not
be assigned. The input cost matrix will not be modified.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>costMatrix</code> - </dd>
</dl>
</li>
</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
<ul class="blockList">
<li class="blockList"><a name="method.detail">
<!-- -->
</a>
<h3>Method Detail</h3>
<a name="solve--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>solve</h4>
<pre>public&nbsp;int[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.157">solve</a>()</pre>
<div class="block">Get the optimal assignments. The returned array will have the same number
of elements as the number of elements as the number of rows in the input
cost matrix. Each element will indicate which column should be assigned to
that row or -1 if no column should be assigned, i.e. if result[i] = j then
row i should be assigned to column j. Subsequent invocations of this method
will simply return the same object without additional computation.</div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>an array with the optimal assignments</dd>
</dl>
</li>
</ul>
<a name="preliminaries--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>preliminaries</h4>
<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.222">preliminaries</a>()</pre>
<div class="block">Corresponds to the "preliminaries" step of the original algorithm.
Guarantees that the matrix is an equivalent non-negative matrix with at
least one zero in each row.</div>
</li>
</ul>
<a name="testIsDone--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>testIsDone</h4>
<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.257">testIsDone</a>()</pre>
<div class="block">Test whether the algorithm is done, i.e. we have the optimal assignment.
This occurs when there is exactly one starred zero in each row.</div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>true if the algorithm is done</dd>
</dl>
</li>
</ul>
<a name="stepOne--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>stepOne</h4>
<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.309">stepOne</a>()</pre>
<div class="block">Corresponds to step 1 of the original algorithm.</div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>false if all zeroes are covered</dd>
</dl>
</li>
</ul>
<a name="stepTwo--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>stepTwo</h4>
<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.343">stepTwo</a>()</pre>
<div class="block">Corresponds to step 2 of the original algorithm.</div>
</li>
</ul>
<a name="stepThree--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>stepThree</h4>
<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.387">stepThree</a>()</pre>
<div class="block">Corresponds to step 3 of the original algorithm.</div>
</li>
</ul>
<a name="findUncoveredZero--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>findUncoveredZero</h4>
<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.438">findUncoveredZero</a>()</pre>
<div class="block">Find a zero cost assignment which is not covered. If there are no zero cost
assignments which are uncovered, then null will be returned.</div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>pair of row and column indices of an uncovered zero or null</dd>
</dl>
</li>
</ul>
<a name="updateMin-int-int-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>updateMin</h4>
<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.453">updateMin</a>(int&nbsp;row,
int&nbsp;col)</pre>
<div class="block">A specified row has become covered, and a specified column has become
uncovered. The least value per row may need to be updated.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>row</code> - the index of the row which was just covered</dd>
<dd><code>col</code> - the index of the column which was just uncovered</dd>
</dl>
</li>
</ul>
<a name="starInRow-int-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>starInRow</h4>
<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.475">starInRow</a>(int&nbsp;r)</pre>
<div class="block">Find a starred zero in a specified row. If there are no starred zeroes in
the specified row, then null will be returned.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>r</code> - the index of the row to be searched</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>pair of row and column indices of starred zero or null</dd>
</dl>
</li>
</ul>
<a name="starInCol-int-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>starInCol</h4>
<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.490">starInCol</a>(int&nbsp;c)</pre>
<div class="block">Find a starred zero in the specified column. If there are no starred zeroes
in the specified row, then null will be returned.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>c</code> - the index of the column to be searched</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>pair of row and column indices of starred zero or null</dd>
</dl>
</li>
</ul>
<a name="primeInRow-int-">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>primeInRow</h4>
<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/MunkresAssignment.html#line.505">primeInRow</a>(int&nbsp;r)</pre>
<div class="block">Find a primed zero in the specified row. If there are no primed zeroes in
the specified row, then null will be returned.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>r</code> - the index of the row to be searched</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>pair of row and column indices of primed zero or null</dd>
</dl>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
</div>
<!-- ========= END OF CLASS DATA ========= -->
<!-- ======= START OF BOTTOM NAVBAR ====== -->
<div class="bottomNav"><a name="navbar.bottom">
<!-- -->
</a>
<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
<a name="navbar.bottom.firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="class-use/MunkresAssignment.html">Use</a></li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../../../index-all.html">Index</a></li>
<li><a href="../../../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../../org/apache/hadoop/hbase/util/MovingAverage.html" title="class in org.apache.hadoop.hbase.util"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
<li><a href="../../../../../org/apache/hadoop/hbase/util/MurmurHash.html" title="class in org.apache.hadoop.hbase.util"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../index.html?org/apache/hadoop/hbase/util/MunkresAssignment.html" target="_top">Frames</a></li>
<li><a href="MunkresAssignment.html" target="_top">No&nbsp;Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_bottom">
<li><a href="../../../../../allclasses-noframe.html">All&nbsp;Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
allClassesLink = document.getElementById("allclasses_navbar_bottom");
if(window==top) {
allClassesLink.style.display = "block";
}
else {
allClassesLink.style.display = "none";
}
//-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li><a href="#field.summary">Field</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li><a href="#field.detail">Field</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a name="skip.navbar.bottom">
<!-- -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
<p class="legalCopy"><small>Copyright &#169; 2007&#x2013;2021 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</small></p>
</body>
</html>