Published January 1, 2015 | Version v1
Journal article Open

Two approximation algorithms for bipartite matching on multicore architectures

  • 1. Nord Europe, Inria Lille, F-59650 Villeneuve Dascq, France
  • 2. Sabanci Univ, Fac Engn & Nat Sci, Istanbul, Turkey
  • 3. Univ Lyon, INRIA, UCBL, LIP,UMR5668,CNRS,ENS Lyon, Lyon, France

Description

We propose two heuristics for the bipartite matching problem that are amenable to shared-memory parallelization. The first heuristic is very intriguing from a parallelization perspective. It has no significant algorithmic synchronization overhead and no conflict resolution is needed across threads. We show that this heuristic has an approximation ratio of around 0.632 under some common conditions. The second heuristic is designed to obtain a larger matching by employing the well-known Karp-Sipser heuristic on a judiciously chosen subgraph of the original graph. We show that the Karp-Sipser heuristic always finds a maximum cardinality matching in the chosen subgraph. Although the Karp-Sipser heuristic is hard to parallelize for general graphs, we exploit the structure of the selected subgraphs to propose a specialized implementation which demonstrates very good scalability. We prove that this second heuristic has an approximation guarantee of around 0.866 under the same conditions as in the first algorithm. We discuss parallel implementations of the proposed heuristics on a multicore architecture. Experimental results, for demonstrating speed-ups and verifying the theoretical results in practice, are provided. (C) 2015 Elsevier Inc. All rights reserved.

Files

bib-3b76bc60-c8bb-450c-ab86-f365f3f064b1.txt

Files (184 Bytes)

Name Size Download all
md5:653774afa15cc5927d5f12b7d53bfb15
184 Bytes Preview Download