The Bounded Pathwidth of Control-Flow Graphs

被引:1
作者
Conrado, Giovanna Kobus [1 ]
Goharshady, Amir Kafshdar [1 ]
Lam, Chun Kit [1 ]
机构
[1] Hong Kong Univ Sci & Technol, Dept Math, Dept Comp Sci & Engn, Clear Water Bay, Hong Kong, Peoples R China
来源
PROCEEDINGS OF THE ACM ON PROGRAMMING LANGUAGES-PACMPL | 2023年 / 7卷 / OOPSLA期
关键词
Control-flow Graphs; Parameterized Algorithms; Pathwidth; Treewidth; TREE-WIDTH; REGISTER ALLOCATION; TREEWIDTH; MINORS; ALGORITHMS; HARDNESS;
D O I
10.1145/3622807
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Pathwidth and treewidth are standard and well-studied graph sparsity parameters which intuitively model the degree to which a given graph resembles a path or a tree, respectively. It is well-known that the control-flow graphs of structured goto-free programs have a tree-like shape and bounded treewidth. This fact has been exploited to design considerably more efficient algorithms for a wide variety of static analysis and compiler optimization problems, such as register allocation, mu-calculus model-checking and parity games, data-flow analysis, cache management, and liftetime-optimal redundancy elimination. However, there is no bound in the literature for the pathwidth of programs, except the general inequality that the pathwidth of a graph is at most O (lg n) times its treewidth, where n is the number of vertices of the graph. In this work, we prove that control-flow graphs of structured programs have bounded pathwidth and provide a linear-time algorithm to obtain a path decomposition of small width. Specifically, we establish a bound of 2 center dot d on the pathwidth of programs with nesting depth d. Since real-world programs have small nesting depth, they also have bounded pathwidth. This is significant for a number of reasons: (i) pathwidth is a strictly stronger parameter than treewidth, i.e. any graph family with bounded pathwidth has bounded treewidth, but the converse does not hold; (ii) any algorithm that is designed with treewidth in mind can be applied to bounded-pathwidth graphs with no change; (iii) there are problems that are fixed-parameter tractable with respect to pathwidth but not treewidth; (iv) verification algorithms that are designed based on treewidth would become significantly faster when using pathwidth as the parameter; and (v) it is easier to design algorithms based on bounded pathwidth since one does not have to consider the often-challenging case of merge nodes in treewidth-based dynamic programming. Thus, we invite the static analysis and compiler optimization communities to adopt pathwidth as their parameter of choice instead of, or in addition to, treewidth. Intuitively, control-flow graphs are not only tree-like, but also path-like and one can obtain simpler and more scalable algorithms by relying on path-likeness instead of tree-likeness. As a motivating example, we provide a simpler and more efficient algorithm for spill-free register allocation using bounded pathwidth instead of treewidth. Our algorithm reduces the runtime from O (n center dot r(2 center dot tw center dot r+2 center dot r)) to O (n center dot pw center dot r(pw center dot A +r) (+1)), where n is the number of lines of code, A is the number of registers, pw is the pathwidth of the control-flow graph and tw is its treewidth. We provide extensive experimental results showing that our approach is applicable to a wide variety of real-world embedded benchmarks from SDCC and obtains runtime improvements of 2-3 orders of magnitude. This is because the pathwidth is equal to the treewidth, or one more, in the overwhelming majority of real-world CFGs and thus our algorithm provides an exponential runtime improvement. As such, the benefits of using pathwidth are not limited to the theoretical side and simplicity in algorithm design, but are also apparent in practice.
引用
收藏
页数:26
相关论文
共 50 条
  • [31] An Efficient Algorithm to Compute the Toughness in Graphs with Bounded Treewidth
    Katona, Gyula Y.
    Khan, Humara
    GRAPHS AND COMBINATORICS, 2024, 40 (05)
  • [32] Posets with Cover Graph of Pathwidth two have Bounded Dimension
    Biro, Csaba
    Keller, Mitchel T.
    Young, Stephen J.
    ORDER-A JOURNAL ON THE THEORY OF ORDERED SETS AND ITS APPLICATIONS, 2016, 33 (02): : 195 - 212
  • [33] Evaluating network reliability and 2-edge-connected reliability in linear time for bounded pathwidth graphs
    Lucet, C
    Manouvrier, JF
    Carlier, J
    ALGORITHMICA, 2000, 27 (3-4) : 316 - 336
  • [34] Vertex partitioning problems on graphs with bounded tree width
    Aravind, N. R.
    Kalyanasundaram, Subrahmanyam
    Kare, Anjeneya Swami
    DISCRETE APPLIED MATHEMATICS, 2022, 319 : 254 - 270
  • [35] The NLC-width and clique-width for powers of graphs of bounded tree-width
    Gurski, Frank
    Wanke, Egon
    DISCRETE APPLIED MATHEMATICS, 2009, 157 (04) : 583 - 595
  • [36] On fixed-parameter tractability of the mixed domination problem for graphs with bounded tree-width
    Olyaei, Meysam Rajaati Bavil
    Hooshmandasl, Mohammad Reza
    Dinneen, Michael J.
    Shakiba, Ali
    DISCRETE MATHEMATICS AND THEORETICAL COMPUTER SCIENCE, 2018, 20 (02)
  • [37] Circumference and Pathwidth of Highly Connected Graphs
    Marshall, Emily A.
    Wood, David R.
    JOURNAL OF GRAPH THEORY, 2015, 79 (03) : 222 - 232
  • [38] Isomorphism for Graphs of Bounded Connected-Path-Distance-Width
    Otachi, Yota
    ALGORITHMS AND COMPUTATION, ISAAC 2012, 2012, 7676 : 455 - 464
  • [39] CFG Construction Soundness in Control-Flow Integrity
    Tan, Gang
    Jaeger, Trent
    PROCEEDINGS OF THE 2017 WORKSHOP ON PROGRAMMING LANGUAGES AND ANALYSIS FOR SECURITY (PLAS' 17), 2017, : 3 - 13
  • [40] Induced subgraphs and tree decompositions II. Toward walls and their line graphs in graphs of bounded degree
    Abrishami, Tara
    Chudnovsky, Maria
    Dibek, Cemil
    Hajebi, Sepehr
    Rzazewski, Pawel
    Spirkl, Sophie
    Vuskovic, Kristina
    JOURNAL OF COMBINATORIAL THEORY SERIES B, 2024, 164 : 371 - 403