Simultaneous Column-and-Row Generation for Large-Scale Linear Programs with Column-Dependent-Rows

Ibrahim Muter, S. Ilker Birbil, Kerem Bulbul

Research output: Contribution to journalArticlepeer-review

30 Citations (SciVal)


In this paper, we develop a simultaneous column-and-row generation algorithm that could be applied to a general class of large-scale linear programming problems. These problems typically arise in the context of linear programming formulations with exponentially many variables. The defining property for these formulations is a set of linking constraints, which are either too many to be included in the formulation directly, or the full set of linking constraints can only be identified, if all variables are generated explicitly. Due to this dependence between columns and rows, we refer to this class of linear programs as problems with column-dependent-rows. To solve these problems, we need to be able to generate both columns and rows on-the-fly within an efficient solution approach. We emphasize that the generated rows are structural constraints and distinguish our work from the branch-and-cut-and-price framework. We first characterize the underlying assumptions for the proposed column-and-row generation algorithm. These assumptions are general enough and cover all problems with column-dependent-rows studied in the literature up until now to the best of our knowledge. We then introduce in detail a set of pricing subproblems, which are used within the proposed column-and-row generation algorithm. This is followed by a formal discussion on the optimality of the algorithm. To illustrate our approach, the paper is concluded by applying the proposed framework to the multi-stage cutting stock and the quadratic set covering problems.
Original languageEnglish
Pages (from-to)47-82
JournalMathematical Programming
Issue number1-2
Publication statusPublished - Dec 2013


Dive into the research topics of 'Simultaneous Column-and-Row Generation for Large-Scale Linear Programs with Column-Dependent-Rows'. Together they form a unique fingerprint.

Cite this