An architecture refactoring approach to reducing software hierarchy complexity.
Saved in:
| Title: | An architecture refactoring approach to reducing software hierarchy complexity. |
|---|---|
| Authors: | Zhao, Yongxin1 (AUTHOR), Wu, Wenhan1 (AUTHOR), Fei, Yuan2 (AUTHOR) yuanfei@shnu.edu.cn, Liu, Zhihao1 (AUTHOR), Li, Yang3 (AUTHOR), Yang, Yilong3 (AUTHOR) yilongyang@buaa.edu.cn, Shi, Ling4 (AUTHOR), Zhang, Bo2 (AUTHOR) |
| Source: | Journal of Software: Evolution & Process. Apr2024, Vol. 36 Issue 4, p1-27. 27p. |
| Subjects: | Software refactoring, Computer software correctness, Computer software quality control, Software architecture, Computer programming, Battery management systems |
| Abstract: | Summary: Software complexity is the very essence of computer programming. As the complexity increases, the potential risks and defects of software systems will increase. This makes the software correctness analysis and the software quality improvement more difficult. In this paper, we present a quantitative metric to describe the complexity of a hierarchical software and a Complexity‐oriented Software Architecture Refactoring (CoSSR) approach to reduce the complexity. The main idea is to identify and then reassemble subcomponents into one hierarchical component, which achieves minimum complexity in terms of the solution algorithm. Moreover, our algorithm can be improved by introducing partition constraint, heuristic search strategy, and spectral clustering. We implement the proposed method as an automated refactoring tool and demonstrate our algorithm through a case study of battery management system (BMS). The results show that our approach is more efficient and effective to reduce the complexity of hierarchical software system. [ABSTRACT FROM AUTHOR] |
| Copyright of Journal of Software: Evolution & Process is the property of Wiley-Blackwell and its content may not be copied or emailed to multiple sites without the copyright holder's express written permission. Additionally, content may not be used with any artificial intelligence tools or machine learning technologies. However, users may print, download, or email articles for individual use. This abstract may be abridged. No warranty is given about the accuracy of the copy. Users should refer to the original published version of the material for the full abstract. (Copyright applies to all Abstracts.) | |
| Database: | Engineering Source |
|
Full text is not displayed to guests.
Login for full access.
|
|
| Abstract: | Summary: Software complexity is the very essence of computer programming. As the complexity increases, the potential risks and defects of software systems will increase. This makes the software correctness analysis and the software quality improvement more difficult. In this paper, we present a quantitative metric to describe the complexity of a hierarchical software and a Complexity‐oriented Software Architecture Refactoring (CoSSR) approach to reduce the complexity. The main idea is to identify and then reassemble subcomponents into one hierarchical component, which achieves minimum complexity in terms of the solution algorithm. Moreover, our algorithm can be improved by introducing partition constraint, heuristic search strategy, and spectral clustering. We implement the proposed method as an automated refactoring tool and demonstrate our algorithm through a case study of battery management system (BMS). The results show that our approach is more efficient and effective to reduce the complexity of hierarchical software system. [ABSTRACT FROM AUTHOR] |
|---|---|
| ISSN: | 20477473 |
| DOI: | 10.1002/smr.2573 |