Skip to main content

Event-Driven Temporal Logic Pattern for Control Software Requirements Specification

  • Conference paper
  • First Online:
Fundamentals of Software Engineering (FSEN 2021)

Part of the book series: Lecture Notes in Computer Science ((LNPSE,volume 12818))

Included in the following conference series:

Abstract

This paper presents event-driven temporal logic (EDTL), a specification formalism that allows the users to describe the behavior of control software in terms of events (including timeouts) and logical operations over inputs and outputs, and therefore consider the control system as a “black box”. We propose the EDTL-based pattern that provides a simple but powerful and semantically rigorous conceptual framework oriented on industrial process plant developers in order to organize their effective interaction with the software developers and provide a seamless transition to the stages of requirement consistency checking and verification.

This work has been funded by the state budget of the Russian Federation (IA&E project No. AAAA-A19-119120290056-0). Authors are very grateful for the charitable support they received from the JetBrains Foundation.

This is a preview of subscription content, log in via an institution to check access.

Access this chapter

Subscribe and save

Springer+ Basic
$34.99 /Month
  • Get 10 units per month
  • Download Article/Chapter or eBook
  • 1 Unit = 1 Article or 1 Chapter
  • Cancel anytime
Subscribe now

Buy Now

Chapter
USD 29.95
Price excludes VAT (USA)
  • Available as PDF
  • Read on any device
  • Instant download
  • Own it forever

Tax calculation will be finalised at checkout

Purchases are for personal use only

Institutional subscriptions

Similar content being viewed by others

