Executing behavioural definitions in Higher Order Logic

Over the past few years, computer scientists have been using formal verification techniques to show the correctness of digital systems. The verification process, however, is complicated and expensive. Even proofs of simple circuits can involve thousands of logical steps. Often it can be extremely di...

Full description

Bibliographic Details
Main Author: Camilleri, Albert John
Published: University of Cambridge 1988
Subjects:
Online Access:http://ethos.bl.uk/OrderDetails.do?uin=uk.bl.ethos.232795
id ndltd-bl.uk-oai-ethos.bl.uk-232795
record_format oai_dc
spelling ndltd-bl.uk-oai-ethos.bl.uk-2327952015-03-19T09:25:23ZExecuting behavioural definitions in Higher Order LogicCamilleri, Albert John1988Over the past few years, computer scientists have been using formal verification techniques to show the correctness of digital systems. The verification process, however, is complicated and expensive. Even proofs of simple circuits can involve thousands of logical steps. Often it can be extremely difficult to find correct device specifications and it is desirable that one sets off to prove a correct specification from the start, rather than repeatedly backtrack from the verification process to modify the original definitions after discovering they were incorrect or inaccurate. The main idea presented in the thesis is to amalgamate the techniques of simulation and verification, rather than have the latter replace the former. The result is that behavioural definitions can be simulated until one is reasonably sure that the specification is correct. Furthermore, providing the correctness with respect to these simulated specifications avoids the inadequacies of simulation, where it may not be computationally feasible to demonstrate correctness by exhaustive testing. Simulation here has a different purpose: to get specifications correct as early as possible in the verification process. Its purpose is not to demonstrate the correctness of the implementation - this is done in the verification stage when the very same specifications that were simulated are proven correct. The thesis discusses the implementation of an executable subset of the HOL logic, the version of Higher Order Logic embedded in the HOL theorem prover. It is shown that hardware can be effectively described using both relations and functions; relations being suitable for abstract specification, and functions being suitable for execution. The differences between relational and functional specifications are discussed and illustrated by the verification of an <i>n</i>-bit adder. Techniques for executing functional specifications are presented and various optimisation stratagies are shown which make the execution of the logic efficient. It is further shown that the process of generating optimised functional definitions from relational definitions can be automated. Example simulations of three hardware devices (a factorial machine, a small computer and a communications chip) are presented.621.39Hardware verificationUniversity of Cambridgehttp://ethos.bl.uk/OrderDetails.do?uin=uk.bl.ethos.232795Electronic Thesis or Dissertation
collection NDLTD
sources NDLTD
topic 621.39
Hardware verification
spellingShingle 621.39
Hardware verification
Camilleri, Albert John
Executing behavioural definitions in Higher Order Logic
description Over the past few years, computer scientists have been using formal verification techniques to show the correctness of digital systems. The verification process, however, is complicated and expensive. Even proofs of simple circuits can involve thousands of logical steps. Often it can be extremely difficult to find correct device specifications and it is desirable that one sets off to prove a correct specification from the start, rather than repeatedly backtrack from the verification process to modify the original definitions after discovering they were incorrect or inaccurate. The main idea presented in the thesis is to amalgamate the techniques of simulation and verification, rather than have the latter replace the former. The result is that behavioural definitions can be simulated until one is reasonably sure that the specification is correct. Furthermore, providing the correctness with respect to these simulated specifications avoids the inadequacies of simulation, where it may not be computationally feasible to demonstrate correctness by exhaustive testing. Simulation here has a different purpose: to get specifications correct as early as possible in the verification process. Its purpose is not to demonstrate the correctness of the implementation - this is done in the verification stage when the very same specifications that were simulated are proven correct. The thesis discusses the implementation of an executable subset of the HOL logic, the version of Higher Order Logic embedded in the HOL theorem prover. It is shown that hardware can be effectively described using both relations and functions; relations being suitable for abstract specification, and functions being suitable for execution. The differences between relational and functional specifications are discussed and illustrated by the verification of an <i>n</i>-bit adder. Techniques for executing functional specifications are presented and various optimisation stratagies are shown which make the execution of the logic efficient. It is further shown that the process of generating optimised functional definitions from relational definitions can be automated. Example simulations of three hardware devices (a factorial machine, a small computer and a communications chip) are presented.
author Camilleri, Albert John
author_facet Camilleri, Albert John
author_sort Camilleri, Albert John
title Executing behavioural definitions in Higher Order Logic
title_short Executing behavioural definitions in Higher Order Logic
title_full Executing behavioural definitions in Higher Order Logic
title_fullStr Executing behavioural definitions in Higher Order Logic
title_full_unstemmed Executing behavioural definitions in Higher Order Logic
title_sort executing behavioural definitions in higher order logic
publisher University of Cambridge
publishDate 1988
url http://ethos.bl.uk/OrderDetails.do?uin=uk.bl.ethos.232795
work_keys_str_mv AT camillerialbertjohn executingbehaviouraldefinitionsinhigherorderlogic
_version_ 1716769850304495616