GPU acceleration of finite state machine input execution: Improving scale and performance. (8th October 2021)
- Record Type:
- Journal Article
- Title:
- GPU acceleration of finite state machine input execution: Improving scale and performance. (8th October 2021)
- Main Title:
- GPU acceleration of finite state machine input execution: Improving scale and performance
- Authors:
- Yaneva, Vanya
Rajan, Ajitha
Dubach, Christophe - Abstract:
- Summary: Model‐based development is a popular development approach in which software is implemented and verified based on a model of the required system. Finite state machines (FSMs) are widely used as models for systems in several domains. Validating that a model accurately represents the required behaviour involves the generation and execution of a large number of input sequences, which is often an expensive and time‐consuming process. In this paper, we speed up the execution of input sequences for FSM validation, by leveraging the high degree of parallelism of modern graphics processing units (GPUs) for the automatic execution of FSM input sequences in parallel on the GPU threads. We expand our existing work by providing techniques that improve the performance and scalability of this approach. We conduct extensive empirical evaluation using 15 large FSMs from the networking domain and measure GPU speed‐up over a 16‐core CPU, taking into account total GPU time, which includes both data transfer and kernel execution time. We found that GPUs execute FSM input sequences up to 9.28× faster than a 16‐core CPU, with an average speed‐up of 4.53× across all subjects. Our optimizations achieve an average improvement over existing work of 58.95 % for speed‐up and scalability to large FSMs with over 2K states and 500K transitions. We also found that techniques aimed at reducing the number of required input sequences for large FSMs with high density were ineffective when applied toSummary: Model‐based development is a popular development approach in which software is implemented and verified based on a model of the required system. Finite state machines (FSMs) are widely used as models for systems in several domains. Validating that a model accurately represents the required behaviour involves the generation and execution of a large number of input sequences, which is often an expensive and time‐consuming process. In this paper, we speed up the execution of input sequences for FSM validation, by leveraging the high degree of parallelism of modern graphics processing units (GPUs) for the automatic execution of FSM input sequences in parallel on the GPU threads. We expand our existing work by providing techniques that improve the performance and scalability of this approach. We conduct extensive empirical evaluation using 15 large FSMs from the networking domain and measure GPU speed‐up over a 16‐core CPU, taking into account total GPU time, which includes both data transfer and kernel execution time. We found that GPUs execute FSM input sequences up to 9.28× faster than a 16‐core CPU, with an average speed‐up of 4.53× across all subjects. Our optimizations achieve an average improvement over existing work of 58.95 % for speed‐up and scalability to large FSMs with over 2K states and 500K transitions. We also found that techniques aimed at reducing the number of required input sequences for large FSMs with high density were ineffective when applied to all‐transition pair coverage, thus emphasizing the need for approaches like ours that speed up input execution. Abstract : In model‐based development, software is implemented and verified based on a model of the required system. Finite state machines (FSMs) are widely used as models in several domains. Validating that a model accurately represents the required behaviour requires the execution of many input sequences, which is often expensive and time‐consuming. We execute FSM input sequences in parallel on the GPU, optimizing performance and scalability. With our optimizations, GPU execution is up to 9.3× faster than a 16‐core CPU (avg. 4.5×). … (more)
- Is Part Of:
- Software testing, verification & reliability. Volume 32:Number 1(2022)
- Journal:
- Software testing, verification & reliability
- Issue:
- Volume 32:Number 1(2022)
- Issue Display:
- Volume 32, Issue 1 (2022)
- Year:
- 2022
- Volume:
- 32
- Issue:
- 1
- Issue Sort Value:
- 2022-0032-0001-0000
- Page Start:
- n/a
- Page End:
- n/a
- Publication Date:
- 2021-10-08
- Subjects:
- finite state machines -- GPUs -- software testing
Computer software -- Testing -- Periodicals
Computer software -- Verification -- Periodicals
Computer software -- Reliability -- Periodicals
005.14 - Journal URLs:
- http://onlinelibrary.wiley.com/ ↗
- DOI:
- 10.1002/stvr.1796 ↗
- Languages:
- English
- ISSNs:
- 0960-0833
- Deposit Type:
- Legaldeposit
- View Content:
- Available online (eLD content is only available in our Reading Rooms) ↗
- Physical Locations:
- British Library DSC - 8321.457500
British Library DSC - BLDSS-3PM
British Library STI - ELD Digital store - Ingest File:
- 20153.xml