Skip to main content

Research projects in Information Technology

Displaying 11 - 14 of 14 projects.


Interactive Haskell Type Inference Exploration

Advanced strongly typed languages like Haskell and emerging type systems like refinement types (as implemented in Liquid Haskell) offer strong guarantees about the correctness of programs.  However, when type errors occur it can be difficult for programmers to understand their cause.  Such errors are particularly confusing for people learning the language.  The situation is not helped by the cryptic error messages often produced by compilers.

Supervisor: Prof Tim Dwyer

Immersive Network Visualisation

We live and work in a world of complex relationships between data, systems, knowledge, people, documents, biology, software, society, politics, commerce and so on.  We can model these relationships as networks or graphs in the hope of reasoning about them - but the tools that we have for understanding such network structured data (whether algorithmic analytics or visualisation tools) remain crude.  Emerging display and interaction devices such as augmented and virtual reality headsets offer new ways to visualise and interact with data in the world around us rather than on screens.  This…

Supervisor: Prof Tim Dwyer

Improving the usability of constraint-based layout for UI development in mobile apps

When designing user interfaces, developers want to be able to position objects in a structured way such that controls are clear and neat.  In the past, absolute positioning and grids have been used for this purpose.  However, such rigid layout doesn’t now allow adaptive layout for interfaces that run on a variety of screen sizes or that need different control sizes due to application being internationalised into foreign languages.  For this reason, Apple introduced constraint-based GUI layout under the name Auto Layout for iOS developers.  With…

Reimagining digital publishing for technical documents

Digital versions of technical documents, like textbooks and academic papers, are usually produced as static PDF files. Research has shown that working with these on electronic devices is frustrating and inefficient, partly because people do not read such documents in a linear fashion as they do novels.