Unifying program slicing and concept assignment for higher-level executable source code extraction

被引:13
|
作者
Gold, NE [1 ]
Harman, M
Binkley, D
Hierons, RM
机构
[1] Kings Coll London, Dept Comp Sci, London WC2R 2LS, England
[2] Loyola Coll, Baltimore, MD 21210 USA
[3] Brunel Univ, Uxbridge UB8 3PH, Middx, England
来源
SOFTWARE-PRACTICE & EXPERIENCE | 2005年 / 35卷 / 10期
关键词
program slicing; concept assignment; reverse engineering;
D O I
10.1002/spe.664
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Program slicing and concept assignment have both been proposed as source code extraction techniques. Unfortunately, each has a weakness that prevents wider application. For slicing, the extraction criterion is expressed at a very low level; constructing a slicing criterion requires detailed code knowledge which is often unavailable. The concept assignment extraction criterion is expressed at the domain level. However, unlike a slice, the extracted code is not executable as a separate subprogram in its own right. This paper introduces a unification of slicing and concept assignment which exploits their combined advantages, while overcoming these two individual weaknesses. Our ' concept slices ' are executable programs extracted using high-level criteria. The paper introduces four techniques that combine slicing and concept assignment and algorithms for each. These algorithms were implemented in two separate tools used to illustrate the application of the concept slicing algorithms in two very different case studies. The first is a commercially-written COBOL module from a large financial organization, the second is an open source utility program written in C. Copyright (c) 2005 John Wiley & Sons, Ltd.
引用
收藏
页码:977 / 1006
页数:30
相关论文
共 29 条
  • [1] Code extraction algorithms which unify slicing and concept assignment
    Harman, M
    Gold, N
    Hierons, R
    Binkley, D
    [J]. NINTH WORKING CONFERENCE ON REVERSE ENGINEERING, PROCEEDINGS, 2002, : 11 - 20
  • [2] TRANSFER FROM LOWER-LEVEL TO HIGHER-LEVEL CONCEPT
    LEE, SS
    [J]. JOURNAL OF VERBAL LEARNING AND VERBAL BEHAVIOR, 1968, 7 (05): : 930 - +
  • [3] A concept and implementation of higher-level XML transformation languages
    Foetsch, Daniel
    Pulvermueller, Elke
    [J]. KNOWLEDGE-BASED SYSTEMS, 2009, 22 (03) : 186 - 194
  • [4] NAMING RELATIONS AND PROGRAM ALGEBRAS FOR HIGHER-LEVEL LANGUAGES
    KUZENKO, VF
    [J]. PROGRAMMING AND COMPUTER SOFTWARE, 1994, 20 (02) : 80 - 83
  • [5] Causal representation learning through higher-level information extraction
    Silva, Francisco
    Oliveira, Hélder P.
    Pereira, Tania
    [J]. ACM Computing Surveys, 2024, 57 (02)
  • [6] Converting Parallel Code from Low-Level Abstractions to Higher-Level Abstractions
    Okur, Semih
    Erdogan, Cansu
    Dig, Danny
    [J]. ECOOP 2014 - OBJECT-ORIENTED PROGRAMMING, 2014, 8586 : 515 - 540
  • [7] Concept Extraction: A Modular Approach to Extraction of Source Code Concepts
    Chaturvedi, Ritu
    Brar, Veerpal
    Geelal, Jai
    Kong, Kelvin
    [J]. IEEE 2018 INTERNATIONAL CONGRESS ON CYBERMATICS / 2018 IEEE CONFERENCES ON INTERNET OF THINGS, GREEN COMPUTING AND COMMUNICATIONS, CYBER, PHYSICAL AND SOCIAL COMPUTING, SMART DATA, BLOCKCHAIN, COMPUTER AND INFORMATION TECHNOLOGY, 2018, : 1860 - 1866
  • [8] The sparchunk code: A method to build higher-level structures in a sparsely encoded SDM
    Sjodin, G
    [J]. IEEE WORLD CONGRESS ON COMPUTATIONAL INTELLIGENCE, 1998, : 1410 - 1415
  • [9] Synchronous development in open-source projects: A higher-level perspective
    Bock, Thomas
    Hunsen, Claus
    Joblin, Mitchell
    Apel, Sven
    [J]. AUTOMATED SOFTWARE ENGINEERING, 2022, 29 (01)
  • [10] Synchronous development in open-source projects: A higher-level perspective
    Thomas Bock
    Claus Hunsen
    Mitchell Joblin
    Sven Apel
    [J]. Automated Software Engineering, 2022, 29