class: title, smokescreen, shelf, bottom, no-footer background-image: url(images/Internet_of_Things.jpg) # 181U Spring 2020 ### IoT Applications --- layout: true .footer[ - Geoffrey Brown, 2020 - 181U ] <style> h1 { border-bottom: 8px solid rgb(32,67,143); border-radius: 2px; width: 90%; } .smokescreen h1 { border-bottom: none; } .small.remark-slide-content.compact {font-size:1.2rem} .smaller.remark-slide-content.compact {font-size:1.1rem} .small-code.remark-slide-content.compact code {font-size:1.0rem} .very-small-code.remark-slide-content.compact code {font-size:0.9rem} .line-numbers{ /* Set "line-numbers-counter" to 0 */ counter-reset: line-numbers-counter; } .line-numbers .remark-code-line::before { /* Increment "line-numbers-counter" by 1 */ counter-increment: line-numbers-counter; content: counter(line-numbers-counter); text-align: right; width: 20px; border-right: 1px solid #aaa; display: inline-block; margin-right: 10px; padding: 0 5px; } </style> --- class: compact # Agenda * Course Mechanics * Labs * Grading * Policies * What does IoT Mean ? * Outline of Course Topics * Introduction to Internet * IoT Protocols * C Programming * Embedded Programming * IoT Systems --- class: compact # Course Mechanics * **Instructor** * Geoffrey Brown * Office: Edmunds 128 * Office Hours: TBD * geoffrey.brown@pomona.edu * **Laboratory** * Tuesdays 1:15-4:00 Edmunds 105 * No lab this week * **Assignments** * Most assignments will start in Lab * The first few labs are mostly tutorial --- class: compact # Course Grading **Assignment Grading** * Every assignment will have a concise report that - explains any code developed - discusses the goals, design decisions, and issues * Default grade breakdown - 60% correct, working implementation (Please demo in lab) - 40% report **Course Grading** * 60% Lab/Assignments * 20% Final Project * 20% Midterms --- class: compact # This is a Systems Course * Systems building differs from your past experience in programming * Typically, systems are built from collections of existing components * Systems frequently involve communication between distributed components * Systems building often involves using libraries in a variety of languages * Debugging can be challenging * IoT systems building uses Internet Protocols to combine * Cloud-based servers * Local servers and gateways * Embedded devices --- class: compact,small # Assumptions **Current Assumptions** * You have had intro programming + data structures * You are likely comfortable in Java * You may have programmed in Python * You probably have not programmed in C * Some of you have used git for storing your code **My Plan** * To minimize the new languages you need to learn (C) * To teach you in lab how to use the tools you need **The Risks** * My assumptions are wrong -- *I hope you'll feel free to tell me !* * Things take longer than I plan -- *We'll adjust the schedule* --- class: compact # My Hopes * You're not afraid to "break things" * You can cope with the unexpected * You enjoy making stuff --- class: compact # What is IoT ? * An answer is the connection of sensors (and actuators) in distributed applications * IoT builds upon the underlying Internet infrastructure * IoT uses the Internet Infrastructure in new ways with new protocols * IoT also is used to refer to networks that are (generally) disconnected from the Internet -- such as cars (CAN Bus) and people (body area networks) * IoT applications are also characterized by intermittent connectivity --- class: compact # Connectivity data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/1b41e/1b41e8dfed11bac626132289da5889becd3afdbf" alt="" https://www.postscapes.com/what-exactly-is-the-internet-of-things-infographic/ --- class: compact # Sensors data:image/s3,"s3://crabby-images/b18c2/b18c25f65a2a80c437b1b7d16476f3dc682c3c29" alt="" data:image/s3,"s3://crabby-images/210a4/210a4aea1c5c45e1a72b27acd66fd325e7df104a" alt="" https://www.postscapes.com/what-exactly-is-the-internet-of-things-infographic/ --- class: compact # Existing Smart Application Services data:image/s3,"s3://crabby-images/3381c/3381c5d68d92935bc3eab5cd22f652c7d8b6d3b4" alt="" data:image/s3,"s3://crabby-images/fd6d7/fd6d766fdfcb6fcef050b9be3a1796a8ac501c4e" alt="" --- class: compact # Applications data:image/s3,"s3://crabby-images/ba58d/ba58dfd4e9a8ec96a0f88478ce3459883b1d738b" alt="" data:image/s3,"s3://crabby-images/e0856/e08569b9217616d0a3e961c2515d55805296b380" alt="" --- class: compact # Compound Applications data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/0f8e0/0f8e0b880d07e61fb5ba46b526ea9d227bac205b" alt="" --- class: compact # An Application Taxonomy * Consumer - Smart Home - Elder Care * Commercial - Medical/Heathcare - Transportation - Building automation * Industrial - Manufacturing - Agriculture * Infrastructure - Smart Cities - Energy - Environment --- class: compact # E-Health data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/b954e/b954e957b8b7f1444de4c57445f87287b8cdc2ff" alt="" ** Figure from: "The Era of Internet of things", Khaled Salah Mohamed, 2019, Springer** --- class: compact # The Internet The Internet is a remarkable entity that introduced some key ideas to computer science * **Recursive structure** -- "the Internet" is composed of smaller "Internets". In fact, computer operating systems have been structured on similar principles. * **Virtualization** -- applications communicate through "virtual" services. * **Abstraction Layers** --The structure is built in as a series of layers -- each layer "encapsulates" the function of the lower layers and provides a new, more powerful, abstraction to the layers above it. * **Fault Tolerance** -- The Internet is designed to be resilient in the face of failures --- class: compact # Internet Design requirements - scalable connectivity **Point to Point Links** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/5eecf/5eecf59a2abd3af65450727c65eebb38dfb3e788" alt="" --- class: compact # Internet Design requirements - scalable connectivity **Switched Network** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/f5a88/f5a88056f6979860abd59be9ac120701f03c0c94" alt="" --- class: compact # Internet Design requirements - scalable connectivity **Interconnection of Networks** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/ee191/ee191f0deefd260accb1ec41270c140e4585bd77" alt="" --- class: compact # Internet Design requirements **Cost Effective Resource Sharing** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/3ba81/3ba81df0d8ed8be157434f912f15a32760cd4174" alt="" --- class: compact # Internet Design requirements **Switch multiplexing packets onto a link** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/b84a6/b84a6eee3b92746caff1b4ffe0abc4137591afdc" alt="" --- class:compact # Internet Design Requirements -- support for common services **Applications communicating through a virtual channel** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/3706f/3706f9dbbe4c2119ec04cd74cf15ec541f8cbdca" alt="" --- class: compact # Internet Architecture **Protocol layering** data:image/s3,"s3://crabby-images/78261/7826100fd7bb1867f7fdaee76c9c64454556e7fe" alt="" data:image/s3,"s3://crabby-images/3759f/3759f5baba3ebea02b4067ed6d34e86a1a0937ed" alt="" data:image/s3,"s3://crabby-images/8f5b4/8f5b44051cf56b80ede44ba6e86c6a9b1e8a3351" alt="" --- class: compact # Internet Architecture **Hypothetical Protocol Graph** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/465f1/465f12b2935a5583164ed83d6c6f7ef09914e97c" alt="" --- class: compact # Internet Architecture **Encapsulation** data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/37d32/37d32c9f85bf0dc3a4e93d5d772706bc7a87fae1" alt="" --- class: compact # Internet Architecture **Internet Protocol Graph** data:image/s3,"s3://crabby-images/4d4e1/4d4e100ccd012a39fa4b3cb49e1bc780d7bdfa83" alt="" data:image/s3,"s3://crabby-images/ba58d/ba58dfd4e9a8ec96a0f88478ce3459883b1d738b" alt="" data:image/s3,"s3://crabby-images/37f52/37f521426f40721a4d5b1593e585445ee3625a2f" alt="" --- class: compact # Architecture for this class (roughly) * Internet Architecture and Protocols -- 2-3 weeks * IoT Protocols -- 1 week * C Programming -- 2 weeks * Embedded Devices - Foundations -- 2 weeks - Sensors -- 2 weeks * Communication -- 2 weeks * Security -- 1 week * IoT Platforms -- 1 week --- class: compact # Some of the building blocks we'll use data:image/s3,"s3://crabby-images/2d6f4/2d6f4132211f893145e3ded27d7f4c2e542ce763" alt="" data:image/s3,"s3://crabby-images/3381c/3381c5d68d92935bc3eab5cd22f652c7d8b6d3b4" alt="" data:image/s3,"s3://crabby-images/51f0d/51f0df4a013e905537e21cf931efa11692bc0179" alt="" --- class: compact # Example system (Bloomington) **BLE Plant Monitor** data:image/s3,"s3://crabby-images/150cd/150cd1577140d1b029cc70356315ea9a0360a213" alt="" data:image/s3,"s3://crabby-images/9dc11/9dc11e86a1f48ce8e65f57318f6355cc4b7c3a9e" alt="" data:image/s3,"s3://crabby-images/6a235/6a235c719b502bee7d0c21010683ef13be3681af" alt="" --- class: compact # Summary * Slides from https://www.postscapes.com/what-exactly-is-the-internet-of-things-infographic/ * Slides from https://book.systemsapproach.org * Cover Photo and lecture material: By <a rel="nofollow" class="external text" href="https://www.flickr.com/photos/wilgengebroed/">Wilgengebroed on Flickr</a> - Cropped and sign removed from <a href="//commons.wikimedia.org/wiki/File:Internet_of_things_signed_by_the_author.jpg" title="File:Internet of things signed by the author.jpg">Internet of things signed by the author.jpg</a>, <a href="https://creativecommons.org/licenses/by/2.0" title="Creative Commons Attribution 2.0">CC BY 2.0</a>, <a href="https://commons.wikimedia.org/w/index.php?curid=32745645">Link</a>