Hughes, Andrew J (2010) DynamiTE:A 21st-Century Framework for Concurrent Component-Based Design. PhD thesis, University of Sheffield.
Abstract
The free ride for software developers is over. In the past, computer programs have increased in performance simply by running on new hardware with ever increasing clock speeds. Now, however, this line of development has reached its end and chip designers are producing new processors, not with faster clocks, but with more cores.
To take advantage of the speed increases offered by these new products, applications need to be redesigned with parallel processing firmly in mind.
The problem is that mainstream designs are still inherently sequential. Concurrency tends to be an afterthought that may be useful to gain a performance boost, not an essential part of the design process. The current vogue for object-oriented designs tends to also have the side-effect of making them heavily data-oriented which doesn't scale well; each shared element of data has to be protected from simultaneous access, resulting in operations becoming sequential again. In addition, the usual methods
for protecting data tend to be very low-level and error-prone.
In this thesis, we introduce a new design method whereby applications are constructed from small sequential tasks connected by intercommunication primitives. Our approach is based on a two-stage process; first, the individual tasks are created as independent entities and tested with appropriate inputs, then secondly, the communication infrastructure between them is developed. We provide
support for the latter via the DynamiTE framework, which allows the interactions to be defined using the terms of a process calculus.
Depending on the developer's background, they can treat this as just another API, as a design pattern or as an algebraic expression which can be property checked for issues such as deadlocks. Either way, the communication layer can be developed, tested and evaluated separately from the tasks once it is known how the tasks will interface with one
another.
To supplement DynamiTE, we define our own process calculus, Nomadic Time, using a carefully chosen novel selection of constructs. Among the features of the calculus are the ability to perform communication both locally (one-to-one) and globally (one-to-many), and the flexibility to change the location of tasks during execution.
Security is paramount to the design of Nomadic Time and migratory operations can be limited in two ways; by simple enumeration of possibilities or by the optional typing of constructs to allow restriction on a task-by-task basis.
While it can't eradicate all the problems inherent in designing concurrent applications, DynamiTE can make things easier by reducing the dependency on shared resources and enhancing the reusability of concurrent components.
Metadata
Supervisors: | Stannett, Mike P |
---|---|
Awarding institution: | University of Sheffield |
Academic Units: | The University of Sheffield > Faculty of Engineering (Sheffield) > Computer Science (Sheffield) The University of Sheffield > Faculty of Science (Sheffield) > Computer Science (Sheffield) |
Identification Number/EthosID: | uk.bl.ethos.521973 |
Depositing User: | Dr Andrew J Hughes |
Date Deposited: | 21 Jan 2016 15:18 |
Last Modified: | 03 Oct 2016 13:05 |
Open Archives Initiative ID (OAI ID): | oai:etheses.whiterose.ac.uk:10653 |
Download
DynamiTE: A 21st-Century Framework for Concurrent Component-Based Design
Filename: thesis.pdf
Description: DynamiTE: A 21st-Century Framework for Concurrent Component-Based Design
Licence:
This work is licensed under a Creative Commons Attribution-NonCommercial-NoDerivs 2.5 License
Export
Statistics
You do not need to contact us to get a copy of this thesis. Please use the 'Download' link(s) above to get a copy.
You can contact us about this thesis. If you need to make a general enquiry, please see the Contact us page.