Aplicación Domótica Mediante Arduino Y Programación Android

Total Page:16

File Type:pdf, Size:1020Kb

Aplicación Domótica Mediante Arduino Y Programación Android Aplicación Domótica mediante Arduino y Programación Android TITULACIÓN: Enginyeria Automàtica i Electrònica Industrial AUTOR: Luis Rolin Almagro DIRECTOR: Albert Oller Pujol FECHA: Junio / 2014. Índice 1. Descripción de proyecto ......................................................................................3 2. Arduino ...............................................................................................................4 2.1. Historia .........................................................................................................4 2.2. Hardware ......................................................................................................6 2.3. Arduino Software .........................................................................................9 2.3.1. Arduino Software ....................................................................................9 2.3.2. Concurrency ...........................................................................................9 2.3.3. DK-Basic ................................................................................................9 2.3.4. NanoVM .................................................................................................9 3.3.5 Amforth ...................................................................................................9 3. Android ............................................................................................................. 11 3.1. Historia ....................................................................................................... 11 3.2. Entorno de programación .......................................................................... 14 3.2.1. Eclipse. Java para Android ................................................................... 14 3.2.2. Basic4Android ...................................................................................... 14 3.2.3. Mono para Android .............................................................................. 14 3.2.4. App Inventor ......................................................................................... 15 3.2.5. LiveCode ............................................................................................... 15 4. La Aplicación. DomoAndruino ......................................................................... 18 4.1. La Capa Hardware ..................................................................................... 18 4.2. La Capa Software Arduino ........................................................................ 26 4.3. La Capa Software Android ........................................................................ 28 4.3.1. Librerías Utilizadas ............................................................................... 28 4.3.2. Interfaz Gráfica .................................................................................... 29 4.3.3. Núcleo de la aplicación ......................................................................... 34 4.4. Presupuesto ................................................................................................. 36 5. Conclusiones ...................................................................................................... 37 Anexo A. Bibliografía ........................................................................................... 38 Anexo B. Datasheets .............................................................................................. 39 Anexo C. Esquemático .......................................................................................... 40 Anexo D. Código Arduino .................................................................................... 42 Anexo E. Código Android ..................................................................................... 46 2 1. Descripción de proyecto Las tecnologías de la información y de la comunicación (TIC) son una parte omnipresente y dominante de la vida moderna. El mundo conectado o también conocido como el “internet de las cosas” hace que cada vez tengamos más elementos tecnológicos a nuestro alrededor, y al mismo tiempo conectados a internet, incluso dentro de nuestro propio hogar: ordenadores, teléfonos móviles, televisores y cada vez más, lavadoras, frigoríficos, incluso cepillos de dientes. A la vez, tenemos el creciente interés en el diseño de prototipos hardware basados en la filosofía Do It Yourself (DIY) abanderada por la plataforma de Arduino, que permiten que ingenieros y aficionados a la electrónica puedan llevar a cabo sus proyectos reduciendo el capital a invertir. Además, el desarrollo de aplicaciones para móviles que nos permiten interactuar con dichos elementos, a coste cero gracias a Android y su plataforma de software libre (el cual representa el 72% de los móviles inteligentes vendidos en el mundo), nos llevan a la gestación de este proyecto, que consiste en crear una solución asequible para la monitorización de diversas características de interés a tener en cuenta en un hogar y el control básico de algunas funcionalidades. Para llevar este proyecto a término se ha optado por las dos soluciones mencionadas anteriormente, de hardware y software libre, Arduino y Android respectivamente. En nuestro caso concreto trataremos de monitorizar las siguientes variables comunes en cualquier hogar: • temperatura • humedad • ruido • humo • un sistema de alarma con detector de presencia • control de luces y persianas • control del aire acondicionado y calefacción Además mediante el uso de una cámara IP podemos realizar un control visual del recinto, y gracias a las características de motorización de la cámara y de visión nocturna podremos controlar grandes espacios incluso de noche. Con todas estas características, el objetivo es crear un sistema sencillo, intuitivo y de bajo coste, que a la vez sea robusto y configurable. Primeramente, comentaremos las principales características de las dos plataformas que hemos utilizado, tanto hardware como software, así como las diferentes opciones en el mercado para trabajar con ellas. Más tarde, una vez introducidas las dos plataformas, pasaremos a comentar la aplicación que hemos creado: DomoAndruino, resultado final de este proyecto. 3 2. Arduino Arduino es una placa de bajo coste con microcontrolador que permite incluso a un novato llevar a cabo sus proyectos. Arduino puede ser conectado a todo tipo de sensores, luces, motores y otros dispositivos y utilizar un software, fácil de aprender, para programar la aplicación que correrá en el hardware. 2.1. Historia Lanzado en el 2005 como una modesta herramienta creada por Massimo Banzi, un profesor del Instituto de Diseño Interactivo de Ivrea (IDII) y algunos de sus estudiantes, Arduino ha generado una revolución en la electrónica a nivel internacional del “DIY”. Se puede comprar una placa de Arduino por unos 30€ o construirse una propia desde cero. Todos los esquemas del hardware y código fuente están disponibles de forma gratuita bajo licencias públicas. Como resultado, Arduino se ha convertido en el movimiento del hardware open-source más influyente de su Fig. 1. Logo de Arduino tiempo. Arduino surgió de otro tremendo desafío: cómo enseñar a los estudiantes a crear electrónica, de forma rápida. Era el año 2002 y Banzi, un arquitecto de software, fue traído por el IDII como profesor asociado para promover nuevas formas de hacer diseño interactivo- un campo emergente conocido a veces como informática física. Pero con un presupuesto reducido y tiempo limitado, sus opciones para la técnica eran escasas. Al igual que muchos de sus colegas, Banzi confió en el BASIC Stamp, un microcontrolador creado por la compañía californiana Parallax el cual fue usado por los ingenieros durante casi una década. Codificado con el lenguaje de programación BASIC, el Stamp era como una pequeña placa, que contenía lo esencial: fuente de alimentación, un microcontrolador, memoria y puertos de entradas y salidas para el hardware agregado. Pero Banzi descubrió que el BASIC Stamp tenía dos problemas, no tenía suficiente potencia de computación para alguno de los proyectos que sus estudiantes tenían en mente, y además era un poco caro -una placa más las partes básicas podría costar alrededor de los 100€. Además él necesitaba algo que pudiera funcionar en ordenadores Macintosh, los cuales eran comunes entre los diseñadores del IDII. Por lo que se plateó crear una placa que se adaptase a sus propias necesidades. Banzi y sus colaboradores eran grandes partidarios del software de código abierto, puesto que el propósito era crear una plataforma rápida y de fácil acceso. Otro factor que contribuyó a tomar esta decisión fue que después de cinco años de funcionamiento, el IDII se estaba quedando sin fondos y se temía que podría cerrar sus puertas. El modelo de código abierto se ha utilizado durante mucho tiempo para impulsar la innovación para el campo del software, pero no ha sucedido así con el hardware. Para hacerlo funcionar, tuvieron que encontrar una solución apropiada de licencias que pudiese aplicarse a su proyecto. Después de algunas investigaciones, se dieron cuenta de que si simplemente miraban a su proyecto de manera diferente, se podría utilizar una licencia de Creative Commons, el grupo sin fines de lucro cuyos acuerdos se utilizan normalmente para las obras culturales, como la música y la literatura. 4 La primera placa de prototipo, realizado en 2005, fue un diseño simple, y no fue llamado Arduino aunque Massimo Banzi acuñó el nombre ese mismo año. Fig. 2. Prototipo del primer Arduino Para fabricar
Recommended publications
  • A Post-Apocalyptic Sun.Misc.Unsafe World
    A Post-Apocalyptic sun.misc.Unsafe World http://www.superbwallpapers.com/fantasy/post-apocalyptic-tower-bridge-london-26546/ Chris Engelbert Twitter: @noctarius2k Jatumba! 2014, 2015, 2016, … Disclaimer This talk is not going to be negative! Disclaimer But certain things are highly speculative and APIs or ideas might change by tomorrow! sun.misc.Scissors http://www.underwhelmedcomic.com/wp-content/uploads/2012/03/runningdude.jpg sun.misc.Unsafe - What you (don’t) know sun.misc.Unsafe - What you (don’t) know • Internal class (sun.misc Package) sun.misc.Unsafe - What you (don’t) know • Internal class (sun.misc Package) sun.misc.Unsafe - What you (don’t) know • Internal class (sun.misc Package) • Used inside the JVM / JRE sun.misc.Unsafe - What you (don’t) know • Internal class (sun.misc Package) • Used inside the JVM / JRE // Unsafe mechanics private static final sun.misc.Unsafe U; private static final long QBASE; private static final long QLOCK; private static final int ABASE; private static final int ASHIFT; static { try { U = sun.misc.Unsafe.getUnsafe(); Class<?> k = WorkQueue.class; Class<?> ak = ForkJoinTask[].class; example: QBASE = U.objectFieldOffset (k.getDeclaredField("base")); java.util.concurrent.ForkJoinPool QLOCK = U.objectFieldOffset (k.getDeclaredField("qlock")); ABASE = U.arrayBaseOffset(ak); int scale = U.arrayIndexScale(ak); if ((scale & (scale - 1)) != 0) throw new Error("data type scale not a power of two"); ASHIFT = 31 - Integer.numberOfLeadingZeros(scale); } catch (Exception e) { throw new Error(e); } } } sun.misc.Unsafe
    [Show full text]
  • Android Cours 1 : Introduction `Aandroid / Android Studio
    Android Cours 1 : Introduction `aAndroid / Android Studio Damien MASSON [email protected] http://www.esiee.fr/~massond 21 f´evrier2017 R´ef´erences https://developer.android.com (Incontournable !) https://openclassrooms.com/courses/ creez-des-applications-pour-android/ Un tutoriel en fran¸caisassez complet et plut^ot`ajour... 2/52 Qu'est-ce qu'Android ? PME am´ericaine,Android Incorporated, cr´e´eeen 2003, rachet´eepar Google en 2005 OS lanc´een 2007 En 2015, Android est le syst`emed'exploitation mobile le plus utilis´edans le monde (>80%) 3/52 Qu'est-ce qu'Android ? Cinq couches distinctes : 1 le noyau Linux avec les pilotes ; 2 des biblioth`equeslogicielles telles que WebKit/Blink, OpenGL ES, SQLite ou FreeType ; 3 un environnement d'ex´ecutionet des biblioth`equespermettant d'ex´ecuterdes programmes pr´evuspour la plate-forme Java ; 4 un framework { kit de d´eveloppement d'applications ; 4/52 Android et la plateforme Java Jusqu'`asa version 4.4, Android comporte une machine virtuelle nomm´eeDalvik Le bytecode de Dalvik est diff´erentde celui de la machine virtuelle Java de Oracle (JVM) le processus de construction d'une application est diff´erent Code Java (.java) ! bytecode Java (.class/.jar) ! bytecode Dalvik (.dex) ! interpr´et´e L'ensemble de la biblioth`equestandard d'Android ressemble `a J2SE (Java Standard Edition) de la plateforme Java. La principale diff´erenceest que les biblioth`equesd'interface graphique AWT et Swing sont remplac´eespar des biblioth`equesd'Android. 5/52 Android Runtime (ART) A` partir de la version 5.0 (2014), l'environnement d'ex´ecution ART (Android RunTime) remplace la machine virtuelle Dalvik.
    [Show full text]
  • The Use of Java in the Context of AUTOSAR 4.0
    The Use of Java in the Context of AUTOSAR 4.0 Expectations and Possibilities Christian Wawersich [email protected] MethodPark Software AG, Germany Isabella Thomm Michael Stilkerich {ithomm,stilkerich}@cs.fau.de Friedrich-Alexander University Erlangen-Nuremberg, Germany ABSTRACT architecture for system functionality and drivers in automo- Modern cars contain a large number of diverse microcon- tive software. It is motivated by the growing complexity of trollers for a wide range of tasks, which imposes high efforts software functionality provided in cars and facilitates the in the integration process of hardware and software. There integration of multiple applications on fewer, more powerful is a paradigm shift from a federated architecture to an inte- microcontrollers. grated architecture with commonly used resources to reduce Standardized, tested software modules as specified by AU- complexity, costs, weight and energy. TOSAR are shown to contain less software bugs. However, AUTOSAR [3] is a system platform that allows the inte- only a part of a complete AUTOSAR compliant software sys- gration of software components (SW-C) and basic software tem is covered by the standard. Applications, ECU specific modules provided by different manufacturers. The system functionality and drivers for microcontroller external devices platform can be tailored in a wide range to efficiently use have to be developed independently for each project. the resources of the individual electronic control unit. In a network of dedicated microcontrollers, the deployed Software modules - mostly written in C or even Assembler software is physically isolated from each other. This isolation - are rarely isolated from each other and have global access is missing among applications running on the same microcon- to the memory, wherefore an error can easily spread among troller, which enables malfunctioning applications to corrupt different software modules.
    [Show full text]
  • 22 Programming Models and Implementation Platforms for Software Defined Radio Configuration
    22 Programming Models and Implementation Platforms for Software Defined Radio Configuration Tanguy Risset Riadh Ben Abdallah Antoine Fraboulet J´erˆomeMartin 22.1 Introduction Software means programmable. Hence software defined radio means that the radio should now be programmable. We know what computer programming means, and we agree, up to a certain level, on how it should be done. But do we know what programming a radio means? Several questions are still open: what will a sdr platform look like in ten years? Will there exist software radio code? What will be the technical challenges and commercial issues behind this code? Programming is more precise than configuring or tuning, it implies a much greater level of freedom for the programmer. But it also means much cheaper implementations in many cases and in particular a re-use of the same hardware for different protocols (i.e. with different programs). This is, to our point of view, the main difficulty of software radio programming: reconfiguration and in particular dynamic reconfiguration. Dynamic (i.e. very fast) reconfiguration is now mandatory because some protocols, 3GPP-LTE (Third Generation Part- nership ProgramLong Term Evolution) for instance, propose channel adapting for each frame, requiring a setting of the channel estimation parameter in a few milliseconds. In this chapter we will try to have an overview of the technical difficulties of designing a programming environment for software defined radio. Then we will present one particular solution which aims at defining a virtual machine dedicated to the domain of software defined radio. 22.2 Programming Environment and Tools for SDR In this section we present existing sdr platforms and give an insight about how they are programmed or configured.
    [Show full text]
  • Towards a Distributed Java VM in Sensor Networks Using Scalable Source Routing
    Towards a Distributed Java VM in Sensor Networks using Scalable Source Routing [Extended Abstract] Bjoern Saballus Johannes Eickhold Thomas Fuhrmann University of Karlsruhe University of Karlsruhe Technical University Munich Am Fasanengarten 5 Am Fasanengarten 5 Boltzmannstrasse 3 76131 Karlsruhe 76131 Karlsruhe 85748 Garching [email protected] [email protected] [email protected] ABSTRACT broader view of distributed computing: the devices will One of the major drawbacks of small embedded systems share data and distribute their workload among each other. such as sensor nodes is the need to program in a low level The vision will be leveraged by the algorithms and protocols programming language like C or assembler. The resulting that we will develop in this project. code is often unportable, system specific and demands deep knowledge of the hardware details. This paper motivates the The paper is structured as follows: Section 2 gives an overview use of Java as an alternative programming language. We fo- over other projects that have similar goals as the AmbiComp cus on the tiny AmbiComp Virtual Machine (ACVM) which project. In section 3 we describe our novel AmbiComp VM, we currently develop as the main part of a more general its design rationale and the tool chain from the Java file to Java based development platform for interconnected sensor the running program on the ACVM. Section 4 outlines how nodes. This VM is designed to run on different small em- the ACVM addresses code and object migration. Finally, bedded devices in a distributed network. It uses the novel section 5 concludes with a summary of this paper.
    [Show full text]
  • Facilitating Communication Over IEEE 802.15.4 Between Sun Spots and Tinyos-Based Motes
    TinySPOTComm: Facilitating Communication over IEEE 802.15.4 between Sun SPOTs and TinyOS-Based Motes Daniel van den Akker1, Kurt Smolderen1,2, Peter De Cleyn1,BartBraem1, and Chris Blondia1 1 PATS, Dept. of Mathematics and Computer Science, University of Antwerp – IBBT, Middelheimlaan 1, B-2020, Antwerp, Belgium {Daniel.VanDenAkker,Kurt.Smolderen,Peter.DeCleyn, Bart.Braem,Chris.Blondia}@ua.ac.be http://www.pats.ua.ac.be/ 2 Dept. of Industrial Sciences and Technology, Karel de Grote-Hogeschool, Salesianenlaan 30, B-2660, Hoboken, Belgium Abstract. The increasing popularity of sensor network has spawned a wide range of platforms and frameworks for sensor network development. While in theory nodes based on different frameworks should provide radio stack compatibility, in practice this is rarely the case. We explore this problem by providing a case study and introduce TinySPOTComm, a customized radio stack for the Sun SPOT platform which allows for radio communication between IEEE 802.15.4 based TinyOS motes and Sun SPOTs. The TinySPOTComm radio stack remains fully compatible with the Sun SPOT radio stack and its network performance is only marginally affected in comparison to the default Sun SPOT radio stack. Performance tests have shown good results when communicating between TinyOS motes and Sun SPOTs. The round trip time, when measured between a Sun SPOT and a TinyOS mote, is affected by no more than 15%, in comparison to the RTT between two TinyOS motes. In the same scenario an increase in throughput of more than 50% has been measured. Keywords: Sun SPOT, TinyOS, 802.15.4, compatibility, sensor network. 1 Introduction Over the years sensor networks have become increasingly popular, not only as a research topic, but also for real-life applications.
    [Show full text]
  • Virgil: Objects on the Head of a Pin Ben L
    Virgil: Objects on the Head of a Pin Ben L. Titzer UCLA Compilers Group 4810 Boelter Hall Los Angeles, CA 90095 1-310-206-3844 [email protected] Abstract computer may not be readily apparent, such as a fuel-injection Embedded microcontrollers are becoming increasingly system. Microcontrollers represent one of the most extreme prolific, serving as the primary or auxiliary processor in instances of a software-programmable resource-constrained products and research systems from microwaves to sensor embedded system. For example, the 8-bit AVR architecture networks. Microcontrollers represent perhaps the most offers chips with flash sizes between 8 and 128 kilobytes and severely resource-constrained embedded processors, often just 64 to 4096 bytes of RAM, with clock rates usually with as little as a few bytes of memory and a few kilobytes of between 4 and 20mhz. code space. Language and compiler technology has so far been Microcontrollers allow for software programmability by unable to bring the benefits of modern object-oriented storing a program’s instructions in a flash memory that allows languages to such processors. In this paper, I will present the infrequent, coarse-grained updates, usually done only during design and implementation of Virgil, a lightweight object- testing. Software for the smallest of microcontrollers is oriented language designed with careful consideration for generally written in assembly language, but medium to large resource-limited domains. Virgil explicitly separates microcontrollers are often programmed in C. Generally there is initialization time from runtime, allowing an application to not enough code space or memory to fit a true operating build complex data structures during compilation and then system that provides processes, threads, and semaphores; thus run directly on the bare hardware without a virtual machine or most programs run directly on the microcontroller without any any language runtime.
    [Show full text]
  • LA MÁQUINA VIRTUAL En La Máquina Virtual Está El “Secreto”… Y Quién Quiera Puede Innovar
    LA MÁQUINA VIRTUAL En la máquina Virtual está el “secreto”… y quién quiera puede innovar. Proprietary/closed source implementations "WRITE ONCE, RUN ANYWHERE" * Hewlett-Packard's Java for HP-UX, OpenVMS, Tru64 and Reliant (Tandem) UNIX platforms * J9 VM from IBM, for AIX, Linux, MVS, OS/400, Pocket PC, z/OS * Mac OS Runtime for Java (MRJ) from Apple Inc. * JRockit from BEA Systems acquired by Oracle Corporation * Oracle JVM (also known as "JServer" and as "OJVM") from Oracle Corporation * Microsoft Java Virtual Machine (MS JVM) from Microsoft * PERC from Aonix is a real time Java for embedded * JBed from Esmertec is an embedded Java with multimedia capabilities * JBlend from Aplix is a Java ME implementation * Excelsior JET (with AOT compiler) Lesser-known proprietary JVMs * Blackdown Java (port of Sun JVM) * CVM * Gemstone Gemfire JVM - modified for J2EE features * Golden Code Development (EComStation and OS/2 port of Java RTE and SDK for J2SE v1.4.1_07) * Tao Group's intent * Novell, Inc. * NSIcom CrE-ME * HP ChaiVM and MicrochaiVM * MicroJvm from Industrial Software Technology (running of wide rande of microcontrollers 8/16/32-bit) Free/open source implementations * AegisVM * JamVM * Juice * Mika VM * Apache Harmony • Jaos * * Jupiter JVM * Mysaifu JVM * CACAO JC * JX (operating system) * NanoVM * IcedTea * Jikes RVM * Kaffe * SableVM * IKVM.NET * JNode * leJOS * SuperWaba * Jamiga * JOP * TinyVM * JESSICA (Java-Enabled Single-System-Image Computing Architecture) * Squawk virtual machine (Sun JVM for embedded system and small devices) * Sun Microsystems' HotSpot * VMkit of Low Level Virtual Machine * Wonka VM * Xam • Una idea novedosa, pero no del todo: cierta similitud con los lenguajes con código intermedio.
    [Show full text]
  • Trusting Virtual Trust
    Trusting Virtual Trust Jeremy Powell, Trupti Shiralkar © 2009 atsec information security mandag 31. august 2009 Agenda . The Java Virtual Machine . Unmeasured Trust . Java's Assurance © 2009 atsec information security 2 mandag 31. august 2009 The Java Virtual Machine © 2009 atsec information security mandag 31. august 2009 A Few Quick Disambiguations . Overloaded terms . “Virtual Machine” could mean... • A system virtual machine - Xen - HyperV - VMWare • A process (application) virtual machine - Java - Common Language Runtime . We mean a “process virtual machine” © 2009 atsec information security 4 mandag 31. august 2009 A Few Quick Disambiguations . Overloaded terms . “Java” could mean... • ...a spoken language • ...an island • ...cofee • ...a programming language • ...an application platform • ...a virtual machine . We mean “the Java Virtual Machine” . ...usually © 2009 atsec information security 5 mandag 31. august 2009 Just what is the Java Virtual Machine? . Developed by Sun Microsystems . Interprets and runs bytecode . Virtualizes an abstract processor Java Compiler Source Code Java JVM Bytecode Native Instructions © 2009 atsec information security 6 mandag 31. august 2009 Bytecode . Looks very much like native assembly code 0: iconst_1 1: istore_1 2: iconst_1 3: istore_2 4: iload_2 5: bipush 100 7: if_icmpge 20 10: iload_1 11: iload_2 12: imul 13: istore_1 14: iinc 2, 1 17: goto 4 20: getstatic #2 23: iload_1 24: invokevirtual #3 27: return © 2009 atsec information security 7 mandag 31. august 2009 Typed Memory . C / C++ - Memory organized into words . Java - Memory organized into objects 0xdeadbeef 0x0cofee0 String: “Hello, World!” 0x5932a6ef Words V.S. BigInteger: Objects 0zffffe 35960259603520 45360242063240 14501403503629 70493759305039 45 Password: 0z08679305 ******** © 2009 atsec information security 8 mandag 31.
    [Show full text]
  • A Compact Openisa Virtual Platform for Iot Devices
    COISA: A Compact OpenISA virtual platform for IoT devices Carlos Eduardo Millani1, Alisson Linhares1, Rafael Auler1, Edson Borin1 1Institute of Computing – University of Campinas (UNICAMP) Av. Albert Einstein, 1251 – 13083-852 – Campinas – SP – Brazil fcarloseduardomillani,[email protected],[email protected] Abstract. In face of the high number of different hardware platforms that we need to program in the Internet-of-Things (IoT), Virtual Machines (VMs) pose as a promising technology to allow a program once, deploy everywhere strat- egy. Unfortunately, many existing VMs are very heavy to work on resource- constrained IoT devices. We present COISA, a compact virtual platform that relies on OpenISA, an Instruction Set Architecture (ISA) that strives for easy emulation, to allow a single program to be deployed on many platforms, in- cluding tiny microcontrollers. Our experimental results indicate that COISA is easily portable and is capable of running unmodified guest applications in highly heterogeneous host platforms, including one with only 2 kB of RAM. 1. Introduction Current computer science trends suggest a future where platform heterogeneity is grace- fully embraced: with Internet-of-Things (IoT) [17, 32], we will need an increased capac- ity of programming wildly different devices, each exploring distinct energy-performance trade-offs, yet still remain productive enough to make this industry viable from the soft- ware engineering standpoint. There are two distinct development models engineers can explore: (1) the software is custom designed to each device, and all software development is tied to the hardware platform, or (2), software is written once for a virtual platform, but it runs on all devices in a hardware-independent fashion due to the use of virtual machine technology.
    [Show full text]
  • Challenges and Solutions in the Design of a Java Virtual Machine for Resource Constrained Microcontrollers
    Challenges and Solutions in the Design of a Java Virtual Machine for Resource Constrained Microcontrollers Faisal Aslam Dissertation Submitted to the University of Freiburg for Doctorate Degree in Computer Scinece Computer Networks and Telematics Department of Computer Science Faculty of Applied Sciences University of Freiburg, Germany March 2011 Dissertation Defense Date: 17.03.2011 Thesis committee: Chair: Prof. Dr. Georg Lausen Examiner: PD Dr. Cyrill Stachniss Referees: Prof. Dr. Christian Schindelhauer Prof. Dr. Peter Thiemann To Abbu, Ammi and Ayesha Zusammenfassung Diese Arbeit beschreibt die TakaTuka Java Virtual Machine (JVM), die für Microcon- troller mit geringen Kapazitäten an RAM, Speicher und Prozessor entwickelt wurde. TakaTuka optimiert die Speicheranforderungen sowohl des compilierten Java Codes als auch die des JVM Interpreters, die beide auf einem eingebetteten System abgespeichert werden müssen. Im Durchschnitt lässt sich die Größe des compilierten Java Codes der TakaTuka JVM um über 92% der Größe des Standard-Java-Codes eines Programms re- duzieren. Desweiteren kann die Interpreter-Größe für ein gegebenes Programm auf nicht mehr als 25 KB verkleinert werden. Auf diese Weise führt ein Sensorknoten mit geringem Flash Speicher einen hoch optimierten Java Binärcode und Java Interpreter aus. Die Fähigkeit komplexe Java-Programme auszuführen, wird durch den auf den Bauteilen vorhandenen RAM-Speicher beschränkt. Das Speicher-Management für ein Java Pro- gramm besteht aus zwei Teilen: Erstens wird der Speicher, den jedes Objekt konsumiert, durch die Garbage Collection (GC) geregelt, die zwischendurch ausgeführt wird um Spe- icher wieder freizugeben. Zweitens wird der Speicher, den der Frame einer Funktion beansprucht hat, automatisch zurückgefordert, sobald eine aufgerufene Funktion been- det ist.
    [Show full text]
  • Ahead-Of-Time Compilation of Stack-Based JVM Bytecode on Resource-Constrained Devices
    Ahead-of-Time Compilation of Stack-Based JVM Bytecode on Resource-Constrained Devices Niels Reijers, Chi-Sheng Shih Embedded Systems and Wireless Networking Lab Department of Computer Science and Information Engineering National Taiwan University Abstract 1 Introduction Many virtual machines have been developed for tiny de- Sensor nodes and other Internet-of-things devices come in vices with only a few KB of RAM and tens to a few hundred a wide range, with vastly different performance characteris- KB of flash memory. They pack an impressive set of features tics, cost, and power requirements. On one end of the spec- in a very limited space, but suffer from a large performance trum are devices like the Intel Edison and Raspberry Pi: pow- penalty: a slowdown of one to two orders of magnitude com- erful enough to run Linux, but relatively expensive and power pared to optimised native code is typical for most VMs, re- hungry. On the other end are CPUs like the Atmel Atmega or ducing throughput and increasing power consumption. TI MSP430: much less powerful, but also much cheaper and Compiling the VM’s bytecode to native code to improve low power enough to potentially last for months or years on performance has been studied extensively for larger devices, a single battery. For the first class we can use normal operat- but has not received much attention in the context of sensor ing systems, languages, and compilers, but in this paper, we networks, where the restricted resources mean most modern focus specifically on the latter class for which no such clear techniques cannot be applied.
    [Show full text]