References

  1. Darvas, D., Majzik, I., Blanco Viñuela, E.: Formal verification of safety PLC based control software. In: Ábrahám, E., Huisman, M. (eds.) IFM 2016. LNCS, vol. 9681, pp. 508–522. Springer, Cham (2016). https://doi.org/10.1007/978-3-319-33693-0_32

    Chapter  Google Scholar 

  2. Staroletov, S., et al.: Model-driven methods to design of reliable multiagent cyber-physical systems. In: Proceedings of the Conference on Modeling and Analysis of Complex Systems and Processes (MACSPro 2019), vol. 2478, pp. 74–91. CEUR Workshop Proceedings (2019)

    Google Scholar 

  3. Sommerville, I.: Software Engineering. Pearson Education, Harlow (2016)

    Google Scholar 

  4. Feng, L., et al.: Quality control scheme selection with a case of aviation equipment development. Eng. Manag. J. 32(1), 14–25 (2020)

    Article  Google Scholar 

  5. Anureev, I., Garanina, N., Liakh, T., Rozov, A., Zyubin, V., Gorlatch, S.: Two-step deductive verification of control software using reflex. In: Bjørner, N., Virbitskaite, I., Voronkov, A. (eds.) PSI 2019. LNCS, vol. 11964, pp. 50–63. Springer, Cham (2019). https://doi.org/10.1007/978-3-030-37487-7_5

    Chapter  Google Scholar 

  6. IEC: 61131–3 Ed. 3.0 en:2013: Programmable Controllers—Part 3: Programming Languages. International Electrotechnical Commission (2013)

    Google Scholar 

  7. Leveson, N., Heimdahl, M., Reese, J.: Designing specification languages for process control systems: lessons learned and steps to the future. ACM Sigsoft Softw. Eng. Notes. 24(6), 127–145 (1999). https://doi.org/10.1145/318774.318937

  8. Schneider, F., Berenbach, B.: A literature survey on international standards for systems requirements engineering. In: Proceedings of the Conference on Systems Engineering Research, vol. 16, pp. 796–805, January 2013

    Google Scholar 

  9. Konrad, S., Cheng, B.H.: Real-time specification patterns. In: Proceedings of the 27th International Conference on Software Engineering, pp. 372–381. ACM (2005)

    Google Scholar 

  10. Filipovikj, P., Nyberg, M., Rodriguez-Navas, G.: Reassessing the pattern-based approach for formalizing requirements in the automotive domain. In: IEEE 22nd International Requirements Engineering Conference, pp. 444–450. IEEE (2014)

    Google Scholar 

  11. Jue, W., Song, Y., Wu, X. Dai, W.: A semi-formal requirement modeling pattern for designing industrial cyber-physical systems. In: Proceedings of IECON 2019–45th Annual Conference of the IEEE Industrial Electronics Society, Lisbon, Portugal, 2019. pp. 2883–2888 (2019)

    Google Scholar 

  12. Garanina, N., Anureev, I., Sidorova, E., Koznov, D., Zyubin, V., Gorlatch, S.: An ontology-based approach to support formal verification of concurrent systems. In: Sekerinski, E., et al. (eds.) FM 2019. LNCS, vol. 12232, pp. 114–130. Springer, Cham (2020). https://doi.org/10.1007/978-3-030-54994-7_9

    Chapter  Google Scholar 

  13. Ghosh, S., Elenius, D., Li, W., Lincoln, P., Shankar, N., Steiner, W.: ARSENAL: automatic requirements specification extraction from natural language. In: Rayadurgam, S., Tkachuk, O. (eds.) NFM 2016. LNCS, vol. 9690, pp. 41–46. Springer, Cham (2016). https://doi.org/10.1007/978-3-319-40648-0_4

    Chapter  Google Scholar 

  14. Sarmiento, E., do Prado Leite, J.C.S., Almentero, E.: C&L: generating model based test cases from natural language requirements descriptions. In: 2014 IEEE 1st International Workshop on Requirements Engineering and Testing (RET), pp. 32–38. IEEE (2014)

    Google Scholar 

  15. Leveson, N.G., Heimdahl, M.P.E., Hildreth, H., Reese, J.D.: Requirements specification for process-control systems. IEEE Trans. Softw. Eng. 20(9), 684–707 (1994). https://doi.org/10.1109/32.317428

  16. Pang, C., Pakonen, A., Buzhinsky, I., Vyatkin, V.: A study on user-friendly formal specification languages for requirements formalization. In: IEEE 14th International Conference on Industrial Informatics (INDIN), pp. 676–682. IEEE (2016)

    Google Scholar 

  17. Autili, M., Grunske, L., Lumpe, M., Pelliccione, P., Tang, A.: Aligning qualitative, real-time, and probabilistic property specification patterns using a structured English grammar. IEEE Trans. Softw. Eng. 41(7), 620–638 (2015)

    Article  Google Scholar 

  18. Garanina, N., Zubin, V., Lyakh, T., Gorlatch, S.: An ontology of specification patterns for verification of concurrent systems. In: Proceedings of the 17th International Conference on Intelligent Software Methodology Tools, and Techniques (SoMeT_18), pp. 515–528. IOS Press, Amsterdam (2018)

    Google Scholar 

  19. Salamah, S., Gates, A.Q., Kreinovich, V.: Validated patterns for specification of complex LTL formulas. J. Syst. Softw. 85(8), 1915–1929 (2012)

    Article  Google Scholar 

  20. Smith, M.H., Holzmann, G.J., Etessami, K.: Events and constraints: a graphical editor for capturing logic requirements of programs. In: Proceedings of Fifth IEEE International Symposium on Requirements Engineering, 27–31 August 2001, pp. 14–22. IEEE (2001)

    Google Scholar 

  21. Wong, P.Y.H., Gibbons, J.: Property specifications for workflow modelling. In: Leuschel, M., Wehrheim, H. (eds.) IFM 2009. LNCS, vol. 5423, pp. 56–71. Springer, Heidelberg (2009). https://doi.org/10.1007/978-3-642-00255-7_5

    Chapter  Google Scholar 

  22. Yu, J., Manh, T.P., Han, J., Jin, Y., Han, Y., Wang, J.: Pattern based property specification and verification for service composition. In: Aberer, K., Peng, Z., Rundensteiner, E.A., Zhang, Y., Li, X. (eds.) WISE 2006. LNCS, vol. 4255, pp. 156–168. Springer, Heidelberg (2006). https://doi.org/10.1007/11912873_18

    Chapter  Google Scholar 

  23. Mondragon, O., Gates, A. Q., Roach, S.: Prospec: support for elicitation and formal specification of software properties. In: Proceedings of Runtime Verification Workshop. Electronic Notes in Theoretical Computer Science, vol. 89, pp. 67–88. Elsevier (2004)

    Google Scholar 

  24. Garanina, N., Anureev, I., Zyubin, V., Rozov, A., Liakh, T., Gorlatch, S.: Reasoning about programmable logic controllers. Syst. Inform. 17, 33–42 (2020)

    Google Scholar 

  25. Mader, A.: A classification of plc models and applications. In: Boel, R., Stremersch, G. (eds.) Discrete Event Systems. SECS, vol. 569, pp. 239–246. Springer, Boston, MA (2000). https://doi.org/10.1007/978-1-4615-4493-7_24

  26. Estrada-Vargas, A.P., López-Mellado, E., Lesage, J.J.: A black-box identification method for automated discrete-event systems. IEEE Trans. Autom. Sci. Eng. 14(3), 1321–1336 (2015)

    Article  Google Scholar 

  27. Clarke, E.M., Henzinger, Th.A., Veith, H., Bloem, R. (eds.): Handbook of Model Checking. Springer International Publishing, New York (2018)

    Google Scholar 

  28. Zave, P.: Classification of research efforts in requirements engineering. ACM Comput. Surv. (CSUR) 29(4), 315–321 (1997)

    Article  Google Scholar 

  29. Bennaceur, A., et al.: Requirements Engineering. Handbook of Software Engineering. pp. 51–92. Springer, Cham (2019)

    Google Scholar 

  30. Bradner, S.: Key words for use in RFCs to indicate requirement levels (1997). http://www.ietf.org/rfc/rfc2119.txt. Accessed 17 Jan 2021

  31. Mavin, A., et al.: Easy approach to requirements syntax (EARS). In: 2009 17th IEEE International Requirements Engineering Conference. IEEE (2009)

    Google Scholar 

  32. Pang, C., Pakonen, A., Buzhinsky, I., Vyatkin, V.: A study on user-friendly formal specification languages for requirements formalization. In: 2016 IEEE 14th International Conference on Industrial Informatics (INDIN), pp. 676–682. IEEE (2016)

    Google Scholar 

  33. Ljungkrantz, O., Åkesson, K., Fabian, M., Yuan, C.: A formal specification language for PLC-based control logic. In: 8th IEEE International Conference on Industrial Informatics, pp. 1067–1072. IEEE (2010)

    Google Scholar 

  34. Kuzmin, E.V., Ryabukhin, D.A., Sokolov, V.A.: On the expressiveness of the approach to constructing PLC-programs by LTL-specification. Autom. Control. Comput. Sci. 50(7), 510–519 (2016). https://doi.org/10.3103/S0146411616070130

    Article  Google Scholar 

  35. Chen, X., Han, L., Liu, J. Sun, H.: Using safety requirement patterns to elicit requirements for railway interlocking systems. In: 2016 IEEE 24th International Requirements Engineering Conference Workshops (REW), Beijing, 2016, pp. 296–303. IEEE (2016)

    Google Scholar 

  36. Dwyer, M.B., Avrunin, G.S., Corbett, J.C.: Patterns in property specifications for finite-state verification. In: Proceedings of the 21st International Conference on Software Engineering, pp. 411–420. IEEE Computer Society Press (1999)

    Google Scholar 

  37. Grunske, L.: Specification patterns for probabilistic quality properties. In: Proceedings of the 30th International Conference on Software Engineering (ICSE 2008), pp. 31–40. ACM, New York, NY (2008)

    Google Scholar 

  38. Bianculli, D., Ghezzi, C., Pautasso, C., Senti, P.: Specification patterns from research to industry: a case study in service-based applications. In: Proceedings of 34th International Conference on Software Engineering (ICSE), pp. 968–976. IEEE (2012)

    Google Scholar 

  39. Halle, S., Villemaire, R., Cherkaoui, O.: Specifying and validating data-aware temporal web service properties. IEEE Trans. Softw. Eng. 35(5), 669–683 (2009)

    Article  Google Scholar 

  40. Post, A., Menzel, I., Podelski, A.: Applying restricted English grammar on automotive requirements—does it work? A case study. In: Berry, D., Franch, X. (eds.) REFSQ 2011. LNCS, vol. 6606, pp. 166–180. Springer, Heidelberg (2011). https://doi.org/10.1007/978-3-642-19858-8_17

    Chapter  Google Scholar 

  41. Staroletov, S.: EDTL: Object-oriented implementation of the bounded checking algorithm for EDTL-requirements (2020). https://doi.org/10.5281/zenodo.4445663. Accessed 17 Jan 2021

