X-Git-Url: https://git.stderr.nl/gitweb?p=matthijs%2Fmaster-project%2Freport.git;a=blobdiff_plain;f=Chapters%2FIntroduction.tex;h=1b24aced17e7153e055e276fe6393e0ee839deb1;hp=5b11f5d26f3306447338a70c778e9d92d6fbc1ea;hb=58a5aa7ca5edc07ba1070f4f4ed384b42e36e8f3;hpb=124f838008d9e63d36d6626ebeb453d9f83129dc diff --git a/Chapters/Introduction.tex b/Chapters/Introduction.tex index 5b11f5d..1b24ace 100644 --- a/Chapters/Introduction.tex +++ b/Chapters/Introduction.tex @@ -6,6 +6,13 @@ compilers and introduce the hardware description language Cλash that will connect these worlds and puts a step towards making hardware programming on the whole easier, more maintainable and generally more pleasant. +This assignment has been performed in close cooperation with Christiaan +Baaij, whose Master's thesis \cite[baaij09] has been completed at the +same time as this thesis. Where this thesis focuses on the +interpretation of the Haskell language and the compilation process, +\cite[baaij09] has a more thorough study of the field, explores more +advanced types and provides a case study. + % Use \subject to hide this section from the toc \subject{Research goals} This research started out with the notion that a functional program is very @@ -58,7 +65,7 @@ on the whole easier, more maintainable and generally more pleasant. % Draw a dotted line between the middle operations ncline(a2)(a3) "linestyle(dashed withdots)", "arrows(-)"; \stopuseMPgraphic - \placeexample[here][ex:AndWord]{Simple architecture that inverts a vector of bits.} + \placeexample[][ex:AndWord]{Simple architecture that inverts a vector of bits.} \startcombination[2*1] {\typebufferlam{AndWord}}{Haskell description of the architecture.} {\boxedgraphic{AndWord}}{The architecture described by the Haskell description.} @@ -141,7 +148,7 @@ on the whole easier, more maintainable and generally more pleasant. Or... is this the description of a single accumulating adder, that will add one element of each input each clock cycle and has a reset value of - 0\todo{normal 0}? In + {\definedfont[Serif*normalnum]0}? In that case, we would have described the architecture show in \in{example}[ex:RecursiveSumAlt] \startuseMPgraphic{RecursiveSumAlt} @@ -207,13 +214,13 @@ on the whole easier, more maintainable and generally more pleasant. \startitemize \item How to interpret recursion in descriptions? \item How to interpret polymorphism? - \item How to interpret higher order descriptions? + \item How to interpret higher-order descriptions? \stopitemize In addition to looking at designing a hardware description language, we will also implement a prototype to test ideas. This prototype will translate hardware descriptions written in the Haskell functional language - to simple (netlist-like) hardware descriptions in the \VHDL language. The + to simple (netlist-like) hardware descriptions in the \VHDL\ language. The reasons for choosing these languages are detailed in section \in{}[sec:prototype:input] and \in{}[sec:prototype:output] respectively. @@ -241,11 +248,11 @@ on the whole easier, more maintainable and generally more pleasant. In the first chapter, we will sketch the context for this research. The current state and history of hardware description languages will be briefly discussed, as well as the state and history of functional -programming. Since we're not the first to have merged these approaches, +programming. Since we are not the first to have merged these approaches, a number of other functional hardware description languages are briefly described. -Chapter two describes the exploratory part of this research: How can we +Chapter two describes the exploratory part of this research: how can we describe hardware using a functional language and how can we use functional concepts for hardware descriptions?