Real-Time Java for Embedded Devices: the Javamen Project*

Total Page:16

File Type:pdf, Size:1020Kb

Real-Time Java for Embedded Devices: the Javamen Project* REAL-TIME JAVA FOR EMBEDDED DEVICES: THE JAVAMEN PROJECT* A. Borg, N. Audsley, A. Wellings The University of York, UK ABSTRACT: Hardware Java-specific processors have been shown to provide the performance benefits over their software counterparts that make Java a feasible environment for executing even the most computationally expensive systems. In most cases, the core of these processors is a simple stack machine on which stack operations and logic and arithmetic operations are carried out. More complex bytecodes are implemented either in microcode through a sequence of stack and memory operations or in Java and therefore through a set of bytecodes. This paper investigates the Figure 1: Three alternatives for executing Java code (take from (6)) state-of-the-art in Java processors and identifies two areas of improvement for specialising these processors timeliness as a key issue. The language therefore fails to for real-time applications. This is achieved through a allow more advanced temporal requirements of threads combination of the implementation of real-time Java to be expressed and virtual machine implementations components in hardware and by using application- may behave unpredictably in this context. For example, specific characteristics expressed at the Java level to whereas a basic thread priority can be specified, it is not drive a co-design strategy. An implementation of these required to be observed by a virtual machine and there propositions will provide a flexible Ravenscar- is no guarantee that the highest priority thread will compliant virtual machine that provides better preempt lower priority threads. In order to address this performance while still guaranteeing real-time shortcoming, two competing specifications have been requirements. introduced: the “Real-Time Core Extensions” from the J-Consortium (3) and the ``Real-Time Specification for 1. INTRODUCTION Java'' (RTSJ) (4) from Sun Microsystems. The former has not achieved the exposure of the RTSJ, though The Java programming model has become established attempts are now being made to combine the two in mainstream software development as a platform for standards for a safety-critical Java (5). general-purpose applications. The abstraction provided by the virtual machine realises the attractive Write- The Java Virtual Machine specification describes an Once-Run-Anywhere (WORA) concept. Initially abstract stack machine that executes byte-code, the created for developing software for consumer devices, it intermediate code of the Java language. The achieved its success in the rapid expansion of the implementation of this abstraction could be handled Internet for which the WORA concept found an ideal either as a middleware application on top of stock application. Today, Java is penetrating into more niche hardware and operating systems or by a direct hardware markets, from large enterprise applications to small implementation. The tradeoff between these two embedded devices such as mobile phones. In particular, approaches is one of cost and speed; hardware the Micro Edition of the Java 2 Platform (J2ME) implementations are fast but could be expensive. As provides an application development environment that with any programming language, Java code could be specifically addresses the needs of embedded devices compiled down to native code unique to a particular 1 such as personal digital assistants and set-top boxes. platform, thereby deriving a performance benefit at the cost of portability and a significantly larger code size. Despite this new focus on embedded devices, J2ME and This latter overhead occurs because the runtime the Java superset do not address the application domain semantics must be embedded in application code. These of real-time applications. Indeed, until recently, “Java” three approaches are depicted in Figure (1) as described and “real-time” were considered an oxymoron as Java in (6) for the picoJava processor. The majority of lacked the infrastructure to enable development of real- current deployments of Java virtual machine time systems. The specifications of both Language (1) implementations are of the first type. Even devices that and Virtual Machine (2) were never designed with provide J2ME implementations generally execute a software JVM with no Java-specific hardware support. * This work is funded by the Next Wave Technologies Program (UK Government DTI) in conjunction with Sun Microsystems. The JavaMen research project is being carried out at the 1 The J2ME combines a set of configurations, profiles and optional packages University of York to capture the requirements of a that can be combined together to provide this environment. Broadly speaking, this gives a subset of the full Java standard edition with cut-down functionality virtual machine implementation with hardware support in the virtual machine and a smaller set of core and application libraries. that is compatible with a high-integrity subset of the processors that adopt this approach, each with slightly RTSJ, the Ravenscar Java profile (7). Briefly, the two difference optimisations. In essence however, the goals of the JavaMen project are to: architectures are similar; they mostly implement a stack • Design and implement a minimal real-time machine architecture with simpler bytecodes being Java virtual machine to run as an IP-core. executed in a small number of cycles and more complex • Provide distribution functionality through ones executed in microcode or software. PicoJava's which an application may perform a remote optimisations include features such as instruction invocation to offload part of its computation. folding and bytecode prediction, aJile provides simple This paper focuses on the first goal by identifying the synchronisation and scheduling primitives in microcode research niches that are being addressed. The aim here whereas JOP opts for as minimal a model as required to is to motivate the proposed solutions currently under provide predictable real-time guarantees. Other implementation. As will be shown in the next section, examples of existing Java Processors are Moon (14), some areas of this field have already been extensively Lightfoot (15), LavaCore (16) and FemtoJava (17), each researched. While adopting whenever possible positive providing different stack-based implementations. results from existing research in our own LavaCore and FemtoJava allow an analysis of the implementation, this work is unique in that it optimises application to be carried out in order to fine-tune the for the real-time characteristics of the application while hardware generated, thereby providing an application- supporting a flexible co-design strategy for application- specific hardware solution. specific environments. In order to provide the best possible hardware support, The rest of this paper is set out as follows: Section 2 the JVM abstraction must be analysed in order to gives a brief overview of the state-of-the-art in Java identify the optimisations over a naive stack-machine processor research. Section 3 identifies the research implementation. In general this investigation is carried niches that are being addressed in the JavaMen project. out on a set of applications such as the SPECjvm98 (18) A brief description of the RTSJ and the basic principles benchmark suite with optimisations then being driven of hardware/software co-design is provided here in by the ``average'' application. The literature contains order to set the context of this work. Section 4 several examples of research into the characterisation of introduces the proposed solutions and, finally, Section 5 the Java runtime but with the goal generally being to concludes. drive the design of software JVMs. In (19,20), the authors use trace information to optimise components of 2. HARDWARE SUPPORT FOR REAL-TIME the runtime such as the method cache and the decision JAVA strategy of the JIT compiler. Other work applicable to software JVMs can also be used in hardware In 1996, Romer et. al. argued that there existed so much implementations. Examples include the optimisation of possible optimisation of standard Java runtimes that JVM operations such as synchronisation (21) and using proposing hardware support was premature (8). This is common application characteristics such as the average contentious statement given that software runtimes are size of objects in making caching decisions. emulations of the Java abstract machine and that proposed optimisations are only targeted at better El-Kharashi et. al. carry out a two-part investigation emulation. However, given the poor optimisation of into the architectural requirements of a Java software virtual machines at the time, this statement was microprocessors (22, 23). The goal of the work is to probably true. A number of early hardware direct the instruction set design of a hardware JVM by implementations of the Java virtual machine were discovering the common cases of bytecode execution. developed soon after this time but none reached any Their approach is to to insert probes into the main significant levels of distribution. As optimisation of interpretation loop of a software JVM in order to software implementations reaches its peak, hardware calculate information such as the frequency of execution support is once again beginning to prove necessary in and time cost of each bytecode when executing a given order to overcome the performance barrier of Java test-bench application. Other information collected interpretation (and just-in-time runtime compilation)
Recommended publications
  • Java (Programming Langua a (Programming Language)
    Java (programming language) From Wikipedia, the free encyclopedialopedia "Java language" redirects here. For the natural language from the Indonesian island of Java, see Javanese language. Not to be confused with JavaScript. Java multi-paradigm: object-oriented, structured, imperative, Paradigm(s) functional, generic, reflective, concurrent James Gosling and Designed by Sun Microsystems Developer Oracle Corporation Appeared in 1995[1] Java Standard Edition 8 Update Stable release 5 (1.8.0_5) / April 15, 2014; 2 months ago Static, strong, safe, nominative, Typing discipline manifest Major OpenJDK, many others implementations Dialects Generic Java, Pizza Ada 83, C++, C#,[2] Eiffel,[3] Generic Java, Mesa,[4] Modula- Influenced by 3,[5] Oberon,[6] Objective-C,[7] UCSD Pascal,[8][9] Smalltalk Ada 2005, BeanShell, C#, Clojure, D, ECMAScript, Influenced Groovy, J#, JavaScript, Kotlin, PHP, Python, Scala, Seed7, Vala Implementation C and C++ language OS Cross-platform (multi-platform) GNU General Public License, License Java CommuniCommunity Process Filename .java , .class, .jar extension(s) Website For Java Developers Java Programming at Wikibooks Java is a computer programming language that is concurrent, class-based, object-oriented, and specifically designed to have as few impimplementation dependencies as possible.ble. It is intended to let application developers "write once, run ananywhere" (WORA), meaning that code that runs on one platform does not need to be recompiled to rurun on another. Java applications ns are typically compiled to bytecode (class file) that can run on anany Java virtual machine (JVM)) regardless of computer architecture. Java is, as of 2014, one of tthe most popular programming ng languages in use, particularly for client-server web applications, witwith a reported 9 million developers.[10][11] Java was originallyy developed by James Gosling at Sun Microsystems (which has since merged into Oracle Corporation) and released in 1995 as a core component of Sun Microsystems'Micros Java platform.
    [Show full text]
  • Zing:® the Best JVM for the Enterprise
    PRODUCT DATA SHEET Zing:® ZING The best JVM for the enterprise Zing Runtime for Java A JVM that is compatible and compliant The Performance Standard for Low Latency, with the Java SE specification. Zing is a Memory-Intensive or Interactive Applications better alternative to your existing JVM. INTRODUCING ZING Zing Vision (ZVision) Today Java is ubiquitous across the enterprise. Flexible and powerful, Java is the ideal choice A zero-overhead, always-on production- for development teams worldwide. time monitoring tool designed to support rapid troubleshooting of applications using Zing. Zing builds upon Java’s advantages by delivering a robust, highly scalable Java Virtual Machine ReadyNow! Technology (JVM) to match the needs of today’s real time enterprise. Zing is the best JVM choice for all Solves Java warm-up problems, gives Java workloads, including low-latency financial systems, SaaS or Cloud-based deployments, developers fine-grained control over Web-based eCommerce applications, insurance portals, multi-user gaming platforms, Big Data, compilation and allows DevOps to save and other use cases -- anywhere predictable Java performance is essential. and reuse accumulated optimizations. Zing enables developers to make effective use of memory -- without the stalls, glitches and jitter that have been part of Java’s heritage, and solves JVM “warm-up” problems that can degrade ZING ADVANTAGES performance at start up. With improved memory-handling and a more stable, consistent runtime Takes advantage of the large memory platform, Java developers can build and deploy richer applications incorporating real-time data and multiple CPU cores available in processing and analytics, driving new revenue and supporting new business innovations.
    [Show full text]
  • S32 Design Studio for S32 Platform 3.4 Installation Guide
    S32 Design Studio for S32 Platform 3.4 Installation Guide Document Number: S32DSIG Rev. 1.0, 12/2020 Contents System Requirements......................................................................................................................3 Installation prerequisites for Linux platforms.............................................................................5 Downloading S32DS 3.4................................................................................................................12 Downloading the S32DS 3.4 installer................................................................................................................12 Obtaining the activation code.............................................................................................................................12 Installing S32DS 3.4......................................................................................................................14 Debian 8 post-installation settings..................................................................................................................... 20 Installing product updates and packages................................................................................... 23 Installing Synopsys tools...............................................................................................................25 Installing VP Explorer........................................................................................................................................25 Post-installation settings....................................................................................................................................
    [Show full text]
  • Optimizing for Jazelle DBX and Java Hotspot™ Technology Case Study
    Optimizing Midlets for Size and Performance Simon Robinson Innaworks www.innaworks.com TS-5109 2007 JavaOneSM Conference | Session TS-5109 | Goal of This Talk Pushing the size and performance of Java™ Platform, Micro Edition (Java ME platform) applications on today’s handsets 2007 JavaOneSM Conference | Session TS-5109 | 2 Agenda Why size and performance matters Under the bonnet of a Java ME Platform MIDlet Optimization strategy Optimization techniques Optimizing for Jazelle DBX and Java HotSpot™ technology Case study 2007 JavaOneSM Conference | Session TS-5109 | 3 Agenda Why size and performance matters Under the bonnet of a Java ME Platform MIDlet Optimization strategy Optimization techniques Optimizing for Jazelle DBX and Java HotSpot™ technology Case study 2007 JavaOneSM Conference | Session TS-5109 | 4 Why Size and Performance Matters Adoption = Potential market size × How much fun ×Marketing 2007 JavaOneSM Conference | Session TS-5109 | 5 Why Size and Performance Matters Adoption = Potential market size × How much fun ×Marketing Handset coverage matters 2007 JavaOneSM Conference | Session TS-5109 | 6 Why Size and Performance Matters Adoption = Potential market size × How much fun ×Marketing How fun is your game? Perceived quality matters 2007 JavaOneSM Conference | Session TS-5109 | 7 Constraints of Consumer Handsets JAR size Heap memory Nokia S40 v1 (3300, etc.) 64 kB 370 kB Nokia S40 v2 (6230, etc.) 128 kB 512 kB Sharp GX22 100 kB 512 kB DoJa 2.5 (m420i) 30 B 1.5 MB 15% game sales for handsets < 64 kB Java Archive (JAR) file size
    [Show full text]
  • Java in Embedded Linux Systems
    Java in Embedded Linux Systems Java in Embedded Linux Systems Thomas Petazzoni / Michael Opdenacker Free Electrons http://free-electrons.com/ Created with OpenOffice.org 2.x Java in Embedded Linux Systems © Copyright 2004-2007, Free Electrons, Creative Commons Attribution-ShareAlike 2.5 license http://free-electrons.com Sep 15, 2009 1 Rights to copy Attribution ± ShareAlike 2.5 © Copyright 2004-2008 You are free Free Electrons to copy, distribute, display, and perform the work [email protected] to make derivative works to make commercial use of the work Document sources, updates and translations: Under the following conditions http://free-electrons.com/articles/java Attribution. You must give the original author credit. Corrections, suggestions, contributions and Share Alike. If you alter, transform, or build upon this work, you may distribute the resulting work only under a license translations are welcome! identical to this one. For any reuse or distribution, you must make clear to others the license terms of this work. Any of these conditions can be waived if you get permission from the copyright holder. Your fair use and other rights are in no way affected by the above. License text: http://creativecommons.org/licenses/by-sa/2.5/legalcode Java in Embedded Linux Systems © Copyright 2004-2007, Free Electrons, Creative Commons Attribution-ShareAlike 2.5 license http://free-electrons.com Sep 15, 2009 2 Best viewed with... This document is best viewed with a recent PDF reader or with OpenOffice.org itself! Take advantage of internal
    [Show full text]
  • Paper Discusses the Advantages and Disadvantages of Each Approach As Well As Specific Experiences of Using Java in a Commercial Tape Drive Project
    Java and Real Time Storage Applications Gary Mueller 195 Garnet St Broomfield, CO 80020-2203 [email protected] Tel: +1-303-465-4279 Janet Borzuchowski Storage Technology Corporation 2270 South 88th Street M. S. 4272 Louisville CO 80028 [email protected] Tel: +1-303-673-8297 Abstract Storage systems have storage devices which run real time embedded software. Most storage devices use C and occasionally C++ to manage and control the storage device. Software for the storage device must meet the time and resource constraints of the storage device. The prevailing wisdom in the embedded world is that objects and in particular Java only work for simple problems and can not handle REAL problems, are too slow and can not handle time critical processing and are too big and can’t fit in memory constrained systems. Even though Java's roots are in the embedded application area, Java is more widely used in the desktop and enterprise environment. Use of Java in embedded real time environments where performance and size constraints rule is much less common. Java vendors offer a dizzying array of options, products and choices for real time storage applications. Four main themes emerge when using Java in a real time storage application; compiling Java, executing Java with a software Java Virtual Machine (JVM), executing Java with a hardware JVM and replacing a real time operating system (RTOS) with a JVM. The desktop and enterprise environment traditionally run Java using a software JVM that has been ported to a particular platform. The JVM runs as a task or process hosted by the platform operating system.
    [Show full text]
  • Dalvik Bytecode Acceleration Using Fetch/Decode Hardware Extension
    Journal of Information Processing Vol.23 No.2 118–130 (Mar. 2015) [DOI: 10.2197/ipsjjip.23.118] Regular Paper Dalvik Bytecode Acceleration Using Fetch/Decode Hardware Extension Surachai Thongkaew1,a) Tsuyoshi Isshiki1,b) Dongju Li1,c) Hiroaki Kunieda1,d) Received: May 6, 2014, Accepted: November 10, 2014 Abstract: The Dalvik virtual machine (Dalvik VM) is an essential piece of software that runs applications on the Android operating system. Android application programs are commonly written in the Java language and compiled to Java bytecode. The Java bytecode is converted to Dalvik bytecode (Dalvik Executable file) which is interpreted by the Dalvik VM on typical Android devices. The significant disadvantage of interpretation is a much slower speed of program execution compared to direct machine code execution on the host CPU. However, there are many tech- niques to improve the performance of Dalvik VM. A typical methodology is just-in-time compilation which converts frequently executed sequences of interpreted instruction to host machine code. Other methodologies include dedi- cated bytecode processors and architectural extension on existing processors. In this paper, we propose an alternative methodology, “Fetch & Decode Hardware Extension,” to improve the performance of Dalvik VM. The Fetch & De- code Hardware Extension is a specially designed hardware component to fetch and decode Dalvik bytecode directly, while the core computations within the virtual registers are done by the optimized Dalvik bytecode software handler. The experimental results show the speed improvements on Arithmetic instructions, loop & conditional instructions and method invocation & return instructions, can be achieved up to 2.4x, 2.7x and 1.8x, respectively.
    [Show full text]
  • Java Performance Mysteries
    ITM Web of Conferences 7 09015 , (2016) DOI: 10.1051/itmconf/20160709015 ITA 2016 Java Performance Mysteries Pranita Maldikar, San-Hong Li and Kingsum Chow [email protected], {sanhong.lsh, kingsum.kc}@alibaba-inc.com Abstract. While assessing software performance quality in the cloud, we noticed some significant performance variation of several Java applications. At a first glance, they looked like mysteries. To isolate the variation due to cloud, system and software configurations, we designed a set of experiments and collected set of software performance data. We analyzed the data to identify the sources of Java performance variation. Our experience in measuring Java performance may help attendees in selecting the trade-offs in software configurations and load testing tool configurations to obtain the software quality measurements they need. The contributions of this paper are (1) Observing Java performance mysteries in the cloud, (2) Identifying the sources of performance mysteries, and (3) Obtaining optimal and reproducible performance data. 1 Introduction into multiple tiers like, client tier, middle-tier and data tier. For testing a Java EE workload theclient tier would Java is both a programming language and a platform. be a load generator machine using load generator Java as a programming language follows object-oriented software like Faban [2]. This client tier will consist of programming model and it requires Java Virtual users that will send the request to the application server Machine (Java Interpreter) to run Java programs. Java as or the middle tier.The middle tier contains the entire a platform is an environment on which we can deploy business logic for the enterprise application.
    [Show full text]
  • Introduction À Java
    Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/ Février 2018 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/31 Histoire et motivations Langage développé par James Gosling chez Sun Microsystems (Oracle) à partir de 1990 Pour des environnements embarqués : appareils spécifiques ("Appliances") applications Web Contraintes : indépendant du matériel sécurité 3/31 La machine virtuelle Java Le langage Java utilise une machine virtuelle : le compilateur produit un bytecode ce code est indépendant de l’architecture matérielle sur laquelle il est exécuté la machine virtuelle interprète ce bytecode et le transforme en code machine natif à la volée (Just in time compilation) 4/31 Machines virtuelles Java HotSpot (Oracle JRE/JDK) OpenJDK, IcedTea Implémentations sous licence libre ART Android Runtime (Google) (Dalvik) Jazelle extension du jeu d’instruction de certains processeurs ARMv5 pour exécution directe de byte-code java. ThumbEE généralisation de Jazelle sur processeurs ARMv7. Pas spécifique de Java (supporte aussi C#, Perl, Python) 5/31 Cycle de développement Editeur de texte Compilation Exécution Hello, World Hello.java javac Hello.class java 6/31 Premier programme java /** ** Premier programme java **/ public class Hello { public static void main(String argv[]) { System.out.println("Hello, World!"); } } 7/31 Classes et objets Classe définit un type de données, et des fonctions (méthodes) qui le manipulent. Objet une instance de classe : une variable du type définit par la classe et ses méthodes. Héritage permet de créer des classes qui reprennent les données de la classe parente. Interface définition des prototypes des méthodes d’une classe sans préciser leur implémentation.
    [Show full text]
  • Performance Comparison of Java and C++ When Sorting Integers and Writing/Reading Files
    Bachelor of Science in Computer Science February 2019 Performance comparison of Java and C++ when sorting integers and writing/reading files. Suraj Sharma Faculty of Computing, Blekinge Institute of Technology, 371 79 Karlskrona, Sweden This thesis is submitted to the Faculty of Computing at Blekinge Institute of Technology in partial fulfilment of the requirements for the degree of Bachelor of Science in Computer Sciences. The thesis is equivalent to 20 weeks of full-time studies. The authors declare that they are the sole authors of this thesis and that they have not used any sources other than those listed in the bibliography and identified as references. They further declare that they have not submitted this thesis at any other institution to obtain a degree. Contact Information: Author(s): Suraj Sharma E-mail: [email protected] University advisor: Dr. Prashant Goswami Department of Creative Technologies Faculty of Computing Internet : www.bth.se Blekinge Institute of Technology Phone : +46 455 38 50 00 SE-371 79 Karlskrona, Sweden Fax : +46 455 38 50 57 ii ABSTRACT This study is conducted to show the strengths and weaknesses of C++ and Java in three areas that are used often in programming; loading, sorting and saving data. Performance and scalability are large factors in software development and choosing the right programming language is often a long process. It is important to conduct these types of direct comparison studies to properly identify strengths and weaknesses of programming languages. Two applications were created, one using C++ and one using Java. Apart from a few syntax and necessary differences, both are as close to being identical as possible.
    [Show full text]
  • Traffic Congestion Problems Solving
    Using Sense Techniques to Develop a Traffic Control System for Solving Traffic Congestion Problem By Omima Kamal El Din Omer Mohamed B.Sc. Applied Physics and Mathematics Ahlia University, 1999 A Dissertation Submitted in Partial Fulfillment of the Requirements of the Degree of Master of Science In Computer Science and Information Department of Computer Engineering Faculty of Engineering and Technology University of Gezira Supervisor: Dr. Suliman Mustafa Mohamed Abbker Co- supervisor:Dr.Khalid Osman Daffallah Ahmed October 2011 Using Sense Techniques to Develop a Traffic Control System for Solving Traffic Congestion Problem By Omima Kamal El Din Omer Mohamed Examination Committee : Name Position Signature Dr. Suliman Mustafa Mohamed Abbker Supervisor …………. Dr. Mahmoud Ali Ahmed Mohamed External Examiner …………. Dr. Mohamed Abdalla Adam Almaleh Internal Examiner …………. Date of Examination: 22 / 10/2011 بسم اهلل الرحمن الرحيم قال تعالى: ِ ِ ِ َّ ِ ِ ِ ) اللّهُ ﻻَ إلَهَ إﻻَّ ُهَو الْ َح ُّي الَْقيُّومُ ﻻَ تَأْ ُخ ُذهُ سنَةٌ َوﻻَ نَ ْومٌ لهُ َما في ال َّسَماَوات َوَما في اﻷَْر ِض َمن ذَا َِّ ِ ِ ِِ ِِ ِ ِ ِ ِ ٍ ِ ِ ِ ِ ِ الذي يَ ْشَف ُع عْن َدهُ إﻻَّ بإ ْذنه يَ ْعلَ ُم َما بَ ْي َن أَيْديه ْم َوَم ا َخْلَفُه ْم َوﻻَ يُحيطُوَن ب َش ْيء ِّم ْن عْلمه إﻻَّ بَما ِ ِ ِ ِ ِ ِ َشاء َوس َع ُكْرسيُّهُ ال َّسَماَوات َواﻷَْر َض َوﻻَ يَ ُؤوُدهُ حْفظُُهَما َوُهَو الَْعل ُّي الَْعظيم( صدق اهلل العظيم سورة البقرة اﻵية )255( i Dedication To the soul of my Father, the first to teach me.
    [Show full text]
  • Design and Analysis of a Scala Benchmark Suite for the Java Virtual Machine
    Design and Analysis of a Scala Benchmark Suite for the Java Virtual Machine Entwurf und Analyse einer Scala Benchmark Suite für die Java Virtual Machine Zur Erlangung des akademischen Grades Doktor-Ingenieur (Dr.-Ing.) genehmigte Dissertation von Diplom-Mathematiker Andreas Sewe aus Twistringen, Deutschland April 2013 — Darmstadt — D 17 Fachbereich Informatik Fachgebiet Softwaretechnik Design and Analysis of a Scala Benchmark Suite for the Java Virtual Machine Entwurf und Analyse einer Scala Benchmark Suite für die Java Virtual Machine Genehmigte Dissertation von Diplom-Mathematiker Andreas Sewe aus Twistrin- gen, Deutschland 1. Gutachten: Prof. Dr.-Ing. Ermira Mezini 2. Gutachten: Prof. Richard E. Jones Tag der Einreichung: 17. August 2012 Tag der Prüfung: 29. Oktober 2012 Darmstadt — D 17 For Bettina Academic Résumé November 2007 – October 2012 Doctoral studies at the chair of Prof. Dr.-Ing. Er- mira Mezini, Fachgebiet Softwaretechnik, Fachbereich Informatik, Techni- sche Universität Darmstadt October 2001 – October 2007 Studies in mathematics with a special focus on com- puter science (Mathematik mit Schwerpunkt Informatik) at Technische Uni- versität Darmstadt, finishing with a degree of Diplom-Mathematiker (Dipl.- Math.) iii Acknowledgements First and foremost, I would like to thank Mira Mezini, my thesis supervisor, for pro- viding me with the opportunity and freedom to pursue my research, as condensed into the thesis you now hold in your hands. Her experience and her insights did much to improve my research as did her invaluable ability to ask the right questions at the right time. I would also like to thank Richard Jones for taking the time to act as secondary reviewer of this thesis.
    [Show full text]