Download references

Author information

Authors and Affiliations

Authors

Corresponding author

Correspondence to Vladimir Zyubin .

Editor information

Editors and Affiliations

A Bounded Checking of EDTL-requirements

A Bounded Checking of EDTL-requirements

In this appendix, we describe an algorithm which checks if an EDTL-requirement is satisfied for every finite initial path of a control system in some finite set of such paths. To check the EDTL-requirement tp, the algorithm follows the FOL-formula \(F_{tp}\) given in Sect. 3. For control system CS, we consider finite initial paths of length \(len > 0\). The algorithm (implemented in [41]) is defined by the C-like functions take and check. The EDTL-requirements tp is represented by a structure with the corresponding fields trigger, final and other, the path is represented by an array p storing the finite history of system states, and an array pp stands for a set of such paths. In contrast to the bounded model checking method, this algorithm does not explore every initial path of a verified system.

figure a

In Figure 3, we depict a class diagram based on our implementation [41] of the bounded checking algorithm for given EDTL-requirements. We implemented the EDTL-formulas as classes based on the EDTL terms. Then we encoded the R1..R5 requirements for our case study using information from Table 2. So the user can use provided classes by implementing their own system consisted of cases inherited from CheckableReq and overriding six methods that specify the requirements in terms of our logic. This integrates the requirements checking process into the unit testing process.

Fig. 3.
figure 3

Object-oriented implementation of the bounded checking algorithm for EDTL-requirements

Rights and permissions

Reprints and permissions

Copyright information

© 2021 IFIP International Federation for Information Processing

About this paper

Check for updates. Verify currency and authenticity via CrossMark

Cite this paper

Zyubin, V., Anureev, I., Garanina, N., Staroletov, S., Rozov, A., Liakh, T. (2021). Event-Driven Temporal Logic Pattern for Control Software Requirements Specification. In: Hojjat, H., Massink, M. (eds) Fundamentals of Software Engineering. FSEN 2021. Lecture Notes in Computer Science(), vol 12818. Springer, Cham. https://doi.org/10.1007/978-3-030-89247-0_7

Download citation

  • DOI: https://doi.org/10.1007/978-3-030-89247-0_7

  • Published:

  • Publisher Name: Springer, Cham

  • Print ISBN: 978-3-030-89246-3

  • Online ISBN: 978-3-030-89247-0

  • eBook Packages: Computer ScienceComputer Science (R0)

Publish with us

Policies and ethics