myriad of typos
[phd-thesis.git] / back / summary.tex
1 \documentclass[../thesis.tex]{subfiles}
2
3 \input{subfilepreamble}
4
5 \begin{document}
6 \input{subfileprefixsmall}
7 \ifSubfilesClassLoaded{\chapter*{Summary}}{\chapter{Summary}}%
8 \label{chp:summary}%
9 \glsresetall%
10 The number of computers around us is growing exponentially, compounding the complexity of the systems in which they operate.
11 Many of these computers are \emph{edge devices} operating in \gls{IOT} systems.
12 Within these orchestrations of computers, they interact with the environment using sensors and actuators.
13 Edge devices often use low-cost microcontrollers designed for embedded applications.
14 They have little memory, unhurried processors, and are slow in communication but are also small and energy efficient.
15 Programming \gls{IOT} systems is complex since they are dynamic, interactive, distributed, collaborative, multi-tiered, and multitasking in nature.
16 The complexity is increased further by semantic friction that arises through different hardware and software characteristics between tiers.
17
18 A solution is found in \gls{TOP}.
19 %A solution is found in the declarative programming paradigm \gls{TOP}.%, a declarative programming paradigm.
20 In \gls{TOP}, the main building blocks are tasks, an abstract representation of work.
21 During execution, the current value of the task is observable, and other tasks can act upon it.
22 Collaboration patterns can be modelled by combining and transforming tasks into compound tasks.
23 From this declarative description of the work, a ready-for-work computer system is generated that guides all operators in doing the work.
24 An example of a \gls{TOP} system is \gls{ITASK}, a language which describes interactive web applications.
25 Programming edge devices benefits from \gls{TOP} as well.
26 However, it is not straightforward to run \gls{TOP} systems on resource-constrained edge devices.
27
28 This dissertation demonstrates how to orchestrate complete \gls{IOT} systems using \gls{TOP}.
29 First, I present advanced \gls{DSL} embedding techniques.
30 Then \gls{MTASK} is shown, a \gls{TOP} \gls{DSL} for \gls{IOT} edge devices, embedded in \gls{ITASK}.
31 Tasks are constructed and compiled at run time.
32 This allows tasks to be tailor-made for the current work requirements.
33 The compiled task is sent to the device for interpretation.
34 For a device to be used in an \gls{MTASK} system, it is programmed once with a lightweight domain-specific \gls{OS}.
35 This \gls{OS} executes tasks in an energy-efficient way and automates all communications and data sharing.
36 All aspects of the \gls{MTASK} system are shown: example applications, language design, implementation details, integration with \gls{ITASK}, and green computing facilities.
37 When using \gls{MTASK} in conjunction with \gls{ITASK}, entire \gls{IOT} systems are programmed tierlessly from a single source, language, paradigm, high abstraction level, and type system.
38 Many problems such as semantic friction; maintainability and robustness issues; and interoperation safety are mitigated when using tierless programming.
39 %This is a summary of 350--400 words.
40 \end{document}