Zlib - Pub Building Enterprise Iot Applications
Zlib - Pub Building Enterprise Iot Applications
Zlib - Pub Building Enterprise Iot Applications
Applications
Chandrasekar Vuppalapati
Senior Vice President–Products & Programs
Hanumayamma Innovations and Technologies, Inc.
Fremont, California, USA
and
College of Engineering
San Jose State University
San Jose, California, USA
CRC Press
Taylor & Francis Group
6000 Broken Sound Parkway NW, Suite 300
Boca Raton, FL 33487-2742
© 2020 by Taylor & Francis Group, LLC
CRC Press is an imprint of Taylor & Francis Group, an Informa business
No claim to original U.S. Government works
Version Date: 20190923
International Standard Book Number-13: 978-0-367-17385-2 (Hardback)
This book contains information obtained from authentic and highly regarded sources. Reasonable efforts have been
made to publish reliable data and information, but the author and publisher cannot assume responsibility for the
validity of all materials or the consequences of their use. The authors and publishers have attempted to trace the
copyright holders of all material reproduced in this publication and apologize to copyright holders if permission to
publish in this form has not been obtained. If any copyright material has not been acknowledged please write and let
us know so we may rectify in any future reprint.
Except as permitted under U.S. Copyright Law, no part of this book may be reprinted, reproduced, transmitted,
or utilized in any form by any electronic, mechanical, or other means, now known or hereafter invented, includ-
ing photocopying, microfilming, and recording, or in any information storage or retrieval system, without written
permission from the publishers.
For permission to photocopy or use material electronically from this work, please access www.copyright.com
(http://www.copyright.com/) or contact the Copyright Clearance Center, Inc. (CCC), 222 Rosewood Drive, Danvers,
MA 01923, 978-750-8400. CCC is a not-for-profit organization that provides licenses and registration for a variety
of users. For organizations that have been granted a photocopy license by the CCC, a separate system of payment
has been arranged.
Trademark Notice: Product or corporate names may be trademarks or registered trademarks, and are used only for
identification and explanation without intent to infringe.
The Internet of Things (IoT) is a game changer, transforming many enterprises into digital businesses and
facilitating new business models, blue-ocean product strategies, Data Monetization opportunities, just in
time (JIT) product service offerings, service contracts with proactive product maintenance, Enablement
of citizenry services, Smart meters, Smart Cities, Smart Buildings, Smart Manufacturing and many other
next-generation products & services. IoT architectures and deployments can be found in various industries
including: Chemical, Healthcare, Industrial, Pharmaceutical, Construction, Agriculture, Smart Buildings,
Smart cities, E-Governance, Connected Stadiums, Retail, Contact Center, Gaming, Chip Fabrication,
Transportation, IT Services (Managed) and many more. It is clear from market adoption that the Internet
of Things (IoT) is the platform of the future.
IoT based architectures are projected to inter-connect 20 billion new devices with a potential of $11.1
trillion per year in economic value by 2025. At the time of writing this book, IoT has already connected
39% of the world’s population and has generated more data in 1 year than in the previous 5000 years put
together.
In order to harvest the benefits of the IoT revolution, traditional software development paradigms
must be upgraded. The purpose of this book is to prepare current and future software engineering teams
with the skills and tools that fully utilize IoT capabilities. The book introduces essential IoT concepts
from the perspectives of full-scale software development with the emphasis on creating niche blue ocean
products. It also:
• Outlines a fundamental full stack architecture for IoT
• Describes various development technologies in each IoT layer
• Explains deployment of Machine Learning Models at the Edge Level
• Describes Machine Learning Models and Artificial Intelligence
• Presents IoT Use cases from Agriculture, Healthcare, Mobile industry verticals
• Explains IoT solution development from Product management perspective
• Extensively covers security and applicable threat models as part of IoT stack
The book provides details of several IoT reference architectures with emphasis on data integration,
edge analytics, cluster architectures and closed loop responses.
Dedication
The author dedicates his works, book, and efforts of this book to his late father Murahari Rao Vuppalapati,
who had inspired him to write the book and guided the author’s pursuits of life, and to his loving mother
Hanumayamma Vuppalapati, who was the inspiration to develop company and dairy products for the
betterment of humanity and future generations.
Acknowledgement
The author is deeply indebted to the love, support, and encouragement of his wife Anitha Ilapakurti, and
the active support of his daughters, Sriya Vuppalapati and Shruti Vuppalapati who helped draft the first
version of the manuscript.
The author is deeply thankful to the support of his elder brother, Rajasekar Vuppalapati, and the joyful
support of his younger brother, Jaya Shankar Vuppalapati. Additionally, the author is also very thankful
to his elder sisters Padmavati Vuppalapati and Sridevi Vuppalapati.
The author sincerely thanks Santosh Kedari and his team in India for conducting field studies in
India for Dairy and Sanjeevani Healthcare analytics products and bringing the market feedback for the
betterment of services.
The author is deeply indebted to Sharat Kedari, who helped to draft the book structure, code examples
of the book and helped in setting Cloud and machine learning algorithms. In addition, the author is thankful
for the support, hard work and dedication of Vanaja Satish who helped to solve embedded systems and
build of iDispenser and SQLite.
The author sincerely thanks the support of fellow researchers and engineers including Sudha Rama
Chandran, Shruti Agrawal, MeenuYadav, his students Renato Silveira Cordeiro, Sadab Qureshi, and
Suchishree Jena and his graphic illustrator Rohit Ranjan.
Contents
Preface iii
Dedication iv
Acknowledgement v
1. Introduction 1
Industry 4.0 3
The Man and the Machine—Robots may guide collaboration with Humans 5
The Five Forces that shape Industry Competition and Smart Connected Objects 5
Digital Twin 6
Enterprise IoT Platforms 7
Human Touch – artificial intelligence infused Mobile Companion 8
The CRISP-PM Process 8
References 12
2. Foundation Architectures 14
IoT Platform 14
IoT Platform Types 15
Connectivity Platform 18
Case Study: Artik Connectivity Platform 20
Technical Case Study: Using IoT to detect water leakages with Powel 28
IoT & KDD 31
5Vs and IoT 32
Intel IoT Data Flow Diagram 37
CAP Theorem 37
IoT Streams and Reference Architecture 38
Data at Rest 41
References 43
3. Hardware Design 45
Arduino IDE Installation 45
Arduino Uno Pinout Diagram and Guide 45
Tinyduino Humidity Sensor (SI7021) 49
Embedded System Architecture 51
Dairy IoT Sensor 55
References 67
Motion Sensors 78
Accelerometer App 89
Accelerometer Play App – a Precursor to Digital Twin Apps 95
Magnetometer App 96
The Role of Sensors in Healthcare & Wellness 102
Case Study: A System to Detect Mental Stress Using Machine Learning and 102
Mobile Development
Health Fitness IoT App 103
Step Counter Value 104
Android BatchStepSensor Sample 105
Full Sensor & Data List 108
Core Motion Framework in iOS 108
Core Motion iOS Code 112
Pedometer App 117
Case Study: California Reservoir Continuous Water Monitoring 120
Current Reservoir Conditions 122
Video Sensors 129
Image Texture Data 129
Geospatial Data 130
References 131
9. Connectivity 277
5G Network 278
Case Study: Low Power Wide Area (LPWA) and Cellular IoT 279
REST 279
CoAP (Constrained Application Protocol) 287
Bluetooth Low Energy (BLE) 294
iOS App—IoT made easy—Sensor Tag 301
Android 307
Hanumayamma Dairy IoT Design 308
Case Study: Dairy Application—Cow Necklace 310
MQTT 322
IoT and Hardware Clocks 333
MQTT Signals 339
MQTT Client 340
MQTT Wireshark Captures 344
ECG or Electrocardiogram Sesnors 364
References 368
Appendix 401
Appendix A: bench_time.c 401
Appendix: California Reservoir Sensor Details 405
Appendix: Sacramento River At Knights Landing 406
Query Interface 408
Contents ix
Appendix – DO-178B (Software Considerations in Airborne Systems and Equipment Certification) 412
Appendix – STDIO.H File 412
Appendix: Milk Producing Data Centers 415
Pthread Support in Microsoft Windows Services for UNIX Version 3.5 417
Index 421
Chapter 1
Introduction
The Internet of Things (IoT) has become the economic and social disruption of the century.
In its report on the most disruptive technologies—advances that will transform life, business,
and the global economy, the McKinsey global institute has listed Internet of Things as the
third major force that will transform our lives and global economy and commerce (please see
Figure 1). Due to the diffusion of IoT, there has been 300% increase in connected machine-to-machine (M2M)
devices in the past 5 years. The IoT has resulted in 80%–90% decline in MEMS (Microelectromechanical
systems) Sensors costs in the past 5 years. The IoT could connect more than 1 trillion things to the Internet
across industries such as manufacturing, healthcare, and mining. Finally, IoT could generate cost synergies
of magnitude $36 Trillion costs of key connected industries (manufacturing, health care, and mining) [1].
Speed, scope, and economic value at stake of 12 potentially economically disruptive technologies1
The Internet of Things—embedding sensors and actuators in machines and other physical objects to bring
them into the connected world—is spreading rapidly. From monitoring the flow of products through a factory,
to measuring the moisture in a field of crops and tracking the flow of water through utility pipes, the Internet
of Things allows businesses and public-sector organizations to manage assets, optimize performance, and
create new business models. With remote monitoring, the Internet of Things also has great potential to
improve the health of patients with chronic illnesses and attack a major cause of rising health-care costs [2].
The IoT has connected 39% of the world population and is generating more data in one year than in
the previous 5000 years put together. To support the promise and growth of IoT (50 billion Smart Objects
1
McKinsey 12 most disruptive technologies - https://www.mckinsey.com/~/media/McKinsey/Business%20Functions/
McKinsey%20Digital/Our%20Insights/Disruptive%20technologies/MGI_Disruptive_technologies_Full_report_
May2013.ashx
2 Building Enterprise IoT Applications
F1 Icon1
F1 Icon1 F1 Icon4
F1 Icon4
F1
F1Icon2
Icon1
F1 Icon2 F1 Icon5
Icon4
F1
F1 Icon3 F1 Icon5
F1 Icon3
F1 Icon2
F1 Icon5
F1 Icon3
50 Billion
50
“Smart Objects”
50 Billion
50
“Smart Objects”
40
Adoption rate of
F1 Icon4
40 digital infrastructure:
50 Billion
F3
5Adoption
× faster rate of
than
30
50
“Smart
digital andObjects”
infrastructure:
electricity telephony
F3
5 × faster than
n1 30 electricity and telephony
20
40 F1 Icon4 Adoption rate of
F1 Icon5
20 digital infrastructure:
n2
F3
5 × faster than
10
30 electricity and telephony
World Propulation
10
0
F1 Icon5 6.8 7.2 7.6
World Propulation
n3 20
0
6.8 7.2 7.6
2010 2015 2020
[3]—adoption rate 5X faster than electricity and telephony),3 the enterprise compute platforms need to
Adoption rate of
digital infrastructure:
Adoption rate
thanof
First progrmmable logic
control system 1969
sicalvirtual
and production
worldssystems
(CPPS), merging of real
Industry 4.0
scale to F3
5 × faster
and virtual worlds
the needs of data.
digital infrastructure:
electricity and telephony First progrmmable logic
3rd Industrial revolution 4th Industrial revolution
F3
5 × faster than control system 1969
electricity and telephony through application of on the basis ofIndustry 4.0
cyber-phy-
3rd Industrial
electronic and revolution
IT to sical production systems
through
further application of
automate (CPPS), merging of real
of complicity
Case Study: IoT Devices play pivotal role in driving Augmented Analytics4
electronic
production and IT to logic and virtual worlds
World Propulation First progrmmable
6.8 7.2 7.6 First assembly line further
controlautomate
system 1969
of complicity
Augmented Intelligence [4] focuses on Artificial Intelligence (AI)’s assistive role [5], that is,
2nd
1870Industrial
World revolution
Propulation Industry 3.0
through application of
Degree
through
help introduction
of electrical of
energy
production
F4
First mechanical 4th Industrial revolution
0 2015 mass
2020on the basis of cyber-phy- production
First assembly with the
line
weaving loom sical production systems help of electrical energy
means “to improve”, reinforces the role that human intelligence plays when using machine learning
1870 Industry 3.0
First mechanical(CPPS), merging of real
1784 Industry 2.0
and virtual worlds
weaving loom
First progrmmable logic
2nd Industrial revolution
1st
control Industrial
system
1784 1969 revolution Industry 4.0
F4
3rd Industrial mass production with the
4th
1stapplication
Industrial
mechanical
through Industrial
revolution
ofproduction revolution
on the help of electrical energy
electronic and IT to
through
facilities
furtherFirst
with
mechanical
automate
thebasis
introduction helpof of cyber-phy-
andsical production
power systems
Degree of complicity
mechanical
water
production production
steam
weaving loom
Augmented analytics6 [5] helps enterprises perform KDD in order to discover new insights. It helps,
First assembly line
facilities (CPPS),
with the merging
help of of real
1870 1784 and virtual worlds Industry 3.0 Industry 2.0
First progrmmable waterlogic and steam power Industry 1.0
2nd Industrial revolution
control system 19691st Industrial revolutionIndustry 4.0
importantly, to citizen data science7 to the enabler of data analytics [6].
through introduction of
F4
mass production with the through introduction of Industry 1.0
3rd Industrial
help of electrical energy revolution
mechanical production
al through application ofEnd of 18th century Beginning of 20th century Beginning of 1970s of Today
facilities with the help of
electronic and IT to 20th century
water and steam power Industry 2.0
further automate End of 18th century
Mobile is increasingly ubiquitous. With 6.8 billion mobile subscriptions worldwide, access anytime,
Beginning of 20th century Beginning of 1970s of Today
Degree of complicity
volution
ction of production 20th century
bly line
duction Industry 1.0
anywhere through smart gadgets is now putting cheap and connected, mobile computing power in
e help of Industry 3.0
m power
al revolution
F4
ction with the 20th century
trical energy
century Beginning of 20th century Beginning of 1970s of Today
20th century
Industry 2.0
location detection, wireless connectivity and cameras—offer another big step towards closing the
feedback loop in personalized medicine [7]. There is no more personal data than on the-body or
in-the-body sensors. With so many connected devices generating various vital health related data,
Industry 1.0 integrating these data points to Electronic Health Records not only provide more accurate picture
f 20th century Beginning of 1970s of Today
of the patient but also helps to connect with the doctor. Mobile device being universally classic IoT
device, through IoT device and application of augmented intelligence helping humanity.
20th century
2
Samsung - https://www.samsung.com/global/business/networks/solutions/iot-solutions/
3
IoT Platform - https://www.slideshare.net/Cisco/enabling-the-internet-of-everything-ciscos-iot-architecture?from_
action=save
4
Gartner Identifies Augmented Analytics as a Top Technology Trend for 2019 - https://solutionsreview.com/business-
intelligence/gartner-identifies-augmented-analytics-as-a-top-technology-trend-for-2019/
5
Augmented Intelligence - https://whatis.techtarget.com/definition/augmented-intelligence?track=NL-1823&ad=9220
91&src=922091&asrc=EM_NLN_103914963&utm_medium=EM&utm_source=NLN&utm_campaign=20181122_
Word%20of%20the%20Day:%20augmented%20intelligence
6
Augmented Analytics: The Next Disruption in Analytics and BI - https://www.gartner.com/webinar/3846165
7
Gartner Identifies the Top 10 Strategic Technology Trends for 2019 - https://www.gartner.com/en/newsroom/press-
releases/2018-10-15-gartner-identifies-the-top-10-strategic-technology-trends-for-2019
50 Billion
50
“Smart Objects”
Introduction 3
40
Adoption rate of
digital infrastructure:
Industry 4.0
F3
5 × faster than
30 electricity and telephony
We are in the midst20of a digital transformation powered and fueled by Data and Analytics. The Industry
3.0 has introduced Computer and Information Technology. However, the Industry 4.0 is due to availability
of sensors, connecting
10
via smart and high-speed networking, and application of data science and machine
learning to automate business processes
6.8
with intelligence.
7.2
Industry 4.08 is7.6here to stay [8].
World Propulation
The Internet of 0Things and Smart Connected Objects are the main catalysts for the Industry 4.0.9
Machine Learning and Data Science 2010 are the backbone
2015 for deriving2020insights from the Industry 4.0
connected objects (please see Figure 2 and Figure 3) [9].
Degree of complicity
production
First assembly line
1870 Industry 3.0
2nd Industrial revolution
through introduction of
F4
mass production with the
help of electrical energy
First mechanical
weaving loom
1784 Industry 2.0
1st Industrial revolution
through introduction of
mechanical production
facilities with the help of
water and steam power
Industry 1.0
PRODUCT CLOUD
Smart Product Applications
Software applications running on remote servers manage the
monitoring, control, optimization, and autonomous operation
of product functions
Rules/Anlysics Engine
The rules, business logic, and big data analytical capabilities
that populate the algorithms involved in product operation
and reveal new product insights
Application Platform
An application development and execution environment External
enabling the rapid creation of smart, connected business Information Integration
Identity and applications using data access, visualization, and Source with
security run-time tools A gateway for Business
Tools that information Systems
manage user Product Data Database
from eternal
F6
A big-data database system that enable aggregation, Tools that
authentication sources-such from smart,
and system normalization, and management of real-time and historical
product data as weather, connected
access, as traffic, products with
well as commodity core
product, and energy enterprise
connectivity, prices social business
and product CONNECTIVITY media, and systems
cloud layers geomapping such as
Network Communication
The protocols that enable communications between the that informs ERP, CRM,
product and the cloud product and PLM
capabilities
PRODUCT
Product Software
An embedded operating system, onboard software applications,
an enhanced user interface, and product control components
Product Hardware
Embedded sensors, processors, and a connectivity port/
antenna that supplement traditional mechanical and
electrical components
10
are-transforming-competition
F6 after Icon1
How Smart, Connected Products Are transforming Competition - https://hbr.org/2014/11/how-smart-connected-products-
External Systems: Integrating with external systems, such as social media data, twitter data, and weather
Software applications running on remote servers manage the
monitoring, control, optimization, and autonomous operation
of product functions
Rules/Anlysics Engine
Business Databases: Integrating IoT Sensor data with traditional enterprise relational databases (ERP,
Information Integration
Identity and applications using data access, visualization, and Source with
security run-time tools A gateway for Business
Tools that information Systems
manage user Product Data Database
from eternal
F6
A big-data database system that enable aggregation, Tools that
CRM) provides 360-degree view of the customers and enables the formation of blue ocean strategies.
authentication sources-such from smart,
and system normalization, and management of real-time and historical
product data as weather, connected
access, as traffic, products with
well as commodity core
product, and energy enterprise
connectivity, prices social business
and product CONNECTIVITY media, and systems
cloud layers geomapping such as
Network Communication
The protocols that enable communications between the that informs ERP, CRM,
product and the cloud product and PLM
capabilities
The Man and the Machine—Robots may guide collaboration with Humans11
PRODUCT
Product Software
An embedded operating system, onboard software applications,
an enhanced user interface, and product control components
Product Hardware
Embedded sensors, processors, and a connectivity port/
antenna that supplement traditional mechanical and
electrical components
The sensor makes it possible to track the movements and actions of workers inside a factory
or after
F6 warehouse [11].
Icon1
Existing sensors, including cameras and depth sensors, are often affected by lighting and
offer only a rough idea of a person’s position in three-dimensional space. Emerging safety
systems allow people to work in closer proximity to powerful robots, but they shut these
Customer business priorities Drive platform dimensions Which deliver
systems down completely if a person moves too close. By tracking a person’s motions very
Closed loop
precisely, the new system could make it possible for a powerful robot to work in concert
Competitive advantage Continuous intelligence Augmented intelligence
with a person, perhaps handing something to a human coworker [12]. “You could get rid of
10101
Flow Information
Smart Connected Objects enable Flow of Information for the greater good:
The Five Forces that shape Industry Competition and Smart Connected
Objects
Smart, connected products will have transformative effect on Industry structure. The Five Forces that
shape competition13 provide a framework to understand the influence of Smart connected objects on the
competition (please see Figure 5).
Bargaining Power of Buyer: Traditional Segmentation of the market is based on market research, voice
customer details, and unmet needs & value perception. The Smart Connected Objects make the bargaining
power of the buyer more exclusive and driven by digital and traditional strategies. For instance, mobile
recommendations to the shopping loyalists are derived from historical shopping behaviors, Market basket
Just in Time buying behavior, Location awareness, weather cognitive and population sentiment or mood.
Threat of new entrants: New entrants in a smart, connected world face significant new obstacles, starting
with the high fixed costs of more-complex product design, embedded technology, and multiple layers of
new IT infrastructure.14
It is prohibitively expensive to manufacture the products with limited or new resources. Without adequate
resources, it’s very difficult to establish the business.
Though the demand for the Cow Necklace is huge, the new entrants, a Hanumayamma Innovations and
Technologies Inc.,15 a Delaware based company, must face huge challenges in setting up the production
and running the sale and business operations.
11
Intelligent Machines - https://www.technologyreview.com/s/608863/a-radar-for-industrial-robots-may-guide-
collaboration-with-humans/
12
Humantics - https://www.technologyreview.com/s/608863/a-radar-for-industrial-robots-may-guide-collaboration-with-
humans/
13
The Five Forces that Shape Competition - https://hbr.org/2008/01/the-five-competitive-forces-that-shape-strategy
14
https://hbr.org/2014/11/how-smart-connected-products-are-transforming-competition
15
Hanumayamma Innovations and Technologies, Inc – http://www.hanuinnotech.com
Smart, connected products will have transformative effect on Industry structure. The
Five Forces that shape competition13 provide a framework to understand the influence of
Smart connected objects on the competition (please see Figure Porter Five Forces).
6 Building Enterprise IoT Applications
PRODUCT
Product Software Introduction 7
An embedded operating system, onboard software applications,
an enhanced user interface, and product control components
Product Hardware
Enterprise IoT Platforms
Embedded sensors, processors, and a connectivity port/
antenna that supplement traditional mechanical and
The IoT plays a key role in enterprise electrical components
digital transformation. For instance, integration mobile and sensor
data into Electronic Health Records (EHR) or integration of Wearables, Mobile Data, and Electronic Data
Interchange (EDI) processing for better insurance processing. With the right level of integration, IoT acts
as a crucial bridge between the physical assets, legacy systems, business processes, newer competitive
models and the IT infrastructure.
F6 after Icon1
IoT enables enterprises to create a better connected physical world18 by enabling (a) flexible deployment
of architectures, (b) multiple connections, (c) Intelligent management, (d) data security, and (e) an Open
Ecosystem [16]. To successfully monetize the capabilities, for any sizeable company, a state-of-the-art
data and analytics platform is necessary.19 The Enterprise grade of the IoT platforms is weighed on Data
Platform and requires following Key Performance Indicator (please see Figure 6) in order to fulfill customer
and business needs. What this entails is the development of IoT data analytics platform that include: Three
major value drivers to deliver value for customers and businesses [17].
Figure 6: KPIs
1. Customer business priorities: includes integration of IoT data sources with enterprise data assets
to deliver digital innovation and predictive maintenance to provide contextual intelligence of the
devices and to provide adaptive prognosis to transpose from reactive to proactive operations for
device operational longevity and data monetization through service/blue-ocean models.
2. Platform dimensions: include data insights and metrics that have positive impact through the
implementation of adaptive edge processing with closed loop event handling and customer excellence.
3. Delivers: advanced analytics and cognitive intelligence that deliver predictive maintenance and
proactive exclusive recommendations.
There are many public Cloud platforms that offer enterprise IoT platforms. Here is the current trend
of those platforms:20
1. Data is the biggest driver of the IoT Platform
2. IoT Solutions that need integration of several sensors are complex.
18
https://e.huawei.com/us/solutions/technical/iot
19
Building a great data analytics platform - https://www.mckinsey.com/industries/electric-power-and-natural-gas/our-
insights/building-a-great-data-platform
20
Current IoT Platforms - https://www.forbes.com/sites/janakirammsv/2018/09/10/the-current-state-of-public-cloud-
enterprise-iot-platforms/#12f6779256b2
8 Building Enterprise IoT Applications
3. IoT sensor integration requires steep data processing, connectivity, cloud and analytics knowledge.
Given the complexity, many CIOs and companies are planning to Use Cloud platforms [18].
4. Contextual real-time actionable insights require Complex Event Processing (CEP) closer to the Data
Source. Edge Processing bridging the gap between heavy data intense platforms and real-time insights.
5. Lack of standards is hurting the IoT.
6. Security is playing an important role in choosing an enterprise platform.
Business Understanding
In my experience, this is one of the most important phases in an ML process. The success of initiative and
expectations to stakeholders and project outcomes are derived from clear understanding of the business
requirements. This phase also helps to uncover current as-is process and the proposed machine learning
objectives.
21
One is the Loneliest Number: Combating Senior Isolation - https://stonegatesl.com/one-is-the-loneliest-number-
combating-senior-isolation/
22
Senior Loneliness and Public Health Response - https://www.publichealthpost.org/research/senior-loneliness-public-
health-response/
23
Elderly Suicide Rate - https://www.sageminder.com/SeniorHealth/MentalHealth/Suicide.aspx
24
Introduction to IBM SPSS Modeler and Data Mining, ftp://ftp.software.ibm.com/software/analytics/spss/support/
Modeler/Documentation/14/UserManual/CRISP-DM.pdf
Introduction 9
Determine
business objective
Background
Collect initial data
Initial data collection
report
Data set
Data et description
Select modelling
Technique
Modelling technique
Evaluate results
Assessment of data
mining results w.r.t.
Plan deployment
Deployment plan F10
Business objective Select data Modelling business success Plan monitoring
Describe data Rationale for and maintenance
Business success Data description assumption criteria
Criteria inclusion exclusion Approved model Monitoring and
report Generate test maintenance plan
Assess situation Clean data Review process
Explore data design
Inventory of resource Data cleaning Review of process Produce final
Data exploration Test design
Requirements, report report
report Determine next
assumption, and Build model Final report
Construct data steps
constraints Verify data quality Parameter settings Final presentation
Derived attributes List of possible
Risk and contingencies Data quality report models
Generated records actions Review project
Terminology Model description
Decision Experience
Costs and benefits Integrate data
Assess model documentation
Merged data
Determine Model assessment
data mining goals Format data Revised parameter
Data mining goals Reformatted data settings
Data mining success
criteria
Produce project plan
Project plan
Initial assessment of
tools and techniques
Figure 7: CRISP-DM
Data Understanding
Third-
party cloud
Network Cloud
TheSecurity
preamble or pre-requisite
Managemant API libraries,
APIs, SDK for the Gateway
phaseDevices
is the business understanding phase. During the data
understanding phase, involve data scientists and data engineers, as they will be creating data models and
ml algorithms. Generally, this phase accounts for 30 to 40 percent of the project time.
LifeNoCycle - Industry Standards:
internet connectivity
25
Securityplease see below
Management the
API libraries,
APIs, SDK
table
Network
for
Batch & stream Storage
ML Life
infrastructure
Service
cycle standards [23]:
analytical F16
Data Preparation Phase Security Managemant API libraries,
Internet connectivity APIs, SDK
Data preparation phase involves working with several origination units in order to collect the required
data for developing Machine Learning algorithms. During this phase, we need to work with biasness and
product groups in order to develop data processing and transformation rules. These rules will subsequently
Cloud
be deployed at the Edge and at the Cloud level.
Fog nodes a t
d da lysis
ir t u alize ive ana
Lar V d ic t in g
ge V r e ar n
ric/p e le
olum
e of histo machin
data erns
3 patt
and tes
Preparing and Architecting for Machine Learning - https://www.gartner.com/binaries/content/assets/events/keywords/
25
4
le
Ru upda
catalyst/catus8/preparing_and_architecting_for_machine_learning.pdf
Wide Variety of things 1
2
Rules,
patterns,
actions
4
F17
ty)
e l oci Data reduction,
e (V control response,
l-tim
& rea data virtualization/standardization
s
uou
ntin
Co
Data in motion Data in rest
10 Building Enterprise IoT Applications
Data Modelling
This phase is also known as machine learning phase. In this phase, the actual mission learning algorithm
is built, trained, validated and tested in order to meet the biasness objectives. During this phase, both data
scientists and business Subject Matter Experts (SMEs) are closely involved and worked with Users. The
successful development of algorithms is more of a collaborative prosses than siloed approaches.
This phase comprises of following major tasks:
• Select Modeling Technique
○ Supervised:
▪ Classification
Introduction 11
Data Holdout
If a lot of data are available, simply take two independent samples and use one for training and one for
testing. The more training, the better the model. The more test data, the more accurate the error estimate.
Problem: Obtaining data is often expensive and time consuming. Example: Corpus annotated with word
senses, Dairy Sensor data, experimental data on sub-cat preferences.
Solution: Obtain a limited data set and use a holdout procedure. Most straightforward: Random split into
test and training set. Typically, between 1/3 and 1/10 held out for testing.
Data Stratification
Problem: The split into training and test set might be unrepresentative, e.g., a certain class is not represented
in the training set, thus, the model will not learn to classify it.
Solution: Use stratified holdout, i.e., sample in such a way that each class is represented in both sets.
Example: Data set with two classes A and B. Aim: Construct a 10% test set. Take a 10% sample of all
instances of class A plus a 10% sample of all instances of class B.
However, this procedure doesn’t work well on small data sets.
Deployment
The successful ML algorithms are deployed for business and user purposes. The deployment phase consists
of working with HPC, data engineers and IT groups.
Chapter Summary
• You should see the potential positive economic impact of IoT.
• The New Stack that is required to process IoT Data feeds.
• You should see how Industry 4.0 evolved.
• You would learn the importance of augmented analytics.
• You would see the role of analytics and mobile platform as a human companion.
• The Key Performance Indicators (KPIs) of Analytics platform.
• You should understand the phases in CRISP-DM.
References
1. James Manyika, Michael Chui, Jacques Bughin et al. Disruptive technologies: Advances that will transform life,
business, and the global economy. May 2013, https://www.mckinsey.com/~/media/McKinsey/Business%20Functions/
McKinsey%20Digital/Our%20Insights/Disruptive%20technologies/MGI_Disruptive_technologies_Full_report_
May2013.ashx , Access date: 09/18/2018
2. Samsung Software Development. IoT Solutions. 2017, https://www.samsung.com/global/business/networks/solutions/
iot-solutions/, Access date: 09/27/2018
3. Kip Compton and Vikas Butaney. Enabling the Internet of Everything’s, Cisco’s IoT Architecture, https://www.slideshare.
net/Cisco/enabling-the-internet-of-everything-ciscos-iot-architecture?from_action=save , 02/05/2015, Access date:
09/18/2018
4. Timothy King. Gartner Identifies Augmented Analytics as a Top Technology Trend for 2019. November 9, 2018, https://
solutionsreview.com/business-intelligence/gartner-identifies-augmented-analytics-as-a-top-technology-trend-for-2019/,
Access Date: 12/25/2018
5. Margaret Rouse. Augmented Intelligence. July 2017, https://whatis.techtarget.com/definition/augmented-
intelligence?track=NL-1823&ad=922091&src=922091&asrc=EM_NLN_103914963&utm_medium=EM&utm_
source=NLN&utm_campaign=20181122_Word%20of%20the%20Day:%20augmented%20intelligence
Introduction 13
6. Rita L. Sallam. June 2018. Augmented Analytics: The Next Disruption in Analytics and BI Register now for this free
60 minute Disruption and Innovation webinar, https://www.gartner.com/webinar/3846165, Access date: 12/20/2018
7. Jennifer Garfinkel. Gartner Identifies the Top 10 Strategic Technology Trends for 2019. October 15, 2018, https://
www.gartner.com/en/newsroom/press-releases/2018-10-15-gartner-identifies-the-top-10-strategic-technology-trends-
for-2019, Access Date: December 29, 2018
8. Bernard Marr. What is Industry 4.0? Here’s A Super Easy Explanation For Anyone. Sep 2, 2018, 11: 59 pm,
https://www.forbes.com/sites/bernardmarr/2018/09/02/what-is-industry-4-0-heres-a-super-easy-explanation-for-
anyone/#75023f039788
9. Dr. Ralf C. Schlaepfer, Markus Koch, Dr. Philipp Merkofer, October 2014. Industry 4.0 - Challenges and Solutions
for the digital transformation and use of exponential technologies, https://www2.deloitte.com/content/dam/Deloitte/
ch/Documents/manufacturing/ch-en-manufacturing-industry-4-0-24102014.pdf, Access Date: December 10, 2018
10. Michael E. PorterJames E. Heppelmann. How Smart, Connected Products Are Transforming Competition. NOVEMBER
2014 ISSUE, https://hbr.org/2014/11/how-smart-connected-products-are-transforming-competition
11. Will Knight. A Radar for Industrial Robots May Guide Collaboration with Humans. September 20, 2017, https://www.
technologyreview.com/s/608863/a-radar-for-industrial-robots-may-guide-collaboration-with-humans/
12. Will Knight. A Radar for Industrial Robots May Guide Collaboration with Humans The sensor makes it possible
to track the movements and actions of workers inside a factory or warehouse. September 20, 2017, https://www.
technologyreview.com/s/608863/a-radar-for-industrial-robots-may-guide-collaboration-with-humans/, Access Date:
September 18, 2018
13. Michael E. Porter. The Five Competitive Forces That Shape Strategy. THE JANUARY 2008 ISSUE, https://hbr.
org/2008/01/the-five-competitive-forces-that-shape-strategy
14. Bernard Marr, What Is Digital Twin Technology - And Why Is It So Important?, March 06, 2017, https://www.forbes.
com/sites/bernardmarr/2017/03/06/what-is-digital-twin-technology-and-why-is-it-so-important/#2db6e6432e2a
15. Sam Lucero. Enterprise IoT Leading IoT, Driving Industry Digital Transformation. March 2017, https://e.huawei.com/
us/solutions/technical/iot, Access date: 12/14/2018
16. Adrian Booth, Jeff Hart and Stuart Sim. Building a great data platform. August 2018, https://www.mckinsey.com/
industries/electric-power-and-natural-gas/our-insights/building-a-great-data-platform
17. Janakiram MSV. The Current State of Public Cloud Enterprise IoT Platforms. Sep 10, 2018, 10:17 pm, https://www.
forbes.com/sites/janakirammsv/2018/09/10/the-current-state-of-public-cloud-enterprise-iot-platforms/#6f28f4c056b2
18. Stonegate. One is the Loneliest Number: Combating Senior Isolation. https://stonegatesl.com/one-is-the-loneliest-
number-combating-senior-isolation/, Access date: 12/14/2018
19. Gilbert Benavidez. Senior Loneliness and the Public Health Response. September 13, 2017, https://www.
publichealthpost.org/research/senior-loneliness-public-health-response/
20. D. Bowes. Elderly Suicide Rate. May 15, 2015, https://www.sageminder.com/SeniorHealth/MentalHealth/Suicide.
aspx, Access Date: May 27, 2019
21. Pete Chapman, Julian Clinton, Randy Kerber et al. CRISP-DM 1.0. March 2000, ftp://ftp.software.ibm.com/software/
analytics/spss/support/Modeler/Documentation/14/UserManual/CRISP-DM.pdf , Access Date: 11/22/2018
22. Carlton E. Sapp. Preparing and Architecting for Machine Learning. 17 January 2017, https://www.gartner.com/binaries/
content/assets/events/keywords/catalyst/catus8/preparing_and_architecting_for_machine_learning.pdf, Access Date:
11/22/2018
Chapter 2
Foundation Architectures
IoT Platform
Produce project plan
Project plan
Initial assessment of
IoT
toolsPlatform (see Figure 1) provides an end-to-end connectivity to bring it online and brings intelligence
and techniques
to “Things” [6].
F15
No internet connectivity
Security Management API libraries,
APIs, SDK
Network
infrastructure
Batch & stream Storage
analytical
Service
F16
Security Managemant API libraries,
Internet connectivity APIs, SDK
Background report Modelling technique mining results w.r.t.
Business objective Select data Modelling business success Plan monitoring
Describe data Rationale for and maintenance
Business success Data description assumption criteria
Criteria inclusion exclusion Approved model Monitoring and
report Generate test maintenance plan
Assess situation Clean data Review process
Explore data design
Inventory of resource Data cleaning Produce final
Review of process
Data exploration Test design
Requirements, report report
report Determine next
assumption, and Build model Final report
Construct data
constraints Verify data quality Parameter settings Final presentation 15
stepsFoundation Architectures
Derived attributes List of possible
Risk and contingencies Data quality report models
Generated records actions Review project
Terminology Model description
Decision Experience
Costs and benefits Integrate data
At the source level, you have several types Assess model documentation
Merged data of devices that generate data at several different frequencies
Determine Model assessment
anddata
velocities. The Connectivity layerFormat
mining goals
is the one that collects
data data from the Sensors and uploads to either
Revised parameter
edge
Datalevel
mining or to the Cloud level. On Reformatted
goals the Cloud, datathe IoTsettings
data is processed through Analytics frameworks
Data
and mining success
Machine learning engines to derive useful insights. Finally, the end insights are stored in data base
criteria
or looped back to the Users.
Produce project plan
Here
Project planis the end to end platform view from Intel (see Figure 2): The goal of the System Architecture
Specification
Initial assessmentisofvery straight—to connect any device any type to the Cloud. The specification is also a
tools and techniques
guideline for third party developers, Original Equipment Manufacturers (OEM), and other developer
community to develop products for IoT [7].
The tenets for the application developers to deploy IoT solutions are as follows:
• Services to Monetize the IoT Infrastructure.
• Seamless data ingestion.
• Intelligence deployment to any-form-factor devices by running analytics on the Cloud or on to the
F15
device.
In the grand scheme of IoT, the philosophy is very straightforward: Deployment of distributed data
collection, contextual intelligence, centralized data platform,IoT
and holistic
device cloudintegration of devices to the
Enterprise Data architecture systems.WI-FI or
A fleet of devices cellular
connectivity Apps and third
party services
Thinks
Gateway Devices
Third-
party cloud
Network Cloud
Security Managemant API libraries, Gateway Devices
APIs, SDK
No internet connectivity
Security Management API libraries,
APIs, SDK
Network
infrastructure
Batch & stream Storage
analytical
Service
F16
Security Managemant API libraries,
Internet connectivity APIs, SDK
Cloud
IoT Platform Types
Fog nodes ta
lize e aData
na d da lysis
IoT Platform Types can be classified under End-to-End, Connectivity, VCloud,
irtua ictand
iv g
Platforms.
Lar red learnin
ge V
ric/p e
olum
e of histo machin
s
ta da 3 ttern
End to End Platform a n d pa
s
Rule update
4
On the left side (see Figure 10), the data is generated by Sensors, Human Activity, Motors or
Sensors/Actuators. The sensors could be of active, passive or hybrid of the data generators.
The data from the generators are collected by the main processing units Data Controllers
Third-
party cloud
Network Cloud
Security Managemant API libraries, Gateway Devices
APIs, SDK
No internet connectivity
Security Management API libraries,
APIs, SDK
Network
infrastructure
Batch & stream Storage
analytical
Foundation Architectures
Service
F16
17
Cloud
Fog nodes ta
d da nalysis
alize a
Lar Virtu edictive ning
ge V r ar
ric/p e le
olum
e of histo machin
data erns
3 patt
le and tes
Ru upda
4
1 Sensors generate data; The data is collected at source and, using network protocols (Wi-Fi
or Bluetooth), is transmitted to the Edge Nodes. The characteristics of data are:
• Large volume of data
• Wide variety
• Continuous and real-time
Typically, the data is in motion.
3 Before relaying the data to backend or traditional Cloud, the data is formatted in order to
preserve or optimize the network costs. This includes:
• Data Reduction
• Control Response
• Data Virtualization/Standardization
4 Once the data is relayed to the Cloud, adaptive machine learning algorithms compute updated
models with the data generated, the most recent. Any machine learning coefficients or update
to the model classifier is downloaded OTA.
• Predictive Machine Learning Analytics
• Rules and Pattern updates
18
Building Enterprise IoT Applications
Connectivity IoT platforms enable direct integration of Sensors via edge device or
The end to end platform provides several benefits:
•gateway
Over thetoairthe
Firmware
Cloud. (OTA) Upgradeupload the collected data, periodically, to the on-site
The Sensors
• Device Management
•collector device. The Collector on the availability of network connection, uploads to the Cloud.
Cloud Connection
•Connectivity
Cellular or Connectivity
Platform enforces tighter API or Data integration between the Sensor and
• Analytics and
•Gateway devices.
User Interface
Connectivity Platform
The connectivity platform, as the name implies, is ideal for the use cases that solve or address
Connectivity IoT platforms enable direct integration of Sensors via edge device or gateway to the Cloud.
Thenetwork
Sensorsconvexity
upload theissues.
collectedThe
data, periodically,Platform
Connectivity to the on-site collector
potentially device.
allows IoTThe Collector
devices on the
to run
availability of network connection, uploads to the Cloud. Connectivity Platform enforces tighter API or
Data
forintegration between
years on small the Sensor
batteries, and Gateway
occasionally devices.
sending out small packets of data, waiting for a short
The connectivity platform, as the name implies, is ideal for the Study Cases that solve or address
network
time forconvexity
responseissues. The Connectivity
messages, Platform
and then closing potentiallyuntil
the connection allows IoTdata
more devices
needstotorun
be for
sent.years
on small batteries, occasionally sending out small packets of data, waiting for a short time for response
messages, and then closing the connection until more data needs to be sent.
1
LoRa - https://www.loraserver.io/overview/
Foundation Architectures 19
LoRa
LoRaWAN (please see Figure 6) is a long range, low power, wireless protocol that is intended for use
in building IoT networks. IoT devices (“nodes”) send small data packets to any number of “gateways”
that may be in the several-kilometer range of a node via the LoRaWAN wireless protocol. The
gateways then use more traditional communications, such as wired Internet connections, to forward
the messages to a network-server, which validates the packets and forwards the application payload
to an application-server [8].
LoRa Architecture2 [9]
• LoRaWAN devices: IoT Devices that send data to LoRa network (through LoRa gateways).
• LoRa Gateway: LoRa Gateways are central in the network. They receive data from the Sensor
devices and implement packet forward software in order to send data to LoRa Servers.
• LoRa Gateway Bridge: The LoRa gateway bridge takes the Packet forward message (UDP) and
translate into MQTT. The advantage of using MQTT is:
○ It makes debugging easier.
○ Sending downlink data only requires knowledge about the corresponding MQTT topic of the gateway,
the MQTT broker will route it to the LoRa Gateway Bridge instance responsible for the gateway.
○ It enables a secure connection between your gateways and the network (using MQTT over
TLS—see Figure LoRa).
• LoRa Server [9]: LoRa Server manages the WAN and provides the network. It also maintains
registry of active devices on the network. LoRa Server performs one more additional functionality:
When data is received by multiple gateways, LoRa Server will de-duplicate this data and forward it
once to the LoRaWAN application-server. When an application-server needs to send data back to a
device, LoRa Server will keep these items in queue, until it is able to send to one of the gateways.
• LoRa Geo Server: It is an optional component. providing geo resolution of Gateways.
• LoRa App Server: The LoRa App Server component implements a LoRaWAN application-server
compatible with the LoRa Server component. To receive the application payload sent by one of your
devices, you can use one of the integrations that LoRa App Server provides (e.g., MQTT, HTTP or
directly write to an InfluxDB database).
IoT device
UDP UDP
MQTT
MQTT
Application
MQTT geo server gRPC LoRa server
gRPC
F21
gRPC JSON rest
MQTT
F22
Raise lights
Adust temperature
Thermostats
Trigger alarm
Thermostats Alarm
ARTIK cloud
Lights
Rules
Motion
sensor
Meteor sensor ???.
Lights
F22
Raise lights
20 Building Enterprise IoT Applications Adust temperature
Thermostats
Trigger alarm
Thermostats Alarm
Lights Alarm
Artik platform (see Figure 7) provides connectivity platform for the IoT devices [10]. The platform provides
connecting IoT devices to the platform and enable to create custom rules processing engine to evaluate
conditions and integrate action—email or alert.
ARTIK 1
F23
ARTIK 5/10
BLE
Analog
????? Serial
????? Digital
Interface (A0-A5)
????? (SPI/USB)
????? (GPIO)
?????
Signal conditioning
Sensor
Add Device
Add devices enables management of the IoT devices connected to ARTIK Cloud (see Figure 9).
Device Added Successfully (see Figure 9 and see Figure 10 ).
3
Artik Architecture - https://www.artik.io/blog/2015/10/iot-101-sensors/
Foundation Architectures 21
F24
F24
F25
F25
F26
F26
22 Building Enterprise IoT Applications
F26
Data Simulation
Devices are activated and enabled simulation by running simulation data points.
F27
Foundation Architectures 23
DataData
Interval enables
Interval the the
enables datadata
generation as per
generation mentioned
as per Interval
mentioned (simulation
Interval (simulationinterval – see
interval—see
Figure 12);
Figure 19);
Data Pattern
The data can be generated Randomly, in increments, at a constant value, or you can
The data can be generated Randomly, in increments, at a constant value, or you can cycle the data (see
Figure 13).
cycle the data (see The
Figure 20).
data can be generated Randomly, in increments, at a constant value, or you can
F30
F30
F31
F31
F32
F32
Multiple Charts
Once configured, the device data can be viewed (see Figure 17)
F33
F33
F34
26 Building Enterprise IoT Applications
Edge Rules
Create Edge Rules to process the data before relayed to the Cloud. Graphically we can provide rules (see
figure Create Rule UI).
Anomaly detection
Specified Anomaly detection for the data points (see Figure 18); Can be provided data edge conditions.
F35
Rule Created
TEMP > 40—the rule4 is fully qualified. In our case, if morning temperature is more than 40 degrees
Celsius, send email to User email—[email protected]
Rule meta5 data: F36
1 {
2 “if”: {
3 “and”: [ {
4 “sdid”: ... the device ...,
5 “field”: ... the field ...,
6 “operator”: ... the operator ...,
7 “operand”: { “value”: ... the value ... },
8 “duration”: {
9 “value”: ... duration in seconds ...,
10 “acceptUpdate”: ... true/false ...
11 }
12 } ]
13 }
14 }
4
Rule - https://developer.artik.cloud/documentation/rules-engine.html
5
Rules engine - https://developer.artik.cloud/documentation/rules-engine.html
F36
Figure3120:
Once data violates the rule, email notification is sent
Emailto the User (see Figure 27).
31
Cloud Integration - https://developer.artik.cloud/documentation/data-management/push-to-
amazon-kinesis.html
6
Cloud Integration - https://developer.artik.cloud/documentation/data-management/push-to-amazon-kinesis.html
F36
Technical Case Study: Using IoT to detect water leakages with Powel7
Water leakage is a costly issue for the water governing bodies across the world [12]. Given the aging
infrastructure across the many municipalities, the water leakage is one of the on-going expenses that
governments and tax paying citizen unwillingly share. In the following Study Case, the municipalities in
Norway used IoT to detect water losses due to leakages (than 30% due to leakages in their water distribution
network and this represents a significant cost that ends up in the hands of consumers).
Key Technologies used:
• Telemetry provided by SCADA Sensors, measuring waterflow and pressure
• Azure Function
• Azure Cloud & Storage
Process: understanding from RAW data to creation of model is needed to see the solution (see Figure 21).
The Data from Sensors are collected by Edge Gateways [12] (see Figure 22) and relayed to IoT Hub for the
data ingestion purposes. The data is retrieved using Sensor Analytics to identify leakage issues by applying
machine learning algorithms. The API and app services enable generation reports for the management
consumption; finally, the data is repented on UI using HTML 5 and Power BI application.
Figure 29: Azure Solution Architecture Figure 22: Azure Solution Architecture
The Data from Sensors are collected by Edge Gateways [12] (see Figure 29 ) and relayed to IoT Hub for the data ingestion purposes. The data is
Overlying historical data with machine learning prediction (see Figure 23) results in identification of
retrieved using Sensor Analytics to identify leakage issues by applying machine learning algorithms. The API and app services enable generation
water flow outliers, a good indicator of leakage, at an interval of time. In general [12].
reports for the management consumption; finally, the data is repented on UI using HTML 5 and Power BI application.
7
Using IoT to detect Water leakages - https://microsoft.github.io/techcasestudies/iot/2016/11/29/Powel.html
Foundation Architectures 29
100
80
60
40
20
Oct 06 Oct 10 Oct 20 Oct 27
Avvik vindu by date
2k
1k
0k
Date
–1k
Oct 06 Oct 10 Oct 20 Oct 27
Y O M W D
Oct 2013 - Oct 2013
Month
2013 2014 2015
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec
Angle of attack
Horizontal plane
Relative wind
F42
Earth
Nadir
In the figure above, the angle of attack is measures by taking horizontal plan reference and relative
wind positions that flow through the wing mounted AOA sensor.
The Angle of Attack (AoA) Probe provides AoA or Sideslip (SS) by sensing the direction of local airflow.
It is mounted on the fuselage with the sensing probe L extending through the aircraft fuselage [13].
I
8
W
E
I
G
H
T
Earth
Nadir
L
I
F
T
Portion of wing able
THRUST to generate lift DRAG
Wind chordline
Disturbed flow F43
Relative wind
Direction of
flight
W
E
I
G
H
T
Stall is defined as the condition which arises when the angle grows so large that the flow is completely
disrupted, and not enough lift is generated to overcome the weight of the aircraft. This AOA, the stall angle,
is constant for a particular aircraft, although various wing designs stall at differing angles. The amount
of useful lift and drag generated by any wing at some specific AOA will depend upon the influence of
variables as the wing geometry, density altitude, aircraft gross weight and velocity.
Knowledge
Evaluation and
presentation
Process
Data mining
F44
Selection and
transformation
Data
warehouse
Cleaning and
integration
The Knowledge Discovery in Databases is applied to data in rest (see Table 1). That is, the data is stored
in databases and there is no variation of the data. The data is a source of truth. On the other hand, Data
Pattern evaluation
from IoT devices are in motion. The data is continuously changing. In short, the data has velocity and is
in constant flux [16]. Knowledge
The IoT application constructs are different from
Data mining conventional applications
engine base from algorithms and
processing sides. Some of the differences that make IoT applications unique include:
• Data Filtering Database for
data warehouse sever
F45
• Aggregation and Correlation
• Data Enrichment (e.g., Spectrogram or histograms)
Data cleaning, integration and selection
• Location (Geo-context)
• Time Windows
• Temporal Platforms
Data World wide Other info
Database
warehouse web repsitories
Database Plant files
User interface
Pattern evaluation
Knowledge
Data mining engine base
Database for
data warehouse sever
F45
Data cleaning, integration and selection
9
The Next Big Thing in the Internet of Things: Real-time Big Data Analytics - http://www.vitria.com/pdf/Forrester-Vitria-
IOT-Dale-Slides.pdf
10
Why only one of the 5 Vs of big data really matters - https://www.ibmbigdatahub.com/blog/why-only-one-5-vs-big-data-
really-matters
Foundation Architectures 33
Volume
Volume refers to the vast amount of data generated every second. The data could be from traditional
sources such real-time transaction system generating huge amounts of transaction data. For instance,
holiday sales at a popular store.
In IoT’s context, the Volume refers to the number of sensors generating the data at a manufacturing
plan level, or the data generated by oil rigs. For instance, A large refinery generates 1TB of raw data per day.
Velocity
Velocity refers to the speed at which new data is generated and the speed at which data moves around. The
data generated by Sensors is in the denominator of microsecond or millisecond level. Let’s say a sensor
generates 256 bytes data at every microsecond level and all the data points are required to process the
business case study, then in a one day the sensor generates:
24 X 60 X 60 X 1000 X 256 bytes
22118,400,000 bytes (1)
22.1 GB per day
If thousands of sensors collect data, we can see that the Volume and Velocity of data are huge—Big Data
level (see Figure 5Vs) [18].
Variety
Variety refers to the different types of data we can now use. In the past, we focused on structured data
that neatly fits into tables or relational databases, such as financial data (for example, sales by product or
region). In fact, 80 percent of the world’s data is now unstructured and therefore can’t easily be put into
tables or relational databases—think of photos, video sequences or social media updates. In IoT’s context,
the data generated by Sensors falls into variety data (see Table Data Formats). For instance, security camera
data is streaming video data. The voice assistant audio sensors capture the data in the audio format and
the environmental or activity sensors collect data on a time-series basis. Please see the following table for
audio, video and environmental sensor data formats.
Veracity
Veracity refers to the messiness or trustworthiness of the data. Veracity plays an important role in the
IoT—especially the sensors that generate data with out of balance calibration factors.
To achieve the best possible accuracy, a sensor should be calibrated (see Figure 28) in the system
where it will be used.11 This because:
• No Sensor is perfect
○ Sensors subject to heat, cold, shock, humidity, etc., during storage, shipment and/or assembly may
show a change in response.
○ Some sensor technologies ‘age’ and their response will naturally change over time—requiring
periodic re-calibration [19].
• The Sensor is only one component in the measurement system [20]. For example:
○ With analog sensors, your ADC is part of the measurement system and subject to variability as
well.
11
Why Calibrate? - https://learn.adafruit.com/calibrating-sensors/why-calibrate
34 Building Enterprise IoT Applications
Source Format
Audio Data
Spectrogram
Image Data
Histogram
Text Data <START> this a rip roaring western and i have watched it many times and it entertains
on every level however if your after the true facts about such legends as <UNK> cody
and <UNK> jane then look elsewhere as john ford suggested this is the west when the
truth becomes legend print the legend the story moves with a cracking pace and there
is some great dialogue between gary cooper and jean arthur two very watchable stars
who help to make this movie the sharp eyed amongst you might just spot <UNK>
hayes as an indian <UNK> also there is a very young anthony quinn making his
debut as <UNK> warrior he actually married one of <UNK> daughters in real life
indeed its <UNK> character who informs cooper of the massacre of <UNK> told in
flash back the finale is well done and when the credits roll it <UNK> the american
west with american history so please take time out to watch this classic western
<PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD>
<PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD>
<PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD>
<PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD>
<PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD>
<PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD>
<PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD> <PAD>
Document Vector
○ Temperature measurements are subject to thermal gradients between the sensor and the measurement
point.
Sensor said to be accurate if it follows ship settings expected behavior:
• Precision
○ The ideal sensor will always produce the same output for the same input.
• Resolution
○ A good sensor will be able to reliably detect small changes in the measured parameter.
The precision is affected by Noise and Hysteresis.
Foundation Architectures 35
se
on
Sensor output
Sensor output
sp
se
re
on
e
ise
sp
ns
e
ec
re
ns
po
pr
ise
po
es
Im
es
lr
ec
ea
lr
pr
ea
Id
Im
F46
Id
Measured parameter Measured parameter
Figure 28: Calibration
Sensor output
1101 1101
sp
se
re
Data-at-rest Data-in-motion
on
e
Data quality0011
issues related to sensor noise, null/static values, and0001 calibration issues are a leading
ise
sp
ns
e
ec
re
ns
po
contributor of poor outcomes when doing industrial analytics. Why? Sensor data are inherently noisy,
pr
ise
po
es
Im
es
lr
ec
large gaps in the data, and can experience calibration drift over time. When dealing
lr
pr
Types
ea
Id
Im
F46
unstructured | Time series | Reporting loop | Complex event processing | Alert
Id
with millions of sensors, these quality issues become significant. Some customers have stated that
F47
these sensor level quality issues are of
100s thedata
rootsources
cause of 40% of the issues they experience100s
in their highly
of sensors
Variety
automated operations. Establishing
(on premisessensor trust +requires
and cloud) EDWs being able to effectively identify
real-time bad(location
sources actor context
sensors through fleet-wide reporting on null values, data gaps, flat lined sensors, calibration and drift
issues, as well as noise.
Volume
Measured parameter
Terabytes/Petabytes
Measured parameter
Gigabytes
Velocity Gigabytes/Second
Machine learning: Pattern recognition, Megabytes/Second
prediction, and anomaly detection
F47
100s of data sources 100s of sensors
Variety (on premises and cloud) + EDWs real-time sources (location context
1101 1101
0011
Data-at-rest
0001
Data-in-motion
Foundation Architectures 37
Historic | Batch processing | Structured + Real-time | Stream processing | Closed
Types unstructured | Time series | Reporting loop | Complex event processing | Alert
Intel IoT Data Flow Diagram
F47
100s of data sources 100s of sensors
Variety (on premises and cloud) + EDWs real-time sources (location context
The following diagram (see figure Intel IoT Data Flow [7]) provides the Data Flow of typical Sensors that
Volume Terabytes/Petabytes Gigabytes
are not connected directly to the internet—Intel IoT Data Flow Architecture.13 The Sensors and Actuators
collect the data relays to the Gateways. The Gateways perform one or all of the operations: Edge Analytics,
Velocity Gigabytes/Second Megabytes/Second
Secure the data, and Manage the data. The Data is posted the to Cloud using Message Queue Telemetry
Transport (MQTT),
Veracity Hyper Text Transport
Attenuate Secure
of data quality (noise)(HTTPS), Constrained Application
Streams (real-time) Access Protocol
multi-temperature (Hot*/Cold**) † ††
(CoAP), Representational State Transfer (REST) Protocol and others. The Calibration / Blast
Data is processed and computed
using Cloud technologies.
*Data is in hot mode–processed through data rule †
Device calibration could impact quality
**Assumed data is store after applying rule ††
Data streams and Blast can create quality issues
Sensor
Enterprise
service bus
Sensor Sensor Data agent Cloud data Cloud
hub handler ingestion analytics
(Including software software
Actuator PMA)
Security
analytics
agent
DB OPS DB
Sensor
Service
orchestration
Security software
Cloud security
agent management
Actuator
Config DB
Gateway agents
Cloud software
Gateway software Cloud software
Open source third-party vendor
13
Intel IoT Reference Architecture - https://www.intel.com/content/www/us/en/internet-of-things/white-papers/iot-
platform-reference-architecture-paper.html
38 Building Enterprise IoT Applications
Consistency Availability
F49
Partition
tolerance
DATA CLEANING
Remove noise and inconsistent
1,3,5,7,9,0,2,5
Collector, 3. Data Synthesizer, 4. Sampling, 5. Rules, 6. Machine Learning, and 7. Data
Persistence.
Foundation Architectures 39
at the edge level has the following steps: (1) Data Filter, (2) Data Collector, (3) Data Synthesizer,
Figure 39:
(4) Sampling, (5) Rules, (6) Machine Learning, Edge
and (7) - Data
Data In Motion
Persistence.
Data Filter performs a crucial step: It identifies outliers in the data. As the data is processed through
the edge, first data filters such as Kalman filters identify the abnormalities of the data. Abnormal increase
in temperature, for example, can easily be identified through Filter process.
Data Filter performs
The Next step, Dataa Collector,
crucial step: It identifies
is in-memory outliers
representation of the in the
data. Thedata. Asthethe
Data at Edgedata
is is processed
continuous stream data that is moving rapidly. The goal of the data collector is to represent the data on
time interval level to be processed. Data Synthesis is merge of data from two or more sources for analytical
through the Sampling
purposes. edge, first data window
or Sliding filters issuch as Kalman
to perform filters
the evaluation identify
of data the abnormalities
in the streams. The sliding of the data.
window (see Figure 33) provides a data comparison between the current event and previous events. The
Abnormal
length of increase in temperature,
previous window for example, can easily be identified through Filter process.
size could be adjusted.
The Machine learning processes performs supervised or unsupervised machine learning algorithms
in order to enable contextual awareness and enable adaptive device behavior intelligence.
Operational View
The Operational View of IoT Processing at the Edge Level includes Kalman Filter at the Filter
processing, In-Memory Data Cubes or Data Collectors, Data Transformation and Synthesis
from various data sources, Data Windowing algorithms (see Figure 34) such as sliding
window, Rules application, Machine Learning module that provides contextual and geolocation intelligence,
and data persistence using local file system and/or external drives.
of data in the streams. The sliding window (see Figure 40) provides a data comparison between
the current event and previous events. The length of previous window size could be adjusted.
40 Building Enterprise IoT Applications
Consistency Availability
F49
Partition Figure 33: Sliding Window
tolerance Figure 40: Sliding Window
FILTER
Kalman, outlier
The Machine1,3,5,7,9,0,2,5
learning processes performs supervised or unsupervised machine learning
DATA COLLECTOR
In memory, circular buffers, double buffers
algorithms ina,e,r,t,y,u,a,s,u,l,z,s,
order to enable contextual awareness and enable adaptive device behavior
DATA SYNTHESIS
1,0,1,1,1,1,0,0,0,1 Multiplex or mix data with other sources (audio, OUTPUT
noise, spectrum, histogram, voice and others)
intelligence.
[1,3], [1,2], [4,7] WINDOW OR SAMPUNG
Time window, sliding window, custom window
ROLES
F53
... Device ship setting rules, ML roles, data validation
:
MACHINE LEARNING
The Operational
Time View of IoT Processing at the Edge Level includes Kalman Filter at
Context aware, geolocation, adaptive behavior
DATA PERSISTENCE
the Filter processing, In-Memory Data Cubes
Local fileor Data
system, Collectors,
external, or network Data Transformation and
Synthesis from various data sources, Data Windowing algorithms (see Figure 41) such as
Closer to source – edge processing
Embedded
local storage
Data in motiom
Figure 34: Edge – Data in Motion
DATA CLEANING
Remove noise and inconsistent data
1,3,5,7,9,0,2,5
DATA INTEGRATION
Integrating with other data sources
a,e,r,t,y,u,a,s,u,l,z,s,
DATA SELECTION
Foundation Architectures 41
Data at Rest
At the Edge level, data is in motion (see Figure 35 and Figure 36). It’s fast and needs to be processed in a
millisecond or less time (sub-millisecond). Once the data is relayed to traditional Cloud backend, data is at
rest and is combined with other sources in order to generate quality reporting or insights. The processing
of the data follows pretty much KDD steps, as shown in the figure below.
Data Source
Edge/Fog Compute
Data Stores/Collector
Data Connectivity
F54
Operational View:
ROLES
F53
... Device ship setting rules, ML roles, data validation
MACHINE LEARNING
Context aware, geolocation, adaptive behavior
Time
DATA PERSISTENCE
42 Building Enterprise IoT Applications Local file system, external, or network
Operational View
Data is CleansedCloser
for simple data–rules,
to source such as missing dates and Sensor values. The Cleansed output (see
edge processing
Embedded
Figure 37) data is integrated with Enterprise or 3rd party data sources in orderlocalto get a complete view of
storage
the data. The next step is the iterative process for picking important data attributes. The attributes selection
Data in motiom
is based on the business case study or algorithm under the case.
DATA CLEANING
Remove noise and inconsistent data
1,3,5,7,9,0,2,5
DATA INTEGRATION
Integrating with other data sources
a,e,r,t,y,u,a,s,u,l,z,s,
DATA SELECTION
1,0,1,1,1,1,0,0,0,1 Select data for the use case, attribute, features OUTPUT
F56
[1,3], [1,2], [4,7] DATA TRANSFORMATION
Feature engineering, dimension reduction
DATA MINING
... Algorithms, Al to perform data mining
MODEL STORAGE
Dynamic data mode and store
Time
DATA STORAGE
Store the data and models
Data
Cloud archiving Data
archiving
Data at rest
Figure 37: Data Processing in the Cloud
Digital Transformation:16
In McKinsey’s survey of top executives making a transformation at traditional companies with
digital technology [26] it was found that the enterprise architecture teams can play an integral role in
transforming companies with technologies [** R1]. The five key factors include:
1. Engage Top Executives in key decisions
2. Emphasize in strategic planning
3. Focus on Business outcomes
4. Use Capabilities to connect business and IT
5. Develop and retain high caliber talent
16
Five enterprise-architecture practices that add value to digital transformations - https://www.mckinsey.com/~/media/
McKinsey/Business%20Functions/McKinsey%20Digital/Our%20Insights/Five%20enterprise%20architecture%20
practices%20that%20add%20value%20to%20digital%20transformations/Five-enterprise-architecture-practices-that-
add-value-to-digital-transformations-vF.ashx
Foundation Architectures 43
Business processes
Technology stack
11
11
F5
Use of capabilities as primary grouping of milestones for
delivery of target architecture, % of survey-population segment
No target architecture 6
and road map
F64
SDA Bluetooth
Temperature
Chapter Summary: SCL
and humidity
Accelerometer
After reading the chapter: VCC sensor
• Should able to blue-print forbreakout
GND
board
Knowledge Discovery in Data bases Timer sensor
• Should able to develop IoT devices reference architecture
• Customize a third-party Cloud & IoT platform, specifically,SDA
Artik
• Should able to understand Sensors in action for Water leakSCLdetection and Angle
Proto of Attack
terminal
• Should able to list 5Vs for Data at rest vs. Data in motion VCC blocks
• Should able to apply CAP theorem for IoT Devices GND
• Able to apply IoT Streams architecture
SDI EEPROM
SCK Temperature
and humidity Microcontroller
References VCC sensor
Battery
1. James Manyika, MichaelGND Chui, Jacues Bughin et al. Disruptive technologies: Advances that will transform life,
business, and the global economy. May 2013, https://www.mckinsey.com/~/media/McKinsey/Business%20Functions/
McKinsey%20Digital/Our%20Insights/Disruptive%20technologies/MGI_Disruptive_technologies_Full_report_
May2013.ashx, Access Date: April 30 2018
2. Kip Compton and Vikas Butaney. Enabling the Internet of Everything’s, Cisco’s IoT Architecture. 02/05/2015, https://
Yes
www.slideshare.net/Cisco/enabling-the-internet-of-everything-ciscos-iot-architecture?from_action=save, Access date:
If
09/18/2018 mobile CND = 49 Send ambient temperature
3. Timothy King. Gartner Identifies Augmented Analytics as a Top Technology Trend for 2019. November 9, 2018, https://
solutionsreview.com/business-intelligence/gartner-identifies-augmented-analytics-as-a-top-technology-trend-for-2019/,
No
Access Date: 12/25/2018 Yes
4. Margaret If mobile
Rouse. CND Send https://whatis.techtarget.com/definition/augmented-
= 50 Intelligence. July 2017,
Augmented ambient humidity
intelligence?track=NL-1823&ad=922091&src=922091&asrc=EM_NLN_103914963&utm_medium=EM&utm_
source=NLN&utm_campaign=20181122_Word%20of%20the%20Day:%20augmented%20intelligence
No
5. Rita L. Sallam. June 2018. Augmented Yes
Analytics: The Next Disruption in Analytics and BI Register now for this free
60 minute Disruption
If mobile CNDand=Innovation
51 webinar. https://www.gartner.com/webinar/3846165,
Send cattle temperature Access date: 12/20/2018
6. Jeffrey Lee, How to Choose the Right IoT Platform: The Ultimate Checklist, April 25, https://hackernoon.com/how-
to-choose-the-right-iot-platform-the-ultimate-checklist-47b5575d4e20 , Access Date: August 06 2018
No
Yes
If mobile CND = 52 Send cattle humidity
No
If mobile CND = 53
Yes
Send cattle activity
F67
No
Yes
44 Building Enterprise IoT Applications
7. David McKinney. Intel Champions Internet of Things and The Intel IoT Reference Architecture. April 23, 2015, https://
www.intel.com/content/www/us/en/internet-of-things/white-papers/iot-platform-reference-architecture-paper.html,
Access Date: August 06 2018
8. Donna Moore. The LoRa Server project. March 2016, https://www.loraserver.io/overview/ Access Date: 11/22/2018
9. Alper Yegin. The LoRa Architecture. December 2016, https://www.loraserver.io/overview/architecture/Access Date:
11/22/2018
10. Kevin Sharp. IoT 101: Sensors. October 7, 2015 https://www.artik.io/blog/2015/10/iot-101-sensors/ Access Date:
10/30/2018
11. Wei Xiao. Artik Cloud Developer, Develop Rules for devices. February 7, 2017 , https://developer.artik.cloud/
documentation/rules-engine.html, Access Date: 10/30/2018
12. Pedro Dias, Using IoT to detect water leakages with Powel, Nov 29, 2016, https://microsoft.github.io/techcasestudies/
iot/2016/11/29/Powel.html, Access Date: 11/08/2018
13. Rick Snyder. Angle of Attack. March 2018, https://www.aerosonic.com/angle-of-attack, Access Date: 11/08/2018
14. Jiawei Han, Micheline Kamber and Jian Pei, Data Mining: Concepts and Techniques, Morgan Kaufmann; 3 edition
(July 6, 2011)
15. Anand Rajaraman and Jeffrey David Ullman, Mining of Massive Datasets, Cambridge University Press (December
30, 2011)
16. Nilamadhab Mishra, Chung-Chih Lin and Hsien-Tsung Chang. A Cognitive Adopted Framework for IoT Big-Data
Management and Knowledge Discovery Prospective. First Published October 5, 2015 Research Article https://doi.
org/10.1155/2015/718390
17. Dale Skeen. The Next Big Thing in the Internet of Things: Real-time Big Data Analytics. March 2017, http://www.
vitria.com/pdf/Forrester-Vitria-IOT-Dale-Slides.pdf , Access Date: 11/08/2018
18. Bernard Marr. Why only one of the 5 Vs of big data really matters. March 19 2015, https://www.ibmbigdatahub.com/
blog/why-only-one-5-vs-big-data-really-matters, Access Date: Nov 22 2018
19. Bill Earl. Calibrating Sensors. July 23 2018, https://learn.adafruit.com/calibrating-sensors/why-calibrate, Access Date:
November 22 2018
20. Kayla Matthews. The Importance of Sensor Calibration in Real-Time Data Analytics. April 19, 2018, https://www.
rtinsights.com/importance-sensor-calibration-real-time-data-analytics/, Nov 14 2018
21. Andy Bane. 4 Steps to Data Readiness for Industrial Analytics. July 21 2016, https://www.elementanalytics.com/
blog/4-steps-to-data-readiness-for-industrial-analytics, Access Date: November 14, 2018
22. Bernard Marr. Why only one of the 5 Vs of big data really matters. MARCH 19, 2015, https://www.ibmbigdatahub.
com/blog/why-only-one-5-vs-big-data-really-matters, Access Date: November 14, 2018
23. Dr. Eric A. Brewer. Towards Robust Towards Robust Distributed Systems Distributed Systems. July 19 2000, http://
pld.cs.luc.edu/courses/353/spr11/notes/brewer_keynote.pdf, Access Date: November 14, 2018
24. Mike Stolz. No, You Can’t Cheat the CAP Theorem. But Pivotal Cloud Cache on PCF Comes Close. Here’s How.
June 4 2018, https://content.pivotal.io/blog/acid-cap-and-pcc, Access Date: Sep 18 2018
25. Adam Wray. How IoT is making distributed computing cool again. 04 OCT 2016, https://internetofthingsagenda.
techtarget.com/blog/IoT-Agenda/How-IoT-is-making-distributed-computing-cool-again, Access Date: Sep 18 2018
26. Sven Blumberg, Oliver Bossert and Jan Sokalski, Five enterprise-architecture practices that add value to digital
transformations, November 2018, https://www.mckinsey.com/business-functions/digital-mckinsey/our-insights/five-
enterprise-architecture-practices-that-add-value-to-digital-transformations, Access Date: Dec 10, 2018.
Chapter 3
Hardware Design
1
Arduino - https://www.arduino.cc/en/Main/Software
2
Arduino Pin Diagram - https://www.circuito.io/blog/arduino-uno-pinout/
46 Building Enterprise IoT Applications
Figure 2: Sketch
Figure 46: Sketch
VIN Pin—This pin is used to power the Arduino Uno board using an external power source. The voltage
should be within the range mentioned above.
USB cable—when connected to the computer, provides 5 volts at 500 mA.
There is a polarity protection diode (see Figure 4) connecting between the positive of the barrel jack
to the VIN pin, rated at 1 Ampere.
The power source you use determines the power you have available for your circuit. For instance,
powering the circuit using the USB limits you to 500 mA. Take into consideration that this is also used for
powering the MCU, its peripherals, the on-board regulators, and the components connected to it. When
powering your circuit through the barrel jack or VIN, the maximum capacity available is determined by
the 5 and 3.3 volts regulators on-board the Arduino.
5v and 3v3
They provide regulated 5 and 3.3v to power external components according to manufacturer specifications.
GND
In the Arduino Uno pinout, you can find 5 GND pins, which are all interconnected.
The GND pins are used to close the electrical circuit and provide a common logic reference level
throughout your circuit. Always make sure that all GNDs (of the Arduino, peripherals and components)
are connected to one another and have a common ground.
RESET—resets the Arduino
IOREF—This pin is the input/output reference. It provides the voltage reference with which the
microcontroller operates.
Hardware Design 49
Serial Communication
Serial communication is used to exchange data between the Arduino board and another serial devices
such as computers, displays, sensors and more. Each Arduino board has at least one serial port. Serial
communication occurs on digital pins 0 (RX) and 1 (TX) as well as via USB. Arduino also supports serial
communication through digital pins with the Software Serial Library. This allows the user to connect
multiple serial-enabled devices and leave the main serial port available for the USB.
I2C
• SCL/SDA pins are the dedicated pins for I2C communication. On the Arduino Uno they are found
on Analog pins A4 and A5.
• I2C is a communication protocol commonly referred to as the “I2C bus”. The I2C protocol was
designed to enable communication between components on a single circuit board. With I2C, there
are 2 wires referred to as SCL and SDA.
• SCL is the clock line which is designed to synchronize data transfers.
• SDA is the line used to transmit data.
• Each device on the I2C bus has a unique address, up to 255 devices can be connected on the same
bus.
SI702—Header file
The Header file defines environmental sensors data structure:
typedef struct si7021_env {
int celsiusHundredths;
int fahrenheitHundredths;
unsigned int humidityBasisPoints;
} si7021_env;
The structure contains Celsius & Fahrenheit Hundredth Second value of temperature had Humidity
basis values. Similarly, si7021_thc contains temperature in Celsius and relative humidity values (see
Table 1).
3
https://github.com/LowPowerLab/SI7021
50 Building Enterprise IoT Applications
classSI7021
{
public:
SI7021();
#ifdefined(ARDUINO_ARCH_ESP8266) || defined(ARDUINO_ARCH_ESP32)
bool begin(int SDA, int SCL);
#else
bool begin();
#endif
Table 1 contd. ...
Hardware Design 51
...Table 1 contd.
bool sensorExists();
int getFahrenheitHundredths();
int getCelsiusHundredths();
unsignedint getHumidityPercent();
unsignedint getHumidityBasisPoints();
structsi7021_env getHumidityAndTemperature();
structsi7021_thc getTempAndRH();
int getSerialBytes(byte * buf);
int getDeviceId();
void setPrecision(byte setting);
void setHeater(boolon);
private:
void _command(byte cmd, byte * buf );
void _writeReg(byte * reg, intreglen);
int _readReg(byte * reg, intreglen);
int _getCelsiusPostHumidity();
};
#endif
SI720—Implementation File
To retrieve Sensor values (temperature and Humidity) and pass it to connectivity, the following command
locations are used (see Table 2):
#define I2C_ADDR 0x40
// I2C commands
#define RH_READ 0xE5
#define TEMP_READ 0xE3
#define POST_RH_TEMP_READ 0xE0
#define RESET 0xFE
#define USER1_READ 0xE7
#define USER1_WRITE 0xE6
/*
Copyright 2014 Marcus Sorensen <[email protected]>
This program is licensed, please check with the copyright holder for terms
Updated: Jul 16, 2015: TomWS1:
eliminated Byte constants,
fixed ‘sizeof’ error in _command(),
added getTempAndRH() function to simplify calls for C & RH only
*/
#include“Arduino.h”
#include“SI7021.h”
#include<Wire.h>
#defineI2C_ADDR 0x40
// I2C commands
#defineRH_READ 0xE5
#defineTEMP_READ 0xE3
#definePOST_RH_TEMP_READ 0xE0
#defineRESET 0xFE
#defineUSER1_READ 0xE7
#defineUSER1_WRITE 0xE6
// compound commands
byte SERIAL1_READ[] ={ 0xFA, 0x0F };
byte SERIAL2_READ[] ={ 0xFC, 0xC9 };
SI7021::SI7021() {
}
#ifdefined(ARDUINO_ARCH_ESP8266) || defined(ARDUINO_ARCH_ESP32)
bool SI7021::begin(int SDA, int SCL) {
Wire.begin(SDA,SCL);
#else
boolSI7021::begin() {
Wire.begin();
#endif
Wire.beginTransmission(I2C_ADDR);
if (Wire.endTransmission() == 0) {
_si_exists = true;
}
return _si_exists;
}
boolSI7021::sensorExists() {
return _si_exists;
}
intSI7021::getFahrenheitHundredths() {
int c = getCelsiusHundredths();
return (1.8 * c) + 3200;
}
...Table 2 contd.
intSI7021::getCelsiusHundredths() {
byte tempbytes[2];
_command(TEMP_READ, tempbytes);
long tempraw = (long)tempbytes[0] << 8 | tempbytes[1];
return ((17572 * tempraw) >> 16) - 4685;
}
intSI7021::_getCelsiusPostHumidity() {
byte tempbytes[2];
_command(POST_RH_TEMP_READ, tempbytes);
long tempraw = (long)tempbytes[0] << 8 | tempbytes[1];
return ((17572 * tempraw) >> 16) - 4685;
}
unsignedintSI7021::getHumidityPercent() {
byte humbytes[2];
_command(RH_READ, humbytes);
long humraw = (long)humbytes[0] << 8 | humbytes[1];
return ((125 * humraw) >> 16) - 6;
}
unsignedintSI7021::getHumidityBasisPoints() {
byte humbytes[2];
_command(RH_READ, humbytes);
long humraw = (long)humbytes[0] << 8 | humbytes[1];
return ((12500 * humraw) >> 16) - 600;
}
...Table 2 contd.
return 1;
}
intSI7021::getSerialBytes(byte * buf) {
byte serial[8];
_writeReg(SERIAL1_READ, sizeof SERIAL1_READ);
_readReg(serial, 8);
//Page23 - https://www.silabs.com/Support%20Documents%2FTechnicalDocs%2F
Si7021-A20.pdf
buf[0] = serial[0]; //SNA_3
buf[1] = serial[2]; //SNA_2
buf[2] = serial[4]; //SNA_1
buf[3] = serial[6]; //SNA_0
_writeReg(SERIAL2_READ, sizeof SERIAL2_READ);
_readReg(serial, 6);
buf[4] = serial[0]; //SNB_3 - device ID byte
buf[5] = serial[1]; //SNB_2
buf[6] = serial[3]; //SNB_1
buf[7] = serial[4]; //SNB_0
return 1;
}
intSI7021::getDeviceId() {
//0x0D=13=Si7013
//0x14=20=Si7020
//0x15=21=Si7021
byte serial[8];
getSerialBytes(serial);
int id = serial[4];
return id;
}
// 0x00 = 14 bit temp, 12 bit RH (default)
// 0x01 = 12 bit temp, 8 bit RH
// 0x80 = 13 bit temp, 10 bit RH
// 0x81 = 11 bit temp, 11 bit RH
voidSI7021::setPrecision(byte setting) {
byte reg = USER1_READ;
_writeReg(®, 1);
_readReg(®, 1);
...Table 2 contd.
byte userbyte;
if (on) {
userbyte = 0x3E;
} else {
userbyte = 0x3A;
}
byte userwrite[] = {USER1_WRITE, userbyte};
_writeReg(userwrite, sizeof userwrite);
}
ret.humidityPercent = getHumidityPercent();
ret.celsiusHundredths = _getCelsiusPostHumidity();
return ret;
while(true) {
statusData = checkStatus(); // Check if any interrupts happened
processInterrupts(statusData); // Run any code to handle whatever happened
performPeriodicMaintenance(); // timers, LEDs, polling, etc.
}
The processing loop continuously checks for the interrupt status, runs the code to handle the interrupt
and performs periodic calibration of timer or other maintenances.
For deploying adaptive edge analytics, we have developed IoT Embedded device (Edge) with following
Sensor stack, comprising of hardware, connectivity and sensors.
1. BLE Chip (top)
2. Accelerometer
Primary grouping of milestones for
3. Timer
delivery of target Sensor % of
architecture,
respondents 4. Proto Terminal Block
5. EEPROM
6. Microcontroller
Business processes 11 (ATmega328P)
7. Power Supply (bottom)
Technology stack 11
F5
Use of
We have based the sensor capabilities
design as primary
on reference grouping
architecture of milestones
provided for
by Hanumayamma Innovations
delivery of target
and Technologies, Inc., IoT Dairy Sensor. 4 architecture, % of survey-population segment
The embedded system, Figure, is built on top of a high-performance 8-bit AVR RISC-based
microcontroller that combines Digital
32KB ISP leaders with or beyond
flash memory industry
with read-while-write capabilities, 1024B EEPROM,
2KB SRAM, Other conpanies
Capabilities 5023 general purpose I/O lines, 32 general purpose working registers, three flexible timer/
counters with compare modes, internal and external interrupts and serial programmable USART. 80 The
device operates between 1.8–5.5 volts.
38 +42
The embedded system consists of following components: Battery Power Supply, Microcontroller,
percentage
EPROM, Terminal Blocks, Timer Sensor, Accelerometer, Bluetooth Low Energy (BLE) and Temperature
points
& Humidity Sensors.
Applications 22
F64
SDA Bluetooth
Temperature
SCL and humidity
Accelerometer
VCC sensor
breakout board
GND Timer sensor
SDA
SCL Proto terminal
VCC blocks
GND
SDI EEPROM
SCK Temperature
and humidity Microcontroller
VCC sensor
GND Battery
Yes
If4 mobile CND = 49 Send ambient temperature
Hanumayamma Innovations and Technologies, Inc., http://hanuinnotech.com/dairyanalytics.html
No
Yes
If mobile CND = 50 Send ambient humidity
No
Yes
If mobile CND = 51 Send cattle temperature
Hardware Design 57
Microcontroller
The embedded system is built on top of high-performance 8-bit AVR RISC5-based microcontroller [4]
that combines 32KB ISP flash memory (see Figure 5: Dairy Microcontroller board) with read-while-write
capabilities, 1024B EEPROM, 2KB SRAM, 23 general purpose I/O lines, 32 general purpose working
registers, three flexible timer/counters with compare modes, internal and external interrupts and serial
programmable USART. The device operates between 1.8–5.5 volts.
EEPROM
EEPROM (see Figure 5: Dairy Microcontroller board) provides nonvolatile data storage support. 0–255
record counters will be stored in EEPROM location zero. 256–336 record counter with maximum of 2 weeks
at 24 records/day will be stored in EEPROM location one. Records will start at EEPROM location two.
Additionally, the data arrays store on EEPROM and retrieve command over Bluetooth Low Energy (BLE).
Bluetooth
The Bluetooth module (see Table 1) provides an interface to receive commands from mobile application.
In addition, the EEPROM stored values are transferred back to the mobile application via Bluetooth
transfer protocol.
void setup(void)
{
Wire.begin();
SerialMonitorInterface.begin(9600);
// initialize record counters here for testing - must be removed or
power cycling loses all data
EEPROMwrite(0, 0);
EEPROMwrite(1, 0);
delay(500);
if (!htu.begin()) {
Serial.println(“Couldn’t find HTU21 sensor!”);
while (1);
}
if (!bme.begin()) {
Serial.println(“Could not find a valid BME280 sensor, check wir-
ing!”);
while (1);
}
//Case LED Support.
pinMode(A3, OUTPUT);
int tickEvent = t.every(3600000, HourlySensorReadAndStore); // hourly
data grab 3600000 is an hour
accel.begin(BMA250_range_2g, BMA250_update_time_64ms);//This sets up
the BMA250 accelerometer
RTC.start(); // ensure RTC oscillator is running, if not already
BLEsetup();
}
Figure 6: Bluetooth setup
5
AVR RISC – Advanced Virtual reduced instruction set computer (http://www.atmel.com/products/microcontrollers/avr/ )
58 Building Enterprise IoT Applications
Setup
The Sensor Module kicks-in by running setup command (see Figure 7). As part of the setup, Serial Monitor
Interface with 9600 milliseconds, initiates humidity and temperature sensor, initiates BME 280 Sensor
module, starts real-time clock, and initiates Bluetooth.
Continuous Loop
Sensor is a state machine with continuous event loop (see Table 3) capture Cow movement, temperature,
Humidity and Data & Time Stamp. The State machine (see Figure 7) initiates the call as in the following
diagram:
• Initiate Bluetooth Radio (call to aci_loop())
• Update Motion Detection (UpdateMotionDetection())
• Check Mobile Request for the Connection (Check module Command)
• Transfer Data (Data Transfer)
Received mobile No
request to
transfer data
Transfer data
void loop() {
F65
Table 3: Loop Code
Libraries
Dairy IoT Sensor is a real-time RTOS based Sensor with Temperature, Humidity, and Activity Level
detection for Cattle. It’s an agriculture sensor for Veterinarian purposes.
The following libraries used (see Table 4):
• Bluetooth Low Energy Sensor
#include <Event.h>
#include <Timer.h>
//Bluetooth Section
//when using this project in the Arduino IDE, set the following to false
and rename file UART.h to UART.ino
#define CODEBENDER false
#if defined(ARDUINO_ARCH_SAMD)
#define SerialMonitorInterface SerialUSB
#else
#define SerialMonitorInterface Serial
#endif
#define BLE_DEBUG false
#include <SPI.h>
#include “lib_aci.h”
#include “aci_setup.h”
#include “uart_over_ble.h”
#include “services.h”
#include “kalman.h”
#if CODEBENDER
#include “UART.ino”
#endif
// Sensor Support Section
#include <Wire.h>
#include “Adafruit_HTU21DF.h”
#include <Adafruit_Sensor.h>
#include <Adafruit_BME280.h>
#define SEALEVELPRESSURE_HPA (1013.25) //necessary to know at local loca-
tion for precision elevation measurement.
Adafruit_BME280 bme; // I2C
Adafruit_HTU21DF htu = Adafruit_HTU21DF();
#include “BMA250.h”
BMA250 accel;
//RTC board support
#include “DSRTCLib.h”
DS1339 RTC = DS1339();
// Periodic hourly timer support for data storage, non blocking delay.
//#include “Timer.h” //http://github.com/JChristensen/Timer
Timer t; //instantiate the timer object
60 Building Enterprise IoT Applications
Transfer Data
The Transfer (see Figure 8 & Table 7) to Mobile is performed based on commands sent to the Sensor by
the phone.
The following commands will result in the corresponding actions:
• Send Ambient Temperature
• Send Ambient Humidity
• Send Cattle Temperature
• Send Cattle Humidity
• Send Cattle Activity
• Send Record Count
• Send Read Pointer
6
BMA Acceleration Sensor - http://www1.futureelectronics.com/doc/BOSCH/BMA250-0273141121.pdf
7
Real-Time Clock - https://www.maximintegrated.com/en/products/digital/real-time-clocks/DS1339.html
8
Tiny Circuits BLE Module - https://tinycircuits.com/products/bluetooth-low-energy-tinyshield
9
ACI - https://devzone.nordicsemi.com/f/nordic-q-a/6487/
Hardware Design 61
void aci_loop()
{
static bool setup_required = false;
// We enter the if statement only when there is a ACI event available
to be processed
if (lib_aci_event_get(&aci_state, &aci_data))
{
aci_evt_t * aci_evt;
aci_evt = &aci_data.evt;
switch (aci_evt->evt_opcode)
{
case ACI_EVT_DEVICE_STARTED: // As soon as you reset the
nRF8001 you will get an ACI Device Started Event
{
aci_state.data_credit_available = aci_evt->params.de-
vice_started.credit_available;
switch (aci_evt->params.device_started.device_mode)
{
case ACI_DEVICE_SETUP: //When the device is in the setup
mode
aci_state.device_state = ACI_DEVICE_SETUP;
Serial.println(F(“Evt Device Started: Setup”));
setup_required = true;
break;
case ACI_DEVICE_STANDBY:
aci_state.device_state = ACI_DEVICE_STANDBY;
...Table 5 contd.
Serial.println(aci_evt->params.cmd_rsp.cmd_status,
HEX);
Serial.print(F(“ACI Command 0x”));
Serial.println(aci_evt->params.cmd_rsp.cmd_opcode,
HEX);
Serial.println(F(“Evt Cmd respone: Error. Arduino
is in a while(1); loop”));
while (1);
}
break;
case ACI_EVT_PIPE_STATUS:
Serial.println(F(“Evt Pipe Status”));
// Check if the peer has subscribed to any particleBox
characterisitcs for notifications
if (lib_aci_is_pipe_available(&aci_state, PIPE_AIR_QUAL-
ITY_SENSOR_TEMPERATURE_MEASUREMENT_TX)
&& (false == timing_change_done))
{
// Request a change to the link timing as set in
the GAP -> Preferred Peripheral Connection Parameters
lib_aci_change_timing_GAP_PPCP();
timing_change_done = true;
}
if (lib_aci_is_pipe_available(&aci_state, PIPE_AIR_QUAL-
ITY_SENSOR_RELATIVE_HUMIDITY_TX)
&& (false == timing_change_done))
{
// Request a change to the link timing as set in
the GAP -> Preferred Peripheral Connection Parameters
lib_aci_change_timing_GAP_PPCP();
timing_change_done = true;
}
if (lib_aci_is_pipe_available(&aci_state, PIPE_AIR_QUAL-
ITY_SENSOR_CARBON_MONOXIDE_LEVEL_TX)
&& (false == timing_change_done))
{
// Request a change to the link timing as set in
the GAP -> Preferred Peripheral Connection Parameters
lib_aci_change_timing_GAP_PPCP();
timing_change_done = true;
}
if (lib_aci_is_pipe_available(&aci_state, PIPE_AIR_QUAL-
ITY_SENSOR_PM10_CONCENTRATION_TX)
&& (false == timing_change_done))
{
// Request a change to the link timing as set in
the GAP -> Preferred Peripheral Connection Parameters
lib_aci_change_timing_GAP_PPCP();
timing_change_done = true;
}
if (lib_aci_is_pipe_available(&aci_state, PIPE_AIR_QUAL-
ITY_SENSOR_PM25_CONCENTRATION_TX)
&& (false == timing_change_done))
{
// Request a change to the link timing as set in
the GAP -> Preferred Peripheral Connection Parameters
Table 5 contd. ...
Hardware Design 63
...Table 5 contd.
lib_aci_change_timing_GAP_PPCP();
timing_change_done = true;
}
break;
case ACI_EVT_TIMING: // Link timing has changed
Serial.print(F(“Timing changed: “));
Serial.println(aci_evt->params.timing.conn_rf_interval,
HEX);
break;
case ACI_EVT_CONNECTED:
radio_ack_pending = false;
timing_change_done = false;
aci_state.data_credit_available = aci_state.data_credit_
total;
Serial.println(F(“Evt Connected”));
break;
case ACI_EVT_DATA_CREDIT:
aci_state.data_credit_available = aci_state.data_credit_
available + aci_evt->params.data_credit.credit;
/**
Bluetooth Radio ack received from the peer radio for the
data packet sent.
This also signals that the buffer used by the nRF8001
for the data packet is available again.
*/
radio_ack_pending = false;
break;
case ACI_EVT_PIPE_ERROR:
/**
Send data failed. ACI_EVT_DATA_CREDIT will not come.
This can happen if the pipe becomes unavailable by the
peer unsubscribing to the Heart Rate
Measurement characteristic.
This can also happen when the link is disconnected after
the data packet has been sent.
*/
radio_ack_pending = false;
//See the appendix in the nRF8001 Product Specication
for details on the error codes
Serial.print(F(“ACI Evt Pipe Error: Pipe #:”));
Serial.print(aci_evt->params.pipe_error.pipe_number,
DEC);
Serial.print(F(“ Pipe Error Code: “));
Serial.println(aci_evt->params.pipe_error.error_code,
HEX);
//Increment the credit available as the data packet was
not sent.
//The pipe error also represents the Attribute protocol
Error Response sent from the peer and that should not be counted
//for the credit.
if (ACI_STATUS_ERROR_PEER_ATT_ERROR != aci_evt->params.
pipe_error.error_code)
{
aci_state.data_credit_available++;
}
break;
...Table 5 contd.
case ACI_EVT_DISCONNECTED:
// Advertise again if the advertising timed out
if (ACI_STATUS_ERROR_ADVT_TIMEOUT == aci_evt->params.
disconnected.aci_status)
{
Serial.println(F(“Evt Disconnected -> Advertising
timed out”));
{
Serial.println(F(“nRF8001 going to
sleep”));
lib_aci_sleep();
aci_state.device_state = ACI_DEVICE_SLEEP;
}
}
if (ACI_STATUS_EXTENDED == aci_evt->params.disconnected.
aci_status)
{
Serial.print(F(“Evt Disconnected -> Link lost.
Bluetooth Error code = “));
Serial.println(aci_evt->params.disconnected.btle_
status, HEX);
lib_aci_connect(180/* in seconds */, 0x0050 /*
advertising interval 50ms*/);
Serial.println(F(“Advertising started”));
}
break;
case ACI_EVT_HW_ERROR:
Serial.print(F(“HW error: “));
Serial.println(aci_evt->params.hw_error.line_num, DEC);
for (uint8_t counter = 0; counter <= (aci_evt->len - 3);
counter++)
{
Serial.write(aci_evt->params.hw_error.file_
name[counter]); //uint8_t file_name[20];
}
Serial.println();
lib_aci_connect(30/* in seconds */, 0x0100 /* advertis-
ing interval 50ms*/);
Serial.println(F(“Advertising started”));
break;
}
}
else
{
// Serial.println(F(“No ACI Events available”));
// No event in the ACI Event queue and no event in ACI comman
queue
// Arduino can go to sleep now
}
/* setup_required is set to true when the device starts up and enters
setup mode.
* It indicates that do_aci_setup() should be called. The flag should be
cleared if
* do_aci_setup() returns ACI_STATUS_TRANSACTION_COMPLETE.
*/
if (setup_required)
{
Table 5 contd. ...
No target architecture 6
and road map
Hardware Design 65
SDA Bluetooth
Temperature
...Table 5 contd. and humiditySCL
Accelerometer
sensor
VCC == do_aci_setup(&aci_state))
if (SETUP_SUCCESS
{ breakout board
GND
setup_required = false; Timer sensor
}
} SDA
}
SCL Proto terminal
Table 6: Update Motion Code VCC blocks
Yes
If mobile CND = 49 Send ambient temperature
No
Yes
If mobile CND = 50 Send ambient humidity
No
Yes
If mobile CND = 51 Send cattle temperature
No
Yes
If mobile CND = 52 Send cattle humidity
No
If mobile CND = 53
Yes
Send cattle activity
F67
No
Yes
If mobile CND = 54 Send record count
No
Yes
If mobile CND = 55 Send read pointer
//Receive from Celphone App after connect and command decode section.
if (ble_rx_buffer_len) {//Check if data is available
moduleCommand = ((char*)ble_rx_buffer[0]); //look at first char
in buffer
if (moduleCommand == 49) { // cmd “1”
SendKelman();
SendAmbientTemp();
}
if (moduleCommand == 50) { // cmd “2”
SendAmbientHumdity();
}
if (moduleCommand == 51) { // cmd “3”
SendCowTemp();
}
if (moduleCommand == 52) { // cmd “4”
SendCowHumidity();
}
if (moduleCommand == 53) { // cmd “5”
SendCowActivity();
}
if (moduleCommand == 54) { // cmd “6”
SendDateTime();
}
if (moduleCommand == 55) { // cmd “7”
SendRecordCount(); // count of current number of records
stored
}
if (moduleCommand == 56) { // cmd “8”
SendRecordPartOne(); //send timedate and 4 sensor values
part of record, MUST be followed by cmd “9”
}
if (moduleCommand == 57) { // cmd “9”, MUST be preceeded by cmd
“8”
SendRecordPartTwo(); //send timedate and cow activity
value part of record
}
if (moduleCommand == 48) { // cmd “0” // zero
ResetCurrentRecordCount(); // explicit clear of number
of records available to return
// and reset both
eeprom read and write address counters to beginning
// read and write
addresses of 02 which is first record in eeprom.
// This is the cor-
rect way to end a reading session and log will
// now begin to
overwrite starting at first record.
}
if (moduleCommand == 82) { // cmd “R” // capital letter R -
used only for testing it
ResetRecordPointer(); // resets base address of record
storage so can read again from first
// record without
clearing current record count. Does not affect write address counter.
}
if (moduleCommand == 75) { // cmd “K”
SendKelman();
}
ble_rx_buffer_len = 0;//clear after reciept
DataTransferBlink();
}
Table 7 contd. ...
Hardware Design 67
Chapter Summary:
• Covers in-depth Arduino board and should enable the design of the Arduino based Sensors
• Write code to initiate Bluetooth & Temperature/Humidity value reads
• Should enable design of Microcontroller & sensor board
References
1. Facchinm. Download the Arduino IDE. May 21, 2018, https://www.arduino.cc/en/Main/Software, Access date:
September 18, 2018
2. Anat Zait. An Introduction to Arduino Uno Point. April 22, 2018, https://www.circuito.io/blog/arduino-uno-pinout/
Access Date: September 10, 2018
3. Ken Burns, Ben Rose and Tiny Circuits Staff. Temperature/Humidity Tiny Shield. March 22 2016, https://tinycircuits.
com/blogs/learn/139739207-temperature-humidity-tinyshield-tutorial, Access Date: September 10, 2018
4. Mina Khan and Atmel Software Developers. AVR RISC – Advanced Virtual reduced instruction set computer. March
2016, http://www.atmel.com/products/microcontrollers/avr/Access Date: September 10, 2018
5. Bosch Product Group, BMA 250 – Digital, Triaxial Accelerometer, 03 March 2011, http://www1.futureelectronics.
com/doc/BOSCH/BMA250-0273141121.pdf, Access Date: September 10, 2018
6. Maxim Software Group, I2C Serial Real-Time Clock, Feb 2018, https://www.maximintegrated.com/en/products/digital/
real-time-clocks/DS1339.html, Access date: August 06 2018
7. Mouser Development Group, Bluetooth Development Tool Kit, December 2017, https://www.mouser.com/
ProductDetail/TinyCircuits/ASD2116-R?qs=5aG0NVq1C4whKPU%252bTAaEBw%3D%3D, Access date: August
06 2018
8. Carltonlee. 2015. Nordic, Multiple notifications on multiple characteristics, https://devzone.nordicsemi.com/f/nordic-
q-a/6487/multiple-notifications-on-multiple-characteristics, Access Date: September 08, 2018
9. Tiny Circuits, Bluetooth Low Energy Tinyshield (ST), https://tinycircuits.com/products/bluetooth-low-energy-tinyshield
i
ATmega328P - http://www.microchip.com/wwwproducts/en/ATmega328P
Chapter 4
IoT Data Sources
The purpose of the chapter is to provide an overview of several different types of IoT devices that generate
data at various velocities and that generate with several different formats and that would generate with
different frequencies. The Devices are diverse, and there are no rules about size, form factor or origin.
For instance, some devices will be the size of small chip, some will be as large as a connected vehicle
or Oil drilling equipment. The devices include a wide range of hardware with various capabilities.
Additionally, the rate of new devices developed by entrepreneurs and IoT by manufacturer over the world
is steadily increasing. In general, as per Cisco IoT reference architecture,1 [1] the IoT device must contain
(see Figure 1):
• Analog to Digital (A/D) Conversion, as required
• Generating data
• Being queried/Controlled Over the net
The data sources include basic sensors, mobile devices, cameras, audio systems, video systems, geospatial
sensors, industrial equipment, satellite imagery, edge devices that are closes to earth and telecommunication
equipment. The velocity includes data generation frequencies in microsecond, milliseconds, and seconds.
The format includes intrinsic sensor values (Humidity, temperature, etc.) and compound data values (Audio
& video signal).
1
Cisco IoT Reference Model - http://cdn.iotwf.com/resources/71/IoT_Reference_Model_White_Paper_June_4_2014.pdf
rules about size, form factor or origin. For instance, some devices will be the size of small
• Being queried / Controlled Over the net
chip, some will be as large as a connected vehicle or Oil drilling equipment. The devices
include
The data a wide
sources range of
include hardware
basic withmobile
sensors, various devices,
capabilities. Additionally,
cameras,
IoT audio the rate
69 of new
systems,
Data Sources video
systems, geospatial sensors, industrial equipment, satellite imagery, edge devices that are
closes to earth and telecommunication equipment. The velocity includes data generation
frequencies in microsecond, milliseconds, and seconds. The format includes intrinsic sensor
values (Humidity, temperature, etc.) and compound data values (Audio & video signal).
The World generates more than 2 Exabytes of data every day [1]. Connected Smart Sensor
Enterprise
1.1 billion IoT per
data points Dataday
Sources
[1]. Similarly, a single CPG (Consumer Packaged Good)
The World generates more than 2 Exabytes of data every day [1]. Connected Smart Sensor Objects (IoT)
manufacturing
generatemachine generates
Big Data.2 For instance, 4613 MBSmart
million datameters
samples
in US per
aloneday [2]1.1
generate (see Figure
billion 2). per
data points
day [1]. Similarly, a single CPG (Consumer Packaged Good) manufacturing machine generates 13 MB
data samples per day [2] (see Figure 2).
2
Connected Objects generate Big Data - https://www.cisco.com/web/offer/emear/38586/images/Presentations/P11.pdf
70 Building Enterprise IoT Applications
machinery.
3
Building a Great Data Platform - https://www.mckinsey.com/industries/electric-power-and-natural-gas/our-insights/
building-a-great-data-platform
4
GE IIOT - https://www.ge.com/docs/chapters/Industrial_Internet.pdf
IoT Data Sources 71
Sensors & Devices Real-Time Sensor Data: Basic Sensors data, Employee
Temperature, Humidity, GPS Latitude/ Engagement
Location, Access Control, Longitude, Time &
Surveillance Data Resource Access
Open & Web Data Open Source Data like Structured/ Click Stream and
NYC Open Data,6 Traffic & Unstructured Safety Data
Geospatial Data
Media Camera Data Unstructured Safety & Security
Location Gel Location, GPS Location User gets location data
5
7 Types of Industrial IoT Data - http://xmpro.com/7-types-industrial-iot-data-sources/
6
NYC Open Data - https://data.cityofnewyork.us/Transportation/Real-Time-Traffic-Speed-Data/qkm5-nuaq
72 Building Enterprise IoT Applications
Industrial IoT Data Sources
Industrial IoT Data Sources
Industrial IoT Data Sources itself does not solve Use cases. It is fusion of Industrial IoT Data
Industrial IoT Data Sources itself does not solve case study. It is fusion of Industrial IoT Data Sources
Sources
with otherwith othersources
disparate disparate sources
would would
enable enableofsolutioning
solutioning of several
several business cases.business cases. please
As an example, As
find NYC Real-Time [6] (see Figure 5) Traffic Speed Data.7
7
The common
an example, denominator
please find NYC among “Industrial
Real-Time Data
[6] (see Sources”,
Figure GE’sSpeed
5) Traffic IIOT, Data
and Seven
. Sources of
Enterprise IoT is the Sensor that captures data.
Figure 5: New York Data Sources Figure 5: New York Data Sources
Sensors
The common denominator among “Industrial Data Sources”, GE’s IIOT, and Seven Sources
A Sensor is a device that converts a physical phenomenon into an electrical signal. Generally, a Sensor
of Enterprise
In the IoT is the
diagram Sensor that captures data.
represents the part of(see Figure
interface 6), the
between physical world
the physical (left
world side)
andactivities
the world areoftranslated into
electrical or electronic devices,
such aselectrical
computers and/or mobile phones.
signals and fed to electronic devices (Phone, Computer etc.,) through the Sensors.
In the diagram (see Figure 6), the physical world (left side) activities are translated into electrical
Sensors
signals and fed to electronic devices (Phone, Computer, etc.) through the Sensors.
Generally, a Sensor represents the part of interface between the physical world and the world
7
NYC Data - https://data.cityofnewyork.us/Transportation/Real-Time-Traffic-Speed-
Figure
Figure6: Sensoractivities
6: Sensor activities
Data/qkm5-nuaq
7
NYC Data - https://data.cityofnewyork.us/Transportation/Real-Time-Traffic-Speed-Data/qkm5-nuaq
In an IoT environment, high sensitivity sensors result in more number of
Use Case: Investment in IoT is investment in our future generations’ Safety &
IoT Data Sources 73
In an IoT environment, high sensitivity sensors result in more number of data events
and demand a low latency closed loop behavior.
Case Study: Investment in IoT is investment in our future generations’ Safety & Security
IoT Data sources are the best means to protect our planet from global warming and Climate change
affects. Through IoT Devices data collection, one can deduce the impacts of global warming and can
take proactive steps to building engineering products, policies, and government regulations that can
help humanity move forward.
<50
users
F75
(Accelerometer) and Video cameras. The data collected by these sensors are processed on premises
(Bus) and analyzed for any immediate closed loop actions. The major sensor modules include: F76
1. Backhaul Work Group Bridge (WGB)9
2. Digital Screens Rt
R5 (3.01kW) Vout = V1
3. Customer
V1 (5V) Facing APIs/Antennas Rt, + R 5
Vout
The Connected Bus enables case study that define Smart City and Smart Transportation. The principal
advantage of Smart
Rt, Connected Bus–4tis) Wthat it enables Safety & Security and Fleet management for the
R0 ~ (1+ 39.08´10
F77
cities.
Hysteresis Temperature (%)
Sensor output
Deceasing
Transferpressure
Function
F78
A Sensor translates an input signal into electrical signal (see Figure 9). Transfer function represents the
relationship between input signal and output electrical signal.
Increasing
In the figure below, the transfer function relates the output signal Volts to input signal Temperature
pressure
(a classical temperature sensor—please see Figure 10).
Pressure
Reference pressure point Full scale pressure
180
8
Cisco160
Connected IoT Case Studys - https://www.cisco.com/web/offer/emear/38586/images/Presentations/P11.pdf
9
Cisco Mobility - https://www.cisco.com/c/en/us/support/docs/wireless/4400-series-wireless-lancontrollers/111902-
outdoor-mobi-guide-00.pdf
140
120
100
80
F79
60
40
20
F75
Sensor
Sensor
Electric
e1 e2 e3 signal Electric
Direct
eTransducer 1 e2
Transducer 2 e3 signal
1 sensor Direct
Stimulus Transducer 1 Transducer 2
F76F76
sensor
Stimulus
R5 (3.01kW) Rt
Vout = V1 Rt
R5 (3.01kW) Rt,V+outR5 = V1
V1 (5V) Rt, + R5
V1 (5V)
Vout (V )
Rt, R0 = 100 W Vout
Vout (V)
F77F77
Rt, R0 = 100 W Vout
Pressure Pressure
Span or Dynamic
Reference pressure
Range
point
Reference Full point
pressure scale pressure
Full scale pressure
A dynamic rage or span is the range of input signals that are converted into electrical signals by the sensor.
180The wider
180the span, the greater the number of events being generated.
160 160 In an IoT environment, a high sensitivity & high span sensor result in a
140 greater number of data events with higher magnitude of output signal.
140
120 120
100Hysteresis
100
80
80Some sensors
is the width
do not return to the same output value when the input signal is scaled up or down. Hysteresis
60 of the output signal error in terms of measured quantity.
F79F79
60
For instance, in the figure below, presence of Hysteresis error is clearly depicted in terms of the width
40
40of graph of pressure difference (see Figure 11).
20
20 In an IoT deployment, the Hysteresis error results in error in data and huge
0 number of service calls!
0 0.00 ?.?? ?.?? ?.?? ?.?? 0.00 ?.??
0.00 ?.?? ?.?? ?.?? ?.?? 0.00 ?.??
V1 (5V) Rt, + R 5
Vout (V)
<50
users
Rt, R0 = 100 W Vout F75
76 Building Enterprise IoT ApplicationsRt, R0 ~ (1+ 39.08´10 t) W
–4
Computer/storage PoE
Ticketing
machine 1 Backhaul WGB switch Hysteresis
Telemetry
transmitter Sensor 1-2 Digital Digital
Temperature
camerara 1 (%)
Sensor
Poweroutput
Media
Screens
Cabin unit player Router Engine/undercarriage Cabin
Sensor Hysteresis
Electric
e1 e2 e3 signal
Direct
Transducer 1 Transducer 2 sensor
Stimulus
Deceasing F76
pressure
V1 (5V)
R5 (3.01kW) Vout =
Rt
Rt, + R 5
V1 F78
Vout (V)
Rt, R0 = 100 W Vout
Increasing
Rt, R0 ~ (1+ 39.08´10pressure
–4
t) W
F77
Hysteresis Temperature (%)
Sensor output
Pressure
Hysteresis
Reference pressure point Full scale pressure
Figure 11: Hysteresis Curve
160
Hanumayamma Dairy IoT Sensor
F78
Hanumayamma140 Dairy IoT Sensors are a CLASS 10 Veterinary Diagnostics Cow Sensor. We have
Increasing
pressure
observed the reporting of humidity values greater than 100% during the five month period of October
30, 2016 to January
12018, 2017. The x-axis 0:00 Pressure
represents midnight (12:00 am) and value 9.36 data at
morning 9:36 Reference
am (see Figure
pressure 12).
point Full scale pressure
100
180
160 80
140
120
60
100
40
80
20
F79
60
40
0
20
0.00 ?.?? ?.?? ?.?? ?.?? 0.00
0
0.00 4.48
?.?? 9.36
?.?? 14.24
?.?? 19.32
?.?? 0.00 4.48
?.??
Later we discovered that the residual values of humidity on the Sensor casing had resulted in
accumulation of hysteresis error range and triggered a huge number of service calls from Farmers.
IoT Data Sources 77
Type of Sensors
Given the wide range input physical activities and the corresponding sensors to translate into electrical
signals, classifying sensors is a very complex process. On a broad case study level, in this book, we have
divided sensors based on their availability to the public. A good example would be the Smartphone mobile
world (see Figure 13) [7]. The Mobile Smartphone is the universal edge device that is the center of the
IoT, connecting both individual aspirations and enterprise business opportunities.10
Acceleration/tilt Motion/velocity/displacement
Temperature
Electric/magenic
Universal
IoT device
Humidity/moisture
Leaks/levels
F81
x
z
10
Smartphone: The Ultimate IoT and IoE Device - https://www.intechopen.com/books/smartphones-from-an-applied-
research-perspective/smartphone-the-ultimate-iot-and-ioe-device
Acoustic sound vibraton
Motion Sensors
Acceleration forces and rotational forces along three axes are measured by motion sensors. Example of
sensors include: accelerometer, gravity sensors, gyroscope, and rotational sensors. Sensor Framework in
F80
popular Smartphone systems, Android and iOS, use standard three coordinate system to express the relative
position of the device. The relative position is relative to the default position of the phone to the screen.
• When device is held in its default orientation (as shown in the Figure 14), the x axis is horizontal and
points to the right
• The Y axis is vertical and points up
• And the Z axis is points to outward of the screen face.
F81
x
z
11
Sensor Types in Android - https://developer.android.com/guide/topics/sensors/sensors_overview
IoT Data Sources 79
Android Architecture12
The following are the major components in Android architecture [9] (please see Figure 15):
System Apps
The System applications are shipped during the device manufacture or delivered as part of Original
Equipment Manufacturer rollout (OEM). The System Apps include Email, Calendar or Camera.
Content Provider
Content Providers enable Android Applications to access data from other applications (Calendar, Contacts)
or to share their own data.
Activity Manager
The role of Activity Manager is to handle life cycle of Activities (please see Figure 16).
12
Android Architecture - https://developer.android.com/guide/platform/
80 Building Enterprise IoT Applications
System Apps
Managers
Content providers
Activity Location Package Notification
Linux kernel
Drivers
Power management
F82
IoT Data Sources 81
Activity
launched
OnCreate()
OnStart() OnRestart()
User navigates
The activity is to the activity
no longer visible
OnStop()
1
OnDestroy()
Activity
shutdown
Figure 16:
Simulink Activity
model Lifecycledevices
for Android
3:
Activity Heap:
Activity Heap: In general,
In general, the through
the movement movement through
an activity's lifecyclean activity’s
looks like this: lifecycle looks like this:
onRestart() Called after your activity has been stopped, prior No onStart()
to it being started again. Always followed Called after activity is stopped
by onStart()
onStart() Called when the activity is becoming visible to the No onResume()or onStop()
user. Followed by onResume() if the activity comes to
the foreground, or onStop() if it becomes hidden.
Activity becoming visible to the Users
onResume() Called when the activity will start interacting with the No onPause()
user. At this point your activity is at the top of the
activity stack, with user input going to it.
Always followed by onPause(). Activity start interacting with the
Users
onPause() Called when the system is about to start resuming a previous activity. This is Pre- onResume()or
typically used to commit unsaved changes to persistent data, stop HONEYCOMB onStop()
animations and other things that may be consuming CPU, etc.
Implementations of this method must be very quick because the next
activity will not be resumed until this method returns.
Followed by either onResume() if the activity returns back to the front, Quick
Context Switch to previous or onStop() if it becomes invisible to the user.
activity
onStop() Called when the activity is no longer visible to the user, because another Yes onRestart()or
activity has been resumed and is covering this one. This may happen either onDestroy()
because a new activity is being started, an existing one is being brought in front New activity
When the activity is no longer of this one, or this one is being destroyed.
visible to the Users Followed by either onRestart() if this activity is coming back to interact with Existing – in font
the user, or onDestroy() if this activity is going away.
Being destroyed
onDestroy() The final call you receive before your activity is destroyed. This can happen Yes nothing
either because the activity is finishing (someone called finish() on it, or because
the system is temporarily destroying this instance of the activity to save space.
You can distinguish between these two scenarios with the isFinishing() method.
device or Sensors of phone and either process locally at phone or move the data to the
Cloud.
The Sensor Framework in Android enables to setup listener for supported sensors and
Sensor Framework
process the sensor events by handling OnSensorChanged() call back handler [10].
The Sensor Framework in Android enables to setup listener for supported sensors and process the sensor
events The followingOnSensorChanged()
by handling steps are required to get
calldata from
back sensors:
handler [10].
The following steps are required to get data from sensors:
Sensor Manager
A) create an instance of the sensor service
B) provides various methods for accessing and listing
1 sensors, registering and unregistering sensor event
listeners, and acquiring orientation information
2 Sensor
A) create an instance of a specific sensor
Sensor Event
A) The system uses this class to create a sensor event
3 object, which provides information about a sensor
event.
B) The raw sensor data, the type of sensor that
generated the event, the accuracy of the data, and
the timestamp for the event
Sensor Service
Sensor and
Service and Sensor
Sensor Values Values
registeredListener
registeredListener
public boolean registerListener (SensorEventListener listener,
public boolean registerListener
Sensor sensor, (SensorEventListener listener,
Sensor sensor,
int samplingPeriodUs,
int maxReportLatencyUs,
int samplingPeriodUs,
Handler
int handler)
maxReportLatencyUs,
Handler handler)
Registered Listener API 13 configures [10] and setup sensor event listener.
Parameters
sensor values
platform.
parameter includes:
• SENSOR_DELAY_NORMAL
Registered Listener API 13 configures [10] and setup sensor event listener.
Parameters
Listener SensorEventListener is the object that receives installed sensor
values.
Sensor Sensor The Sensor that is supported on current the Android platform.
samplingPeriodUs Integer The configurable sampling period between two consecutive sensor
events. The possible values for this parameter includes:
• SENSOR_DELAY_NORMAL
o Rate suitable for orientation change
• SENSOR_DELAY_UI
o Suitable for User Interface
• SENSOR_DELAY_GAME
o Suitable for games
• SENSOR_DELAY_FATEST
o Gets the sensor values as fast as possible
• Custom delay in Microseconds
MaxReportLatencyUs Integer The maximum time in microseconds that the events can be held or
delayed before reporting to the application.
The values include Custom value in microseconds.
Handler Call back Sensor Event Handler to which the Events are delivered.
handler
Code example:
SensorManager sm = null;
sm = (SensorManager) getSystemService(SENSOR_SERVICE);
sm.registerListener(this,
SensorManager.SENSOR_ORIENTATION |
SensorManager.SENSOR_ACCELEROMETER,
SensorManager.SENSOR_DELAY_NORMAL);
To retrieve Sensor value, you need to register the sensor Listener with the Sensor Manager and when
complete, on listening, unregister the sensor by calling UnregisterListener.
Un Register Sensor
public void unregisterListener (SensorEventListener listener)
Parameters
Listener SensorEventListener: a SensorListener object
UnRegisterListener API14 unregisters all the Sensors [11]. If you would like to un register a specific sensor,
please call following API:
public void unregisterListener (SensorEventListener listener, Sensor sensor)
13
Register Listener - https://developer.android.com/reference/android/hardware/SensorManager#registerListener(android.
hardware.SensorEventListener,%20android.hardware.Sensor,%20int,%20int,%20android.os.Handler)
14
Un register all sensors - https://developer.android.com/reference/android/hardware/SensorManager.
html#unregisterListener(android.hardware.SensorEventListener)
List All Sensors App - Sensor Code in Android
List All Sensors App code is very straightforward code. It provides a detailed viewSources
IoT Data of 85
interfacing with the Android Sensor manager and retrieves all the sensors in the user’s
List All Sensors App—Sensor Code in Android
Smartphone (please see Figure 17).
List All Sensors App code is very straightforward code. It provides a detailed view of interfacing with the
Android Sensor manager and retrieves all the sensors in the user’s Smartphone (please see Figure 17).
Android Manifest
AndroidManifest
Android Manifestfile (see Table 2) is one central place holder that contains all the versions, features,
Sensors and securities used by the application.
The above manifest file has default SDK and Main Activity.
Sensor Code
The code performs reference to SYSTEM Services and retrieves a reference to SENSOR_SERVICE
object. The Sensor Manager emulates all the sensors available on the device. The next step is to retrieve
all ACTIVE sensors in the phone by calling getSensorList of ALL Sensor Type. After this call, the Sensors
LIST will be populated with all the Sensors on the Android phone that are in current usage (see Table 3).
package com.androidbook.sensors.list;
//This file is MainActivity.java
import java.util.HashMap;
import java.util.List;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.hardware.Sensor;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.widget.TextView;
public class MainActivity extends Activity {
@SuppressLint(“NewApi”)
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
TextView text = (TextView)findViewById(R.id.text);
SensorManager mgr = (SensorManager) this.getSystemService(SENSOR_SERVICE);
List<Sensor> sensors = mgr.getSensorList(Sensor.TYPE_ALL);
StringBuilder message = new StringBuilder(2048);
message.append(“The sensors on this device are:\n”);
for(Sensor sensor : sensors) {
message.append(sensor.getName() + “\n”);
message.append(“ Type: “ + sensorTypes.get(sensor.getType()) + “\n”);
message.append(“ Vendor: “ + sensor.getVendor() + “\n”);
message.append(“ Version: “ + sensor.getVersion() + “\n”);
try {
message.append(“ Min Delay: “ + sensor.getMinDelay() + “\n”);
} catch(NoSuchMethodError e) {} // ignore if FIFO method not found
try {
message.append(“ FIFO Max Event Count: “ + sensor.getFifoMaxEventCount() + “\n”);
} catch(NoSuchMethodError e) {} // ignore if FIFO method not found
message.append(“ Resolution: “ + sensor.getResolution() + “\n”);
message.append(“ Max Range: “ + sensor.getMaximumRange() + “\n”);
message.append(“ Power: “ + sensor.getPower() + “ mA\n”);
}
text.setText(message);
}
private HashMap<Integer, String> sensorTypes = new HashMap<Integer, String>();
...Table 3 contd.
getSensorList() will retrieve all the Sensors on the current phone hardware. It’s not required
that the current hardware has all the sensors as supported by the Android.
Now iterate through each Sensors list and display sensor attributes that include:
• Sensor Name
• Sensor Type
• Vendor
• Version
• Delay
• Resolution
• Maximum Range
• And Power
• Resolution
• Maximum Range
• And Power
88 Building Enterprise IoT Applications
Screen Capture:
Screen Capture
The
Theoutput
outputofofthethe
application is below
application (see (see
is below Figure 18): 18):
Figure
15
Google Nexus 5X - https://www.google.com/search?q=nexus+5x+sensors&rlz=1C1GGRV_enUS808US808&oq=Nexu
s+5X+Sensors&aqs=chrome.0.0l6.2149j0j8&sourceid=chrome&ie=UTF-8
IoT Data Sources 89
Accelerometer App
The purpose of the App is to measures the ambient geomagnetic field for all three physical axes (x, y, z)
in micro Tesla (μT) units. The magnetometer sensor (used in Android device) is crucial for detecting the
orientation of your device relative to the Earth’s magnetic north. In Android platform, the Magnetometer
sensor is a Hardware Sensor.
Let’s look at the Magnetometer App. It has three parts.
1. Android Manifest Code
2. Sensor Configuration Code
3. Sensor processing & application logic code
90 Building Enterprise IoT Applications
Android UI
The UI contains following (see Figure 19):
Figure 65: Magnetometer App IDE Figure 19: Magnetometer App IDE
IoT Data Sources
91
92 Building Enterprise IoT Applications
package com.hanuinnotech.android.magnetometer;
import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
import java.text.DecimalFormat;
import java.text.DecimalFormatSymbols;
import java.util.Locale;
public class MainActivity extends AppCompatActivity implements
SensorEventListener {
private TextView value;
private SensorManager sensorManager;
private Sensor sensor;
public static DecimalFormat DECIMAL_FORMATTER;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
value = (TextView)findViewById(R.id.value);
DecimalFormatSymbols symbols = new
DecimalFormatSymbols(Locale.US);
symbols.setDecimalSeparator(‘.’);
DECIMAL_FORMATTER = new DecimalFormat(“#.000”, symbols);
sensorManager = (SensorManager)getSystemService(Context.
SENSOR_SERVICE);
sensor = sensorManager.getDefaultSensor(Sensor.TYPE_
MAGNETIC_FIELD);
}
To activate the Sensor data collection, the sensor register listener is tied to OnResume as this system
callback function is called whenever App life cycle triggers:
We are retrieving Magnetic values on a Normal retrieval level. Similarly, the Pause method unregisters
the Sensor to conserve the battery and other valuable resources.
The Accelerometer Sensor values are captured on Sensor Changed event value (Eq. 1). The net magnetic
field value is computed by square root and all the sums of square of X, Y and Z values.
2 —
Magnetic Value = √ x2 + y2 + z2 (1)
package com.hanuinnotech.android.accelerometer;
import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity implements
SensorEventListener, View.OnClickListener{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initializeView();
btnstart = (Button)findViewById(R.id.btn_start);
btnstart.setOnClickListener(this);
btnstop = (Button)findViewById(R.id.btn_stop);
btnstop.setOnClickListener(this);
sensorManager = (SensorManager)getSystemService(Context.
SENSOR_SERVICE);
if (sensorManager.getDefaultSensor(Sensor.TYPE_
ACCELEROMETER) != null) //we have accelerometer
{
accelerometer = sensorManager.getDefaultSensor(Sensor.
TYPE_ACCELEROMETER);
Table 7 contd. ...
94 Building Enterprise IoT Applications
...Table 7 contd.
sensorManager.registerListener(this, accelerometer,
SensorManager.SENSOR_DELAY_NORMAL);
}
else {
//no accelerometer
}
}
Figure 66:vector
Any effects from the device’s acceleration Accelerometer
(including bothPlay
gravity and temporary movement)
will be translated to the on-screen particles.
Source Code
Please see Table 8 for critical laws of motion compute code.
Table 8: Accelerometer Play Code
al laws of motion compute code.
public void computePhysics(float sx, float sy, float dT) {
...Table 8 contd.
This illustration shows the orientation of the X, Y, and Z axes for a typical Android tablet.
IoT Data Sources 97
platform, the Magnetometer sensor is a Hardware Sensor [13]. This illustration shows the orientation of
the X, Y, and Z axes for a typical Android mobile phone.
This illustration shows the orientation of the X, Y, and Z axes for a typical Android tablet (please
see Figure 22).
Activity
launched
OnCreate()
OnStart() OnRestart()
3:01
Weak performance-
mance
Android UI
The development of view of the Magnetometer (please see Figure 24):
The Code (see Table 19 ) calls getSystemServices context Sensor Service to get the system
sensor services. Next, it will get the default sensor for the TYPE_MAGNETIC_FIELD.
package com.hanuinnotech.android.magnetometer;
import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
import java.text.DecimalFormat;
import java.text.DecimalFormatSymbols;
import java.util.Locale;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
value = (TextView)findViewById(R.id.value);
sensorManager = (SensorManager)getSystemService(Context.
SENSOR_SERVICE);
sensor = sensorManager.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD);
}
To activate the Sensor data collection, the sensor register listener is tied to OnResume as this system
callback function is called whenever App life cycle triggers (see Table 11):
100 Building Enterprise IoT Applications
We are retrieving Magnetic values on a Normal retrieval level. Similarly, the Pause method (see
Table 12) will unregisters the Sensor in order to conserve the battery and other valuable resources.
The Magnetic Sensor values are captured on Sensor Changed event value (Eq. 1). The net magnetic
field value computed by square root and all the sums of square of X, Y and Z values. The values are
displaced on the UI (see Figure 25).
2 —
Magnetic Value = √ x2 + y 2 + z2 (1)
package com.hanuinnotech.android.magnetometer;
import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
import java.text.DecimalFormat;
import java.text.DecimalFormatSymbols;
import java.util.Locale;
public class MainActivity extends AppCompatActivity implements SensorEventLis-
tener {
private TextView value;
private SensorManager sensorManager;
private Sensor sensor;
public static DecimalFormat DECIMAL_FORMATTER;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
value = (TextView)findViewById(R.id.value);
DecimalFormatSymbols symbols = new DecimalFormatSymbols(Locale.US);
symbols.setDecimalSeparator(‘.’);
DECIMAL_FORMATTER = new DecimalFormat(“#.000”, symbols);
sensorManager = (SensorManager)getSystemService(Context.SENSOR_SERVICE);
sensor = sensorManager.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD);
}
@Override
public void onResume()
{
super.onResume();
if (sensor != null)
{
sensorManager.registerListener(this, sensor, SensorManager.SENSOR_DELAY_
NORMAL);
}
else {
Toast.makeText(this, “Not Supported”, Toast.LENGTH_SHORT).show();
finish();
}
}
@Override
public void onPause()
{
OnCreate()
OnStart() OnRestart()
...Table 13 contd.
App process Activity
killed running 3
super.onPause();
sensorManager.unregisterListener(this);
Another activity comes 2
F83
} into the foreground User returns
@Override to the activity
public void onSensorChanged(SensorEvent
Apps with higher priority
OnPause() event) {
float azimuthneed= memory
Math.round(event.values[0]);
float pitch = Math.round(event.values[1]);
The activity is
User navigates
to the activity
float roll = Math.round(event.values[2]);
no longer visible
capture useful User activity related data points that are directly related to the health andMegnetometer
fitness of the User.
Android Android
APP MPO
Weak performance-
Your pereformance
Optimal performance
F94
Impaired performance-
too much stress
Timely stress detection and the individual propensity/level to healthily operate under stress “the
Stress Hump [14] see Figure 27” are very important in managing and curing physiological disorders.
However, the traditional methods of assessing stress levels, such as:
(I) interviewing the individual and asking stress related questions in order to gain a better understanding
of their condition and (II) Observing the facial gestures—people under stress react by giving different
facial expressions, i.e., the eyebrows shape differently, their pupils dilate, or the blinking rate might
differ, are limited [14] as they may miss stress episodes. Thus, we argue that our novel approach
employ detection using sensors, machine learning, de-identified collaborative insights and mobile
devices.
IoT Data Sources 103
The hump
Fatigue
Exhaustion
Comfort
zoon
F94
Health
Performence
Health
tentsion
Breakdouwn
Arousal stress
<?xml version=“1.0”
Window messageencoding=“utf-8”?>
processing
<manifest 5.xmlns:android=“http://schemas.android.com/apk/res/android”
Effects seen
package=“com.example.shruti.stepcounter”> 3. Dispatches Message
on Window UI Window pump in
message to
Window procedure Window Proc. owner thread
<uses-feature android:name=“android.hardware.sensor.stepcounter”
While (GetMessage())
android:required=“true”/> {
<uses-feature android:name=“android.hardware.sensor.stepdetector”TranslateMessage();
DispatchMessage();
android:required=“true”/> }
4. Executes
<application code for Window
Massage queue
android:allowBackup=“true” of thread
android:icon=“@mipmap/ic_launcher” 2. Each massage
android:label=“@string/app_name” in queue is
F101
processed by
android:roundIcon=“@mipmap/ic_launcher_round” massage pump
android:supportsRtl=“true”
android:theme=“@style/AppTheme”>
1a. PostMessage() or 1c. PostMessage() or
<activity android:name=“.MainActivity”>
SendMessage() SendMessage()
<intent-filter>
Thread1 Thread2 Thread3
<action android:name=“android.intent.action.MAIN” />
1b. PostMessage() or
<category android:name=“android.intent.category.LAUNCHER”
SendMessage() />
</intent-filter>
</activity>
</application>
</manifest>
104 Building Enterprise IoT Applications
package com.example.shruti.stepcounter;
import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity implements
SensorEventListener{
private TextView textView;
private SensorManager sensorManager = null;
boolean running = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = (TextView)findViewById(R.id.steps);
sensorManager = (SensorManager)getSystemService(Context.SENSOR_SERVICE);
}
@Override
protected void onResume() {
super.onResume();
Sensor countSensor = sensorManager.getDefaultSensor(Sensor.TYPE_STEP_
COUNTER);
if (countSensor != null){
sensorManager.registerListener(this, countSensor, SensorManager.
SENSOR_DELAY_UI);
}
else {
Toast.makeText(this, “Sensor not found”, Toast.LENGTH_SHORT).show();
}
}
@Override
protected void onPause() {
super.onPause();
running= false;
}
@Override
public void onSensorChanged(SensorEvent event) {
if (running)
{
textView.setText(String.valueOf(event.values[0]));
}
}
@Override
public void onAccuracyChanged(Sensor sensor, int accuracy) {
}
}
IoT Data Sources 105
App UI
Sensor Batching
Android 4.4 introduces Sensor batching in an effort to help preserve power for Sensor operations. With
the sensor batching, Hardware collects the sensor event data based on MaxReportLatencyUs.
Sensor batching is a useful optimization technique for long running IoT Case Studys,
such as fitness, tracking, continuous updating, and high activity sensor Apps.
In the following application, let’s say your App is listening for Sensor events from an Accelerometer
sensor in order to detect the movement of the User.
Without Sensor Batching (see Figure 28), the Application OnSensorChanged event method will be
called whenever User moves. The events are delivered to OS queue through HAL and from OS Queue
the events are delivered to Application.
With Sensor Batching (see Figure 28), we can optimize the rate at which events are delivered to the
application. For instance, we can set MaxReportLatencyUs to batch the events in the sensor and have
them delivered to the Application. Please note that the hardware collects the events but will not wake up
the CPU to deliver events to your application.
17
Sensor Batch - https://github.com/googlesamples/android-BatchStepSensor/
Good stress Distress
The hump
Fatigue
106 Building Enterprise IoT Applications Exhaustion
Comfort
zoon
Android BatchStepSensor Sample
F94
Health
Performence
This sample demonstrates the use of the two step sensors (step detector and counter) and sensor batching.
17
Health
It shows how to register a SensorEventListener with and without batching and shows how these
tentsion
events are received.
The Step Detector sensor (see Figure 29) fires an event when a step is detected, while the step counter
returns the total number of steps since a listener was first registered for this sensor.
Both sensors only count steps while a listener is registered. This sample only covers the basic case,
Breakdouwn
where a listener is only registered while the app is running. Likewise, batched sensors can be used in the
background (when the CPU is suspended),Arousal
whichstress
requires manually flushing the sensor event queue before
it overflows, which is not covered in this sample.
Adapted from Nison, P. Practioner, 1979
F97
2. Each massage
in queue is
F101
processed by
massage pump
1b. PostMessage() or
SendMessage()
IoT Data Sources 107
package com.example.shruti.stepcounter;
import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity implements SensorEventLis-
tener{
private TextView textView;
private SensorManager sensorManager = null;
boolean running = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = (TextView)findViewById(R.id.steps);
sensorManager = (SensorManager)getSystemService(Context.SENSOR_SERVICE);
}
@Override
protected void onResume() {
super.onResume();
Sensor countSensor = sensorManager.getDefaultSensor(Sensor.TYPE_STEP_
COUNTER);
if (countSensor != null){
sensorManager.registerListener(this, countSensor, SensorManager.SEN-
SOR_DELAY_UI);
}
else {
Toast.makeText(this, “Sensor not found”, Toast.LENGTH_SHORT).show();
}
}
@Override
protected void onPause() {
super.onPause();
running= false;
}
@Override
public void onSensorChanged(SensorEvent event) {
if (running)
{
textView.setText(String.valueOf(event.values[0]));
}
}
@Override
public void onAccuracyChanged(Sensor sensor, int accuracy) {
}
}
108 Building Enterprise IoT Applications
App Architecture
The iOS architecture following Model-View-Controller design pattern (see Figure 30) with clear separation
of roles of Controller (handles events), Model (lifecycle of data objects) and View (User Interface elements).
The Application Delegate Object creates the Window Object. Under the Window Object, View and View
Controller Objects are created. The data is stored in the Data Object that connects to Application and View
objects in order to send or receive the data [15].
18
Android Platform - https://developer.android.com/guide/topics/sensors/sensors_motion
IoT Data Sources 109
For instance, in the following figure (Figure 77) the User launches the Application by clicking
In the main event loop, an application continuously routes incoming events to objects
for handling and, because of that handling, updates its appearance and state. An event loop is
simply a run loop: An event-processing loop for scheduling work and coordinating the receipt
of events from various input sources attached to the run loop. Every thread has access to a run
loop. In all but the main thread, the run loop must be configured and run manually by your
code. In Cocoa applications, the run loop for the main thread—the main event loop—is run
What distinguishes the main event loop is that its primary input source receives events
from the operating system that are generated by user actions—for example, tapping a view or
The Click event is enqueued into Operating System Queue. When Operating System allocated
time to process the event, in a round-robin scheduling, the event is dequeued and processed.
The result of the process creates the application and Show the application, in this case, Weather
App. The Scheduler maintains several queues: Idle Queue, Dead Queue, and Ready Queue62.
The Human Function Curve
The hump
In the main event loop, an application continuously Comfort routes incoming events to objects for handling and,
Exhaustion
because of that handling, updates its appearance and state. An event loop is simply a run loop: An event-
zoon
processing loop for scheduling work and coordinating the receipt of eventsHealth from various input sources
F94
Performence
attached to the run loop. Every thread has access
Health
to a run loop. In all but the main thread, the run loop must
be configured and run manually by your code. In Cocoa applications, the run loop for the main thread—the
tentsion
While (GetMessage())
{
TranslateMessage();
DispatchMessage();
}
4. Executes
code for Window
Massage queue
of thread
2. Each massage
in queue is
F101
processed by
massage pump
1b. PostMessage() or
SendMessage()
19
Inside iOS - https://cdn.ttgtmedia.com/searchNetworking/downloads/InsideIOS.pdf
IoT Data Sources 111
Users generate motion events when they move, shake, or tilt the device. These motion events are detected
by the device hardware, specifically, the accelerometer and the gyroscope. The Core Motion framework
lets your application receive motion data from the device hardware and process that data.
Core Motion provides following device events:
• Accelerometer
• Gyroscope
• Pedometer
• Magnetometer
• Barometer
Like Android Sensor Framework, iOS Core Motion Framework20 in iOS provides and reports motion
and environmental related data from onboard hardware of iOS devices (see Figure 33), including from the
accelerometers and gyroscopes, and from the pedometer, magnetometer, and barometer.
20
Core Motion Framework - https://developer.apple.com/documentation/coremotion
112 Building Enterprise IoT Applications
F102
CMAttitude
CMDerviceMotion
CMAttitude
rage, and acceleration
CMAccelerometerData
CMPedometerData
F
to know reference at a point in
CMSensorData
time CMPedometerEvent
data. The data can be fetched at user configured rate (as shown in Figure 35).
“CoreMotionPost” Would Like
to Access Your Motion &
Fitness Activity
In order to count steps I need an
access to your pedometer
F106
Don’t OK
IoT Data Sources 113
CM Motion Manager
CMDerviceMotion
CMAttitude
CMAccelerometerData
CMRecordedAccelerometerData
CMPedometer
CMPedometerData
F103
CMSensorData CMPedometerEvent
CMSensorDataList
Device Motion Altitude
Magnetometer
CMGyroscopeData CMAltimeter
CMMagnometerData
The core motion iOS App uses Sensor Manager to capture Device Motion,CMAltimeterData
Gyroscope
x
Bright Pedometer
F106
Don’t OK
Stop
//
// AppDelegate.swift
// CoreMotionExample
114 Building Enterprise IoT Applications
//
// AppDelegate.swift
// CoreMotionExample
//
//
import UIKit
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions
launchOptions: [UIApplication.LaunchOptionsKey : Any]? = nil) -> Bool {
// Override point for customization after application launch.
return true
}
func applicationWillResignActive(_ application: UIApplication) {
// Sent when the application is about to move from active to inactive state.
This can occur for certain types of temporary interruptions (such as an incoming phone call
or SMS message) or when the user quits the application and it begins the transition to the
background state.
// Use this method to pause ongoing tasks, disable timers, and throttle down
OpenGL ES frame rates. Games should use this method to pause the game.
}
func applicationDidEnterBackground(_ application: UIApplication) {
// Use this method to release shared resources, save user data, invalidate
timers, and store enough application state information to restore your application to its current
state in case it is terminated later.
// If your application supports background execution, this method is called
instead of applicationWillTerminate: when the user quits.
}
func applicationWillEnterForeground(_ application: UIApplication) {
// Called as part of the transition from the background to the inactive state;
here you can undo many of the changes made on entering the background.
}
func applicationDidBecomeActive(_ application: UIApplication) {
// Restart any tasks that were paused (or not yet started) while the
application was inactive. If the application was previously in the background, optionally refresh
the user interface.
}
func applicationWillTerminate(_ application: UIApplication) {
// Called when the application is about to terminate. Save data if appropriate.
See also applicationDidEnterBackground:.
}
}
IoT Data Sources 115
//
// ViewController.swift
// CoreMotionExample
//
//
import UIKit
import CoreMotion
class ViewController: UIViewController {
let motionManager = CMMotionManager()
var timer: Timer!
Output
x 0.082092 y -0.638794 z -0.770035 @ 118190.336395
x -0.613495 y 0.366119 z -0.493500 @ 118190.431574
x -7.839874 y -18.345612 z -65.320282 @ 118190.435309
QuaternionX 0.337296 QuaternionY 0.038609 QuaternionZ -0.008262 QuaternionW
0.940570 UserAccelX -0.007219 UserAccelY -0.000872 UserAccelZ 0.000194
RotationRateX -0.022522 RotationRateY 0.010460 RotationRateZ -0.000189
MagneticFieldX 0.000000 MagneticFieldY 0.000000 MagneticFieldZ 0.000000
MagneticFieldAccuracy -1 Heading -1.000000 @ 118190.436584
x 0.251816 y -0.750671 z -0.894073 @ 118193.332021
x 35.390411 y -10.392548 z 10.837311 @ 118193.337030
x 18.206879 y -16.890945 z -61.640625 @ 118193.327468
QuaternionX 0.385979 QuaternionY 0.054317 QuaternionZ -0.052126 QuaternionW
0.919431 UserAccelX 0.111695 UserAccelY -0.046572 UserAccelZ -0.197934
RotationRateX 0.605888 RotationRateY -0.177316 RotationRateZ 0.197591
MagneticFieldX 0.000000 MagneticFieldY 0.000000 MagneticFieldZ 0.000000
MagneticFieldAccuracy -1 Heading -1.000000 @ 118193.342040
x 0.096817 y -0.679611 z -0.996552 @ 118196.337638
x 112.781448 y 102.204865 z 49.687347 @ 118196.332628
x 15.080399 y -13.295288 z -60.180542 @ 118196.334916
QuaternionX 0.359207 QuaternionY 0.006589 QuaternionZ -0.009305 QuaternionW
0.933187 UserAccelX 0.073929 UserAccelY 0.008747 UserAccelZ -0.260938
RotationRateX 1.956633 RotationRateY 1.787879 RotationRateZ 0.875666
MagneticFieldX 0.000000 MagneticFieldY 0.000000 MagneticFieldZ 0.000000
MagneticFieldAccuracy -1 Heading -1.000000 @ 118196.337638
x 0.234695 y -0.696487 z -0.841339 @ 118199.333216
x 43.316010 y 52.855972 z 21.723465 @ 118199.338226
x 27.676117 y -16.922943 z -61.158340 @ 118199.341703
QuaternionX 0.392182 QuaternionY 0.143840 QuaternionZ 0.039591 QuaternionW
0.907705 UserAccelX 0.004620 UserAccelY 0.026874 UserAccelZ -0.190333
RotationRateX 0.896214 RotationRateY 1.405376 RotationRateZ 0.458711
MagneticFieldX 0.000000 MagneticFieldY 0.000000 MagneticFieldZ 0.000000
MagneticFieldAccuracy -1 Heading -1.000000 @ 118199.338226
x -0.113968 y -0.540314 z -0.805084 @ 118202.338797
x 28.752853 y -81.964859 z -6.410049 @ 118202.333788
x 11.785004 y -8.191986 z -60.685181 @ 118202.311253
RotationRateZ 0.084201 MagneticFieldX 0.000000 MagneticFieldY 0.000000
MagneticFieldZ 0.000000 MagneticFieldAccuracy -1 Heading -1.000000 @
118217.341415
x -0.010315 y 0.009766 z -1.008194 @ 118220.331888
x 1.210968 y -0.627075 z -1.095947 @ 118220.336897
x 11.762009 y -7.462921 z -39.715225 @ 118220.317951
QuaternionX -0.007884 QuaternionY -0.007102 QuaternionZ -0.422925 QuaternionW
0.906097 UserAccelX 0.009224 UserAccelY 0.001486 UserAccelZ -0.008419
RotationRateX 0.009441 RotationRateY -0.006884 RotationRateZ -0.010602
MagneticFieldX 0.000000 MagneticFieldY 0.000000 MagneticFieldZ 0.000000
MagneticFieldAccuracy -1 Heading -1.000000 @ 118220.341906
x -0.009247 y 0.005402 z -0.998627 @ 118223.337378
x 1.703171 y -0.557861 z -0.544861 @ 118223.332369
x 12.780258 y -8.298157 z -41.708649 @ 118223.325466
QuaternionX -0.007103 QuaternionY -0.006643 QuaternionZ -0.493429 QuaternionW
0.869726 UserAccelX 0.008860 UserAccelY 0.001083 UserAccelZ -0.003317
RotationRateX 0.018035
IoT Data Sources 117
CMPedometerData
Another class that should catch our attention is CMPedometerData. This class represents data that will be
CMPedometerData
sent with class
Another everythat
update in thecatch
should above functions.
our attentionIt is
contains a lot of useful information
CMPedometerData. like:
This class represents data
that will be sent with every update in the above functions. It contains a lot of useful information
like:
numberOfSteps: NSNumber?
118 Building Enterprise IoT Applications
numberOfSteps: NSNumber?
distance: NSNumber?
currentPace: NSNumber?
floorsAscended: NSNumber?
floorsDescended: NSNumber?
CMMotionActivityManager
If we want to start counting steps, it would be good to know about what kind of activity our user is doing
now. Here, with some help, comes the CMMotionActivityManager class (please see Table 20). Using
the instance of this class we can get updates about the user activity type. To do this, we should call: The
permissions UI will grant necessary privileges to access the device core features.
CMPedometerData
Another class that should catch our attention is CMPedometerData. This class represents data that
will be sent with every update in the above functions. It contains a lot of useful information like:
numberOfSteps: NSNumber?
distance: NSNumber?
currentPace: NSNumber?
floorsAscended: NSNumber?
floorsDescended: NSNumber?
CMMotionActivityManager
If we want to start counting steps, it will be good to know about what kind of activity our user is
doing at the moment. Here with some help comes the CMMotionActivityManager class. Using the
instance of this class we are able to get updates about the user activity type. In order to do this we
should call:
open func startActivityUpdates(to queue: OperationQueue, withHandler handler: @escaping
CoreMotion.CMMotionActivityHandler)
and the result of that is getting updates with CMMotionActivity which represents data for a single
motion event update. This data is a pack of bool values:
stationary: Bool
walking: Bool
running: Bool
automotive: Bool
cycling: Bool
unknown: Bool
Code step by step…
1. Add NSMotionUsageDescription to your info.plist
As we can read in Apple docs
Important An iOS app linked on or after iOS 10.0 must include usage description keys in its Info.
plist file for the types of data it needs. Failure to include these keys will cause the app to crash. To
>access motion and fitness data specifically, it must include NSMotionUsageDescription.
So add to your info.plist NSMotionUsageDescription key modifying plain file:
<key>NSMotionUsageDescription</key>
<string>In order to count steps I need an access to your pedometer</string>
or adding new key via Xcode
info plist motion usage description
Table 20 contd. ...
IoT Data Sources 119
...Table 20 contd.
DispatchQueue.main.async {
self?.stepsCountLabel.text = pedometerData.numberOfSteps.stringValue
}
}
}
5. Start getting updates
private func startUpdating() {
if CMMotionActivityManager.isActivityAvailable() {
startTrackingActivityType()
}
if CMPedometer.isStepCountingAvailable() {
startCountingSteps()
}
}
App in Action
The deployed app can detect User activities and updates the UI.
120 Building Enterprise IoT Applications
21
Continuous monitoring station - https://water.ca.gov/Programs/State-Water-Project/Water-Quality/Continuous-
Monitoring-Stations#
22
Station and Sensors - https://water.ca.gov/Programs/State-Water-Project/Water-Quality/Continuous-Monitoring-
Stations#
23
Station Pictures and Sensor Information - https://water.ca.gov/Programs/State-Water-Project/Water-Quality/Continuous-
Monitoring-Stations/Station-Pictures-and-Information
24
Station Pictures and Sensor Information - https://water.ca.gov/Programs/State-Water-Project/Water-Quality/Continuous-
Monitoring-Stations/Station-Pictures-and-Information
Table 21: Water Quality parameters
# CDEC Station Name Lat Long County Turb EC Temp pH UVA- Fluoro
ID 254
1 BKS Barker Sough Pumping Plant 38.275900 –121.796500 Solano X X X X
2 C13 Check 13 37.074200 –121.015100 Merced X X X X X
3 C21 Check 21 36.014200 –119.976900 Kings X X X X
4 C41 Check 41 34.834000 –118.711900 Kern X X X X
5 C66 Check 66 34.336000 –117.303600 San X X X
Bernardino
6 CLC Clifton Court 37.829800 –121.557400 Contra Costa X X X X X
7 CPP Cordelia Pumping Plant 38.227600 –122.134700 Solano X X X
8 CSO Castaic Lake Outlet 34.527000 –118.611000 Los Angeles X X X X
9 DC2 Devil Canyon 2nd Afterbay 34.230500 –117.340500 San X X X X
Bernardino
10 DCO Del Valle COW 37.617800 –121.746800 Alameda X X X X
11 DV7 Del Valle 37.654700 –121.741900 Alameda X X X X X
Check 7
12 DYR Dyer Reservoir 37.757824 –121.674913 Contra Costa X X X X X
13 HBP Banks Pumping Plant 37.801944 –121.620278 Contra Costa X X X X X X
14 PPP Pacheco Pumping Plant 37.061900 –121.180600 Merced X X X X X
15 TEE Teerink Pumping Plant 35.032749 –119.008102 Kern X X X X
16 VSB Vallecitos Turnout 37.598500 –121.819300 Alameda X X X X
IoT Data Sources
121
122 Building Enterprise IoT Applications
Audio Sensors
Microphone plays an important role in capturing the critical audio data (see Figure 39). The audio data
plays an important role in creating mobile applications that are senior citizen assistant apps, in capturing
audio signals data that could predict health conditions for agriculture and detecting presence of crowd to
detect venue based ambient analytics.
Microphone Sensors
A measurement microphone is like an ordinary microphone in the superficial features: It is typically tubular,
with a sensor at one end and a connector at the other, and the sensor itself is a lightweight diaphragm that is
25
Current Reservoir Conditions - http://cdec.water.ca.gov/reportapp/javareports?name=rescond.pdf
The Sensor collected data from different reservoirs are posted on the Web site to report current
IoT Data Sources 123
reservoir conditions68 (please see Figure 84):
26
Sound Sensor - https://www.osepp.com/electronic-modules/sensor-modules
124 Building Enterprise IoT Applications
After a device is activated, it may sometimes transmit the full range of audible sounds (including voices), for example to enable cloud-based
speech-to-text translation. However, other devices may not send audio at all, but instead may use the microphone to detect patterns and
transmit other information about the user’s environment.
void loop() {
// read the value from the sensor:
micValue90 = analogRead(micPin);
67 10 1 0 0 11100001 1 0 0
micValue = constrain(micValue, 0, 100); //set sound detect clamp 0-100
70 70 40 5 = 70 1 70 0 128 70 0
} 2 64 2 32 2 16 6 5 4
27
OSEPP Sound Sensor - https://www.osepp.com/downloads/pdf/SOUND-01-Schematic.pdf
F112
IoT Data Sources 125
R1
VCC F115
10K 1
C1
C2 6 VCC V OUT 5 274
3 IN+ GAIN 1
2 IN– GAIN 8 C3
MK1 154 7 BYPASS GND 4 10uF
R2
C4 C3 LM386 D1 10K
154 10uF IN4148 1
Mic2 VCC 2
3
P1
GND
R3
470R
GND VCC
C6 D2
154
Figure 40: MIC Circuit Board
Figure
Figure 41: Soundwave
87: Sound wave
translated into several representations: Spectral Centroid, Mega Centroid, Spectral Mega
28
Sanjeevani Electronic Health Records – http://www.sanjeevani-ehr.com
Centroid, Log Power Spectrogram (please see Table 31 and Figure 88)
@author: cvuppalapati
"""
126 Building Enterprise IoT Applications
...Table 22 contd.
sr = sample_rate).T)
tonnetz_mean = np.mean(librosa.feature.tonnetz(y = librosa.ef fects.
harmonic(sig), sr = sample_rate).T, axis = 0)
print(“\n tonnetz_mean \n”)
print(tonnetz_mean)
#https://librosa.github.io/librosa/generated/librosa.feature.spectral_cen-
troid.html
#Compute the spectral centroid.
cent = librosa.feature.spectral_centroid(y = sig, sr = sample_rate)
print(“\n Compute the spectral centroid. \n”)
print(cent)
# From spectrogram input :
S, phase = librosa.magphase(librosa.stft(y = sig))
cent_mega = librosa.feature.spectral_centroid(S = S)
print(“\n Compute the spectral mega centroid. \n”)
print(cent_mega)
# Using variable bin center frequencies :
if_gram, D = librosa.ifgram(sig)
cent_if_gram = librosa.feature.spectral_centroid(S = np.abs(D), freq = if_
gram)
print(“\n Compute the spectral mega cent_if_gram centroid. \n”)
print(cent_if_gram)
import matplotlib.pyplot as plt
plt.figure()
plt.subplot(4, 1, 1)
plt.semilogy(cent.T, label = ‘Spectral centroid’)
plt.ylabel(‘Hz’)
plt.xticks([])
plt.xlim([0, cent.shape[-1]])
plt.legend()
plt.subplot(4, 1, 2)
plt.semilogy(cent_mega.T, label = ‘spectralcent_if_gram mega centroid.’)
plt.ylabel(‘Hz’)
plt.xticks([])
plt.xlim([0, cent_mega.shape[-1]])
plt.legend()
plt.subplot(4, 1, 3)
plt.semilogy(cent_if_gram.T, label = ‘spectral mega centroid.’)
plt.ylabel(‘Hz’)
plt.xticks([])
plt.xlim([0, cent_if_gram.shape[-1]])
plt.legend()
plt.subplot(4, 1, 4)
librosa.display.specshow(librosa.amplitude_to_db(S, ref = np.max),
y_axis = ‘log’, x_axis = ‘time’)
plt.title(‘log Power spectrogram’)
plt.tight_layout()
plt.show()
# mel spectrogram
#S = librosa.feature.melspectrogram(S = power, n_mels = hp.n_mels) #
(n_mels, T)
#np.transpose(S.astype(np.float32)), np.transpose(magnitude.astype(np.
float32)) # (T, n_mels), (T, 1 + n_fft / 2)
#np.transpose(S.astype(np.float32)),
np.transpose(magnitude.astype(np.float32)) # (T, n_mels), (T, 1 + n_fft / 2)
128 Building Enterprise IoT Applications
Figure 42: Spectrum representations (Spectral Centroid, Mega Centroid, Spectral Mega Centroid, Log Power Spectrogram)
Figure 88: Spectrum representations (Spectral Centroid, Mega Centroid,
Spectral Mega Centroid, Log Power Spectrogram)
mfccs_40
[-3.381e+02 1.510e+02 1.213e+01 3.792e+00 -1.770e+01 5.671e+00
7.133e+00 3.313e+00 4.679e-01 1.043e+00 6.319e+00 -8.136e+00
1.755e+01 5.969e-01 -8.928e+00 3.334e+00 -1.379e+01 1.120e+00
-1.356e+00 2.967e-01 -8.713e+00 -3.432e+00 -4.748e+00 -2.915e+00
mfccs_40
-7.313e+00 8.319e-01 -1.378e+00 -3.427e+00 -5.394e+00 -3.428e+00
-3.671e+00 -3.549e+00 -5.258e+00 -4.364e+00 -1.555e+00 -1.035e+00
[-3.381e+02 1.510e+02
-2.676e+00 -2.589e+00 1.213e+01
-1.439e+00 3.792e+00 -1.770e+01 5.671e+00
-1.890e+00]
7.133e+00
chroma_mean 3.313e+00 4.679e-01 1.043e+00 6.319e+00 -8.136e+00
1.755e+01 5.969e-01 -8.928e+00 3.334e+00 -1.379e+01 1.120e+00
[0.76 0.737 0.636 0.653 0.513 0.5 0.636 0.532 0.493 0.515 0.554 0.793]
-1.356e+00 2.967e-01 -8.713e+00 -3.432e+00 -4.748e+00 -2.915e+00
-7.313e+00
mel_mean 8.319e-01 -1.378e+00 -3.427e+00 -5.394e+00 -3.428e+00
-3.671e+00 -3.549e+00
[6.560e-02 9.925e-02 -5.258e+00
9.475e-02 3.093e+01-4.364e+00 -1.555e+00
1.764e+02 3.447e+01 -1.035e+00
2.622e+00
-2.676e+00 -2.589e+00
6.215e-01 4.713e+00 -1.439e+00
1.150e+01 -1.890e+00]
1.963e+00 4.612e-01 3.314e-01 4.742e+00
5.957e+00 5.211e-01 3.500e-01 6.001e-01 7.821e+00 8.187e+00 1.049e+00
1.207e+00 5.452e+00 2.276e+01 1.354e+01 1.444e+00 1.408e+00 8.959e+00
chroma_mean
2.608e+01 1.309e+01 1.450e+00 5.430e-01 1.220e+00 3.141e+00 1.014e+00
2.969e-01 1.195e+00 5.588e+00 1.000e+01 3.956e+00 1.197e+00 3.418e+00
[0.76 0.7375.784e+00
1.340e+01 0.636 0.653 0.5132.678e-01
7.605e-01 0.5 0.636 0.5322.547e-01
4.327e-01 0.493 0.515 0.554 0.793]
7.372e-02
6.208e-02 8.290e-02 3.146e-02 2.345e-02 5.013e-02 2.081e-02 2.065e-02
mel_mean
5.877e-02 3.494e-02 4.685e-02 8.992e-02 3.469e-02 3.762e-02 2.273e-02
1.160e-02 1.793e-02 2.614e-03 3.574e-03 5.626e-03 4.474e-03 2.523e-03
3.231e-03 1.520e-03
[6.560e-02 9.925e-021.129e-03 6.526e-04
9.475e-02 5.206e-04
3.093e+01 3.561e-04 5.273e-04
1.764e+02 3.447e+01 2.622e+00
6.941e-04 1.071e-03 2.515e-03 4.463e-03 6.817e-03 6.032e-03 4.016e-03
6.215e-01 4.713e+00 1.150e+01 1.963e+00 4.612e-01 3.314e-01 4.742e+00
3.331e-03 2.937e-03 2.446e-03 1.666e-03 1.246e-03 9.489e-04 5.047e-04
5.957e+00
2.592e-04 1.498e-04 9.508e-05 9.836e-05 1.467e-04 9.150e-05 7.593e-05 1.049e+00
5.211e-01 3.500e-01 6.001e-01 7.821e+00 8.187e+00
1.207e+00 5.452e+00
1.924e-04 4.853e-04 2.276e+01
7.612e-04 1.354e+01
7.914e-04 7.920e-041.444e+00 1.408e+00 8.959e+00
7.561e-04 6.802e-04
2.608e+01 1.309e+01 1.450e+00 5.430e-01 1.220e+00 3.141e+00 1.014e+00
5.451e-04 4.409e-04 2.875e-04 1.245e-04 3.594e-05 2.505e-05 1.930e-05
2.969e-01 1.195e+00
1.408e-05 7.108e-06 5.588e+00
4.246e-06 1.000e+01
5.054e-06 8.094e-063.956e+00 1.197e+00 3.418e+00
9.321e-06 1.008e-05
4.968e-05 1.616e-04 8.759e-05 1.142e-05 2.858e-05 7.231e-05 4.736e-05
4.161e-06 4.115e-07]
those patterns. For example, a city sensor might alert
CRT Television
Cells Average Flute (positions are law enforcement when a “gunshot” pattern is detected.
Running
(lowest rate) Human Voices (highest rate) approximate)
Video Sensors
The Camera, a classical video sensor, is replacing other traditional sensors. For example, AT&T replaces
IoT Sensors with cameras
R1
VCC
in order to capture the state of aluminum cans in a refrigerating Units. AT & T F115
moves 186 petabytes10Kacross networks
1 and 53% of that traffic is video data.C1
30
AT & T replaces IoT Sensors
with cameras. “Just 6
C2 by measuringVCC the size of
V OUT the 5 condensation beads on
274 the aluminum cans, you can
3 IN+ 1
calculate what the temperature and relative GAIN
2 IN– humidity
GAIN 8 is and taking
C3 a high-resolution camera and attaching
154 10uF
itMK1
to some very sophisticated image recognition
7 BYPASS GND software,
4 you can do some amazingR2 things.”
C4 Data analysis,
For Image and C3 the
LM386 Video data is a translated series of
D1 contiguous10Kimages and image
154 10uF IN4148 1
Mic2
processing enables us to find the image patterns. VCC 2
3
P1
GND
Image Texture Data
There are several ways to extract the texture of an image
R3 and one of the efficient algorithms is Local Binary
Pattern (LBP). The purpose of LBP (see Figure 43) is
470R to generate the histogram of an image.
The purpose of Local Binary Pattern
GND (LBP) operator is to transform an image
C6 D2 into an array or image
VCC
of integer labels describing the small scale appearance of the image. In other words, LBP translates an
image into a histogram of integer labels and is used for image154 texture analysis purposes.
90 67 10 1 0 0 11100001 1 0 0
70 70 40 5 = 70 1 70 0 128 70 0
7 6 5 4 3 2 1 0
82 71 66 1 1 0 22222222 64 32 0
20 1 21 2 23 4
F121
27 128 70 23 8 255
26 64 25 32 24 16
29
Hanumayamma Dairy Sensor - http://hanuinnotech.com/dairyanalytics.html
30
AT&T replaces IoT Sensors with Camera - https://enterpriseiotinsights.com/20171102/news/att-sees-video-replacing-
lower-bandwidth-iot-traffic-tag4
130 Building Enterprise IoT Applications
The local binary pattern assumes that the image texture has two complimentary features: Pattern and
strength. The original version of LBP is based on a 3×3 pixel block of an image.
The LBP performs texture classification based on principle looking points surrounding a central
point and tests whether surrounding points are greater than or less than the central point—performs binary
transition.
In the figure “LBP In Action”, the central pixel value [70] is compared with surrounding pixel values
[90,67,10,40,66,71,82,70] and produces the bit pattern. The central pixel is greater than the surrounded pixel
the pattern is coded with 1. For example: Surround pixel [90]—Central Pixel [70] = 1. Similarly, Surround
pixel [90]—Central Pixel [67] results in 0. The comparison would produce in bit pattern [11100001].
Next step, is to encode bit pattern on binary scale. For instance, the bit pattern [11100001] coded in
to binary form: [(1*27) + (1*26) + (1*25) + (0*24) + (0*23) + (0*22) + (0*21) + (1*20) ] and thus producing
value of 255.
As shown in below figure “LBP In Action”, based on color patterns of surrounding pixels with that
of the central one, following types of LBP are possible:
• When surrounding pixels are all white ([11111111]) or all black ([00000000]), then the image is flat
or featureless. This is due to the values produced being either 255 or 0 respectively.
• A group of continuous black or white pixels are considered “uniform” patterns and can be interpreted
as corners ([00001110]) or edges ([01110000]).
• If surrounding pixels switch back-and-forth between black and white pixels, the pattern is considered
non-uniform.31
Geospatial Data
Geospatial data is a location relating to or denoting data that is associated with a geographical location.
The data contains natural geographical markers and man-made changes. For instance, natural markers
include geolocation perimeter and man-made changes include global warming trends & pollution indexes
(see figure Hourly Air Quality Index32 (AQI)).
The Data sources include:
• Pollution Index
• Air Quality
• Geo Location—Latitude and Longitude
• Geofence
31
Texture feature extraction using LBP - Texture Feature Extraction by Using Local Binary Pattern - https://www.
researchgate.net/publication/305152373_Texture_Feature_Extraction_by_Using_Local_Binary_Pattern
32
AQI - https://airnow.gov/index.cfm?action=airnow.local_city&cityid=312&mapdate=20181205
IoT Data Sources 131
Chapter Summary
After reading the chapter:
• Should able to understand IoT Sensor types
• Should able to analyze different data types (Audio, Video, Image, Geospatial)
• Would able to understand how sensors created basic IoT sensor module
References
1. Cisco, The Internet of Things Reference Model. 2014, http://cdn.iotwf.com/resources/71/IoT_Reference_Model_
White_Paper_June_4_2014.pdf, Access Date: April 2018
2. Khaled Allam, The Internet of Things – Vertical Solutions, Cisco Connect 2015, https://www.cisco.com/web/offer/
emear/38586/images/Presentations/P11.pdf, Access Date: June 2018
3. Adrian Both, Building a Great Data Platform. August 2018, https://www.mckinsey.com/industries/electric-power-and-
natural-gas/our-insights/building-a-great-data-platform, Access Date: September 2018
4. Peter C. Evans and Marco Annunziata, Industrial Internet—Pushing the boundaries of Minds and Machines, November
26, 2012, https://www.ge.com/docs/chapters/Industrial_Internet.pdf, Access Date: May 2018
5. Kirsten Schwarzer, 7 Types of Industrial IoT Data Sources (and How to Use them), http://xmpro.com/7-types-industrial-
iot-data-sources/, Access Date: September 2018
6. NYC, NYC Open Data. 2018, https://data.cityofnewyork.us/Transportation/Real-Time-Traffic-Speed-Data/qkm5-nuaq,
Access Date: August 2018
7. Mehdia Ajana El Khaddar and Mohammed Boulmalf. Smartphone: The Ultimate IoT and IoE Device. November 2nd
2017, Access Date: August 2018
8. Android Developers, Sensors Overview, https://developer.android.com/guide/topics/sensors/sensors_overview, Access
Date April 2018
9. Android Developers, Architecture, https://developer.android.com/guide/platform/ Access Date April 2018
10. Android Developers, Sensors Manager, https://developer.android.com/reference/android/hardware/
SensorManager#registerListener, Access Date April 2018
11. Android Developers, Sensors Manager, https://developer.android.com/reference/android/hardware/SensorManager#
unregisterListener, Access Date April 2018
12. Github. Android AccelerometerPlay Sample, https://github.com/googlesamples/android-AccelerometerPlay
13. Android. Motion Sensors, https://developer.android.com/guide/topics/sensors/sensors_motion. Access Date April 2018
132 Building Enterprise IoT Applications
14. Chandrasekar Vuppalapati. A System To Detect Mental Stress Using Machine Learning And Mobile Development,
2018 International Conference on Machine Learning and Cybernetics (ICMLC). IEEE, July 2018
15. Apple. Core Motion Framework, https://developer.apple.com/documentation/coremotion, 2018, Access Date April
2018
16. California. Reservoir Water Condition, http://cdec.water.ca.gov/reportapp/javareports?name=rescond.pdf,
17. Sound Sensor. OSEPP Sound Sensor, https://www.osepp.com/downloads/pdf/SOUND-01-Schematic.pdf, 08/10/2015.
Access Date April 2018
18. Martha DeGrasse. AT&T replaces IoT sensors with cameras, November 02 2017, https://enterpriseiotinsights.
com/20171102/news/att-sees-video-replacing-lower-bandwidth-iot-traffic-tag4, access date: September 18, 2018
19. EPA. Air Now, https://airnow.gov/index.cfm?action=airnow.local_city&cityid=312&mapdate=20181205
20. Esa Praksa. Texture Feature Extraction by Using Local Binary Pattern, May 2016, https://www.researchgate.net/
publication/305152373_Texture_Feature_Extraction_by_Using_Local_Binary_Pattern, Access Date: August 2018
Chapter 5
IoT Data Collectors
The Data generated by IoT Sensors contain valuable information about the device, the environment,
device health, diagnostics, state of firmware, state machine, and more. Generally, the data is time-
series with events spaced at an interval. Sensors generate events at a faster pace. Some of the devices
might generate the data samples multiple times per second, 24 hours a day, and 365 days a year (see
Figure 1). The volume of data per day might be very high. For instance, if a sensor is generating
data at every microsecond level by the end of the day, the sensor would have produced 86.4 million
(24 x 60 x 60 x 1000) data samples. Not only is the data huge, but the velocity is also very rapid. The
basic principle of IoT1 is that the intelligent system initiates and processes the information as early and
as close to the source as possible [1]. This is sometimes to referred as fog computing. In this chapter, we
will introduce Fog computing, provide technological imperatives2 that drives edge computing choices,
and the high-performance algorithms that process the data in real-time.
The advantage of analyzing the data closer to the source is that Edge Analytics not only provides a
rapid response but also aids in the detection of device health markers, data anomalies and abnormalities
in order to predict device operational and/or health prognostics and, thus, potentially improve the overall
performance and life of the device. “A sensor network can be applied to collect the real-time production
line data. The data is then used to analyze the asset health and predict failure or the mean time to failure
(MTTF) and suggest possible solutions to minimize disruptive and unscheduled downtime [5]”. Edge
Analytics with prognostics capabilities, in general, promote core tenets of the Open System Architecture
for Condition Based Monitoring (OSA-CBM) architecture—reduces cost & improves the life of the
device. As shown in Figure 3, the OSA-CBM architecture consists of seven layers: Data acquisition, data
manipulation, state detection, health assessment, prognostics, decision support and presentation [6] and
edge analytics, all of which enhance device health capabilities.
2
The Future Shape of Edge Computing: Five Imperatives - https://www.gartner.com/doc/3880015/future-shape-edge-
computing-imperatives
IoT Data Collectors 135
Sensor/Transducer/Manual Entry
1. Data Acquisition
2. Data Manipulation
COMMON NETWORK
External
F125
3. State Detection
systems, data
archiving and
block
4. Health Assessment
configuration
5. Prognostics Entry
Sensor/Transducer/Manual
1.6.Data Acquisition
Decision Support
2. Data Manipulation
7. Presentation
COMMON NETWORK
Figure 3: OSA-CBM Model [4] External
F125
3. State Detection
systems, data
Include: archiving and
Edge (Fog) Computing block
3
At Edge or Fog level4.(see
HealthFigure 4), since we are
Assessment
(Data Element Analysis
closer
• Data to cleanup,
filtering, source,configuration
generally,
aggregation the events are generated
at a rapid pace. The processing is performed and includes
& Transformation) 3
[1]: inspection
• Packet content
• Combination of network and data level analytics
• Evaluation 5. Prognostics
Level 3 functionality • Thresholding
• Formatting focuses on North-South • Event generation
communications
F126
6. Decision Support
• Expanding
Information
• Distillation or reduction7. Presentation
Data packets understandable
to the higher levels
• Assessment
Include:
Edge (Fog) Computing
3 (Data Element Analysis
• Data filtering, cleanup, aggregation
• Packet content inspection
& Transformation)
• Combination of network and data level analytics
Level 3 functionality • Thresholding
focuses on North-South • Event generation
communications
Data packets
Information
understandable
F126
to the higher levels
Data Source
Edge/Fog Compute
Evaluation
Data Stores/Collector
Evaluating data for criteria as to whether the data needs to be processed immediately or it should be
F127
processed at a higher level. For instance, to notify or alert a plant floor manager if temperature spiked or
Data Connectivity
Data Source
increased at rapidly in consecutive time intervals.
Edge/Fog Compute
3
The IoT Reference Model - http://cdn.iotwf.com/resources/71/IoT_Reference_Model_White_Paper_June_4_2014.pdf
COMMON NETWORK
External
F125
3. State Detection
Expanding systems, data
archiving and
block
4. Health Assessment
configuration
Handling cryptic data with additional context (such as the origin).
5. Prognostics
Reducing and/or summarizing data in order to minimize the impact of data and traffic on the network and
7. Presentation
higher-level processing systems.
Data Source
Edge/Fog Compute
4
The Future Shape of Edge Computing: Five Imperatives - https://www.gartner.com/doc/3880015/future-shape-edge-
computing-imperative
IoT Data Collectors 137
• Data/Bandwidth
• Privacy/Security
• Limited Autonomy
Circular Buffers
Circular Buffers are very useful data structures that are used memory constrained embedded device
applications. As the name implies, Circular buffers use predefined fixed size buffers that wrap to the
beginning as a close tube (please see Figure 6).
Technically, Circular buffers provide message queue semantics. That is, the data inserted Last in First
Out (LIFO) mode.
Circular buffers (also known as ring buffers) are fixed-size buffers that work as if the memory
is contiguous & circular in nature. As memory is generated and consumed, data does not need to be
reshuffled—rather, the head/tail pointers are adjusted. When data is added, the head pointer advances.
When data is consumed, the tail pointer advances. If you reach the end of the buffer, the pointers simply
wrap around to the beginning.
Here are design pointers:
• Head pointer—Points to the front of the Queue. Or, in other words, it points to the element to be
removed if the dequeue operation is called.
• Tail pointer—Points to the next empty spot in which the new element can be inserted.
• Full—If you tried to fill the queue completely you wouldn’t be able to enqueue after the Maximum
length or Queue length (Maximum size of the Circular Buffer) index. This is because the Tail has no
empty spot to point to after an element is inserted. The queue is considered full and the new elements
are inserted restarting from 0. It is for this reason that it is called a circular queue.
138 Building Enterprise IoT Applications
F130
Head 0 Tail 0
F130
Head 0 Tail 0
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
Figure 7: Circular Buffer - Head and Tail POS 0
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
• Insert first element—enqueue first element, fills index 0 position; head is point to 0 index and tail
points to 1 index (see Figure 8).
Head 0 Tail 1 F131
Head 0 Tail 1 F131
1
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
1
0
Head
1
0
2
Tail
3
2
4 5 6 7
F132
8 9 10 11
Figure 8: Circular Buffer—Head and Tail POS Insert First Element
12 13 14
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
1 2
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
1
• Insert Second Element: Index 1 is populated with new element; Head points to 0 index; tail points 1
0index 1(see Figure
2 9).3 4 5 6 7 8 9 10 11 12 13 14
1
Head 0 Tail 1 F131
0 Head 1 0 2 Tail 3 2 4 5 6F132 7 8 9 10 11 12 13 14
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
1
Head
2
0 Tail 2 F132
Figure 9: Circular Buffer – Head and Tail POS Insert Second Element
F133
0 1 2 3 4 5 6 7 8 9 10 11 12 13
• Insert Third Element: New element is inserted into index 2; head points 0 index; tail points to 2 index 14
(see Figure 10)
Head 0 Tail 3
1 2
0
Head
1
0
2
Tail
3
3
4 5 6
F133 7 8 9 10 11 12 13 14
1 2 3
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
1
Dequeued
2 3
0 1 Tail
Head Value: 3 F133
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
Figure 10: Circular Buffer – Head and Tail POS Insert Third Element
1 1 Tail
Head Value: 3
F134
Dequeued
1 2 3
• Dequeue Element: Dequeue first element fetches & removes the element from Index 0. Now, Index
0 is empty; Head points to index 1; Tail points to index 3 (see Figure 11).
0Head 1 1 2 Tail 3 3 4 5 6 7 8 9 10 11 12 13 14
2 3
Dequeued Value: 1
F134
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
2 3
Head 1 Tail 3
0 1 2 3 4 5 6F134 7 8 9 10 11 12 13 14
Head 1 Tail 0
0
2
1
3
2 3 4 5 6
F135 7 8 9 10 11 12 13 14
Head 1 Tail 0
2 3 4 5 6 7F135
Figure 11: Circular Buffer – Deque Element
8 9 10 11 12 13 14 15
• Reached End: Inserting to the size of the circular buffer will make tail points to 0 index and head to
0 1 2 3 4 5
1 index (no change) – see Figure 12. 6 7 8 9 10 11 12 13 14
2 3 4 5 6 7 8 9 10 11 12 13 14 15
Head 1 Tail 0
0 1 2 3 4 5 6F135 7 8 9 10 11 12 13 14
2 3 4 5 6 7 8 9 10 11 12 13 14 15
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
2 3
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
Head 1 Tail 0
F135
2 3 4 5 6 7 8 9 10 11 12 13 14 15
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
Figure 12: Circular Buffer – Circular Buffer Reached End
• Number of Elements5
o Tail>=Head: Number of elements = Tail - Head. For instance, if Head = 2 and Tail = 5, then the
number of elements will be 5 – 2 = 3
o Head>Tail: Number of elements = (Size of Queue) - (Head-Tail) = (Size of Queue) - Head + Tail.
For instance, Head = 9, Tail = 5 and Size of Queue = 10, then the number of elements = 10 – (9 –
5) = 6
Algorithm
1. Initialize the queue, size of the queue (maxSize), head and tail pointers
2. Enqueue:
a. Check if the number of elements (size) is equal to the size of the queue (maxSize):
b. If yes, throw error message “Queue Full!”
c. If no, append the new element and increment the tail pointer
3. Dequeue:
a. Check if the number of elements (size) is equal to 0:
b. If yes, throw error message “Queue Empty!”
c. If no, increment head pointer
4. Size:
a. If tail>=head, size = tail – head
b. if head>tail, size = maxSize - (head – tail)
5
https://www.pythoncentral.io/circular-queue/
IoT Data Collectors 141
We have defined Circular buffer and defined access data member cbuf_handle_t;
IoT Data Collectors 143
#define EXAMPLE_BUFFER_SIZE 10
uint8_t * buffer = malloc(EXAMPLE_BUFFER_SIZE * sizeof(uint8_t));
printf(“\n=== C Circular Buffer Check ===\n”);
cbuf_handle_t cbuf = circular_buf_init(buffer, EXAMPLE_BUFFER_SIZE);
First order of business, first we need to allocate buffer. The Malloc with number of entries in buffer
and size of each entry are needed to allocate buffer.
The following code implements allocation of buffer. First things first, in order to initialize buffer, we
need to create circular buffer and assign to cbuf variable. Next, assign each data member of cbuf with the
newly allocated buffer.
1
1
Energy availability
As shown in the Figure 15, both “head” and “tail” points to the same memory address location.
Security req
Next, once allocated buffer, calling circular buffer initialize method would allocate the buffer to our
– Energy efficiency – Security?
structure. After this, we can insert entries into the buffer.
Moore’s
law
E1 En E3 E2 E1
011001010010
Dequeue and
create Index
tor
E
IoT Data Collectors 145
After for loop, we have filled all the entries of circular buffer.
******
Adding 9 values
Added 0, size now: 1
Added 1, size now: 2
Added 2, size now: 3
Added 3, size now: 4
Added 4, size now: 5
Added 5, size now: 6
Added 6, size now: 7
Added 7, size now: 8
Added 8, size now: 9
Full: 0, empty: 0, size : 9
The put operation performs the following: buffer needs to be valid and head points to data.
2
1
1
Security requirement
for security
F14
law
Research need
146 Building Enterprise IoT Applications
As data are getting populated, both tail and head move one block at a time (see Figure 17).
2
1
1
F138 F139
Please note: head points to new block and tail points first block.
cbuf->full ==encbuf->tail);
t
rgy efficiency – Security?
}
Driver
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <stddef.h>
#include <stdbool.h>
#include <assert.h>
#include “CircularBuffer.h”
#define EXAMPLE_BUFFER_SIZE 10
int main(void)
{
uint8_t * buffer = malloc(EXAMPLE_BUFFER_SIZE * sizeof(uint8_t));
printf(“\n=== C Circular Buffer Check ===\n”);
cbuf_handle_t cbuf = circular_buf_init(buffer, EXAMPLE_BUFFER_SIZE);
printf(“Buffer initialized. Full: %d, empty: %d, size: %zu\n”,
circular_buf_full(cbuf),
circular_buf_empty(cbuf),
circular_buf_size(cbuf));
printf(“\n******\nAdding %d values\n”, EXAMPLE_BUFFER_SIZE - 1);
for (uint8_t i = 0; i < (EXAMPLE_BUFFER_SIZE - 1); i++)
{
circular_buf_put(cbuf, i);
printf(“Added %u, Size now: %zu\n”, i, circular_buf_
size(cbuf));
}
148 Building Enterprise IoT Applications
2
1
{
uint8_t data; 1
circular_buf_get(cbuf, &data);
printf(“%u “, data);
}
printf(“\n”);
free(buffer);
circular_buf_free(cbuf);
return 0;
}
F138A
Case Study: Constrained Devices F138 F139
ement
+ Cheap computing
ity requir
Secur
Energy availability
Resource available
Security requirement
for security
– Energy efficiency – Security?
Moore’s
F140
law
/***************************************************************************/
static bool aci_setup_fill(aci_state_t *aci_stat, uint8_t *num_cmd_offset)
3. Dairy Cattle Sensor Data Event Queue
{
bool ret_val = false;
E1 En E3 E2 E1
while (*num_cmd_offset < aci_stat->aci_setup_info.num_setup_msgs)
011001010010
{
//Board dependent defines
Dequeue and
#if defined (__AVR__) create Index
2. Stream Collector
E2 //For Arduino copy the setup ACI message from Flash to RAM.
4. Stream Indexer
111100102010
memcpy_P(&msg_to_send, &(aci_stat->aci_setup_info.setup_
msgs[*num_cmd_offset]), Calls Stream
Injector
111100103010
E3
5. Stream Injector
Insert into
Data Cube
F159
6. Rule Processor Process
Events
En
111300303010
7. Data Cube Archiver
150 Building Enterprise IoT Applications
pgm_read_byte_near(&(aci_stat->aci_setup_info.
setup_msgs[*num_cmd_offset].buffer[0]))+2);
#elif defined(ARDUINO_ARCH_SAMD)
//For Arduino copy the setup ACI message from Flash to RAM.
memcpy_P(&msg_to_send, &(aci_stat->aci_setup_info.setup_
msgs[*num_cmd_offset]),
pgm_read_byte_near(&(aci_stat->aci_setup_info.
setup_msgs[*num_cmd_offset].buffer[0]))+2);
#elif defined(__PIC32MX__)
//In ChipKit we store the setup messages in RAM
//Add 2 bytes to the length byte for status byte, length for
the total number of bytes
memcpy(&msg_to_send, &(aci_stat->aci_setup_info.setup_
msgs[*num_cmd_offset]),
(aci_stat->aci_setup_info.setup_msgs[*num_cmd_
offset].buffer[0]+2));
#endif
//Put the Setup ACI message in the command queue
if (!hal_aci_tl_send(&msg_to_send))
{
//ACI Command Queue is full
// *num_cmd_offset is now pointing to the index of the Setup command that did
not get sent
return ret_val;
}
ret_val = true;
(*num_cmd_offset)++;
}
Double Buffers
In general, double buffering algorithm is applied to User Interface, Printing, and Graphic Device (GDI)
Interface rendering Case study. A classic example is Screen update for Game programming. The chief
reason is continuous user screen or service updates without interruptions. In the same vein, double buffering
is also used for Edge processing data payloads that need to be uploaded to central server, involving
processing and background uploading on a continuous stream basis. To put it simply, when streams of data
are handled between producer (in this Sensor) and consumers (backend server or edge mobile device),
double buffering is the best candidate.
As the name implies, double buffering contains two buffers: One buffer gets data from the provider
and the other buffer relays data to consumers or a backend data host [9].
The following design factors are critical in designing a double buffer (see Figure 19):
• Data Producer Frequency
• Relay Time Interval
• Capacity or Memory footprint of the device
ecurity requirement
Energy avai
for secur
Resource av
– Energy efficiency – Security?
Moore’s
F140
law
Shannon’s Research need
IoT + Wireless
law
connectivity
IoT Data Collectors
Time 151
Decreasing size of node
Producer Consumer
000111
100110
010000
F141
Figure 19: Double Buffers
• We want to E2 be able to read the state and we don’t want to have to wait while it’s being written.
111100102010
4. Stream Indexer
Under the hood, Double Buffer must implement thread synchronization primitives toStream
Calls protect the data.
Injector
The OS offers following primitive techniques:
• Pthread_join: pthread_join allows
• Mutex
111100103010
E3
5. Stream Injector
one thread to suspend until other thread has terminated.Insert into
variable: A mutex acts as a mutually exclusive lock, allowing threads to control access Data to
Cube
F159
the data.
• Condition variable functions: A6.condition variable provides
Rule Processor a way of naming an event in which
Process
the threads have a general interest. Signal Event. Events
En
• pthread_once
111300303010
function: Special functions that ensure threads are executed once and only once.
• Reader/Writer exclusion: Multiple threads
7. Data Cubecan read but only one thread is permitted to write.
Archiver
• Semaphores: A counting semaphore is like a mutex, but it isPersistent
associated with a counter.
Storage
Semaphore vs. Mutex 1
Mutexes are typically used to serialize access to a section of re-entrant code that cannot be executed
concurrently by more than one thread. A mutex object only allows one thread into a controlled
section, forcing other threads which attempt to gain access to that section to wait until the first thread
has exited from that section.
A semaphore restricts the number of simultaneous users of a shared resource up to a maximum
number. Threads can request access to the resource (decrementing the semaphore) and can signal that
they have finished using the resource (incrementing the semaphore).
The mutex is like the principles of the binary semaphore with one significant difference: The principle
of ownership. Ownership is the simple concept that when a task locks (acquires) only a mutex it can
unlock (release) it. If a task tries to unlock a mutex it hasn’t locked (i.e., doesn’t own) then an error
condition is encountered and, most importantly, the mutex is not unlocked. If the mutual exclusion
object doesn’t have ownership then, irrelevant of what it is called, it is not a mutex.
6
Double Buffer - http://gameprogrammingpatterns.com/double-buffer.html
152 Building Enterprise IoT Applications
Audio Buffers—Spectrograms
Audio Signals are processed and stored at the Edge level in the form of Audio spectrograms.
As indicated in,7 there are several frames to sounds features [10]:
• Time domain features include: Zero Crossing Rate (ZCR) and Short Time Energy (STE).
• Spectral Features Include: Linear Predictive Coding (LPC) coefficients, Relative Spectral Predictive
Linear Coding (RASTA PLP), Pitch, Sone, Spectral Flux (SF) and coefficients from basic time to
frequency transforms (FFT, DFT, DWT, CWT and Constant Q-Transform).
• Cepstral domain features are Mel Frequency Cepstral Coefficient (MFCC) and Bark Frequency
Cepstral Coefficient (BFCC).
build a critical threshold number of misfires into the system, which, when crossed, lights up
Data Sample
the Check Engine light and shuts down the misfiring cylinder in order to avoid damage.
The Voice samples were obtained from a voice clinic in a tertiary teaching hospital (Far Eastern Memorial
Hospital, FEMH), these included 50 normal voice samples and 150 samples of common voice disorders,
including vocal nodules, polyps, and cysts (collectively referred to Phonotrauma); glottis neoplasm;
The Voice samples were obtained from a voice clinic in a tertiary teaching hospital (Far Eastern
7 Memorial Hospital, FEMH), these included 50 normal voice samples and 150 samples of
Discrimination and retrieval of animal sounds - http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=1651344&is
number=34625
common voice disorders, including vocal nodules, polyps, and cysts (collectively referred to
8
Aston Martin gets Neural Network - https://www.theinquirer.net/inquirer/news/1015284/aston-martin-gets-neural-
network
Phonotrauma); glottis neoplasm; unilateral vocal paralysis. Voice samples of a 3-second
sustained vowel sound /a:/ were recorded at a comfortable level of loudness, with a
(Model: SM58, SHURE, IL), with a digital amplifier (Model: X2u, SHURE) under a
background noise level between 40 and 45 dBA. The sampling rate was 44,100 Hz with a 16-
IoT Data Collectors 153
unilateral vocal paralysis. Voice samples of a 3-second sustained vowel sound /a:/ were recorded at a
comfortable level of loudness, with a microphone-to-mouth distance of approximately 15–20 cm, using
a high-quality microphone (Model: SM58, SHURE, IL), with a digital amplifier (Model: X2u, SHURE)
under a background noise level between 40 and 45 dBA. The sampling rate was 44,100 Hz with a 16-bit
resolution, and data were saved in an uncompressed.wav format.
import os
import matplotlib
#matplotlib.use(‘Agg’) # No pictures displayed
import pylab
import librosa
import librosa.display
import numpy as np
np.set_printoptions(precision=3)
np.set_printoptions(threshold=np.nan)
# https://librosa.github.io/librosa/generated/librosa.feature.melspectrogram.html
print(“\n PART I \n”)
print(“\n mel \n”)
sig, sample_rate = librosa.load(“002.wav’)
mel = librosa.feature.melspectrogram(y=sig, sr=sample_rate)
print(mel)
print(“\n mel_mean \n”)
mel_mean = np.mean(librosa.feature.melspectrogram(sig, sr=sample_rate).T,axis=0)
print(mel_mean)
image data extraction is to identify texture changes. The commonly-used algorithm is Local
Image Texture Extraction—Histograms
Binary Pattern (LBP).
For image data (see Figure 21), there are many ways to extract the features. One method of image data
extraction is to identify texture changes. The commonly-used algorithm is Local Binary Pattern (LBP).
imagepath = r"sanjeevani_eye_diag.png"
9
Librosa – melspectrogram - https://librosa.github.io/librosa/generated/librosa.feature.melspectrogram.html
image = cv2.imread(imagepath)
# 2 resize the image
image = resizeImage(image)
(h, w) = image.shape[:2]
cellSize = h/10
# 3 convert the image to grayscale and show it
IoT Data Collectors 155
imagepath = r”sanjeevani_eye_diag.png”
image = cv2.imread(imagepath)
# 2 resize the image
image = resizeImage(image)
(h, w) = image.shape[:2]
cellSize = h/10
# 3 convert the image to grayscale and show it
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
cv2.waitKey(10)
# save the image
cv2.imwrite(“gray_resized_sanjeevani_eye_diag.png”, gray)
# construct the figure
plt.style.use(“ggplot”)
(fig, ax) = plt.subplots()
fig.suptitle(“Local Binary Patterns”)
plt.ylabel(“% of Pixels”)
plt.xlabel(“LBP pixel bucket”)
# plot a histogram of the LBP features and show it
features = feature.local_binary_pattern(gray, 10, 5, method=”default”)
cv2.waitKey(10)
# Save figure of lbp_image
cv2.imwrite(“lbp_sanjeevani_eye_diag.png”, features.astype(“uint8”))
ax.hist(features.ravel(), normed=True, bins=20, range=(0, 256))
ax.set_xlim([0, 256])
ax.set_ylim([0, 0.030])
# save figure
Chapter Summary:
• Understand basic data collector algorithms for IoT
• Audio signal representations Should enable design of Microcontroller & sensor board
• Video signal representation
References
1. Cisco, The Internet of Things Reference Model, 2014, http://cdn.iotwf.com/resources/71/IoT_Reference_Model_
White_Paper_June_4_2014.pdf , Access Date: April 2018
2. Thomas Bittman & Bob Gill, The Future Shape of Edge Computing: Five Imperatives, 28 June 2018, https://www.
gartner.com/doc/3880015/future-shape-edge-computing-imperatives
3. Ryan Gillespie and Saurabh Gupta, 2017, Real-time Analytics at the Edge: Identifying Abnormal Equipment Behavior
and Filtering Data near the Edge for Internet of Things Applications, SAS Institute Inc., http://support.sas.com/resources/
papers/proceedings17/SAS0645-2017.pdf, Access date: June 6, 2017
4. MIMOSA, Open System Architecture for Condition-Based Maintenance, 2017, http://www.mimosa.org/mimosa-osa-
cbm/, Access Date: April 2018
5. Dr. David Baglee, Dr Salla Marttonen, and Professor Diego Galar, 2015, International Conference Data Mining, http://
worldcompproceedings.com/proc/p2015/DMI8005.pdf , Access Date: June 7, 2017
6. Liangwei Zhang, 2016, Big Data Analytics for Fault Detection and its Application in Maintenance, http://ltu.diva-
portal.org/smash/get/diva2:1046794/FULLTEXT01.pdf , Access Date: June 01, 2017
7. Python Development, Circular Queue: An implementation tutorial, August 23 2017, https://www.pythoncentral.io/
circular-queue/, Access Date: April 2018
156 Building Enterprise IoT Applications
8. Chandrasekar Vuppalapati et al., Cognitive Secure Shield—A Machine Learning enabled threat shield for resource
constrained IoT Devices, December 2018, https://www.icmla-conference.org/icmla18/program_2018.pdf, Access Date:
December 2018
9. Robert Nystrom, C Programming—Double Buffers, 2014, http://gameprogrammingpatterns.com/double-buffer.html,
Access Date: July 2018
10. D. Mitrovic, Discrimination and retrieval of animal sounds, 2006 12th International Multi-Media Modelling Conference,
2006, IEEE, Access Date: March 2018
11. Nick Farrell, Aston Martin gets neural network—Much more useful than an ejector seat, 27 September 2004, https://
www.theinquirer.net/inquirer/news/1015284/aston-martin-gets-neural-network, Access Date: April 2018
12. Librosa, Melspectrogram, https://librosa.github.io/librosa/generated/librosa.feature.melspectrogram.html
Chapter 6
Data Storage
Data process at Edge device or near to the sensor needs to be very quick. The process requires the analysis
of outlier conditions, batching through time-window to detect trends in the data, and filtering the data for
prediction and prognosis purposes. The data in motion relied to the backend to the traditional enterprise data
stores or to the cloud. Edge devices continuously process the data and generally does not require storage.
However, for constrained environments, intermittent network connections or long-periodic connection to
the network, the edge devices need to store the data near the source.
The chapter introduces the data stores at the IoT device; It also provides the data store in the universal
edge devices; mobile Operating Systems.
Before going into each storage option in the embedded devices, let’s look at the data representation
for storage. Generally, the data to be persisted is represented in either a single dimensional array, or two-
dimensional array or N-dimensional array.
#include <stdio.h>
const int CITY = 2;
const int WEEK = 7;
int main()
{
int temperature[2][7];
for (int i = 0; i < CITY; ++i) {
for (int j = 0; j < WEEK; ++j) {
printf(“City %d, Day %d: ”, i + 1, j + 1);
scanf_s(“%d”, &temperature[i][j]);
}
}
printf(“\nDisplaying values: \n\n”);
for (int i = 0; i < CITY; ++i) {
for (int j = 0; j < WEEK; ++j)
{
printf(“City %d, Day %d = %d\n”, i + 1, j + 1,
temperature[i][j]);
}
}
return 0;
}
printf("\nDisplaying values: \n\n");
for (int i = 0; i < CITY; ++i) {
for (int j = 0; j < WEEK; ++j)
{
printf("City %d, Day %d = %d\n", i + 1, j + 1,
temperature[i][j]);
}
}
return 0; Data Storage 159
}
Three-Dimensional array
Ǧ
Three-Dimensional array contains rows, columns and layers (see Figure 3).
Figure 3: 3D Cube
Figure 114: 3D Cube
Three-Dimensional array contains rows,Figure 114: 3D
columns Cube
and layers (see Figure 114).
Three-Dimensional array contains rows, columns and layers (see Figure 114).
Data Storage 161
C Style representation:
X [L] [ M] [N]
Initializing the three-dimensional array: In the following example, the array X is initialized with 2
rows, 3 columns, and 4 layers.
int X [2][3][4] = {
{{3, 4, 2, 3}, {0, -3, 9, 11}, {23, 12, 23, 2}},
{{13, 4, 56, 3}, {5, 9, 3, 5}, {3, 1, 4, 9}}
};
#include <stdio.h>
int main()
{
int i, j, k, test[2][3][2];
printf(“Enter 12 values: \n”);
for (i = 0; i < 2; ++i) {
for (j = 0; j < 3; ++j) {
for (k = 0; k < 2; ++k) {
scanf_s(“%d”, &test[i][j][k]);
}
}
}
// Printing values with proper index.
printf(“\nDisplaying values:\n”);
for (i = 0; i < 2; ++i) {
for (j = 0; j < 3; ++j) {
for (k = 0; k < 2; ++k) {
printf(“test[%d][%d][%d] = %d\n”, i, j, k,
test[i][j][k]);
}
}
}
return 0;
}
Arrays in Python
NumPy1 is a Python library that can be used for scientific and numerical applications and is the tool to
use for linear algebra operations. The main data structure in NumPy is the ndarray, which is a shorthand
name for N-dimensional array. When working with NumPy, data in an ndarray is simply referred to as an
array (see Figure 5) [1].
It is a fixed-sized array in memory that contains data of the same type, such as integers or floating-
point values.
1
https://machinelearningmastery.com/gentle-introduction-n-dimensional-arrays-python-numpy/
162 Building Enterprise IoT Applications
NumPy85 is a Python library that can be used for scientific and numerical applications and is
the tool to use for linear algebra operations. The main data structure in NumPy is the ndarray,
which is a shorthand name for N-dimensional array. When working with NumPy, data in an
NumPy85 is a Python library that can be used for scientific and numerical applications and is
the tool to use for linear algebra operations. The main data structure in NumPy is the ndarray,
which is a shorthand name for N-dimensional array. When working with NumPy, data in an
https://machinelearningmastery.com/gentle-introduction-n-dimensional-arrays-python-
285
Numpy book - http://web.mit.edu/dvp/Public/numpybook.pdf
numpy/
Hierarchy of type objects (see Figure 117) representing the array data types86. All the number
types can be obtained using bit-width names as well [2]. Data Storage 163
Empty Function
The empty () function will create a new array of the specified shape [2].
The argument to the function is an array or tuple that specifies the length of each dimension of the array
to create. The values or content of the created array will be random and will need to be assigned before use.
Running the example prints the content of the empty array. Your specific array contents will vary.
Zeros
The zeros () function will create a new array of the specified size with the contents filled with zero values.
The argument to the function is an array or tuple that specifies the length of each dimension of the
array to create
The example below creates a 3×5 zero two-dimensional array.
164 Building Enterprise IoT Applications
The zero
# create example
array below creates a 3×5 zero two-dimensional array.
from numpy import zeros
#a =create zero array
zeros([3,5])
from numpy import zeros
print(a)
a = zeros([3,5])
print(a)
Ones
The ones () function will create a new array of the specified size with the contents filled with
Ones
one values.
The ones ()The argument
function willtocreate
the function
a new is an array
array or specified
of the tuple that size
specifies
withthe
thelength of each
contents filled with one values.
The argument to the function is
dimension of the array to create [2].
an array or tuple that specifies the length of each dimension of the array
to create [2].
The example
The example below below
creates creates a 5-element
a 5-element one-dimensional
one-dimensional array (see figure).
array (see figure).
Combining Arrays
NumPy provides many functions to create new arrays from existing arrays. Let’s look at two of the most
popular functions you may need or encounter [2].
• Vertical Stack
• Horizontal Stack
Vertical Stack
Given two or more existing arrays, you can stack them vertically using the vstack() function.
For example, given two one-dimensional arrays, you can create a new two-dimensional array with
two rows by vertically stacking them.
Data Storage 165
# vstack
3 from numpy import array
4 from numpy import vstack
5 a1 = array([1,2,3])
6 print(a1)
7 a2 = array([4,5,6])
8 print(a2)
9 a3 = vstack((a1, a2))
10 print(a3)
print(a3.shape)
Running the example first prints the two separately defined one-dimensional arrays. The arrays are
vertically stacked resulting in a new 2×3 array, the contents and shape of which are printed.
Horizontal Stack
Given two or more existing arrays, you can stack them horizontally using the hstack() function (see Table
4 and Figure 7). For example, given two one-dimensional arrays, you can create a new one-dimensional
array orfrom
one row withimport
numpy the columns
array of the first and second arrays concatenated.
This is demonstrated in the example below.
from numpy import hstack
a1 = array([1,2,3]) Table 4: HStack
print(a1)
# hstacka2 = array([4,5,6])
print(a2)
from numpy import array
a3 = hstack((a1,
from numpy a2))
import hstack
print(a3)
a1 = array([1,2,3])
print(a3.shape)
print(a1)
a2 = array([4,5,6])
Running the example first prints the two separately defined one-dimensional arrays. The arrays
print(a2)
a3 = hstack((a1, a2))
are then horizontally stacked resulting in a new one-dimensional array with 6 elements, the
print(a3)
print(a3.shape)
contents and shape of which are printed.
Embedded and SCADA based devices use Input/output (IO) operations that are driven from C
device drivers. In nutshell, the IO operations are directly tied to how C based IO.
166 Building Enterprise IoT Applications
Running the example first prints the two separately defined one-dimensional arrays. The arrays are
then horizontally stacked resulting in a new one-dimensional array with 6 elements, the contents and
shape of which are printed.
C File operations File IO operations are performed in Embedded Storage software such as
File IO and embedded data base SQLite.
File Operations
In C the following file operations are performed:
1. Creating file
2. Opening an existing file
3. Reading and Writing into the file
4. Closing the file
When working with files, you need to declare a pointer of type file. This declaration is needed for
communication between the file and program.
FILE *fptr;
The above line defines a pointer to a file.
Opening a file—for creation or edit
Opening a file is performed by calling fopen—defined stdio.h
ptr = fopen(“fileopen”,“mode”)
File Operation modes:
r Open for reading. If the file does not exist, fopen() returns NULL.
rb Open for reading in binary mode. If the file does not exist, fopen() returns NULL.
w Open for writing. If the file exists, its contents are overwritten. If
the file does not exist, it will be created.
wb Open for writing in binary mode. If the file exists, its contents are overwritten. If
the file does not exist, it will be created.
a Open for append, i.e., Data is added to If the file does not exists, it will be created.
end of file.
Data Storage 167
ab Open for append in binary mode, i.e., If the file does not exists, it will be created.
Data is added to end of file.
r+ Open for both reading and writing. If the file does not exist, fopen() returns NULL.
rb+ Open for both reading and writing in If the file does not exist, fopen() returns NULL.
binary mode.
w+ Open for both reading and writing. If the file exists, its contents are overwritten. If
the file does not exist, it will be created.
wb+ Open for both reading and writing in If the file exists, its contents are overwritten. If
binary mode. the file does not exist, it will be created.
a+ Open for both reading and appending. If the file does not exists, it will be created.
ab+ Open for both reading and appending in If the file does not exists, it will be created.
binary mode.
Closing a File
The file should be closed after reading/writing. Closing a file is performed using library function fclose().
fclose(fptr); //fptr is the file pointer associated with file to be closed.
Reading a File
For reading and writing to a text file, we use the functions fprintf() and fscanf(). They are just the file versions
of printf() and scanf(). The only difference is that, fprint and fscanf expects a pointer to the structure FILE.
In the code below, the scanf is loading a number of sensors in the variable.
environment, please go to Project Properties and Code Generation and Turn off Security Check
(see
168 Figure 119
Building and Table
Enterprise 37).
IoT Applications
#include<stdio.h>
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
char sensor_name[50];
int readings, i, sensor_nums;
printf(“Enter number of sensors: ”);
scanf(“%d”, &sensor_nums);
FILE *fptr;
fptr = (fopen(“C:\\Temp\\sensors.txt”, “w”));
if (fptr == NULL)
{
printf(“Error!”);
exit(1);
}
for (i = 0; i < sensor_nums; ++i)
{
printf(“For sensor%d\nEnter name: ”, i + 1);
scanf(“%s”, sensor_name);
printf(“Enter readings: ”);
scanf(“%d”, &readings);
fprintf(fptr, “\nName: %s \nMarks=%d \n”, sensor_name,
readings);
}
fclose(fptr);
return 0;
}
Data Storage 169
Output
The code above generates the following output (see Figure 9):
File Output
: The file output is written to file (see Figure 121)
The file output is written to file (see Figure 10)
Binary files are very similar to arrays of structures, except the structures are in a disk file rather
than in an array in memory. Because the structures in a binary file are on disk, you can create
170 Building Enterprise IoT Applications
Sterilization is the process of storing memory objects on to file and reloading them. C File
operations make it possible.
Binary files3 also usually have faster read and write times than text files, because a binary image of the
record is stored directly from memory to disk (or vice versa). In a text file, everything has to be converted
back and forth to text, and this takes time.
C supports the file-of-structures concept very cleanly. Once you open the file you can read a structure,
write a structure, or seek to any structure in the file. This file concept supports the concept of a file pointer.
When the file is opened, the pointer points to record 0 (the first record in the file). Any read operation
reads the currently pointed-to structure and moves the pointer down one structure. Any write operation
writes to the currently pointed-to structure and moves the pointer down one structure. Seek moves the
pointer to the requested record.
Keep in mind that C thinks of everything in the disk file as blocks of bytes read from disk into memory
or read from memory onto disk. C uses a file pointer, but it can point to any byte location in the file.
Functions fread() and fwrite() are used for reading from and writing to a file on the disk respectively,
in case of binary files.
3
Binary files - https://computer.howstuffworks.com/c39.htm
Data Storage 171
Figure 122: Visual Studio IDE Figure 11: Visual Studio IDE
172 Building Enterprise IoT Applications
#include <stdio.h>
#include <stdlib.h>
#include <stdio.h>
/* Sensor records */
struct sensor_diag
{
int x, y, z;
};
/* writes and then reads 10 arbitrary records
from the file “sensor_diag”. */
int main()
{
int i, j;
FILE *f;
struct sensor_diag sd_record;
/* create the file of 10 records */
printf(“\n create the file of 10 records \n”);
f = fopen(“sensor_diag”, “w”);
if (!f)
return 1;
for (i = 1;i <= 10; i++)
{
sd_record.x = i;
fwrite(&sd_record, sizeof(struct sensor_diag), 1, f);
}
fclose(f);
printf(“\n read the 10 records \n”);
/* read the 10 records */
f = fopen(“sensor_diag”, “r”);
if (!f)
return 1;
for (i = 1;i <= 10; i++)
{
fread(&sd_record, sizeof(struct sensor_diag), 1, f);
printf(“%d\n”, sd_record.x);
}
fclose(f);
printf(“\n”);
/* use fseek to read the 10 records in reverse order */
printf(“\n use fseek to read the 10 records in reverse order \n”);
f = fopen(“sensor_diag”, “r”);
if (!f)
return 1;
for (i = 9; i >= 0; i--)
{
fseek(f, sizeof(struct sensor_diag)*i, SEEK_SET);
fread(&sd_record, sizeof(struct sensor_diag), 1, f);
printf(“%d\n”, sd_record.x);
}
fclose(f);
printf(“\n”);
/* use fseek to read every other record */
printf(“\n use fseek to read every other record \n”);
f = fopen(“sensor_diag”, “r”);
if (!f)
return 1;
fseek(f, 0, SEEK_SET);
for (i = 0;i<5; i++)
Table 6 contd. ...
Data Storage 173
...Table 6 contd.
{
fread(&sd_record, sizeof(struct sensor_diag), 1, f);
printf(“%d\n”, sd_record.x);
fseek(f, sizeof(struct sensor_diag), SEEK_CUR);
}
fclose(f);
printf(“\n”);
/* use fseek to read 4th record, change it, and write it back */
printf(“\n use fseek to read 4th record, change it, and write it
back\n”);
f = fopen(“sensor_diag”, “r+”);
if (!f)
return 1;
fseek(f, sizeof(struct sensor_diag) * 3, SEEK_SET);
fread(&sd_record, sizeof(struct sensor_diag), 1, f);
sd_record.x = 100;
fseek(f, sizeof(struct sensor_diag) * 3, SEEK_SET);
fwrite(&sd_record, sizeof(struct sensor_diag), 1, f);
fclose(f);
printf(“\n”);
/* read the 10 records to insure 4th record was changed */
printf(“\n read the 10 records to insure 4th record was changed\n”);
f = fopen(“sensor_diag”, “r”);
if (!f)
return 1;
for (i = 1;i <= 10; i++)
{
fread(&sd_record, sizeof(struct sensor_diag), 1, f);
printf(“%d\n”, sd_record.x);
}
fclose(f);
return 0;
}
The program above generates the following output (see Figure 12)
The embedded system On-chip ISP (In-System Programing) Flash allows the program
EEPROM provides nonvolatile data storage support. 0-255 record counters will be
4
Bootloader - http://arduinoinfo.mywikis.net/w/images/3/35/Atmel-42735-8-bit-AVR-Microcontroller-ATmega328-
stored in EEPROM location zero (see Figure 124) [4]. 256-336 record counter with
328P_Datasheet.pdf
maximum of 2 weeks at 24 records/day will be stored in EEPROM location one. Records will
start at EEPROM location two. Additionally, the data arrays store on EEPROM and retrieve
holds for pointing purposes. As the new records are added, the current file pointer value changes to
the latest memory position. Similarly, the Last retrieved file pointer stores the most recent retrieval of
records by external connectivity mechanisms—Bluetooth or the Internet transfer.
The uniqueness of this innovation is that it maintains the file storage and pointer mechanism to pre-
defined circular file system slots rather than expanding the footprint unfathomable manner. In addition,
the innovation can produce:
a) Mobile Software Application that reprieves file system data on low powered connectivity such
as Bluetooth.
b) Application Programmable Interface (APIs): The software exposes APIs to connect with exter-
nal modules.
The Version of The Invention Discussed Here Includes (see Figure 14):
• In-memory dairy data cube
• Stream Collector
• Dairy Cattle Sensor Data Event Queue
• Stream Indexer
• Stream Injector
• Rule Processor
• Data Cube Archiver
000111
100110
010000 Data Storage 177
F141
Relationship Between the Components (see Figure 15):
E1 En E3 E2 E1
011001010010
Dequeue and
create Index
2. Stream Collector
E2
111100102010
4. Stream Indexer
Calls Stream
Injector
111100103010
E3
5. Stream Injector
Insert into
Data Cube
F159
6. Rule Processor Process
Events
En
111300303010
7. Data Cube Archiver
Persistent
Storage
1
Dairy Data Cube (1) is constructed using a software collections framework that can store the streams
of data emitted from sensors in real-time. The stream collector (2) collects the sensor data through the
Internet protocols or through the blue tooth low energy (BLE) communication protocols. Once the
streams are emitted from the sensors, the communication protocol handler invokes the stream collector
and passes the real-time sensor data in an asynchronous manner. The asynchronous invocation is
required to un-block the events that are generated at Sensor level. Once the event data are received, the
stream collector queues the data into the Dairy Cattle Sensor Data Event queue (3) and relinquishes
the control back to the sensor communication handler. The Stream Indexer (4) dequeues the event data
and creates a new hash index and passes the hash index and event sensor queue data to the Stream
injector (5). The stream injector stores the new event data into a data cube cell (1). The cell position
is determined based on the date and time of the sensor event. The completion of the Stream injector
process ensures the proper stacking of an event queue in the dairy data cube (1). The Rule processor
(6) is a background thread that periodically checks the availability of sensor event data in the dairy
cube (1). Once available, the rule processor processes sensor data to validate any rules violations
by application of stream sliding window algorithms. Once the rule processor (6) completes the rule
evaluation, the data cube archiver (7) stores the elapsed time window dairy events (3) to persistent data
storage. The persistent data storage could include a network server or local data storage (see Figure 16).
178 Building Enterprise IoT Applications
000023121AIO_20140101_TEL_HYD_DAIRY_00123
0000231889ABM_20140101_TEL_HYD_DAIRY_00121
000023121ABM_20140101_TEL_HYD_DAIRY_00122
Capture Time
14 7:00
12/29/2014 – 12:00 28.23 38.33 40.9 1015 am,
Pressure
12/29/2014 – 3:00 PM 30 40.33 60.9 1015 >
F160
Future
Temperature
Humidity
Pressure
Ambient Temperature
Sensor Attributes
Setup real-time clock event handler that collects data on an hourly basis:
Trigger Azure function Output
int tickEvent = t.every(3600000, HourlySensorReadAndStore); // hourly data grab 3600000 is an hour
The data is collected in the following order: F170
• Get Current Memory Pointer
• Read Sensor Values from the Store (see Table 7)
• Clear variables.
Azure cosmos DB
Table 7: Hourly
input binding Sensor Values
void HourlySensorReadAndStore ()
{
GetCurrentRecordCount (); // get global count of existing valid stored records
ReadSensorsAndStore(); // get all 5 sensor current readings and store in EEprom datalog
ClearCowActivity (); // clear the running
Trigger
count of cow activityAzure
Azure function
measurement
IncrementCurrentRecordCount (); // increment the total recordsinput
cosmos DB
now
to start again
stored in EEprom datalog (on
binding
F171
EEprom)
}
Data Storage 179
EPROM Read
The following (see Table 9) code provides access to EPROM Read functionality:
//Reads out of EEprom and send Part One of the records over ble
//Part One is date time, amb temp, amb humidity, cow temp, cow humidity.
//This is the maximum data transfer possible with this ble arrangement apparently.
//Note that baseRecordByteAddrCount is set to zero on power up, first sw load, cmd “R”, and “0” cmd.
void SendRecordPartOne() {
GetCurrentRecordCount (); //0 to 335 integer count of records in eeprom. At 336 it restarts at 0.
if ((currentCountBothBytes) > 0)// if no records yet, just exit. Otherwise process just one set.
{
//read section and send section
EEPROMread((baseRecordByteAddrCount),(uint8_t*)timeDateData,int(sizeof(timeDateData)));
// Send it over bluetooth.
while (!lib_aci_send_data(PIPE_UART_OVER_BTLE_UART_TX_TX, (uint8_t*)timeDateData, sizeof
(timeDateData)))
{
for(int i=0; i<50; i++)
aci_loop();
delay (1);
//SerialMonitorInterface.println(F(“TX dropped!”));
}
nextRecordByteAddrCount = baseRecordByteAddrCount + (sizeof (timeDateData));
EEPROMread((nextRecordByteAddrCount),(uint8_t*)ambientTemp, int(sizeof (ambientTemp)));
while (!lib_aci_send_data(PIPE_UART_OVER_BTLE_UART_TX_TX, (uint8_t*)ambientTemp, sizeof
(ambientTemp)))
{
for(int i=0; i<50; i++)
aci_loop();
delay (1);
// SerialMonitorInterface.println(F(“TX dropped!”));
}
nextRecordByteAddrCount2 = nextRecordByteAddrCount + (sizeof (ambientTemp));
EEPROMread((nextRecordByteAddrCount2),(uint8_t*)ambientHumd, int(sizeof (ambientHumd)));
while (!lib_aci_send_data(PIPE_UART_OVER_BTLE_UART_TX_TX, (uint8_t*)ambientHumd,
sizeof(ambientHumd)))
{
for(int i=0; i<50; i++)
aci_loop();
delay (1);
// SerialMonitorInterface.println(F(“TX dropped!”));
}
nextRecordByteAddrCount3 = nextRecordByteAddrCount2 + (sizeof (ambientTemp));
EEPROMread((nextRecordByteAddrCount3),(uint8_t*)cowTemp, int(sizeof (cowTemp)));
while (!lib_aci_send_data(PIPE_UART_OVER_BTLE_UART_TX_TX, (uint8_t*)cowTemp,
sizeof(cowTemp)))
{
for(int i=0; i<50; i++)
aci_loop();
delay (1);
// SerialMonitorInterface.println(F(“TX dropped!”));
}
void ReadSensorsAndStore () {
String timeDateString;
RTC.readTime(); // update RTC library’s buffers from chip
timeDateString += (int(RTC.getMonths()));
timeDateString += “/”;
timeDateString += (int(RTC.getDays()));
timeDateString += “/ ”;
timeDateString += (RTC.getYears());
timeDateString += ” ”;
timeDateString += (int(RTC.getHours()));
timeDateString += “:”;
timeDateString += (int(RTC.getMinutes()));
timeDateString.toCharArray(timeDateData, sizeof (timeDateData)); // copy into timeDateData buffer
// Get ambient temp into array
floatVal= (htu.readTemperature());
dtostrf(floatVal, 3, 2, ambientTemp); //4 is mininum width, 4 is precision; float value is copied onto buff
ambientTemp
// Get cow activity into array, first convert integer count to string
String str = String(activityCount);
// Length (5 digits with one extra character for the null terminator), cowActivity is 6 bytes.
str.toCharArray(cowActivity, sizeof (cowActivity)); // copy into cowActivity buffer
//store sensor data as record by Writing to EEProm section. Have to use separate “W”address records
//since this is part of a timered interrupt routine and can be called during other operations.
EEPROMwrite((baseRecordByteAddrCountW),(uint8_t*) timeDateData,sizeof(timeDateData));
...Table 10 contd.
return val;
}
Based on the need of the applications, the Edge application design can use file storage to
embedded relational database systems (RDBMS).
<uses-sdk
android:minSdkVersion=“8”
android:targetSdkVersion=“18” />
<application
android:allowBackup=“true”
android:icon=“@drawable/ic_launcher”
Table 11 contd. ...
5
Get Shared Preference - https://developer.android.com/reference/android/content/Context#getSharedPreferences(java.
lang.String,%20int)
184 Building Enterprise IoT Applications
...Table 11 contd.
android:label=“@string/app_name”
android:theme=“@style/AppTheme” >
<activity
android:name=“com.secondassig.androiddatastorage.MainActivity”
android:label=“@string/app_name” >
<intent-filter>
<action android:name=“android.intent.action.MAIN” />
<category android:name=“android.intent.category.LAUNCHER” />
</intent-filter>
</activity>
<activity
android:name=“com.secondassig.androiddatastorage.SetPreferencesActivity”
android:label=“@string/title_activity_set_preferences”
android:parentActivityName=”com.secondassig.androiddatastorage.
MainActivity” >
<meta-data
android:name=“android.support.PARENT_ACTIVITY”
android:value=“com.secondassig.androiddatastorage.MainActivity” />
</activity>
<activity
android:name=“com.secondassig.androiddatastorage.SQLiteActivity”
android:label=“@string/title_activity_sqlite”
android:parentActivityName=”com.secondassig.androiddatastorage.
MainActivity” >
<meta-data
android:name=“android.support.PARENT_ACTIVITY”
android:value=“com.secondassig.androiddatastorage.MainActivity” />
</activity>
</application>
</manifest>
App IDE
App IDE
Main Activity
The purpose of the main activity is to handle User interactions:
• Shared Preferences
• SQLite Data Storage
When the User clicks on the Share Preference button, the app calls openPreference() (see Table 12).
package com.secondassig.androiddatastorage;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
protected void onResume()
{
super.onResume();
try
{
InputStream in=openFileInput(SetPreferencesActivity.STORE_PREFERENCES);
if(in!=null)
{
InputStreamReader tmp=new InputStreamReader(in);
BufferedReader reader=new BufferedReader(tmp);
String str;
StringBuilder buf=new StringBuilder();
while((str=reader.readLine())!=null)
{
buf.append(str +”\n”);
}
in.close();
TextView savedPref=(TextView)findViewById(R.id.saved_data);
savedPref.setText(buf.toString());
}
}
Table 12 contd. ...
186 Building Enterprise IoT Applications
...Table 12 contd.
catch(Exception e)
{
e.printStackTrace();
}
}
Clicking on the Preference button, creates an intent to invoke Set Preference Activity.
package com.secondassig.androiddatastorage;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.text.SimpleDateFormat;
import java.util.Date;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;
import android.support.v4.app.NavUtils;
import android.annotation.TargetApi;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.os.Build;
import android.preference.PreferenceManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_set_preferences);
// Show the Up button in the action bar.
setupActionBar();
}
@Override
public void onResume()
{
super.onResume();
Table 13 contd. ...
188 Building Enterprise IoT Applications
...Table 13 contd.
SharedPreferences sharedPreferences=PreferenceManager.getDefaultSharedPreferences(this);
Editor editor=sharedPreferences.edit();
...Table 13 contd.
editor.putInt(“COUNTER”, counter);
editor.putInt(“HELLOCMPE277”, counter);
editor.commit();
}
//Retrieve the contents of the file in the OnResume() in MainActivity
The saved preference is updated to the UI. The Shared Preferences file is saved on the device storage.
Using Android Device Monitor, we can inspect the stored data (see Figure 18).
The device monitor provides the system view from the development point of view. On the actual device,
the shared preference file is still stored at the same relative position on the App’s directory (see Figure 19).
The location is:
APP Location\Data\Files\StrorePref.txt
The Contents of file: The above application creates the following Preferences file (see Figure 20).
190 Building Enterprise IoT Applications
The Contents of file: The above application creates the following Preferences file (see Figure
131).
Data Storage 191
Figure
Figure 20:Shared
131: Shared Preferences
Preferences Content
Content
SQLite
Classic Serverless: The database engine runs as in-proc server, i.e., within the same process, thread, and
address space as the application. There is no message passing or network activity.
Neo-Serverless: The database engine runs in an out of process server, i.e., a separate namespace from
the application, probably on a separate machine, but the database is provided as a turn-key service by the
hosting provider, requires no management or administration by the application owners, and is so easy to
use that the developers can think of the database as being serverless even if it really does use a server.
SQLite is an example of a classic serverless database engine. To compare classic serverless to neo-
serverless, please consider Azure Cosmos DB and Amazon S3. Both are Neo-serverless databases6 [6].
6
Serverless vs. Neo-serverless - https://www.sqlite.org/serverless.html
Capture
Pressure
12/29/2014 – 3:00 PM 30 40.33 60.9 1015 >
12/29/2014 – 7:00 PM
Temperature
25.23 35.33 60.9 1015
Humidity
Pressure
F160
Future
192 Building Enterprise IoT Applications Ambient Temperature
Change feed
Change feed
Azure cosmos Azure function Output
F169
stream from Azure
stream from Azure
cosmos DB Azure
DB cosmos
trigger Azure function Output
cosmos DB DB triggerFigure 21: Azure Functions
Input binding (Azure function to Cosmos DB): Create an input function at Azure that invokes a function
on the Cosmos DB (see Figure 22) [6].
F170
Trigger Azure function Output
Azure cosmos DB
input binding
Trigger Azure
Azurecosmos
function DB Azure cosmos DB F171
input binding input binding
Bind a function (see Figure 22) to an Azure Cosmos DB container using an output binding. Output
bindings write data to a container when a function completes (see Figure 23) [7].
Serverless embedded databases are essential ingredients to make edge level data storage.
SQLite Transactional
A transactional database is one in which all changes and queries appear to be Atomic, Consistent, Isolated,
and Durable (ACID). SQLite implements serializable transactions that are atomic, consistent, isolated, and
durable, even if the transaction is interrupted by a program crash, an operating system crash, or a power
failure to the computer.7
1200
1100
1000
900
800
700
600
500 F172
400
300
200
100
0
gcc 7 -O6 gcc 5 -O6 gcc 7 -Os gcc 5 -Os gcc 7 -Os gcc 5 -Os Clang Clang
--profile-use --poifile-use 3.5.2 O3 3.5.2 Os
IOT small
form
7
SQLite Transactional
factor - https://www.sqlite.org/transactional.html
iot Data Prepare training input
devices collection outputs pair
from the
device
iot
iot
iot
Training Testing
F186
data data
194 Building Enterprise IoT Applications
SQLite is well suited for IoT and embedded devices for the following reasons:
• 500 kb foot-print
• Highly reliable DO-178B9
• Supports huge number of transactions
The maximum number of bytes in a string or BLOB in SQLite is defined by the preprocessor
macro SQLITE_MAX_LENGTH. The default value of this macro is 1 billion (1 thousand million or
1,000,000,000). You can raise or lower this value at compile-time using a command-line option like this:
• SQLite is in the public domain,10so you can freely use and distribute it with your app.
-DSQLITE_MAX_LENGTH=123456789
Some benefits of using SQLite for local storage11
• SQLite works across platforms and architectures.
SQLite is light-weight and self-contained. It’s a code library without any other dependencies. There’s
nothing to configure.
• There’s no database server. The client and the server run in the same process.
• SQLite is in the public domain, so you can freely use and distribute it with your app.
Supported
• SQLiteSQL Commands
works (please
across platforms andsee Figure 136)96:
architectures.
Supported SQL Commands (please see Figure 25):12
8
SQLite & Reliability - https://www.sqlite.org/hirely.html
9
https://www.sqlite.org/hirely.html
10
Limits - https://sqlite.org/limits.html
11
Some benefits of using SQLite for local storage - https://docs.microsoft.com/en-us/windows/uwp/data-access/sqlite-
databases
12
SQL Commands - https://www.sqlite.org/lang.html
SQLite Database can be build and distributed as part of an embedded application. The foot-
print of SQLite data is less than 500 KB. To build SQLite, Eclipse Mars IDE with MinGW
SQLite Database can be build and distributed as part of an embedded application. The foot-print of
SQLite data is less than 500 KB. To build SQLite, Eclipse Mars IDE with MinGW GCC (see Figure 26
and Figure 27).
Step 1: Create C Project
Step 2: Enter the Project name and select the compiler
Step 1: Create C Project
Add sqlite3.c and sqlite3.h in your project. Create a file iDispenser.c and add it in the project. This is
the program where we will create a database, create a table and insert data in the database. Step 3: Create
a main driver in C to access SQLite functionalities (see Figure 28).
Add sqlite3.c and sqlite3.h in your project. Create a file iDispenser.c and add it in the project. This is the program where we will create a
196 Building
database, Enterprise
create a table and insert IoT
data Applications
in the database. Step 3: Create a main driver in C to access SQLite functionalities (see Figure 139).
The activity User Interface is created by calling on create on SQL activity layout:
Data Storage 197
package com.secondassig.androiddatastorage;
import java.io.OutputStreamWriter;
The SQLite button creates SQLite Activity and creates the UI (see Figure 141 and Table 46
import java.text.SimpleDateFormat;
): import java.util.Date;
import android.os.Bundle;
import android.app.Activity;Table 46: Android Data Storage SQL Code
import
package android.view.Menu;
Ǥ ǤǢ
import android.view.MenuItem;
import
import android.view.View;
ǤǤǢ
import
import android.widget.EditText;
ǤǤ Ǣ
import android.widget.Toast;
import ǤǤǢ
import android.support.v4.app.NavUtils;
import android.annotation.TargetApi;
import ǤǤǢ
import android.content.Context;
import ǤǤ Ǣ
import android.content.Intent;
import ǤǤǢ
import android.content.SharedPreferences;
import ǤǤ Ǣ
import android.content.SharedPreferences.Editor;
import ǤǤǢ
import android.os.Build;
import android.preference.PreferenceManager;
Table 14 contd. ...
198 Building Enterprise IoT Applications
...Table 14 contd.
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sqlite);
// Show the Up button in the action bar.
setupActionBar();
@Override
public void onResume()
{
super.onResume();
SharedPreferences sharedPrefs = PreferenceManager.getDefaultSharedPreferences(this);
counter=sharedPrefs.getInt(“SQL_COUNTER”, 0);
}
/**
* Set up the {@link android.app.ActionBar}, if the API is available.
*/
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
private void setupActionBar() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
getActionBar().setDisplayHomeAsUpEnabled(true);
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.sqlite, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
// This ID represents the Home or Up button. In the case of this
// activity, the Up button is shown. Use NavUtils to allow users
// to navigate up one level in the application structure. For
// more details, see the Navigation pattern on Android Design:
//
// http://developer.android.com/design/patterns/navigation.html#up-vs-back
//
NavUtils.navigateUpFromSameTask(this);
return true;
}
return super.onOptionsItemSelected(item);
}
Table 14 contd. ...
Data Storage 199
...Table 14 contd.
try
{
counter+=1;
SharedPreferences sharedPreferences=PreferenceManager.getDefaultSharedPreferences(this);
Editor editor=sharedPreferences.edit();
editor.putInt(“SQL_COUNTER”, counter);
editor.commit();
Data Controller
The Data Controller class connects to SQLite and performs SQL operations:
The main SQLite libraries used are:
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
200 Building Enterprise IoT Applications
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.database.sqlite.SQLiteOpenHelper;
SQLIite Tables and Database
The goal of the app is to store user entered text in the database. The DATABASE_NAME and TABLE_
NAME is defined as follows:
public static final String MESSAGE=“Message”;
public static final String TABLE_NAME=“Msg_Table”;
public static final String DATABASE_NAME=“Assignment2.db”;
public static final int DATABASE_VERSION=4;
public static final String TABLE_CREATE=“create table Msg_Table (Message text not null);”;
SQL Commands
The Data Controller class connects to SQLite and performs SQL operations (see Table 15).
DataBaseHelper dbHelper;
Context context;
SQLiteDatabase db;
...Table 15 contd.
@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
try
{
db.execSQL(TABLE_CREATE);
}
catch(SQLiteException e)
{
e.printStackTrace();
}
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
db.execSQL(“DROP TABLE IF EXISTS Msg_Table”);
onCreate(db);
}
}
13
Apple Sandbox - https://developer.apple.com/library/archive/documentation/Security/Conceptual/AppSandboxDesign
The Foundation Framework provides three classes that are indispensable when it
Guide/AboutAppSandbox/AboutAppSandbox.html
• NSFileManager - The NSFileManager class can be used to perform basic file and
directory operations, such as creating, moving, reading and writing files and reading
and setting file attributes. In addition, this class provides methods for, amongst other
202 Building Enterprise IoT Applications
//
// FileExampleViewController.m
// FileExample
//
// Created by Chandrasekar Vuppalapati – 11/24/2018
// Copyright (c) 2018 Hanumayamma. All rights reserved.
//
#import “FileExampleViewController.h”
@interface FileExampleViewController ()
@end
@implementation FileExampleViewController
- (void)viewDidLoad
{
[super viewDidLoad];
NSFileManager *filemgr;
NSString *dataFile;
NSString *docsDir;
NSArray *dirPaths;
filemgr = [NSFileManager defaultManager];
// Identify the documents directory
dirPaths = NSSearchPathForDirectoriesInDomains(
NSDocumentDirectory, NSUserDomainMask, YES);
docsDir = dirPaths[0];
...Table 16 contd.
- (IBAction)saveText:(id)sender {
NSFileManager *filemgr;
NSData *databuffer;
NSString *dataFile;
NSString *docsDir;
NSArray *dirPaths;
filemgr = [NSFileManager defaultManager];
dirPaths = NSSearchPathForDirectoriesInDomains(
NSDocumentDirectory, NSUserDomainMask, YES);
docsDir = dirPaths[0];
dataFile = [docsDir
stringByAppendingPathComponent: @“datafile.dat”];
databuffer = [_textBox.text
dataUsingEncoding: NSASCIIStringEncoding];
[filemgr createFileAtPath: dataFile
contents: databuffer attributes:nil];
}
@end
Figure
Figure144:
33: File onDevice
File on Device
TheSimulator
iOS file location
pathisstructure:
as shown above (see Figure 144).
iOS App needs to add reference to libsqlite3.0dylib in order to enable SQL commands in iOS App (see
Figure 34).
The Database app has simple screen: enter User Name, address, and Phone click save should save
MacOS X is shipped with SQLite pre-installed, including an interactive
the values into SQL Database.
environment for issuing SQL commands from within a Terminal window.
Tensors as Storage
iOS App needs to add reference to libsqlite3.0dylib in order to enable SQL commands in iOS
The Database View Controller Header File (please see Table 17)
App (see Figure 145).
206 Building Enterprise IoT Applications
//
// DatabaseViewController.h
// Database
//
// Created by Chandrasekar Vuppalapati
// Copyright (c) 2018 Hanumayamma. All rights reserved.
//
#import <UIKit/UIKit.h>
#import <sqlite3.h>
@interface DatabaseViewController : UIViewController
@property (strong, nonatomic) NSString *databasePath;
@property (nonatomic) sqlite3 *contactDB;
@property (weak, nonatomic) IBOutlet UITextField *name;
@property (weak, nonatomic) IBOutlet UITextField *address;
@property (weak, nonatomic) IBOutlet UITextField *phone;
@property (weak, nonatomic) IBOutlet UILabel *status;
- (IBAction)saveData:(id)sender;
- (IBAction)findContact:(id)sender;
@end
The Database View Controller header file creates Interface Builder Property and action outlets.
@property (weak, nonatomic) IBOutlet UITextField *name;
The values from the Screens are stored to the database by calling save method.
The code checks
(a) Database file is open by calling sqlite3_open command.
(b) If open is successful, the code inserts data into DB, by calling SQL INSERT
Data Storage 207
sqlite3_stmt *statement;
const char *dbpath = [_databasePath UTF8String];
if (sqlite3_open(dbpath, &_contactDB) == SQLITE_OK)
{
NSString *insertSQL = [NSString stringWithFormat:
@“INSERT INTO CONTACTS (name, address, phone) VALUES (\“%@\”, \“%@\”, \“%@\”)”,
_name.text, _address.text, _phone.text];
const char *insert_stmt = [insertSQL UTF8String];
sqlite3_prepare_v2(_contactDB, insert_stmt,
-1, &statement, NULL);
if (sqlite3_step(statement) == SQLITE_DONE)
{
_status.text = @“Contact added”;
_name.text = @””;
_address.text = @””;
_phone.text = @””;
} else {
_status.text = @“Failed to add contact”;
}
sqlite3_finalize(statement);
sqlite3_close(_contactDB);
}
//
// DatabaseViewController.m
// Database
//
// Created by Neil Smyth on 9/18/13.
// Copyright (c) 2013 Neil Smyth. All rights reserved.
//
#import “DatabaseViewController.h”
@interface DatabaseViewController ()
@end
@implementation DatabaseViewController
- (void)viewDidLoad
{
[super viewDidLoad];
NSString *docsDir;
NSArray *dirPaths;
// Get the documents directory
dirPaths = NSSearchPathForDirectoriesInDomains(
NSDocumentDirectory, NSUserDomainMask, YES);
docsDir = dirPaths[0];
// Build the path to the database file
_databasePath = [[NSString alloc]
initWithString: [docsDir stringByAppendingPathComponent:
@“contacts.db”]];
...Table 18 contd.
...Table 18 contd.
sqlite3_stmt *statement;
if (sqlite3_open(dbpath, &_contactDB) == SQLITE_OK)
{
NSString *querySQL = [NSString stringWithFormat:
@“SELECT address, phone FROM contacts WHERE name=\“%@\””,
_name.text];
const char *query_stmt = [querySQL UTF8String];
if (sqlite3_prepare_v2(_contactDB,
query_stmt, -1, &statement, NULL) == SQLITE_OK)
{
if (sqlite3_step(statement) == SQLITE_ROW)
{
NSString *addressField = [[NSString alloc]
initWithUTF8String:
(const char *) sqlite3_column_text(
statement, 0)];
_address.text = addressField;
NSString *phoneField = [[NSString alloc]
initWithUTF8String:(const char *)
sqlite3_column_text(statement, 1)];
_phone.text = phoneField;
_status.text = @”Match found”;
} else {
_status.text = @”Match not found”;
_address.text = @””;
_phone.text = @””;
}
sqlite3_finalize(statement);
}
sqlite3_close(_contactDB);
}
}
@end
The SQL App enables the User to insert and query SQL data (see figure SQL Query).
Chapter Summary
After reading the chapter:
• Should able to define two, three dimensional arrays in C
• Should able to create data storages in android and ios platforms
• Should be able to create embedded database in SQLite
• Should be able to create in memory arrays
References
1. Jason Brownlee, A Gentle Introduction to N-Dimensional Arrays in Python with NumPy, January 31, 2018, https://
machinelearningmastery.com/gentle-introduction-n-dimensional-arrays-python-numpy/, Access date: June 2018
2. Travis E. Oliphant, Guide to NumPy: 2nd Edition 2nd Edition, ISBN-13: 978-1517300074, http://web.mit.edu/dvp/
Public/numpybook.pdf
3. Marshall Brain, The Basic of C Programming, 2016, https://computer.howstuffworks.com/c39.htm , June 2018
4. Atmel Corporation, 8-bit AVR Microcontroller, Nov 2016, http://arduinoinfo.mywikis.net/w/images/3/35/Atmel-
42735-8-bit-AVR-Microcontroller-ATmega328-328P_Datasheet.pdf, Access date: June 2018
210 Building Enterprise IoT Applications
IEEE defined embedded systems are the devices that are used to Control, Monitor or Assist the Operation
of Equipment Machinery or Plants. As we can see, development of embedded systems has seen a significant
increase over the past few years, their application changing our lives enormously. From the traditional
embedded systems to the advanced systems that we use today, one severe issue we are facing is how to
effectively and efficiently deal with the massive amounts of data collected from sensors and inter-device
communication.
To process this data, we need machine learning techniques that can scale at the embedded or constrained
IoT devices. Machine Learning is a trending technology which uses data to draw meaningful insights, like
prediction, classification and clustering. Machine Learning is widely used in most sectors these days for
various problem-solving mechanisms. Embedded Systems typically include microcontrollers, CPU cycles,
memory constraints and cost and consumption of power. One trending topic is the utilization of machine
learning techniques on data coming from sensors in a microcontroller environment and analyzing it.
Advancement in Sensors and reduction in cost in micro controllers has led to emerging technologies
where companies use sensors attached to embedded systems like MCU board and plummeted sensor
based artificial intelligence and autonomous based vehicles. Machine learning uses sophisticated tools to
optimize signal issues and can aid in speeding up the process for embeddable code. It drives developers
to work on the code functionality rather than the statistics and mathematical logical behind it. This is a
big pain point for most developers in the real world.
The most important advantage of ML is that it eludes traditional models by detecting fault or anomaly
in a system. This makes ML efficient and best usage of data to overcome variation. Machine learning
models can learn independently with raw data and directly detect anomaly without any human intervention.
This plays an important role in embedded systems.
Machine learning (see Figure 1) denotes the application of artificial intelligence (AI) to provide systems
with the ability to automatically learn and improve from experience without being explicitly programmed to
do so. Machine Learning started from the computer, but the emerging trend suggests that machine learning
has fostered a new generation of applications and devices viz. mobile phones and embedded systems that
can sense, perceive, learn from, and respond to their users and environment, transforming businesses like
0
gcc 7 -O6 gcc 5 -O6 gcc 7 -Os gcc 5 -Os gcc 7 -Os gcc 5 -Os Clang Clang
--profile-use --poifile-use 3.5.2 O3 3.5.2 Os
IOT small
form
factor iot Data Prepare training input
devices collection outputs pair
from the
device
iot
iot
iot
Training Testing
F186
data data
predictions
humans. The guided learning processes of humans o ail (Lused to incorporate their reasoning in the apps.
en rcan
ga vembe o
en w or
g
The most common ML model techniques used einmemobile t
n of
and
No farm factors are listed below–
) t cus C
tom onne
1. K-Nearest Neighbor er c
exp tivity
2. Case Based Reasoning eri Ven
en
ces ues
3. Artificial Neural Network an – ne
d b ed
ran
4. Support vector Machine d
F186
intelligent systems, are a lack of engagement
data with patrons at a personal and emotional
data level, this
leading to missed recurring business opportunities and poor long-term brand loyalty.
The
List Long Tail: Issue at stake
of Supervised 1
Score and
ML tasks evaluate
The internet has changed the dynamics of the venue and hospitality marketplace (see Figure 2). Since
• Classification
the development of the internet, all the attributes of the hospitality & venue industry have deeply
• Regression
continuously evolved:Machine
and• Dimensionality Usage Learning
of connected networks, usage of consumer digital
outputs ML data & mining
Algorithm for
of consumer
reduction preferences, exclusive recommendations gleaned from Web 2.0 & 3.0 data sources,
model
Supervised task
Internet Of Things (IoT), wearable data sources and new business models reshape the industry.
This process has even been sped up recently by the emergence of disruptive innovations, from the
evolutions of web & mobile technologies to the Artificial Intelligence (AI) platforms. The long tail
[1] is used in this paper (Case Study), as a multitude of a small, independent venue operators with
limited digital connected infrastructure and deficient intelligent systems can grasp predictions
and synthesize this
complexity.
Lo
n
imp g-Ta
F187
Connected Venue
en rove il (Lo
ga
ge ment w or
me N
nt of cu o) C
sto onn
me e
r e ctivi
xpe ty V
rie e
nce nues
s a –n
nd e
bra ed
nd
High Low
Customer Experience & Brand Engagement
Figure 2: Long Tail
1
Long Tail in Tourism Industry - https://halshs.archives-ouvertes.fr/halshs-01248302/document
214 Building Enterprise IoT Applications
Applications
User Activity Recognition
Analyze raw data from mobile device accelerometer sensor, apply KNN to help classify user activity.
Application finds out which template is closer to the current activity vector by measuring distance of
each point of our target pattern with all points of each template. The development of the proposed activity
recognition classifier proceeds with a supervised learning algorithm. Supervised techniques rely on labeled
data. An application is developed to execute on the phone in order to collect the data. The application
allows the user to set the sampling rate, start and stop the data collection, and label the activity being
performed with an elegant graphical user interface. Data are collected every 10 milliseconds. The user
is granted the freedom to set the orientation of the mobile phone at will. The user can hold the phone in
hand, or put it in a pocket or in a handbag. User activities include staying, walking, running, ascending
stairs, and descending stairs.
Travel Guide
Using location dependent systems in Android Mobile Phones to provide to provide tourism information
to the mobile users on the move using GPS.
Naive-Bayes Classification
This method infers the conditional probability that a new instance belongs to a particular class based on
applying Bayes’ theorem with the “naive” assumption of conditional independence between every pair of
features for the given value of the class variable.
Application
• Text categorization—Naive Bayes classification model works with Bag-of-Word feature extraction
which avoids the position of the word in the document. It predicts the probability that a given feature
set belongs to a particular label.
• Malware Detection—Using android application file which contain dataset and attributes, get permission
to access the attribute in the application, xml file contains actual object, transfer text file into integer
value. The malware detection is based on probability rule, which predicts the value and permission
access for different applications. It contains a data set in terms of matrix which produce output in the
form of integer value, which shows the result of detected malware. It is found that malware can be
present in SMS, MMS, Bluetooth, Videos, or social networking, etc.
Machine Learning at the Edge 215
• Spam filtering
• Sentiment Analysis
• Fraud detection
Applications
Automatic task classification—can be implemented for mobile devices by using the support vector machine
algorithm and crowdsourcing.
• The training data set obtained via crowdsourcing using the Amazon Mechanical Turk platform.
Personal assistant services—A user’s voice command is first transmitted to a server, which is running
the speech-to-text converter and the task classifier. The received speech at the server is converted to text,
and the converted text is given to the task classifier, a core part of the overall system. The task classifier
classifies the given text into the most probable task, and the predicted task is transmitted back to the
user’s mobile device. Then, the task launcher of the personal assistant system performs the predicted task
accordingly on behalf of the user.
AdaBoost
Adaptive Boosting is an ensemble algorithm used to train a boosted classifier by training learners on the
filtered output of other learners. For instance, it can boost the performance of decision trees on binary
classification problems.
Applications
• For boosting the performance of a Mobile phone crowdsourcing parking app. It combines multiple
trust prediction approaches with a real-time data fusion method in order to create the final map.
Applications
• For the identification of ADL (Activities of Daily living)—The mobile application captures the data
in 5 seconds slots every 5 minutes, where the frequency of the data acquisition is around 10 ms. For
the definition of the experiments, 25 individuals aged between 16 and 60 years old were selected.
The dataset is composed by Standard Deviation of the raw signal, Average of the raw signal, Variance
of the of the raw signal, and Median of the raw signal, extracted from the accelerometer and the
magnetometer sensors
• Computer vision, speech recognition, machine translation, social network filtering and medical
diagnosis.
216 Building Enterprise IoT Applications
Gaussian Process
A Gaussian process in a machine learning algorithm uses lazy learning. It measures the similarity between
points in order to predict the value for an unseen point from training data.
Applications
• Build a context aware application—When several users are in a room and each of them carries a
mobile device, we can find the matching relationship between the users and the mobile devices by
advanced inertial sensors of the phone.
• Prediction of spatiotemporal fields by the use of mobile sensor networks.
• Nonparametric Gaussian process regression (or kriging in geo-statistics) has been widely used as a
nonlinear regression technique in order to estimate and predict geostatistical data.
• Disease tracking
• Weather forecasting
Decision Tree
Tree data structure is formed by recursively splitting points from a set of input values, based on a cost
function, to predict an output value. The information gain is calculated at every node, and the node with
the lowest entropy is chosen as the split node.
Applications
• To get the real-life impression of the most common user behavior and infer presence status—Mobile
Data Challenge (MDC) data set was collected from around 200 individuals over more than a year.
The logs contain information related to GPS, WiFi, Bluetooth and accelerometer traces, as well as
call and SMS logs, multimedia and application usage. All the features are turned to nominal. GSM
cell identifier is also used as a nominal feature after determining all the possible values during the
preprocessing. For leaf nodes, only the nodes with class labels were used. Classification error is used
as fitness function.
Linear Regression
Tree data structure is formed by recursively splitting points from a set of input values, based on a cost
function, in order to predict an output value.
Clustering
Clustering is a data mining algorithm used to divide data into groups or segments based on some similarity
criteria. Real time embedded Systems include devices which monitor and observe the physical world with
sensors and provide real time control or reaction. There is a wide range of such systems, from a stand-alone
small devices to global networked real time embedded systems. Some examples are Temperature Sensors,
Traffic control sensors, electric power grid controls, IoT devices, etc. All these devices generate streaming
time series data or multivariate time series data. Clustering of the time series data may include the similar
behavior of attributes in a given time window, similar time series pattern, etc. However, Clustering with
such a large amount of data (time series data is generated over time and is huge in comparison to static
data) is challenging, since multivariate time series data cannot be scanned multiple times, unlike regular
static data.
Machine Learning at the Edge 217
Clustering Techniques
In the following, we will discuss some clustering techniques for time series data as per below:
1. Partitioning methods (k-means, k-medoid)
2. Hierarchical methods (AGNES, DIANA)
3. Incremental Clustering (COBWEB, BIRCH)
4. Online Divisive Agglomerative Clustering
5. Density based methods (DBSCAN)
6. Grid based methods (STING)
7. Model based methods (Expectation Maximization)
Partitioning methods—Also called Portioning methods. Partitioning methods tend to minimize the cost
function while maintaining the optimality. The Dataset is divided into k-partitions, such that the object
distance among the cluster is minimum, whereas inter-cluster distance is maximized. Major approaches
in partitioning methods are: k-means and k-medoid.
Hierarchical methods—There are three features that give hierarchical clustering the advantage over Parti-
tioning methods—(1) No need to pre-define the number of clusters k. (2) No assumptions on data distribution,
(3) Representation in pair-wise dissimilarity matrix. In hierarchical methods, split can be done based on
K-means technique at each hierarchy.
IANA (Divisive ANAlysis) is a hierarchical clustering technique that uses a top-down approach—from
top (large cluster) to bottom (several clusters). The top cluster contains all the data. At each hierarchy, the
cluster with the largest diameter is selected and divided into new clusters until all the clusters have only
one piece of data.
Incremental Clustering—To overcome the limitation of time, memory and sample size for multivariate
time series data, over which multiple passes are not achievable, an incremental clustering system was
developed for compact representation, quickly and incrementally processing new data. Several methods
introduced for this purpose:
• COBWEB—conceptual, incremental, hierarchical algorithm for hill-climbing search on classifiers.
• BIRCH—builds CF-tree by agglomerative procedure which is a hierarchical structure.
• Single Pass K-means—buffer to keep all points in compressed form.
• CURE: each group is represented by a constant number of points, arbitrary shape of groups can be
found out.
• STREAM—minimizes the sum-of-squares quality measure.
• CluStream—online method extends CF vectors of BIRCH, offline method performs global clustering.
• One problem with these models is how to determine the minimum number of observations that are
necessary to achieve a converged model.
Online Divisive Agglomerative Clustering (ODAC)—This method of clustering is a time series whole
clustering system which constructs a tree-shaped hierarchical structure using top-down strategy. Leaves
of the tree are the final clusters with a set of variables at each leaf, the Union of which gives the complete
set of variables and intersection gives an empty set. Cluster diameters are monitored at each level in order
to minimize the intra-cluster dissimilarity after each split. For each cluster, the system finds the diameter
of the cluster based on two variables, if the given condition is met on this cluster, it is split into two new
clusters for each chosen variable called pivot variable for that cluster. All remaining variables on the old
cluster are assigned a new cluster with closest pivot. A test is performed on this model to see whether the
diameters of children leaves approached parent’s diameter, if yes, then the previous structure needs to
be re-aggregated. This agglomerative phase which starts new statistics on selected node is used to detect
concept drift.
218 Building Enterprise IoT Applications
Density based methods (DBSCAN)—Density based methods find data groups or clusters based on the
density instead of centers unlike the hierarchical or partitioning methods. DBSCAN is an example of this
method.
Grid based methods—An object is divided into n number of cells and then clustering is performed on
them.
STING (Statistical Information Grid) is an example of this method. It decomposes spatial area into
rectangular cells.
Model based methods—model based methods try to fit the data into a predefined mathematical model.
Expectation maximization is a n example of this method.
These days there are many IOT devices prompting data scientists to use clustering algorithms on real
time data because of the massive amounts of data an IOT device can provide. One popular unsupervised
clustering partitioning algorithm that is K means clustering. This clustering algorithm partitions a data set
into k number of clusters by comparing how similar a data point is to the centroid value for each cluster;
however, the drawbacks to this clustering method are that it cannot be applied to nominal attributes/
categorical values and it cannot handle outliers. The k is a value that is determined by the developer,
based on his or her understanding of the data. A common example where k-means is used with an IOT
device is fitness trackers. The data collected from these devices can be used to determine which workouts
are similar and put them into the same cluster. STREAM and CluStream are extensions to the K-means
algorithms that are widely used today for partitioning clustering algorithms.
Hierarchical clustering algorithms are also commonly used with real time data. The main goal behind
hierarchical clustering is to form tree clusters by decomposing the data. It creates a binary-tree, also known
as a dendrogram, and can be built both ways, i.e., bottom up or top down. This tree, once created, can be
modified by a user by changing the number of levels, without having to rerun the clustering algorithm.
One drawback, however, is that once a split in the algorithm is made, it cannot be reverted.
Balanced Iterative Reducing and Clustering using Hierarchies (BIRCH) is a clustering algorithm for
real time data that is being proposed to improve the hierarchical clustering. It clusters multidimensional
data dynamically and incrementally. This algorithm was designed with the thought that not every data
point is important, so not everything should be stored in memory, therefore, BIRCH proposes better usage
of the system’s available resources, such as memory.
G-Stream is a clustering algorithm based on the GNG algorithm. Growing Neural Gas algorithm is
where a graph is created from data and then clustered to find similar structure. It is an unsupervised clus-
tering algorithm mostly used with topological map. G-stream is an industry used GNG algorithm and is
often used for the visualization purpose of the clustering algorithm.
D-Stream clustering is a commonly used Grid based clustering algorithm. Unlike K-means/partitioning
clustering grid-based clustering, for example, D-Stream can handle outliers well. D-stream is a grid-
based stream method, which means the clustering is density based. There are two parts to this algorithm;
first, the input data is mapped on a grid and second, the density is calculated for the grids and then clus-
tered based on the density. D-Stream clustering doesn’t require the user to specify the number of clusters,
instead the algorithm dynamically determines the number of clusters.
References
1. Christian Longhi, Sylvie Rochhia, Long tails in the tourism industry: towards knowledge intensive service suppliers,
2015, https://halshs.archives-ouvertes.fr/halshs-01248302/document, Access Date: July 2018
Chapter 8
Edge Analytics
In just ten years, the Internet of Things (IoT) has gone from science fiction, to reality, to exceeding our
wildest expectations. By 2020 there will be nearly 26 billion connected devices,1 generating more bits of
data than there are stars in the known universe.2 Companies need a way to process and analyze this data
faster and smarter across the network in order to achieve distinct business value [1].
The upside for businesses that can harness more of their data is undeniable. For example, McKinsey
estimates the potential economic impact of IoT to be as much as $11.1T per year by 2025 [2]. Factories
are estimated to feel an estimated impact of up to $3.7T, while worksites in sectors such as mining, oil
and gas and construction could see an impact on the scale of $930B3 [3].
However, the massive amount of data being generated is both the promise of IoT and its most critical
pain point. Not only do businesses need solutions that can help Wikibon IoT Project [A] estimates
them tap more of their IoT data, but they also need a way to that data processing costs are reduced by
separate high-value data from the noise. In light of these IoT 30% when the edge is 200 miles away
challenges, organizations increasingly recognize the advantages from the network and by 60% when the
of leaving certain data right where it is captured—at the edge— edge is 100 miles away.4
and analyzing it there. The result of this is the ability to take
instant action and affect immediate control over the connected things.4
1
Gartner Says the Internet of Things Installed Base Will Grow to 26 Billion Units By 2020 http://www.gartner.com/
newsroom/id/2636073
2
Data Growth, Business Opportunities, and the IT Imperatives - https://www.emc.com/leadership/digital-
universe/2014iview/executive-summary.htm
3
Unlocking the potential of the internet of things - http://www.mckinsey.com/business-functions/digital-mckinsey/our-
insights/the-internet-of-things-the-value-of-digitizing-the-physical-world
4
The Vital Role of Edge Computing in the Internet of Things - https://wikibon.com/the-vital-role-of-edge-computing-in-
the-internet-of-things/
220 Building Enterprise IoT Applications
Edge Analytics help organizations harness the power of the data they generate remotely by delivering
analytics and machine learning at the
ǣ– point of data collection. In this chapter, some of the Edge level
analytics are introduced: Supervised, Unsupervised, and reinforcement models.
Intelligent Dispenser (iDispenser 103 ) works by applying precision of decision, learned
Case Study: Smart City—Intelligent
through analyzing & applying Dispenser
data science, with real-time sensing of sensors (see Figure
Intelligent Dispenser (iDispenser)5 works by applying precision of decision, learned through
148), adaptively builds data models through historical and Venue analytics, and improves
analyzing & applying data science, with real-time sensing of sensors (see Figure 1), adaptively builds
the overall performance through learning. The iDispenser communicates through the Internet
data models through historical and Venue analytics, and improves the overall performance through
learning. The iDispenser
of Thingscommunicates through
(IoT) stack. It uses BluetooththeLow
Internet
Energy of Things
(BLE) (IoT)
protocol and stack.
Wi-Fi It uses Bluetooth
Low Energy (BLE)communication
protocol and Wi-Fi communication modules
modules to perform intelligent dispensing [4]. to perform intelligent dispensing [4].
The custom hardware, built on top of ARM processor, collects environmental and location
Figure 1: iDispenser
specific influential attributes (as predicted by our Data science model) and evaluates the
Figure 148: iDispenser
dispensing both at IoT Edge and Cloud compute level. The sensor module captures real-time
Sensor Modules :
The custom hardware, built on top of ARM processor, collects environmental and location specific
venue temperature and humidity characteristics (see Figure 149). Additionally, it calculates
influential attributes (as predicted by our Data science model) and evaluates the dispensing both at
IoT Edgethe and Cloud ofcompute
people inlevel. The sensor
Finally,module captures
venuereal-time venuewith
temperature
location and
103 Hanumayamma iDispenser -
number the venue. it correlates characteristics
http://hanuinnotech.com/images/VenueAnalytics_ProductBrochure_v7_20160801_Final.pd
humidity characteristics
f (see Figure 2). Additionally, it calculates the number of people in the venue.
Finally, itgeo
correlates
weather.venue characteristics with location geo weather.
Ƭ
Algorithms at the edge level, based on business requirements, can include supervised,
Edge Analytics 221
Decision Trees
A decision tree algorithm is used to classify the attributes and select the outcome of the class attribute.
To construct a decision tree, both class attribute and item attributes are required. A decision tree is a tree
like structure wherein the intermediate nodes represent attributes of the data, the leaf nodes represent
the outcome of the data and the branches hold the attribute value. Decision trees are widely used in the
classification process because no domain knowledge is needed to construct the decision tree. Following
Figure 3 shows simple decision trees.
F190
Outlook
Figure 3: Decision Tree
Sunny Rain
The primary step in the decision tree algorithm is to identify the root node for the given set of data.Overcast
Multiple methods exist to decide the root node of the decision tree. Information gain and Gini impurity
are the primary methods used toOutlook
identify the root node. The root node plays an important role in deciding ?
Humidity
?
which side of decision tree the data falls into. Like every classification method, decision trees are
Lowalso
Value
< 79.5
constructed using Sunny
the training data and tested with the
Rain test data.
Information Gain: Information Overcast
gain is used to identify the root node and the branch nodes in the
> = 79.5
decision tree. Information gain is calculated using entropy and information. The purpose of the information
gain calculation is to identify the node that has the ?least randomness orLow Value Entropy is calculated
impurity.
?
using the following formula Low Value
F192
High Value
m Low Value
Info (D) = – ∑i=1 pi log2 (pi) (1)
High Value
F191
Information of the attribute is calculated using the following formula:
v
|Dj| High Value
InfoA (D) = ∑j=1 —— x info (Dj) (2)
|D|
The information gain of an attribute is the difference between entropy and the information of that
attribute. The attribute with the highest information gain is the root node, and the next level nodes are
identified using the next highest information
Outlook gain attributes.
Sunny Rain
Overcast Outlook
? Sunny Rain
Humidity
? Low Value Overcast
< 79.5
> = 79.5 ?
Temp?
222 Building Enterprise IoT Applications
Information Gain (D) = –Σ (Probability of ‘Low Value * Log2 (Probability of ‘Low Value) + Probability
of ‘High Value * Log2 (Probability of High Value))
Information Gain (D) = –Σ ((5/14) * Log2 (5/14) + (9/14) * Log2 (9/14))
Information gain (D) = 0.9402 bits
Expected information required for each attribute:
Edge Analytics 223
Outlook
<79.5 >=79.5
True False
Low High
Low High
High Low
High Low
Low Low
For attribute wind
Low Play
y - Wind Low
True False
Low High
Edge Analytics 225
Outlook Humidity
? Low Value
< 79.5
Sunny Rain
Overcast > = 79.5
? Low Value
?
F
Low Value High Value
F190
Figure 4: Outlook node
Low Value
High Value
F191
Once the root node is known, the step is to select with attributes become internal nodes (see Figure 5).
Info (D) = – 25 log2(25) – 35 log2(35) = 0.971 bits
High Value
Outlook
Outlook
Sunny Rain
Sunny Overcast Rain
Overcast Outlo
?
Outlook Humidity
? Low Value ?
Humidity Sunny
< 79.5 ?
Sunny Rain Low Value
< 79.5 > = 79.5
Overcast
> = 79.5 Temp?
? Low Value
? Low Va
F192
Low Value Low Value High Value < 71.5
F193
Low Value High Value > = 71.5
High Value
Low Value
F191
Low Value
High Value
High Value Low Value
Infowindy(D) = 25 x ( −12 log2(12) + −12 log2(12) ) + 35 x ( −32 log2(23) + −31 log2(13) ) 0.4 +
Outlook High Value
0.551 0.951 bits (see Figure 6) Outlook
Sunny Rain
Sunny Rain High Value
Overcast Outlook
Overcast
? Sunny Rain
Humidity Windy
? Low Value Humidity
Overcast
79.5 Low Value False
< 79 .5
> = 79.5 ? True
Temp?
Low Value > = 79.5 Low Value
F
Low Value High Value
Low Value
High Value
Outlook
Sunny Rain
? Sunny
Humidity
? Low Value Ov
< 79.5
F193
High Value > = 71.5
Sunny Rain
Low Value
Overcast Low Value
High Value
? Low Value
Outlook Humidity
? Low Value
< 79.5 High Value
unny Rain High Value
Overcast > = 79.5
Figure 6: Humidity Node High Value
F195
Overcast Outlook
? Sunny Rain
Humidity
? Low Value Overcast
> = 79.5 ?
Temp?
Low Value
< 71.5
F193
High Value > = 71.5
Low Value
High Value
F194
Low Value
High Value
High Value
F193
High Value > = 71.5
Low Value
Low Value
High Value
F194
Low Value
Edge Analytics 227
High Value
High Value
Windy
Humidity
Low Value False
< 79 .5
True
> = 79.5 Low Value
High Value
Low Value
High Value
...Table 1 contd.
Windy Attribute
Tuples
True 1
False 0
Class Variable - adaptive coefficent
Low Value 0
High Value 1
Outlook Temp(oF) Humidity(%) Windy Adaptive Coefficient
1 75 70 1 0
1 80 90 1 1
1 85 85 0 1
1 72 95 0 1
1 69 70 0 0
2 72 90 1 0
2 83 78 0 0
2 64 65 1 0
2 81 75 0 0
3 71 80 1 1
3 65 70 1 1
3 75 80 0 0
3 68 80 0 0
3 70 96 0 0
”””
X = np.array([[1, 75, 70, 1],
[1, 80, 90, 1],
[1, 85, 85, 0],
[1, 72, 95, 0],
[1, 69, 70, 0],
[2, 72, 90, 1],
[2, 83, 78, 0],
[2, 64, 65, 1],
[2, 81, 75, 0],
[3, 71, 80, 1],
[3, 65, 70, 1],
[3, 75, 80, 0],
[3, 68, 80, 0],
[3, 70, 96, 0]])
y = [‘Low Value’, ‘High Value’, ‘High Value’, ‘High Value’, ‘Low
Value’, ‘Low Value’, ‘Low Value’, ‘Low Value’, ‘Low Value’, ‘High Value’,
‘High Value’, ‘Low Value’, ‘Low Value’, ‘Low Value’]
dtree = DecisionTreeClassifier()
dtree.fit(X, y)
dot_data = export_graphviz(dtree,
out_file = ‘edgedecisiontree.dot’,
feature_names = [‘Outlook’, ‘Temperature’, ‘Humidity’,‘Windy’],
class_names = [‘Low Value’, ‘High Value’],
filled = True,
rounded = True)
call([‘dot’, ‘-Tpng’, ‘edgedecisiontree.dot’, ‘-o’, ‘edgedecisiontree.
png’])
Edge Analytics 229
True False
F196
gini = 0.48
samples = 5 samples = 9
value = [3, 2] value = [2, 7]
class = Low Value class = High Value
Decision Rule
The above code is converted into decision rules within the edge processor. The values for the Humidity,
Windy, and Temperature are used to dynamically compute the adaptive edge coefficient (see Figure 9 and
Table 2). F208
F (0.05, 6,62178)
Table 2: Edge Processor Decision Rules
/*
Accept Reject region
Codification
Region
Outlook Attributes
Tuples:
Sunny 1
Overcast 2
Rain 3
Windy Attribute
Tuples
True 1
False 0
*/
double computeAdaptiveEdgeCoefficent(int Outlook, bool Windy) F209
{
If(Outlook == 1)
{
if (Humidity <t (p,df)
79.5)
{
Reject region Accept region Reject region
adaptiveEdgeCoefficent = 0.3
}
else {
adaptiveEdgeCoefficent = 0.8
}
} Else if (Outlook == 2)
Table 2 contd. ...
230 Building Enterprise IoT Applications
...Table 1 contd.
{
adaptiveEdgeCoefficent = 0.3
}
else if (outlook == 3) {
if (Windy == True)
{
adaptiveEdgeCoefficent = 0.8
}
else {
adaptiveEdgeCoefficent = 0.3
}
}
else {
// Do nothing
}
}
Sliding Window
Sliding-window (see Figure 10) analysis is a common way to analyze and identify trends in the stream
data. The term “sliding-window analysis” refers to a common pattern analysis of real-time and continuous
data and uses rolling counts of incoming data to examine trending, temperature, and humidity.
takeTestnecessary
message hello world. This is a sample sliding window in C.
actions (see Figure 158).
For Window Size: 25, the parsing is performed as follows:
For Window Size greater than length of the text in the file, a single Window transfer is sufficient (see
–
Figure 12).
For Window Size: 25, the parsing is performed as follows:
The following C Code generates Sliding window and transfers the data by Window Buc
Bucket.
For Window Size greater than length of the text in the file, a single Window transfer is
sufficient (see Figure 159).
#include<stdio.h>
#include<conio.h>
void main()
{
int i, m, n, j, w, l;
char c;
FILE*f;
f = fopen("sensordata.txt", "r");
printf("window size");
scanf("%d", &n);
m = n;
if (f == NULL)
{
printf("File is not open");
return 0;
}
while (!feof(f))
{
i = rand() % n + 1;
j = i;
l = i;
232 Building Enterprise IoT Applications
#include<stdio.h>
#include<conio.h>
void main()
{
int i, m, n, j, w, l;
char c;
FILE*f;
f = fopen(“sensordata.txt”, “r”);
printf(“window size”);
scanf(“%d”, &n);
m = n;
if (f == NULL)
{
printf(“File is not open”);
return 0;
}
while (!feof(f))
{
i = rand() % n + 1;
j = i;
l = i;
if (m>i)
{
m = m - i;
if (m>0)
{
printf(“\n”);
while (i>0 & !feof(f))
{
c = getc(f);
printf(“%c”, c);
i--;
}
printf(“\n%d transferred”, j);
if (j>3)
printf(“\n 1 acknowledgement received”);
else
printf(“\n acknowledgement received”, j +
1);
}
}
m = m + j - 1;
}
}
you specify a window size called the window width. This defines the number of raw observations used
to calculate the moving average value. The “moving” part in the moving average refers to the fact that
the window defined by the window width is slid along the time series in order to calculate the average
values in the new series.
There are two main types of moving average that are used: Centered and Trailing Moving Average.
The moving average value can also be used directly to make predictions. It is a naive model and assumes
that the trend and seasonality components of the time series have already been removed or adjusted for. The
moving average model for predictions can easily be used in a walk-forward manner. As new observations
are made available (e.g., daily), the model can be updated, and a prediction made for the next day. We
can implement this manually in Python (see Table 3). Below is an example of the moving average model
used in a walk-forward manner.
The Data (see Figure 13) for the sliding window is from
The Data (see Figure 160) for the sliding window is from
Figure
Figure13: 160:
Data Data
Predicted: See the console output of predicted values (see Figure 161)
Predicted: See the console output of predicted values (see Figure 14)
Predicted: See the console output of predicted values (see Figure 161)
simple linear regression. When the outcome, or class, is numeric, and all the attributes are numeric, linear
regression is a natural technique to consider. This is a staple method in statistics. The idea is to express
the class as a linear combination of the attributes, with predetermined weights:
x = w0 + w1a1 + w2a2 + … + wkak
where x is the class; a1, a2,…, ak are the attribute values; and w0, w1,…, wk are weights
The weights are calculated from the training data. Here, the notation gets a little heavy, because we
need a way of expressing the attribute values for each training instance. The first instance will have a class,
say x(1), and attribute values, a1(1), a2(1),…, ak(1), where the superscript denotes that it is the first example.
Moreover, it is notationally convenient to assume an extra attribute a0, whose value is always 1.
Dataset
We have downloaded Kaggle dataset (see figure Kaggle Dataset) to get crowdedness to temperature
machine learning model [10].
Dataset: https://www.kaggle.com/nsrose7224/crowdedness-at-the-campus-gym
The dataset consists of 26,000 people counts (about every 10 minutes) over the last year. In addition,
extra information was gathered, including weather and semester-specific information that might affect how
crowded it is. The label is the number of people, which is predicted, given some subset of the features.
Label:
1. Number of people
Features:
• date (string; datetime of data)
• timestamp (int; number of seconds since beginning of day)
• day_of_week (int; 0 [monday] - 6 [sunday])
• is_weekend (int; 0 or 1) [boolean, if 1, it’s either saturday or sunday, otherwise 0]
• is_holiday (int; 0 or 1) [boolean, if 1 it’s a federal holiday, 0 otherwise]
• temperature (float; degrees fahrenheit)
• is_start_of_semester (int; 0 or 1) [boolean, if 1 it’s the beginning of a school semester, 0 otherwise]
• month (int; 1 [jan] - 12 [dec])
• hour (int; 0 - 23) (see Figure 15)
Model Development
To develop a model equation, we have used the Excel regression data model packet (see Figure 16).
Our goal of the model is to predict the influencing factors that affect the room temperature. The
influencing parameters include: Number of people, day of the week, holiday and other dataset parameters
(see Figure 17).
236 Building Enterprise IoT Applications
• month (int; 1 [jan] - 12 [dec])
Model Development
To develop a model equation, we have used the Excel regression data model pack
Model Development
To develop a model equation, we have used the Excel regression data model packet (see Figure
163).
Our goal of the model is to predict the influencing factors that affect the room tem
Figure 163: Excel Data Analysis Pack
Our goal of the model is to predict the influencing factors that affect the room temperature. The
influencing parameters include: Number of people, day of the week, holiday and
influencing parameters include: Number of people, day of the week, holiday and other dataset
parameters (see(seeFigure
parameters ). ).
164
Figure 164
Edge Analytics 237
Model generation: Running data analysis pack with regression parameters creates mod
Figure 165)
F208
F (0.05, 6,62178)
T-Test
The T-Tests are used to conduct hypothesis tests on the regression coefficients obtained in simple linear
regression. The goal is to find out the most influencing parameters in the regression model equation (see
Figure 21).
T Critical = TINV (0.05, 62178) = 1.960002138
All the above values of the fall within the reject region of the t critical. Hence, all the above variables
have the explanatory power in explaining the temperature (see Figure 22).
F209
t (p,df)
Reject region Accept region Reject region
Accept Reject region
Region
F209
t (p,df)
Reject region Accept region Reject region
Data Assumptions
Residually are normally distributed: From the residuals plot, the data points are normally distributed (see
Figure 23).
80.
60.
40.
F211
20.
0.
0 10000 20000 30000 40000 50000 60000 10000
–20.
–40.
–60.
Figure 23: Data Samples
F(t)
Noisy measurement
A posteri estimate
0.5 Truth value
F217
0.4
Temperature
0.3
0.2
suddenly
Modelentered into a room, keeping all other effect variables constant, the room temperature
Equation
From the dataset, we have derived model equation that will calculate the temperature value bases on
would increase
parameters: by apeople,
Number factor dayof
of 0.3019.
the week, is_weekend, is_holiday, month and hour.
Temperature = 0.3019 * number_people + 5.7507 * day_of_week – 11.4933 * is_weekend + 32.4674
* is_holiday + 2.9673 * month + 0.7805 * hour
In other words:
Model Equation & Independent Parameters Coefficients
Change of Temperature
As provided giventhe
by the model equation, number of parameter
independent people in a room
“number is (see
of people” Figure
influences 172):
to the state
variable “temperature”. What this means is, if a number of people suddenly entered into a room, keeping
all other effect variables constant, the room temperature would increase by a factor of 0.3019.
Temperature
In other words:Change Number of People = 0.30198
Change of Temperature given number of people in a room is (see Figure 25):
Temperature Change Number of People = 0.30198
Scatter Diagram
To perform a linearity check, a scatter plot diagram will help (see figure linearity).
As you can see Figure 26, a linear relationship exists in all cases.
The sklearn performs linear regression (see Table 4).
Stock_Market = pd.read_csv(r’C:\Hanumayamma\CRCBook\Code\MachineLearning\Crowdedness_To_
Temperature_20170403.csv’)
df = DataFrame(Stock_Market,columns=[‘number_people’,‘day_of_week’,‘is_weekend’,‘is_holiday’,‘mon
th’,‘hour’,‘temperature’])
X = df[[‘number_people’,‘day_of_week’,‘is_weekend’,‘is_holiday’,‘month’,‘hour’]] # here we have 5 vari-
ables for multiple regression. If you just want to use one variable for simple linear regression, then use X =
df[‘Interest_Rate’] for example.Alternatively, you may add additional variables within the brackets
Y = df[‘temperature’]
# with sklearn
regr = linear_model.LinearRegression()
regr.fit(X, Y)
# with statsmodels
X = sm.add_constant(X) # adding a constant
print_model = model.summary()
print(print_model)
The output contains both model and sklearn output (see Table 5 and Figure 27):
Intercept:
53.97404514884691
Coefficients:
[ 0.11713168 0.01120827 1.2402437 -6.95555267 0.17810501 -0.04197969]
Predicted Temperature:
[60.41575833]
coef std err t P>|t| [0.025 0.975]
---------------------------------------------------------------------------------
const 53.9740 0.083 646.981 0.000 53.811 54.138
number_people 0.1171 0.001 92.547 0.000 0.115 0.120
day_of_week 0.0112 0.019 0.587 0.557 –0.026 0.049
is_weekend 1.2402 0.085 14.650 0.000 1.074 1.406
is_holiday –6.9556 0.463 –15.015 0.000 –7.863 –6.048
month 0.1781 0.007 26.171 0.000 0.165 0.191
hour –0.0420 0.004 –10.049 0.000 –0.050 –0.034
=========================================================
Omnibus: 1796.583 Durbin-Watson: 0.025
Prob(Omnibus): 0.000 Jarque-Bera (JB): 3150.086
Skew: 0.248 Prob(JB): 0.00
Kurtosis: 3.984 Cond. No. 786.
=========================================================
244 Building Enterprise IoT Applications
Figure 27:174:sklearn
Figure model
sklearn model output
output
Kalman Filter
The Kalman filter theory has been proved an efficient tool for correcting systematic forecast errors,
combining observations with model forecasts. Applications of the Kalman filter theory for the correction
of surface temperature forecasts are based either only on temperature information where other parameters,
such as relative humidity and surface winds, are used. A complete description of the Kalman filter can
be found in Kalman. For the convenience of the reader, some basic notions of the general Kalman filter
theory are presented in the following paragraphs.
In the Kalman filter, the fundamental concept is the notion of the state. By this is meant, intuitively,
some quantitative information (a set of numbers, a function, etc.) that is the least amount of data one has
to know about the past behavior of the system in order to predict its future behavior. The dynamics are
then described in terms of state transitions, i.e., one must specify how one state is transformed into another
as time passes.
In order to use the Kalman filter to estimate the internal state of a process given only a sequence of
noisy observations, one must model the process in accordance with the framework of the Kalman filter.
This means specifying the following matrices:
• Fk, the state-transition model;
• Hk, the observation model;
• Qk, the covariance of the process noise;
• Rk, the covariance of the observation noise; and
• Sometimes Bk, the control-input model, for each time-step, k, as described below
The Kalman filter model assumes the true state at time k is evolved from the state at (k − 1) according to
x k = Fkxk–1 + Bkuk + wk
where
• Fk is the state transition model which is applied to the previous state xk−1;
• Bk is the control-input model which is applied to the control vector uk;
• wk is the process noise which is assumed to be drawn from a zero mean
Edge Analytics 245
Time E=represents
where k+1 → Future value (or mean) of the parenthesized expression, x̂ is the state estimate, and
the expectation
x is the true state vector. The term {x̂ – x} is the state estimation error. The diagonal elements of P contain
the variance (the square of the standard deviation) of the state estimation error. The off-diagonal terms
represent the correlation between the errors of the state vector elements.
The integrator stands for n integrators such that the output of each is a state variable; F(t) indicates
how the outputs of the integrators are fed back to the inputs of the integrators. Thus fij(t) is the coefficient
with which the
output of
the jth integrator is fed back to the input of the ith integrator. It is not hard to
relate this formalism to more conventional methods of linear system analysis (see Figure 29).
Where
• u(t) is an m-vector (m ≤ n) representing the inputs to the system
The is
Kalman filter Kalman filter
a recursive dataforms an optimal
processing algorithmstate estimatethe
that generates forbest
a state-space
measurement plant
based model
on in the
all previous measurements. It basically consists of two methods, prediction and correction. Thus, it is
good fit to predict anomaly behavior in the system at the edge level. Another use of the Kalman filter is
presence of process and measurement noise. The optimality criterion for the steady-state
Kalman filter is the minimization of the steady-state error covariance matrix P shown
–20.
–40.
246
–60. Building Enterprise IoT Applications
F(t)
0.3
Kalman filtering is useful for analyzing real-time inputs about a system that can exist in certain states.
Typically,
0.2 there is an underlying model of how the various components of the system interact with and
affect each other. A Kalman filter processes the various inputs, attempts to identify the errors in the input,
and predicts the current state. For example, a Kalman filter in our Smart Cities Ambiance Maintenance
System
0.1 can process various inputs, such as number of people, day of the week, month, hour and location,
and update the estimate of the room temperature.
In 0.0
our system, the model is:
temperature
0 = 0.3019 * number_people
10 + 5.7507
20 * day_of_week
30 - 11.4933 * is_weekend
40 + 32.467450*
Aeration
is_holiday + 2.9673 * month + 0.7805 * hour
Please note: day_of_week, is_weekend, is_holiday and month parameters are computed by
tapping into onboard embedded real-time clock. Since, these values are critical to the embedded
system, we have not modeled filtering for these parameters as part of the Kalman Filter design.
The use of Kalman filters is motivated by: (a) their support for streaming analysis using only current input
measurements (therefore making the solution more memory efficient), (b) they do not require matrix cal-
culations (therefore, the solution is more computationally efficient), (c) the ease of the algorithm tuning
process, and (d) their implementation simplicity.
The number of people can be retrieved either interfacing with Venue system or by adding data from
strip sensor.
During the initialization process the parameters which need tuning are the process noise covariance
q, the sensor measurement noise covariance r, the initial estimated error covariance p and an initial
measurement x.6
6
Filters - http://commons.apache.org/proper/commons-math/userguide/filter.html
Edge Analytics 247
7
Si7020 – A 10 http://www.mouser.com/ds/2/368/Si7020-272416.pdf
80.
xhat[0]
40. = 0.0
P[0] = 1.0
for k in range(1,n_iter):
#
20. time update
xhatminus[k] = xhat[k-1]
Pminus[k] = P[k-1]+Q
F211
#
0. measurement update
0 10000 20000 30000 40000 50000 60000 10000
K[k] = Pminus[k]/( Pminus[k]+R )
xhat[k] = xhatminus[k]+K[k]*(z[k]-xhatminus[k])
P[k]
–20. = (1-K[k])*Pminus[k]
plt.figure()
plt.plot(z,‘k+’,label=‘noisy measurements’)
plt.plot(xhat,‘b-’,label=‘a
–40. posteri estimate’)
plt.axhline(x,color=‘g’,label=‘truth value’)
plt.legend()
plt.title(‘Estimate
–60. vs. iteration step’, fontweight=‘bold’)
plt.xlabel(‘Iteration’)
plt.ylabel(‘Temperature’)
plt.figure()
valid_iter
u(t) = range(1,n_iter) # Pminus x(t)
not valid at step 0 x(t) y(t) F216
D(t) S
plt.plot(valid_iter,Pminus[valid_iter],label=‘a priori error estimate’) M(t)
plt.title(‘Estimated $\it{\mathbf{a \ priori}}$ error vs. iteration step’, fontweight=’bold’)
plt.xlabel(‘Iteration’)
plt.ylabel(‘$(Temperature)^2$’)
plt.setp(plt.gca(),‘ylim’,[0,.01])
plt.show()
F(t)
The goal of the Kalman filter is to predict the deviations in the actual temperature vs. predicted values
(see Figure 30).
Noisy measurement
A posteri estimate
0.5 Truth value
F217
0.4
Temperature
0.3
0.2
0.1
0.0
0 10 20 30 40 50
Aeration
Figure 30: Predicted Values
Edge Analytics 249
K-Means Clustering
K-means clustering8 is a type of unsupervised learning, which is used when you have unlabeled data (i.e.,
data without defined categories or groups). The goal of this algorithm is to find groups in the data, with
the number of groups represented by the variable K. The algorithm works iteratively to assign each data
point to one of K groups based on the features that are provided. Data points are clustered based on feature
similarity. The results of the K-means clustering algorithm are [7]:
• The centroids of the K clusters, which can be used to label new data
• Labels for the training data (each data point is assigned to a single cluster)
Rather than defining groups before looking at the data, clustering allows you to find and analyze
the groups that have formed organically. The “Choosing K” section below describes how the number of
groups can be determined.
Each centroid of a cluster is a collection of feature values which define the resulting groups. Examining
the centroid feature weights can be used to qualitatively interpret what kind of group each cluster represents.
This introduction to the K-means clustering algorithm covers:
• Common business cases where K-means is used
• The steps involved in running the algorithm
The K-means clustering algorithm is used to find groups which have not been explicitly labeled in
the data. This can be used to confirm business assumptions about what types of groups exist or to identify
unknown groups in complex data sets. Once the algorithm has been run and the groups are defined, any
new data can be easily assigned to the correct group (see Figure 31).
K: Value is passed
in to KMeans No
algorithm
This is a versatile algorithm that can be used for any type of grouping. Some examples of Case Study
are:
8
• Behavioral segmentation:
o Segment by purchase history
F221
6
o Segment by activities on application, website, or platform
o Define personas based on interests
4
o Create profiles based on activity monitoring
8
K Means Clustering - https://www.datascience.com/blog/k-means-clustering
0
0 2 4 6 8 10
10
6
250 Building Enterprise IoT Applications
Case Study: Sensor Signal and Data Interference & Machine Learning
In Cluster Sensor Deployments, for instance, the distance between Sensors and Signal Strengths, the edge
device has to make the decision by taking the most appropriate cluster of sensors with high accuracy (see
Figure 32). For example, in the below figure Dairy Cow necklaces are tied and the edge device, mobile,
could get the data from all the sensors. To connect to appropriate Cow necklace, the K-means clustering
is used:
K Means Example
As a simple illustration of a k-means algorithm, consider the following data set consisting of the signal
strength (Received Signal Strength Indicator) and Distance from seven sensors:
parameters: Let the RSSI and distance parameters values of the two sensors furthest apart (using the
Euclidean distance measure), define the initial cluster means, giving:
cluster’s mean (which is not the case with Sensor 3). Thus, Sensor 3 is relocated to Cluster 2, resulting
in the new partition:
Dataset
10
F221
6
0
0 2 4 6 8 10
Figure 33: K-means
10
F222
convert to a
pandas dataframe
passed Decision check
to algorithm
1. No change to clusters
F
2. The distance are minimized
3. Max number of iterations reaches
Edge Analytics 253
4. Clusters created equal K
F221
6plt.plot(x1[i], x2[i], color=colors[l], marker=markers[l],ls=‘None’)
plt.xlim([0, 10])
plt.ylim([0, 10])
plt.show()
4
10
4
F222
2
0
0 2 4 6 8 10
Figure 34: K=2 Clustering
K=3
Cluster
10 1(Triangles), Cluster 2(Circles) and Cluster 3 (Triangles) (see K=3 Cluster)
4 F223
2
0
0 2 4 6 8 10
2
0
0 2 4 6 8 10
10
4 F223
2
0
0 2 4 6 8 10
Figure 35: K=3 Cluster
K=4
Cluster 1(Triangles), Cluster 2(Circles), Cluster 3 (Squares) and Cluster 4 (see figure K=4 cluster) (Plus
Sign)
10
6
F224
4
0
0 2 4 6 8 10
Figure 36: K = 4 Cluster
Error (CMD_AI)
N Z P
F225
Z NDISP NC DISP
a2
a1 52
Edge Analytics 255
knowhow of the system. For building an intelligent dispenser model, we have modeled a Venue scent
diffusion system using predefined rules governing the behavior of venue activity and developed activity
indicator. Hence, Fuzzy Logic is the most appropriate ML model.
Linguistic Variables
Fuzzy or Linguistic variables are central to FL and were introduced by Professor Lotfi Zadeh in 1973.
Succinctly put, Linguistic variables are language artifacts not numbers.
The control inputs, namely hardware sensors, in intelligent dispenser model are Fuzzy variables.
For instance, “BLE Devices”, “Noise Level”, “Proximity Indicator—received signal strength indicator
(RSSI) Strength”, “Microphone” and “Passive Infra Red (PIR) Sensor” are modeled as Fuzzy parameters.
Table 57: Fuzzy
In addition, the error values of Fuzzy parameters couldVariables
be modeled as Fuzzy Variable.
Another salient principle of FL is=fuzzy
“N” variables
Negative (seeorTable
Error 7) which are themselves adjectives that
error-dot
modify the variable (e.g., “large positive” error,
level “small positive” error “zero” error, “small negative” error,
and “large negative” error). As“Z”a minimum,
= Zeroone could
Error simply have
or error-dot “positive”, “zero”, and “negative”
level
variables for each of the parameters.
“P” = Positive Error or error-dot large burst of devices” and “very
Additional ranges such as “very
small noise thresholds” are added to handle the BURST response or very nonlinear behavior.
level
“D” = “Dispense” Output response
“-“ = Table 7: Fuzzy Variables
“No Change” or Current
“N” Output
= Negative Error or error-dot level
“ND” = No Dispense
“Z” = Zero Error or error-dot level
“P” = Positive Error or error-dot level
“D” = “Dispense” Output response
“-“ = “No Change” or Current Output
“ND” = No Dispense
The goal of the control process is to model/control dispense of Scent through the FL by
Control
detecting Process
people activity in a venue (as Figure 184): Number of people in a room (number of
The
BLEgoal of the control
devices), Motionprocess
Sensoris detection
to model/control dispense
and Noise of Scent
detected through
on the the FL by detecting people
microphones
activity in a venue (as Figure 37): Number of people in a room (number of BLE devices), Motion Sensor
detection and Noise detected on the microphones
ǣ
Definitions
INPUT# 1 System Status
- Error = Command-Feedback (Activity Indicator Eq. 2)
- P = Increased Activity Index (Increase of venue occupancy or Noise or Motion thresholds)
- Z = Muted or no Activity
- N = Decreased Activity Index (Decrease of venue occupancy or Noise or Motion thresholds)
INPUT# 2 System Status Error-dot = d (Error)/dt
- P = Getting Increased Activity Index
- Z = Not changing
- N = getting decreased activity index
OUTPUT Conclusion and System Response
Output:
- DISP = Dispense Scent
- = don’t change
- NDISP = No Dispense
Matrix Rules
The fuzzy parameters of error (# BLE Devices with RSSI, PIR Sensor threshold and Microphone Noise
Levels) and error-dot (rate-of-change-of-error) were modified by the adjectives “negative”, “zero”, and
“positive” (Table 8).
In the Figure 37, the linguistic parameter “BLE Devices” indicates number of devices within a venue
(negative value indicates people leaving the proximity of the iDispenser & positive implies entering into
proximity of the iDispenser).
Matrix
The fuzzy parameters of error (Activity Indicator) and error-dot (rate-of-change-of-activity_Indicator)
were modified by the adjectives “negative”, “zero”, and “positive”. The following diagram provides a
3-by-3 matrix (Figure 38) input and output outcomes. The columns represent “negative error”, “zero error”,
and “positive error” inputs from left to right. Please note: “DISP” results into dispensing of the scent.
NDISP—no Dispensing required and NC implies no Change to the condition (see Figure 38)
The membership function is a graphical representation of the magnitude of participation of each control
input (#BLE Devices, Microphone Thresholds and PIR Sensor Thresholds). It associates a weighting with
# BLE Devices, Microphone and PIR Thresholds inputs, defines functional overlap between inputs (BLE
4
258 Building
0 Enterprise IoT Applications
0 2 4 6 8 10
Error (CMD_AI)
N Z P
F225
Z NDISP NC DISP
Agent
Model-free
Figure 39: Reinforcement Learning
Figure 186: Reinforcement Learning
in a closed venue, and the reward is performance improvement after applying the action. The
maximize the reward, dispense scent or not. Generally, RL approaches learn estimates of the
P NDISP NDISP DISP
4
2
a2
a1 52
0
0 2 4 6 8 10 51
aS
53 a4
Error (CMD_AI)
54
Edge Analytics 259
N Z P Establish
Calibrate a3
a1 52
a2
Value unction
F228
51
aS
a4 Establish
53
54 Calibrate
Establish
Calibrate a3
Agent
Agent State reward Action
St Rt A1 Policy
State reward Action
Policy Rt +1 Determine
St Rt A1
Rt +1 Determine
St +1 Environment
St +1 Environment
Model-free
Model-based
Value unction
Figure 40: Reinforcement Learning F228
On-policy
Calibrate
and Off-policy Establish
An on-policy agent, our current dispenser in case, learns the value based on an action derived from the
Agent
current policy, an off-policy
State reward
agent learns based on the action a* obtained from another policy (a greedy
Action
policy
St R in the case of Q-learning).
t
R
A Policy
1
t +1 Determine
St +1 Environment
Neural Networks
Model-free
Deep learning is a specific subfield of machine learning: A new take on learning representations from data
that puts an emphasis on learning successive layers of increasingly meaningful representations. The “deep”
in deep learning isn’t a reference to any kind of deeper understanding achieved by the approach; rather,
it stands for this idea of successive layers of representations. How many layers contribute to a model of
the data is called the depth of the model. Other appropriate names for the field could have been layered
representations learning and hierarchical representations learning. Modern deep learning often involves
tens or even hundreds of successive layers of representations—and they’re all learned automatically from
exposure to training data. Meanwhile, other approaches to machine learning tend to focus on learning
only one or two layers of representations of the data; hence, they’re sometimes called shallow learning.
The specification of what a layer does to its input data is stored in the layer’s weights, which are
essentially a bunch of numbers. In technical terms, we’d say that the transformation implemented by a
layer is parameterized by its weights. (Weights are also sometimes called the parameters of a layer.) In
this context, learning means finding a set of values for the weights of all the layers in a network, such that
the network will correctly map example inputs to their associated targets (see Figure 41).
The loss function takes the predictions of the network and the true target (what you wanted the network
to output) and computes a distance score, capturing how well the network has done on this specific example.
The fundamental trick in deep learning is to use this score as a feedback signal to adjust the value of
the weights a little, in a direction that will lower the loss score for the current example. This adjustment
is the job of the optimizer, which implements what’s called the Backpropagation algorithm: The central
algorithm in deep learning (see Figure 42).
260 Building Enterprise IoT Applications
Input X
Layer 5000
Weights (data transformation
Goal: finding
right values for
these weights
Layer
Weights (data transformation 4000
F229
Pitch in nels
Predictions Y’
Input
Layer
Weights 2000
(data transformation)
Layer
Weights
(data transformation)
Accuracy 1000
60% ????????
Weights
50%update Predictions Y’ True targets Y’ Fr
40%
20% F233
10% Loss score
F230
0 50000 100000 150000 200000 250000
Voice Detection (Neural Networks)
To perform audio classification, we need to extract the most appropriate and informative acoustic parameters.
Parameters
Traditionally, pitch, jitter and shimmer have been used for this purpose. In recent–years,
Accuracy
the Mel– Frequency
ROC
Cepstral Coefficient
120% (MFCC) has gained popularity as a successful parameter for audio classification. We
are using MFCC to classify between healthy and pathological patient audio.
100%
80%
60%
40%
20%
Edge Analytics 261
We initially started with Machine Learning models like the Random Forest classifier and the XGBoost
classifier. The model performance was moderate, and the accuracy was around 50% to 60%.
The first one is a plain, fully connected neural network. This architecture is equivalent to stacking
multiple perceptron (neurons) and averaging their predictions.
The second architecture is a Convolution Neural Network (CNN). Initially CNNs gained popularity
for their state of the art performance on image dataset. In the recent years, research has shown that CNN
performs well in Text and audio classification as well.
The third architecture is that of an Recurrent Neural Network (RNN). RNN is a neural network with
memory that leverages sequential information and has been used in Natural Language Processing (NLP).
It assumes the inputs are dependent on each other. Hence, RNN has produces state of art results for NLP
tasks, such as predicting the next word in a sentence. Audio data, unlike image data, is time dependent
and, hence, research shows RNN is more relevant for audio classification too.
Data Samples
The Voice samples were obtained from a voice clinic in a tertiary teaching hospital (Far Eastern Memorial
Hospital, FEMH), these included 50 normal voice samples and 150 samples of common voice disorders,
including vocal nodules, polyps, and cysts (collectively referred to as Phono trauma); glottis neoplasm;
unilateral vocal paralysis. Voice samples of a 3-second sustained vowel sound /a:/ were recorded at a
comfortable level of loudness, with a microphone-to-mouth distance of approximately 15–20 cm, using
a high-quality microphone (Model: SM58, SHURE, IL), with a digital amplifier (Model: X2u, SHURE)
under a background noise level between 40 and 45 dBA. The sampling rate was 44,100 Hz with a 16-bit
resolution, and data were saved in an uncompressed .wav format (see Figure 43).
Table 9: Melspectrogram
The above code (see Table 9) loads “002.wav” file and generates Mel spectrogram, Figure 44, by
calling Librosa function.
MFCC
The mel-frequency cepstrum (MFC) [14] is the representation of short-term power spectrum of a sound
that is derived from a linear cosine transform of a log power spectrum on a nonlinear of a mel scale of
frequency. Please note mel scale is a scale of pitches with reference point set to 1000 Hz tone, 40 dB above
listener’s threshold, Figure 44, with a pitch of 1000 mels [15].
The MFCC is derived in the following order [16]:
Signal Pre-emphasis Hamming Window Fast Fourier Transform Log cosine Mel-
frequency Cepstral coefficients MFCC
We have considered Mel-Scale Spectrogram and MFCC as our audio features for our Neural network.
Mel-Scale’s goal is to represent the non-linear perception of sound by human. It is more discriminative
in lower frequencies and less discriminative in higher frequencies. The Spectrogram as a result is highly
correlated. When Discrete Cosine Transform (DCT) is applied on the Mel scaled features, we get the
compressed representation of the Spectrogram by retaining the most prominent features (top 40 in our
case) which are decorrelated [17]. Mel-Scale Spectrogram gives the entire information and bigger picture
of the audio composition and MFCC highlights the top features to focus on.
Input X
Layer 5000
Weights (data transformation
oal: finding
ght values for
ese weights
Layer
Weights (data transformation 4000
F229
Pitch in nels
Predictions Y’
3000
2000
Accuracy 1000
100 200 500 1000 2000 5000 10000
????????????????????????????????????????
Frequency in Hz (Logarithmic scale)
Figure 44: MFCC
F232
Data Wrangling F233
We are wrangling our audio data into a 60×41×2 array. Here 60 is the number of MFCC, 41 is the number
of windows over the audio signal and 2 is the number of channels. In order to have fixed size input for
0 50000 100000 our varying
150000 size audio
200000files, we perform windowing over the audio.
250000
In our case, we can feed in a different feature for each channel. In our first channel, we feed in the
MFCCs and in the second channel, we feed in the delta features (local estimate of the derivative of MFCC)
Parameters – Accuracy – ROC
120% [12]. Now the CNN can learn from not only MFCC but also their deltas. Librosa has been used to extract
100%
the MFCC and delta features. Keras has been used to implement the 5-layer CNN [18,19]. Apart from
80%
60%
40%
20%
0%
F235
Convolution Convolution 2×2 Convolution SGD Tanh Tanh
filter size 1×1 filter size 1×1 filter size Learning momentum Adam for all for 1st
rate = 0.01 = 0.9 optimizer layers layers and
rule for rest
Edge Analytics 263
feeding only MFCC, we have also trained the neural network with both Mel-Scale Spectrogram and
MFCC features. Another method employed to improve the accuracy is using the Mel-Scale Spectrogram
and MFCC features as input to separate Neural networks and bagging of the multiple Neural networks,
by taking a majority voting based on the class probability.
Metrics
We have used Accuracy score and ROC (Receiver Operating Characteristic) metric to evaluate our classifier.
In healthcare applications, sensitivity is given higher importance. It defines the percentage of people the
model can correctly predict as unhealthy. Hence, we have also used sensitivity and specificity as our metric.
Architecture
We studied and applied various Deep learning architectures: 5-layer network, 5-layer CNN and RNN.
A. Neural Network with a 5-layer architecture
We started with a plain Neural Network with a 5-layer architecture [20]. The tuning of the hyper parameters
of the model improved the accuracy by 10%. Each parameter value was tuned with the following values.
• regularization_rate = 0.1, 0.01, 0.001
• activation = ‘tanh’, ‘relu’
• Number of hidden nodes = 64, 40, 100
The values that gave stable and good performance where
• regularization_rate = 0.001
• activation = ‘tanh’
• Number of hidden nodes = 64
The following Table 10 and Figure 45 displays the accuracies for various epoch values.
Accuracy 1000
60% ?????????????????????
50% Frequency in Hz
40%
30%
20% F233
10%
0%
0 50000 100000 150000 200000 250000
Figure 45: Accuracy
bps
10m 100m 1Km 10Km
Weights (data transformation 4000
F229
Pitch in nels
Predictions Y’
3000
Edge Analytics 265
2000
Accuracy 1000
60% ????????????????????????????????????????
50% Frequency in Hz (Logarithmic scale)
40%
30% F232
20% F233
10%
0%
0 50000 100000 150000 200000 250000
Figure 46: Neural Network Architecture
100%
80%
60%
40%
A larger convolution
20%
filter size gives a larger receptive window over the audio pattern. A
0%
Loss Functions
A loss function is an important part of artificial neural networks, which is used to measure the inconsistency
between predicted value and actual label. It is a non-negative value, where the robustness of the model
increases along with the decrease of the value of the loss function. The loss function is the core of an
empirical risk function as well as a significant component of a structural risk function.
Leaky ReLU
Leaky ReLU is used to solve the dying ReLU problem. The leaky ReLU function is nothing but an improved
version of the ReLU function. The leak helps to increase the range of the ReLU function. Usually, the value
is 0.01 or so. When it is not 0.01, then it is called Randomized ReLU. Therefore, the range of the Leaky
ReLU is (-infinity to infinity). Leaky ReLU functions are monotonic in nature. Also, their derivatives also
monotonic in nature.
For the ReLU function, the gradient is 0 for x < 0; this made the neurons die for activations in that
region. Leaky ReLU is defined to address this problem. Instead of defining the ReLU function as 0 for x
less than 0, we define it as a small linear component of x. The main advantage of this is to remove the zero
gradient. So, in this case, the gradient of the negative values is non-zero and so we no longer encounter
dead neurons in that region. Also, this speeds up the training process of the neural network.
However, in the case of a parameterized ReLU function, y = ax, when x < 0. The network learns the
parameter value of ‘a’ for faster and more optimum convergence. The parametrized ReLU function is used
when the leaky ReLU function still fails to solve the problem of dead neurons and the relevant information
is not successfully passed to the next layer.
We have observed from our work that Neural Networks perform better than simpler Machine Learning
Algorithms for audio classification (please see Table 11). CNN consistently performs better than RNN, if
the necessary sequential information is provided. Loss functions, like LeakyRelu and Prelu, have resulted
Edge Analytics 267
in a noticeable improvement in sensitivity and specificity of the model, which are more important than the
accuracy of the model. The best model was a 5-layer CNN trained with MFCC and Mel-Spectrogram. It
had a sensitivity of 96% & specificity of 18% on the test data.
import numpy as np
import pandas as pd
import os
from keras.models import Sequential
from keras.layers import Dense, Dropout, Activation, Flatten
from keras.layers import Convolution2D, MaxPooling2D
from keras.optimizers import SGD
from keras.regularizers import l2
from keras.utils import np_utils
from sklearn.model_selection import train_test_split
from sklearn import metrics
import librosa, glob
from sklearn.preprocessing import LabelEncoder
’’’Data Wrangling for the 5-layer CNN model
Source: http://aqibsaeed.github.io/2016-09-24-urban-sound-classification-part-2/
Environmental sound classification with convolutional neural networks by Karol J. Piczak
’’’
X = []
y = []
def windows(data, window_size):
’’’To generate the window range’’’
start = 0
while start < len(data):
yield int(start), int(start + window_size)
start += (window_size/2)
def extract_features(parent_dir,sub_dirs,file_ext=”*.wav”,bands = 60, frames = 41):
’’’Wrangle audio data into 60x41x2 frames.
Bands = 60 = number of MFCC
frames = 41 = number of windows from the audio signal
Number of channels (like R,G,B channels in images) = 2 = mel-spectrograms and their corresponding
delta’’’
window_size = 512 * (frames - 1)
log_specgrams = []
labels = []
for l, sub_dir in enumerate(sub_dirs):
for fn in glob.glob(os.path.join(parent_dir, sub_dir, file_ext)):
sound_clip,s = librosa.load(fn)
label = l
for (start,end) in windows(sound_clip,window_size):
# print(type(start), start, type(end), end, window_size)
if(len(sound_clip[start:end]) == window_size):
signal = sound_clip[start:end] # window the original audio
melspec = librosa.feature.melspectrogram(signal, n_mels = bands)
# librosa.core.logamplitude has been removed in v0.6
# logspec = librosa.logamplitude(melspec)
...Table 12 contd.
logspec = librosa.amplitude_to_db(melspec)
logspec = logspec.T.flatten()[:, np.newaxis].T
log_specgrams.append(logspec)
labels.append(label)
log_specgrams = np.asarray(log_specgrams).reshape(len(log_specgrams),bands,frames,1) features =
np.concatenate((log_specgrams, np.zeros(np.shape(log_specgrams))), axis = 3)
for i in range(len(features)):
features[i, :, :, 1] = librosa.feature.delta(features[i, :, :, 0])
return np.array(features), np.array(labels,dtype = np.int)
train_data_path = ‘C:\\Hanumayamma\\FEMH\FEMH Data\\Training Dataset Small\\’
test_data_path = ‘C:\\Hanumayamma\\FEMH\\FEMH Data\\Testing Dataset Small\\’
train_csv = train_data_path + ‘Demographics for Training Dataset.xlsx’
label_dict = {0 : ‘Normal/’, 1 : ‘Pathological/Neoplasm/’, 2 : ‘Pathological/Phonotrauma/’, 3 : ‘Pathological/
Vocal palsy/’}
X, y = extract_features(train_data_path,label_dict.values(), file_ext=“*.wav”,bands = 60, frames = 41)
‘’’Encode class labels - y’’’
temp = np.array(y)
encoder = LabelEncoder()
Y = np_utils.to_categorical(encoder.fit_transform(temp.astype(str)))
X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.33)
‘’’
5-layer CNN implementation
Source: 5 layer CNN described in https://arxiv.org/pdf/1608.04363.pdf
‘’’
filter_size = 3
bands = 60
frames= 41
num_channels = 2
num_labels = y_test.shape[1]
model = Sequential()
# Layer 1 - Convolution with 24 filters + Maxpooling
model.add(Convolution2D(24, (filter_size, filter_size), border_mode=’valid’, input_shape=(bands, frames,
num_channels)))
model.add(MaxPooling2D(pool_size=(4, 2)))
model.add(Activation(‘relu’))
# Layer 2 - Convolution with 48 filters + Maxpooling
model.add(Convolution2D(48, (filter_size, filter_size)))
model.add(MaxPooling2D(pool_size=(4, 2)))
model.add(Activation(‘relu’))
# Layer 3 - Convolution with 24 filters + Maxpooling
model.add(Convolution2D(48, (filter_size, filter_size), border_mode=’valid’))
model.add(Activation(‘relu’))
# Flatten the tensors to feed into fully connected layers that follow
model.add(Flatten())
# Layer 4 - fully connected layer
model.add(Dense(64, W_regularizer = l2(0.001)))
model.add(Activation(‘relu’))
model.add(Dropout(0.5))
Table 12 contd. ...
Edge Analytics 269
...Table 12 contd.
CNN Spectrogram
Please
find complete
CNN Spectrogram code (see Table 13 and Figure 49).
Please find complete CNN Spectrogram code (see Table 63 and Figure 196)
import numpy as np
import pandas as pd
from keras.models import Sequential
from keras.layers import Dense, Dropout, Activation, Flatten, LeakyReLU
from keras.layers import Convolution2D, MaxPooling2D
from keras.optimizers import SGD,Adam
from keras.regularizers import l2
from keras.utils import np_utils
from sklearn.model_selection import train_test_split
from sklearn import metrics
import librosa, glob, os
from sklearn.preprocessing import LabelEncoder
from sklearn.metrics import confusion_matrix
import pickle
’’’Data Wrangling for the 5-layer CNN model
Source: http://aqibsaeed.github.io/2016-09-24-urban-sound-classification-part-2/
Environmental sound classification with convolutional neural networks by Karol J. Piczak
’’’
X = []
y = []
def windows(data, window_size):
’’’To generate the window range’’’
start = 0
while start < len(data):
yield int(start), int(start + window_size)
start += (window_size / 2)
def extract_features(parent_dir,sub_dirs,file_ext=”*.wav”,bands = 60, frames = 41):
...Table 13 contd.
log_specgrams = np.asarray(log_specgrams).reshape(len(log_specgrams),bands,frames,1)
#features = np.concatenate((log_specgrams, np.zeros(np.shape(log_specgrams))), axis = 3)
#for i in range(len(features)):
# features[i, :, :, 1] = librosa.feature.delta(features[i, :, :, 0])
...Table 13 contd.
...Table 13 contd.
9
Newark Police department - http://www.newark.org/departments/police/administrative-divisions/red-light-enforcement
Edge Analytics 275
Figure
Figure 51:
198:Dynamic
DynamicPricing
Pricing
After reading this chapter, you should be able to design, implement, and deploy the following
Edge and
Machine Cloud compute
Learning haveinto
Algorithms changed
smallthe industry for
embedded good,and
devices bothmobile
for the platforms.
hotel management
• and
Decision
loyal Trees
patrons. The dynamic pricing (see Figure 198) is performed edge and cloud
• Kalman Filter
• handshake;
K-means clustering
Many hotels or entertainment places have on-site IT systems that take care of
• Sliding Window
• customer check-in through the Hotel Management Software (HMS) Systems. By the by, the
Clustering
• Neural Network for Sound Classification
• Fuzzy Logic and Re-enforcement Learning
107Newark Police department -
http://www.newark.org/departments/police/administrative-divisions/red-light-
10
Apache NiFi - https://nifi.apache.org/index.html
enforcement
276 Building Enterprise IoT Applications
References
1. Gartner. Gartner Says the Internet of Things Installed Base Will Grow to 26 Billion Units By 2020. December 12,
2013, https://www.gartner.com/newsroom/id/2636073, Access Date: 14 December 2018
2. Veron Turner. Data Growth, Business Opportunities, and the IT Imperatives. April 2014, https://www.emc.com/
leadership/digital-universe/2014iview/index.htm, Access Date: June 2018
3. James Manyika, Michael Chui, Peter Bisson, Jonathan Woetzel, Richard Dobbs, Jacques Bughin and Dan Aharon.
Unlocking the potential of the internet of things. June 2015, https://www.mckinsey.com/business-functions/digital-
mckinsey/our-insights/the-internet-of-things-the-value-of-digitizing-the-physical-world, Access Date: December 2018
4. The Apache Software Foundation, Filters. 28 Aug 2016, http://commons.apache.org/proper/commons-math/userguide/
filter.html, Access Date: June 2018
5. The Silicon Laboratiroes. Si7020-A10. 2018, http://www.mouser.com/ds/2/368/Si7020-272416.pdf, Access Date: June
2018
6. Neil Tan. Why Machine Learning On the Edge? 2018, https://towardsdatascience.com/why-machine-learning-on-the-
edge-92fac32105e6, Access Date: December 2018
7. Andrea Trevine. Introduction to K-meand Clustering, 6 December 2016, https://www.datascience.com/blog/k-means-
clustering, Access Date: June 2018
8. Newark Police Department. Red Light Enforcement, 2018, http://www.newark.org/departments/police/administrative-
divisions/red-light-enforcement, Access Date, 7 December 2018
9. The Apache Software Foundation. NiFi. 2018, https://nifi.apache.org/index.html, Access Date 12 Dec 2018
10. Nick Rose. Crowdedness at the Campus Gym. 2016, https://www.kaggle.com/nsrose7224/crowdedness-at-the-campus-
gym, Access Date, 7 December 2018
11. Data Market. Daily total female births in California, 1959, 1988, https://datamarket.com/data/set/235k/daily-total-
female-births-in-california-1959#!ds=235k&display=line, Access Date: 05 Dec 2018
12. Environmental sound classification with convolutional neural networks by Karol J. Piczak, 2015 IEEE INTERNATIONAL
WORKSHOP ON MACHINE LEARNING FOR SIGNAL PROCESSING, SEPT. 17–20, 2015, BOSTON, USA
13. Mitrovic, D., Zeppelzauer, M. and Breiteneder, C. Discrimination and retrieval of animal sounds. 2006 12th International
Multi-Media Modelling Conference, Beijing, 2006, pp. 5, doi: 10.1109 / MMMC.2006.1651344 , URL: http://ieeexplore.
ieee.org/stamp/stamp.jsp?tp=&arnumber=1651344&isnumber=34625
14. Le-Qing, Z. Insect Sound Recognition Based on MFCC and PNN. 2011 International Conference on Multimedia and
Signal Processing, Guilin, China, 2011, pp. 42–46. doi: 10.1109/CMSP.2011.100, URL: http://ieeexplore.ieee.org/
stamp/stamp.jsp?tp=&arnumber=5957464&isnumber=5957439
15. The mel scale as a function of frequency (from Appleton and Perera, eds., The Development and Practice of Electronic
Music, Prentice-Hall, 1975, p. 56; after Stevens and Davis, Hearing; used by permission
16. Deep Convolutional Neural Networks and Data Augmentation for Environmental Sound Classification Justin Salamon
and Juan Pablo Bello, IEEE SIGNAL PROCESSING LETTERS, ACCEPTED NOVEMBER 2016.
17. Haytham Fayek. Speech Processing for Machine Learning: Filter banks, Mel-Frequency Cepstral Coefficients (MFCCs)
and What’s In-Between. Apr 21, 2016, https://haythamfayek.com/2016/04/21/speech-processing-for-machine-learning.
html , accessed on: 11/11/2018
18. James Lyons. Mel Frequency Cepstral Coefficient (MFCC) tutorial, http://practicalcryptography.com/miscellaneous/
machine-learning/guide-mel-frequency-cepstral-coefficients-mfccs/accessed on: 11/11/2018
19. Jordi Pons, Xavier Serra. Randomly weighted CNNs for (music) audio classification. 14 Feb 2019 https://arxiv.org/
abs/1805.00237, Access Date: Feb 14, 2019
20. Annamaria Mesaros, Toni Heittola, Tuomas Virtanen. A multi-device dataset for urban acoustic scene classification.
Thu, 11 Oct 2018, https://arxiv.org/abs/1807.09840, Access Date: Feb 14, 2019
21. Jongpil Lee, Taejun Kim, Jiyoung Park, Juhan Nam. 4 Dec. 2017. Sound Raw Waveform-based Audio Classification
Using Sample-level CNN Architectures, https://arxiv.org/abs/1712.00866, Access Date: Feb. 14, 2019
[A] David Floyer. The Vital Role of Edge Computing in the Internet of Things. October 20 2015, https://wikibon.com/the-
vital-role-of-edge-computing-in-the-internet-of-things/April 30, 2019
i
https://www.kaggle.com/nsrose7224/crowdedness-at-the-campus-gym
Chapter 9
Connectivity
The focus of the chapter is to provide a foundation for all the architecture used to process the IoT Data.
IoT Data exhibit 5Vs1 (Volume, Velocity, Variability, Veracity, and Value) [1] and to process such high-
density data the architectures should scale to provide actionable insights to Users.
Connectivity plays an important role in future IoT products and Services. Current carrier networks
(3G & 4G) have limited capacities, bandwidth and higher latencies. The 5G network is a game changer
as it brings network slices, low latency, and higher bandwidths.2
Applications built on underlying technologies such as augmented reality, virtual reality, telepresence
and artificial intelligence will benefit from massive data pipes and ultra-low latency. Fixed-wireless services
delivering fiber-like speeds will enable UHD video streaming and entirely new business models for cable
companies and streaming subscription providers [2]. Cars and drones will communicate with each other and
coordinate with things around them through the low-latency network. Industrial automation and robotics
will finally be a reality over wide area network. And finally, 5G will get us closer to realizing the true IoT
world of millions of sensor devices connected to the network.
5G enables deployment and allocation of dedicated “network slices” where, within one coverage area
or functional boundary, different services and solutions could occupy their own slice of the network, with
different speeds, guaranteed quality of service and reporting. For the IoT, this will create new possibilities
1
Why only one of the 5 Vs of big data really matters - https://www.ibmbigdatahub.com/blog/why-only-one-5-vs-big-data-
really-matters
2
How The 5G Revolution Will Drive Future Innovations Of IoT - https://www.forbes.com/sites/forbestechcouncil/2018/09/07/
how-the-5g-revolution-will-drive-future-innovations-of-iot/#4b83e79d637e
278 Building Enterprise IoT Applications
5G Network
Different generations of wireless technology so far are:
• The first generation (1G), cellular networks that was created in the early 1990s.
• The second generation (2G) is when text messages were invented, and everyone was actively
sending them through a wireless network.
• The third generation (3G) made it possible for people to access the internet on their mobile
devices.
• The fourth generation (4G) is an expanded version of the 3G’s abilities, 4G is much faster than
3G in terms of internet speed.
• The fifth generation (5G) is a game changer with greater velocities.
3G 4G 5G
Generation Third generation of mobile Fourth generation of mobile Fifth generation of
broadband internet broadband internet mobile broadband
internet
Download Slower than 4G 10 times faster than 3G Faster than 3G and
Speed 4G
Data transfer 200 kilobits/sec 100 megabits/sec for high 20 Gbits/sec
rate mobile communication & 1
Gigabit/sec for low mobility
communication
Compatibility 3G phone cannot Backward compatible,
communicate through 4G so 4G can communicate
network through 3G and 2G
networks
Carrier 3G Frequencies 4G Frequencies 5G Frequencies
Latency depends on carrier depends on carrier 1 ms
Router Like WIFI router but does not It is directly connected to Qualcomm is 1st
use ethernet cord to connect to router, switch or computer company to launch
internet. It uses 3G signal from to provide instant 4G LTE 5G modem, the
cellular networks to get online network Snapdragon X50
modem
5G network is a game changer because it reduces latency (independent of Carrier) and has increased data
transfer, comparable to edge processors. Using 5G network becomes compute platform (within the embedded
device).
for connected devices across all market sectors. There could be one slice supporting the connected car
services, while another is serving environmental monitoring devices. The latter might only transmit
when certain conditions change, while a connected car services slice, which may be leveraging access
to information from network resources near an interstate highway, might be constantly blasting traffic or
route information to passing cars through new, enhanced network broadcasting modes [2,3].
40%
20%
0%
F235
Convolution Convolution 2×2 Convolution SGD Tanh Tanh
filter size 1×1 filter size 1×1 filter size Learning momentum Adam for all for 1st
rate = 0.01 = 0.9 optimizer layers layers and
rule for rest
Accuracy ROC Connectivity 279
Case Study: Low Power Wide Area (LPWA) and Cellular IoT
Gbps Short
distance Cellular
Zigbee
F239
LPWA
kbps
Bluetooth
LoRa, SigFox, NB-IoT, LTE-M
bps
10m 100m 1Km 10Km
Figure 1: LPWA
Low Power Wide Area (LPWA) (see Figure 1) describes a set of technologies used for places where
only small amounts of data need to be transferred but spread across a wide area. LPWA technologies
can be divided between licensed and unlicensed spectrum: LoRa and SIGFOX work in unlicensed
bands, while cellular IoT, such as NB-IoT and LTE-M, are typically used in the licensed spectrum3 [3].
REST
REST stands for Representational State Transfer (REST) protocol. REST is the major application interface
design used to build many enterprise applications.
Advantages of REST:
• Provides Service Oriented Architecture to call remote services
• Stateless and does not keep previous state history
• REST works on HTTP4 and can be easily transportable
HTTP
The Hypertext Transfer Protocol (HTTP) is a stateless application level request/response protocol that uses
extensible semantics and self-descriptive message payloads for flexible interaction with network-based
hypertext information systems [4].
Client/Server Messaging
The Client initiates the connection to the server over a reliable transport or session-layer “Connection”.
An HTTP “client” is a program that establishes a connection to a server for sending one or more HTTP
requests. An HTTP “server” is a program that accepts connections to service HTTP requests by sending
HTTP responses (see Figure 2).
Intermediaries
HTTP enables the service of intermediaries that route the request from the Client to the Server. The
intermediaries (A, B, and C) (see Figure 3) are between the user agent and origin server. A request or
response message that travels the whole chain will pass through four separate connections. Some HTTP
3
Samsung IoT - https://www.samsung.com/global/business/networks/solutions/iot-solutions/
4
HTTP RFC 7230 - https://datatracker.ietf.org/doc/rfc7230/?include_text=1
The Client initiates the connection to the server over a reliable transport or session -layer
sending one or more HTTP requests. An HTTP "server" is a program that accepts connections
to service
280 Building HTTP requests
Enterprise by sending HTTP responses (see Figure 200).
IoT Applications
Figure
Figure 200:2: Internet
Internet Connectivity
Connectivity
Intermediaries
HTTP enables the service of intermediaries that route the request from the Client to the Server.
The intermediaries (A, B, and C) (see Figure 201 ) are between the user agent and origin server.
A request or response message that travels the whole chain will pass through four separate
Architecture
• Upstream & Downstream: All messages flow from upstream to downstream.
The REST Application interface sits on top of HTTP and can perform operations (PUT, POST, GET,
• Inbound: The requests routed to server
HEAD). Six guiding principles define REST:
1. Client-Server Architecture:
• Outbound: RESTrouted
The requests uses Client
to UserServer
Agentarchitecture
(UA) with resources served by the Server,
and the Client can access the server resources through remote procedure calls. The underlying principle
is separation of concerns. Separating the user interface concerns from the data storage concerns
improves the portability of the user interface across multiple platforms. It also improves scalability
bysimplifying
the server components (see Figure 4).
2. Statelessness: In RESTful interface, there is no state representation between client and server. Like
The REST Application interface sits on top of HTTP and can perform operations
HTTP, the Restful interface maintains stateless nature. All the calls are atomic and does not carry and
state representation.
(PUT, POST, GET, HEAD). Six guiding principles define REST:
3. Cacheability: As on the World Wide Web, clients and intermediaries can cache responses. Responses
must therefore, implicitly or explicitly, define themselves as cacheable or not in order to prevent
clients from getting stale or inappropriate data in response to further requests. A “cache” is a local
store 1. Client-Server
of previous Architecture:
response REST
messages and theuses Client that
subsystem Server architecture
controls with storage,
its message resources
retrieval,
and deletion. A cache stores cacheable response to reduce the response time and network bandwidth
served by the Server, and the Client can access the server resources through remote
procedure calls. The underlying principle is separation of concerns. Separating the user
interface concerns from the data storage concerns improves the portability of the user
interface across multiple platforms. It also improves scalability by simplifying the
5
RFC 7230 HTTP - https://www.rfc-editor.org/rfc/pdfrfc/rfc7230.txt.pdf
6
AJAX - https://courses.cs.washington.edu/courses/cse490h/07sp/readings/ajax_adaptive_path.pdf
282 Building Enterprise IoT Applications
Client
User achtivity User achtivity User achtivity
Data transiction
Data transiction
Data transicti
Data transicti
Time
on
on
System proccessing System proccessing
Browser UI
User activity
Display
Display
Display
Display
Input
Input
Input
Input
Ajax engine
Client-side proccessing
Data transiction
Data transiction
Data transiction
Data transiction
Data transiction
Data transiction
Data transiction
Data transiction
Server-side Server-side Server-side Server-side
proccessing proccessing proccessing proccessing
Server
In Ajax Web Application mode (see Figure 6), the blocking nature of request-response is overcome
by the Ajax Compliant browsers that queues the request at the browser client. The blocking call from the
User is relinquished as soon as the call is queued; once the response is received from the Web Server, the
browser client routes the response to the response handler—java script code [5].
Data trans
Data trans
Data trans
transiction
transiction
transiction
transiction
Server-side Server-side Server-side Server-side
Server
proccessing proccessing proccessing Connectivity
proccessing 283
Browser client
User interface
JavaScript call
Browser client HTML+CSS data
Classic Ajax
web application model web application model
<!DOCTYPE HTML>
<html>
<head>
<title>Example</title>
</head>
<body>
<h3> Ajax example </h3>
<div>
<button>Apples</button>
<button>Cherries</button>
<button>Bananas</button>
</div>
<div id=“target”>
Press a button
</div>
<script>
var buttons = document.getElementsByTagName(“button”);
for (var i = 0; i < buttons.length; i++)
{
buttons[i].onclick = handleButtonPress;
}
function handleButtonPress(e) {
try
{
var httpRequest = new XMLHttpRequest();
httpRequest.onreadystatechange = handleResponse;
var reqInnerHTML=e.target.innerHTML + “.html”;
alert(‘request --’ + reqInnerHTML)
httpRequest.open(“GET”, reqInnerHTML);
httpRequest.send();
} catch (err)
{
alert(err);
}
}
284 Building Enterprise IoT Applications
function handleResponse(e) {
if (e.target.readyState == XMLHttpRequest.DONE && e.target.status ==
200) {
alert(e.target.responseText);
document.getElementById(“target”).innerHTML = e.target.responseText;
}
}
</script>
</body>
</html>
The workings of Ajax to call Rest interface is in the code handle button press:
• Step 1: construct Ajax Object
• Step 2: set handler for onreadystatechange
• Step 3: Open request
• Step 4: Send HTTP request
Upon the successful completion of request by the server, the onready state change call back will be
invoked. As soon as the script calls the send method, the browser makes the background request to the
server. Because the request is handled in the background, Ajax relies on events to notify you about how
the request progresses. In this example, these events are handled with the handleResponse function:
function handleResponse(e) {
if (e.target.readyState == XMLHttpRequest.DONE &&
e.target. status == 200) { alert(e.target. responseText);
document.getElementById(“target”).innerHTML =
e.target.responseText;
}
}
When the readystatechange event is triggered, the browser passes an Event object to the specified
handler function. Several different stages are signaled through the readystatechange event, and you can
determine which one you are dealing with by reading the value of the XMLHttpRequest.readyState property.
All the above code does is update innerHTML on target DIV upon completion of request.
Output: The output of the HTML page is Web with Ajax callable functions (see Figure 7).
XMLHttpRequest readyState
As soon as the script calls the send method, the browser makes the background
Ajax Events
Most of these events are triggered at a point in the request. The exceptions are readystatechange and
progress, which can be triggered several times in order to give progress updates.
<!DOCTYPE HTML>
<html>
<head>
<title>Example</title>
<style>
#allheaders, #ctheader {
border: medium solid black;
padding: 2px; margin: 2px;
}
</style>
</head>
<body>
<h3> Ajax example </h3>
<div>
<button>Apples</button>
Table 1 contd. ...
286 Building Enterprise IoT Applications
...Table 1 contd.
<button>Cherries</button>
<button>Bananas</button>
</div>
<div id=”ctheader”></div>
<div id=”allheaders”></div>
<div id=”target”>
Press a button
</div>
<script>
var buttons = document.getElementsByTagName(“button”);
for (var i = 0; i < buttons.length; i++)
{
buttons[i].onclick = handleButtonPress;
}
var httpRequest;
function handleButtonPress(e) {
try
{
httpRequest = new XMLHttpRequest();
httpRequest.onreadystatechange = handleResponse;
var reqInnerHTML=e.target.innerHTML + “.html”;
httpRequest.open(“GET”, reqInnerHTML);
httpRequest.send();
} catch (err)
{
alert(err);
}
}
function handleResponse() {
if (httpRequest.readyState == 2) {
document.getElementById(“allheaders”).innerHTML = httpRequest.
getAllResponseHeaders();
document.getElementById(“ctheader”).innerHTML = httpRequest.
getResponseHeader(“Content-Type”);
} else if (httpRequest.readyState == 4 && httpRequest.status ==
200) {
document.getElementById(“target”).innerHTML = httpRequest.
responseText;
}
}
</script>
</body>
</html>x
Connectivity 287
if (httpRequest.readyState == 2) {
document.getElementById(“allheaders”).innerHTML = httpRequest.ge-
tAllResponseHeaders();
document.getElementById(“ctheader”).innerHTML = httpRequest.
getResponseHeader(“Content-Type”);
} else if (httpRequest.readyState == 4 && httpRequest.status == 200)
{
document.getElementById(“target”).innerHTML = httpRequest.re-
sponseText;
Output
Response header: includes date, Content-encoding, last-modified, Server, Accept-encoding, Content Type,
and Content Length (see).
date: Fri, 23 Nov 2018 03:38:43 GMT content-encoding: gzip etag: "9d68cb63f3b7ce1:0" last-modified: Mon, 23 Sep 2013
date: Fri, 23 Nov 2018 03:38:43 GMT content-encoding: gzip etag: “9d68cb63f3b7ce1:0” last-mod-
00:25:21 Mon, server:
ified:GMT 23 Sep Microsoft-IIS/7.5
2013 00:25:21 GMT x-powered-by: ASP.NET vary:
server: Microsoft-IIS/7.5 Accept-Encoding
x-powered-by: ASP.NETcontent-type:
vary: Ac- text/html accept-
cept-Encoding content-type: text/html accept-ranges: bytes content-length: 1312
ranges: bytes content-length: 1312
7
CoAP - https://developer.artik.cloud/documentation/data-management/coap.html
8
CoAP - http://coap.technology/impls.html
288 Building Enterprise IoT Applications
• packet retransmission
• assigning sequence number within the handshake
• replay detection
CoAP follows a client/server model [7]. Clients make requests to servers, servers send back responses.
Clients may GET, PUT, POST and DELETE resources.
CoAP is designed to interoperate with HTTP and the RESTful web at large through simple proxies.
Because CoAP is datagram based, it may be used on top of SMS and other packet-based communications
protocols.9
Content Negotiation
Like HTTP, CoAP the uses client to specify content type and server responses in the content type. CoAP
requests may use query strings in the form?a=b&c=d. These can be used to provide search, paging and
other features to clients. Nonconfirmable messages are “fire and forget” [8].
As you can see, CoAP and MQTT are application protocols (see Figure 9) [7,8]. Wi-Fi and BLE are
physical layer protocols.10
Application/
server layer oneM2M server
RPL
Network layer Ipv6
6LoWPAN
DataLink layer
Bluetooth 4.0
low energy
802.154
3GPP
IEEE
WiFi
PHY layer
F247
9
CoAP-https://www.eclipse.org/community/eclipse_newsletter/2014/february/article2.php
10
https://www.slideshare.net/HamdamboyUrunov/the-constrained-application-protocol-coap-part-2?from_action=save
Connectivity 289
GET Method
CoAP: communication patterns
HTTP: request/response
Confirmable request
One to one
One to many with more request
F248
In HTTP request, one-to-one communication (see Figure 10) is established between Client and Server.
In CoAP, some messages require a confirmation.
The CoAP protocol sends a one-to-one communication request. Unlike HTTP, the CoAP response is
one-to-one (see Figure 11). The CoAP message contains the following header (see Figure 12):
72 F
coap://myhom
e.in:5683/nes
t_livingroom/te
mp
CoAP sever 2
CoAP client 22 (Thermostat in livingroom)
22 F
Name of
the device Name of
Name of the Part (5683 is the parameter
protocol the default port device controls
CoAP users) (temperature here)
coap://myhome.in:5683/nest_bedroom/temp
Figure 11: CoAP Request Response
F249
:
Error:
11
CoAP - https://www.slideshare.net/HamdamboyUrunov/the-constrained-application-protocol-coap-part-2?from_action=save
Connectivity 291
Client Server
Client hello
Application (CoAP)
Hello verity request
Security (DTLS)
Client hello
...Table 2 contd.
def requestResource(self):
request = coap.Message(code=coap.GET)
# Send request to “coap://coap.me:5683/test”
request.opt.uri_path = (b’test’,)
request.opt.observe = 0
request.remote = (ip_address(“134.102.218.18”), coap.COAP_PORT)
d = protocol.request(request, observeCallback=self.printLaterResponse)
d.addCallback(self.printResponse)
d.addErrback(self.noResponse)
def printResponse(self, response):
print(‘First result: ‘ + str(response.payload, ‘utf-8’))
# reactor.stop()
def printLaterResponse(self, response):
print(‘Observe result: ‘ + str(response.payload, ‘utf-8’))
def noResponse(self, failure):
print(‘Failed to fetch resource:’)
print(failure)
# reactor.stop()
log.startLogging(sys.stdout)
endpoint = resource.Endpoint(None)
protocol = coap.Coap(endpoint)
client = Agent(protocol)
reactor.listenUDP(61616, protocol) # , interface="::")
reactor.listenUDP(61616, protocol) # , interface=”::”)
reactor.run()
reactor.run()
Output
The output of the above application generates the following console output (Figure 212)
The output of the above application generates the following console output (Figure 14).
The CoAP Server is run and the following screen (see Figure 15) provides the CoAP Server.
294 Building Enterprise IoT Applications
The CoAP Server is run and the following screen (see Figure 213)provides the CoAP Server.
The Basic Rate system, for instance Bluetooth available on Mac Systems, includes optional
Enhanced Data Rate (EDR), Alternate Media Access Control (MAC) and Physical (PHY) layer
extensions. The Basic Rate system offers synchronous and asynchronous connections with data
Connectivity 295
Figure 17). A Controller is a logical entity defined as all the layers below HCI. An implementation of the
Host and Controller may contain the respective parts of the HCI. Two types of Controllers are defined in
this version of the Core Specification: Primary Controllers and Secondary Controllers.
F255
Bluetooth Core System Architecture
The following figure (see Figure 18) provides Bluetooth core architecture:13 The Core blocks, each with
its associated communication protocol [10].
ATT/
SMP GATT SOP AMP manager
GAP
Channel manager
F256
L2cap resource
manager
L2CAP
Host
HCI HCI
C/E SCL ACL C/E C/E ACL ACL C/E
Link Link
manager manager AMP PAL
Device
manager Baseband resource manager
AMP PAC
Link
Link controller
controller
13
Bluetooth Specification - https://www.bluetooth.com/specifications/protocol-specifications
296 Building Enterprise IoT Applications
• Link Manager, Link Controller and BR/EDR Radio blocks comprise a BR/EDR Controller.
• An AMP PAL, AMP MAC, and AMP PHY comprise an AMP Controller.
• Link Manager, Link Controller and LE Radio blocks comprise an LE Controller. L2CAP, SDP and
GAP blocks comprise a BR/EDR Host.
• L2CAP, SMP, Attribute protocol, GAP and Generic Attribute Profile (GATT) blocks comprise an LE
Host.
• A BR/EDR/LE Host combines the set of blocks from each respective Host.
14
RF Basics for Non-RF Engineers - http://www.ti.com/lit/ml/slap127/slap127.pdf
Connectivity 297
• Japan:
○ 315 MHz (Ultra low power applications)
○ 426–430, 449, 469 MHz (ARIB STD-T67)
○ 2400–2483.5 MHz (ARIB STD-T66)
○ 2471–2497 MHz (ARIB RCR STD-33)
LE employs two multiple access schemes: Frequency division multiple access (FDMA) and time
division multiple access (TDMA). Forty (40) physical channels, separated by 2 MHz, are used in the
FDMA scheme. Three (3) are used as primary advertising channels and 37 are used as secondary advertising
channels and as data channels. A TDMA based polling scheme is used, in which one device transmits a
packet atLEa predetermined time andaccess
employs two multiple a corresponding device responds
schemes: Frequency divisionwith a packet
multiple after(FDMA)
access a predetermined
and
interval [10].
Devices
timethat transmit
division advertising
multiple access packets
(TDMA). on Forty
the advertising PHYchannels,
(40) physical channelsseparated
are referred
by to as advertisers.
2 MHz, are
Devices that receive advertising packets (see Figure 20) on the advertising channels without the intention to
connect to the in
used advertising
the FDMA device are referred
scheme. Three (3)toare
as scanners. Transmissions
used as primary on the
advertising advertising
channels and 37PHY channels
are used
occur in advertising events. At the start of each advertising event, the advertiser sends an advertising packet
as secondary
corresponding advertising event
to the advertising channels andDepending
type. as data channels. A TDMA
on the type based polling
of advertising scheme
packet, is
the scanner
may make a request to the advertiser on the same advertising PHY channel, which may be followed by a
responseused, in advertiser
from the which one ondevice transmits
the same a packet
advertising PHYat channel.
a predetermined time andPHY
The advertising a corresponding
channel changes
on the next advertising packet sent by the advertiser in the same advertising event. The advertiser may
device responds with a packet after a predetermined interval [10].
end the advertising event at any time during the event. The first advertising PHY channel is used at the
start of the next advertising event.
advertiser on the same advertising PHY channel, which may be followed by a response from
the advertiser on the same advertising PHY channel. The advertising PHY channel changes on
the next advertising packet sent by the advertiser in the same advertising event. The advertiser
t the start of the next advertising event.
Client Server
Central Peripheral
F261
accomplish some task. As Figure 22 shows, for example, a heart rate monitor may have useful information
that your Mac or iOS app may need in order to display the user’s heart rate in a user-friendly way.
Central Ad Ad Ad Peripheral
Peripheral Data
The purpose of connecting to a peripheral is to begin exploring and interacting with the data it has to
offer. Before you can do this, however, it helps to understand how the data of a peripheral is structured.
Peripherals may contain one or more services or provide useful information about their connected signal
strength. A service is a collection of data and associated behaviors for accomplishing a function or feature
of a device (or portions of that device) (see Figure 24). For example, one service of a heart rate monitor
may be to expose heart rate data from the monitor’s heart rate sensor. Services themselves are made up
of characteristics or included services (that is, references to other services). A characteristic provides
further details about a peripheral’s service. For example, the heart rate service just described may contain
one characteristic that describes the intended body location of the device’s heart rate sensor and another
characteristic that transmits heart rate measurement data. Figure 24 illustrates one possible structure of a
heart rate monitor’s service and characteristics.
Peripheral
Characteristic
Heart rate service
Characteristic
Heart measurement
Characteristic
Body sensor lacation
CB Peripheral F263
The CBPeripheral class represents remote peripheral devices that your app, by means of a central manager
(an instance of CBCentralManager), has discovered advertising or is currently connected to (see Figure
25). Peripherals are identified by universally unique identifiers (UUIDs), represented by NSUUID objects.
Peripherals may contain one or more services or provide useful information about their connected signal
strength.
You use this class to discover, explore, and interact with the services available on a remote peripheral
that supports Bluetooth low energy. A service encapsulates the way part of the device behaves. For example,
one service of a heart rate monitor may be to expose heart rate data from the monitor’s heart rate sensor.
Services themselves are made up of characteristics or included services (references to other services).
Characteristics (see Figure 26) provide further details about a peripheral’s service. For example, the
heart rate service just described may contain one characteristic that describes the intended body location of
the device’s heart rate sensor and another characteristic that transmits heart rate measurement data. Finally,
characteristics contain any number of descriptors that provide more information about the characteristic’s
value, such as a human-readable description and a way to format the value.
Connectivity 301
Central Peripheral
CBCentralManager CBPeripheral
CBPeripheral
F264
CBService
CBCharacteristic
CBCharacteristic
CBService
15
TI Sensor Tag - http://www.ti.com/ww/en/wireless_connectivity/sensortag/
302 Building Enterprise IoT Applications
Sprint 11:37 PM
Relative humidity
45.9% rH
Barometer
1015 mBar
mBar
Gyroscope
X: –1.4%S
Y: –0.1%S
myCentralManager =
[[CBCentralManager alloc] initWithDelegate:self queue:niloptions:nil];
Figure
Figure 227: scan 29: Scan
for peripherals for peripherals
Discover Services
After
you
have established
a connection to a peripheral, you can begin to explore its data. The first step
in exploring what a peripheral has to offer is discovering its available services. Because there are size
restrictions on the amount
You can discover all of ofthedata a peripheral
services that acan advertise,offers
peripheral you may discoverthe
by calling thatdiscoverServices:
a peripheral has more
Afterthan
services youwhat
have itestablished
advertisesa(in
connection to a peripheral,
its advertising packets). you
Youcan
canbegin to explore
discover all of its
thedata. The that a
services
peripheral
method ofoffers by calling the discoverServices:
the CBPeripheral class (see Figuremethod of the
229), like CBPeripheral class (see Figure 31), like this
this
first step in exploring what a peripheral has to offer is discovering its available services.
[peripheral discoverServices:nil];
Because there are size restrictions on the amount of data a peripheral can advertise, you may
discover that a peripheral has more services than what it advertises (in its advertising packets).
Connectivity 305
[peripheral
discoverServices:nil];
Discover
If you haveCharacteristic of you
found a service that a Service
are interested in, the next step in exploring what a
If you have found a service that you are interested in, the next step in exploring what a peripheral has to
peripheral
offer has to offer
is discovering all of is
thediscovering all of the service’s
service’s characteristics. characteristics.
Discovering Discoveringofall
all of the characteristics of the is
a service
as simple as calling the discoverCharacteristics: forService: method of the CBPeripheral class, specifying
characteristics
the of a service
appropriate service, like thisis(see
asFigure
simple32 as
andcalling the discoverCharacteristics:forService:
Figure 33):
16
TI Sensor Tag -http://www.ti.com/ww/en/wireless_connectivity/sensortag/
124 TI Sensor Tag -http://www.ti.com/ww/en/wireless_connectivity/sensortag/
Connectivity 307
Android
Android 4.3 (API Level 18) introduces built-in platform support for Bluetooth Low Energy in the central role
and provides APIs that apps can use to discover devices, query for services, and read/write characteristics.
In contrast to Classic Bluetooth, BLE is designed to provide significantly lower power consumption.
This allows Android apps to communicate with BLE devices that have low power requirements, such as
proximity sensors, heart rate monitors, fitness devices, and so on.17
The Android platform includes support for the Bluetooth network stack, which allows a device to
wirelessly exchange data with other Bluetooth devices. The application framework provides access to the
Bluetooth functionality through the Android Bluetooth APIs. These APIs let applications wirelessly connect
to other Bluetooth devices, enabling point-to-point and multipoint wireless features [13].
Using the Bluetooth APIs, an Android application can perform the following:
• Scan for other Bluetooth devices
• Query the local Bluetooth adapter for paired Bluetooth devices
• Establish RFCOMM channels
• Connect to other devices through service discovery
• Transfer data to and from other devices
• Manage multiple connections
This page focuses on Classic Bluetooth. Classic Bluetooth is the right choice for more battery-intensive
operations, which include streaming and communicating between Android devices. For Bluetooth devices
with low power requirements, Android 4.3 (API level 18) introduces API support for Bluetooth Low
Energy. Android Permissions:
<uses-permission android:name=“android.permission.BLUETOOTH”/>
<uses-permission android:name=“android.permission.BLUETOOTH_ADMIN”/>
/**
* Activity for scanning and displaying available BLE devices.
*/
public class DeviceScanActivity extends ListActivity {
17
Android Bluetooth Framework - https://developer.android.com/guide/topics/connectivity/bluetooth
18
Start Bluetooth Scan - https://developer.android.com/guide/topics/connectivity/bluetooth-le#java
308 Building Enterprise IoT Applications
@Override
public void run() {
mScanning = false;
mBluetoothAdapter.stopLeScan(mLeScanCallback);
}
}, SCAN_PERIOD);
mScanning = true;
mBluetoothAdapter.startLeScan(mLeScanCallback);
} else {
mScanning = false;
mBluetoothAdapter.stopLeScan(mLeScanCallback);
}
...
}
...
}
Sensor Operation
• Sensor measures skin temperature every 10 minutes.
• Each sensor has an internal data buffer, which can store up to 30 measurements.
• Each measurement data consists of data consists of
○ Timestamp
○ Skin temperature 1
○ Skin temperature 2
○ Case temperature 1
○ Case temperature 2
○ Checksum
• If the buffer is not empty, the sensor broadcast BLE packets for 5 seconds, waiting for a gateway to
be connected. The BLE packet complies with iBeacon packet format.
• The sensor goes to SLEEP mode if it does not receive a connection request for the next 5 seconds
after starting BLE broadcasting. The sensor wakes up every 3 minutes to broadcast if it has data in
the buffer.
• If a connection is made, the gateway can request data to the sensor.
19
Silicon Valley Company – Hanumayamma Innovations and Technologies, Inc http://www.hanuinnotech.com
Connectivity 309
BLE Broadcasting
A Cow necklace sensor broadcasts BLE packets that comply with iBeacon format (except the UUID) if
data is available in the buffer. Use the following UUID to scan Cow Necklace sensors.
cb30a7d0-5cf2-11e5-885d-feff819cdc9f
Each sensor has a unique pair of Major and Minor numbers. You can use these numbers as sensor IDs.
Bluetooth GATT
You can connect to a sensor using Bluetooth GATT profile. Use the following UUIDs to
• (Service) Discover Bluetooth services,
○ 00002220-0000-1000-8000-00805f9b34fb
• (Characteristic) Receive data from the sensor,
○ 00002221-0000-1000-8000-00805f9b34fb
• (Characteristic) Send data to the sensor,
○ 00002222-0000-1000-8000-00805f9b34fb
• (Descriptor) Configure
○ 00002902-0000-1000-8000-00805f9b34fb
Once a connection is made, you can receive and send bytes from/to the sensor by reading and writing
the corresponding characteristics.
<application
android:allowBackup=”true”
android:icon=”@mipmap/ic_launcher”
android:label=”@string/app_name”
android:roundIcon=”@mipmap/ic_launcher_round”
android:supportsRtl=”true”
android:theme=”@style/AppTheme”>
<activity
android:name=”.CattleHealthData”
android:label=”Cattle Health Data”
android:parentActivityName=”.MainActivity” />
<activity android:name=”.MainActivity”>
<intent-filter>
<action android:name=”android.intent.action.MAIN” />
...Table 3 contd.
</activity>
<activity android:name=“.LoginActivity”></activity>
<activity
android:name=“.RegisterActivity”
android:label=“Register”
android:parentActivityName=“.LoginActivity”></activity>
<activity
android:name=“.activity_forgot_password”
android:label=“Reset Password”
android:parentActivityName=“.LoginActivity”></activity>
<activity android:name=“.weatheriphone”></activity>
<activity android:name=“.LineGraph” />
<activity android:name=“.barchart_activity” />
<activity
android:name=“.MultipleGraphs”
android:label=“@string/title_activity_multiple_graphs” />
<activity
android:name=“.CowManager”
android:label=“Cow Manager” />
<activity android:name=“.profile.BleProfileServiceReadyActivity” />
<activity
android:name=“.dfu.DfuActivity”
android:theme=“@style/AppThemeBase” />
<activity android:name=“.profile.BleProfileActivity” />
<activity android:name=“.profile.BleProfileExpandableListActivity” />
<activity android:name=“.uart.UARTActivity”></activity>
<activity android:name=“.profile.multiconnect.BleMulticonnectProfileService
ReadyActivity” />
<provider
android:name=“.uart.UARTLocalLogContentProvider”
android:authorities=“vamshi.com.dairyapplication.uart.log”
android:exported=“true” />
<service
android:name=“.uart.UARTService”
android:label=“UART SERVICE” />
<activity android:name=“.ShowLogActivity”></activity>
</application>
</manifest>
Bluetooth UART
Bluetooth UART is responsible for discovery and connection of peripherals. The following Table 4
contains Bluetooth UART Code
312 Building Enterprise IoT Applications
UARTConfigurationSynchronizer mWearableSynchronizer;
@Override
protected Class<? extends BleProfileService> getServiceClass() {
return UARTService.class;
}
@Override
protected int getLoggerProfileTitle() {
return R.string.uart_feature_title;
}
@Override
protected Uri getLocalAuthorityLogger() {
return UARTLocalLogContentProvider.AUTHORITY_URI;
}
...Table 4 contd.
@Override
protected void setDefaultUI() {
// empty
}
@Override
protected void onServiceBinded(final UARTService.UARTBinder binder) {
mServiceBinder = binder;
}
@Override
protected void onServiceUnbinded() {
mServiceBinder = null;
}
@Override
protected void onInitialize(final Bundle savedInstanceState) {
mPreferences = PreferenceManager.getDefaultSharedPreferences(this);
mDatabaseHelper = new DatabaseHelper(this);
ensureFirstConfiguration(mDatabaseHelper);
mConfigurationsAdapter = new UARTConfigurationsAdapter(this, this,
mDatabaseHelper.getConfigurationsNames());
/**
* Method called when Google API Client connects to Wearable.API.
*/
@Override
public void onConnected(final Bundle bundle) {
// Ensure the Wearable API was connected
if (!mWearableSynchronizer.hasConnectedApi())
return;
if (!mPreferences.getBoolean(PREFS_WEAR_SYNCED, false)) {
new Thread(() -> {
final Cursor cursor = mDatabaseHelper.getConfigurations();
try {
while (cursor.moveToNext()) {
final long id = cursor.getLong(0 /* _ID */);
try {
final String xml = cursor.getString(2 /* XML */);
final Format format = new Format(new HyphenStyle());
final Serializer serializer = new Persister(format);
final UartConfiguration configuration = serializer. read
(UartConfiguration.class, xml);
mWearableSynchronizer.onConfigurationAddedOrEdited(id,
configuration).await();
} catch (final Exception e) {
Log.w(TAG, “Deserializing configuration with id “ + id + “ failed”, e);
}
}
mPreferences.edit().putBoolean(PREFS_WEAR_SYNCED, true).apply();
} finally {
Table 4 contd. ...
314 Building Enterprise IoT Applications
...Table 4 contd.
cursor.close();
}
}).start();
}
}
/**
* Method called then Google API client connection was suspended.
* @param cause the cause of suspension
*/
@Override
public void onConnectionSuspended(final int cause) {
// dp nothing
}
@Override
protected void onDestroy() {
super.onDestroy();
mWearableSynchronizer.close();
}
@Override
protected void onCreateView(final Bundle savedInstanceState) {
setContentView(R.layout.activity_feature_uart);
mContainer = findViewById(R.id.container);
// Setup the sliding pane if it exists
final SlidingPaneLayout slidingPane = mSlider = findViewById(R.id.sliding_pane);
if (slidingPane != null) {
slidingPane.setSliderFadeColor(Color.TRANSPARENT);
slidingPane.setShadowResourceLeft(R.drawable.shadow_r);
slidingPane.setPanelSlideListener(new SlidingPaneLayout.SimplePane
lSlideListener() {
@Override
public void onPanelClosed(final View panel) {
// Close the keyboard
final UARTLogFragment logFragment = (UARTLogFragment)
getSupportFragmentManager().findFragmentById(R.id.fragment_log);
logFragment.onFragmentHidden();
}
});
}
}
@Override
protected void onViewCreated(final Bundle savedInstanceState) {
getSupportActionBar().setDisplayShowTitleEnabled(false);
final ClosableSpinner configurationSpinner = mConfigurationSpinner =
findViewById(R.id.toolbar_spinner);
configurationSpinner.setOnItemSelectedListener(this);
configurationSpinner.setAdapter(mConfigurationsAdapter);
configurationSpinner.setSelection(mConfigurationsAdapter.getItemPosition
(mPreferences.getLong(PREFS_CONFIGURATION, 0)));
}
...Table 4 contd.
@Override
protected void onRestoreInstanceState(final @NonNull Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
mEditMode = savedInstanceState.getBoolean(SIS_EDIT_MODE);
setEditMode(mEditMode, false);
}
@Override
public void onSaveInstanceState(final Bundle outState) {
super.onSaveInstanceState(outState);
outState.putBoolean(SIS_EDIT_MODE, mEditMode);
}
@Override
public void onServicesDiscovered(final BluetoothDevice device, final boolean
optionalServicesFound) {
// do nothing
}
@Override
public void onDeviceSelected(final BluetoothDevice device, final String name) {
// The super method starts the service
super.onDeviceSelected(device, name);
@Override
protected int getDefaultDeviceName() {
return R.string.uart_default_name;
}
@Override
protected int getAboutTextId() {
return R.string.uart_about_text;
}
@Override
protected UUID getFilterUUID() {
return null; // not used
}
@Override
public void send(final String text) {
if (mServiceBinder != null)
mServiceBinder.send(text);
}
UART Manager
UART Manager handles the code with respect to Service and Characteristic code. See Table 5 for the
service and characteristic code handling.
package vamshi.com.dairyapplication.uart;
import android.bluetooth.BluetoothGatt;
import android.bluetooth.BluetoothGattCharacteristic;
import android.bluetooth.BluetoothGattService;
import android.content.Context;
import android.text.TextUtils;
import java.io.UnsupportedEncodingException;
import java.util.Deque;
import java.util.LinkedList;
import java.util.UUID;
import no.nordicsemi.android.ble.BleManager;
import no.nordicsemi.android.log.Logger;
@Override
protected BleManagerGattCallback getGattCallback() {
return mGattCallback;
}
/**
* BluetoothGatt callbacks for connection/disconnection, service
discovery, receiving indication, etc.
*/
private final BleManagerGattCallback mGattCallback = new
BleManagerGattCallback() {
...Table 5 contd.
@Override
protected Deque<Request> initGatt(final BluetoothGatt gatt) {
final LinkedList<Request> requests = new LinkedList<>();
requests.add(Request.newEnableNotificationsRequest(mTXCharacteristic));
return requests;
}
@Override
public boolean isRequiredServiceSupported(final BluetoothGatt gatt) {
final BluetoothGattService service = gatt.getService(UART_SERVICE_UUID);
if (service != null) {
mRXCharacteristic = service.getCharacteristic(UART_RX_
CHARACTERISTIC_UUID);
mTXCharacteristic = service.getCharacteristic(UART_TX_
CHARACTERISTIC_UUID);
}
@Override
public void onCharacteristicWrite(final BluetoothGatt gatt, final
BluetoothGattCharacteristic characteristic) {
// When the whole buffer has been sent
final byte[] buffer = mOutgoingBuffer;
if (mBufferOffset == buffer.length) {
try {
final String data = new String(buffer, “UTF-8”);
Logger.a(mLogSession, “\”” + data + “\” sent”);
mCallbacks.onDataSent(gatt.getDevice(), data);
} catch (final UnsupportedEncodingException e) {
// do nothing
}
Table 5 contd. ...
318 Building Enterprise IoT Applications
...Table 5 contd.
mOutgoingBuffer = null;
} else { // Otherwise...
final int length = Math.min(buffer.length - mBufferOffset, MAX_PACKET_
SIZE);
enqueue(Request.newWriteRequest(mRXCharacteristic, buffer,
mBufferOffset, length));
mBufferOffset += length;
}
}
@Override
public void onCharacteristicNotified(final BluetoothGatt gatt, final
BluetoothGattCharacteristic characteristic) {
final String data = characteristic.getStringValue(0);
Logger.a(mLogSession, “\”” + data + “\” received”);
mCallbacks.onDataReceived(gatt.getDevice(), data);
}
};
@Override
protected boolean shouldAutoConnect() {
// We want the connection to be kept
return true;
}
/**
* Sends the given text to RX characteristic.
* @param text the text to be sent
*/
public void send(final String text) {
// Are we connected?
if (mRXCharacteristic == null)
return;
Database
The database code handles the Insert, Query and Edit operations (see Table 6).
package vamshi.com.dairyapplication;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import vamshi.com.dairyapplication.WeatherApiClasses.CowManagerModel;
/**
* Created by Vamshi on 1/9/2018.
*/
// Database Name
private static final String DATABASE_NAME = “MyDairyFarm”;
...Table 6 contd.
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
// Drop older table if existed
sqLiteDatabase.execSQL(“DROP TABLE IF EXISTS “ + TABLE_USERS);
SQLiteDatabase db = this.getWritableDatabase();
long i = db.insert(TABLE_USERS, null, values);
return i;
}
public long createCowmanger(CowManagerModel cow) {
ContentValues values = new ContentValues();
values.put(KEY_FARMER, cow.getFarmer());
values.put(KEY_FARMNAME, cow.getFarmname());
values.put(KEY_PHONE, cow.getPhone());
values.put(KEY_NOOFCOW, cow.getNoofcow());
values.put(KEY_LOCATION, cow.getLocation());
SQLiteDatabase db = this.getWritableDatabase();
long i = db.insert(TABLE_COWMANAGER, null, values);
return i;
}
...Table 6 contd.
return cursor;
}
public Cursor validateEmail(String email) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(“SELECT *FROM “ + TABLE_USERS + “ WHERE “ +
KEY_EMAIL + “ = ‘” + email + “’”, null);
System.out.println();
return cursor;
}
public boolean validateAnswer(String email, String sec_ques, String secAns) {
boolean isValid = false;
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.query(TABLE_USERS, new String[]{KEY_EMAIL},
KEY_EMAIL + “ LIKE ‘” + email + “’ AND “ + KEY_SEC_QUES + “ LIKE ‘” + sec_
ques + “’ AND “ + KEY_SEC_ANS + “ LIKE ‘” + secAns + “’”, null, null,
null, null);
System.out.println(cursor.getCount());
if (cursor.getCount() > 0) {
isValid = true;
} else {
isValid = false;
}
return isValid;
}
public int updatePassword(String email, String password){
SQLiteDatabase db=this.getWritableDatabase();
ContentValues values=new ContentValues();
values.put(KEY_PASSWORD,password);
int count = db.update(TABLE_USERS,values,KEY_EMAIL+” =? “,new String[] {
email });
return count;
}
}
package vamshi.com.dairyapplication.scanner;
import android.bluetooth.BluetoothDevice;
import no.nordicsemi.android.support.v18.scanner.ScanResult;
public class ExtendedBluetoothDevice {
/* package */ static final int NO_RSSI = -1000;
public final BluetoothDevice device;
/** The name is not parsed by some Android devices, f.e. Sony Xperia Z1
with Android 4.3 (C6903). It needs to be parsed manually. */
public String name;
public int rssi;
public boolean isBonded;
public ExtendedBluetoothDevice(final ScanResult scanResult) {
this.device = scanResult.getDevice();
this.name = scanResult.getScanRecord() != null ? scanResult.getScanRecord().
getDeviceName() : null;
this.rssi = scanResult.getRssi();
this.isBonded = false;
}
public ExtendedBluetoothDevice(final BluetoothDevice device) {
this.device = device;
this.name = device.getName();
this.rssi = NO_RSSI;
this.isBonded = true;
}
public boolean matches(final ScanResult scanResult) {
return device.getAddress().equals(scanResult.getDevice().getAddress());
}
}
MQTT20
MQTT, a foundational Internet of Things (IoT) standard developed by the OASIS consortium, has now
been approved for release by the International Organization for Standardization (ISO) and the International
Electrotechnical Commission (IEC). Version 3.1.1 of MQTT was balloted through the Joint Technical
Committee on Information Technology (JTC1) of ISO and IEC and given the designation ‘ISO/IEC 20922’.
MQTT is message oriented. Every message is a discrete chunk of data, opaque to the broker [14].
Every message is published to an address, known as a topic. Clients may subscribe to multiple topics.
Every client subscribed to a topic receives every message published to the topic.
For example, imagine a simple network with three clients and a central broker.
All three clients open TCP connections with the broker. Clients B and C subscribe to the topic
temperature.
20
MQTT - https://www.oasis-open.org/news/pr/oasis-mqtt-internet-of-things-standard-now-approved-by-iso-iec-jtc1
Connectivity 323
@Override
protected final void onCreate(final Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ensureBLESupported();
if (!isBLEEnabled()) {
showBLEDialog();
}
...Table 8 contd.
LocalBroadcastManager.getInstance(this).registerReceiver(mCommonBroadcastR
eceiver, makeIntentFilter());
}
Later, Client A publishes a value of 22.5 for topic temperature. The broker forwards the message to
all subscribed clients [15].
The publisher subscriber model allows MQTT clients to communicate one-to-one, one-to-many and
many-to-one (see Figure 34).
Later, Client A publishes a value of 22.5 for topic temperature. The broker forwards the
MQTT Benefits
Out of all the available protocols for the communication system and for the IoT network, MQ Telemetry
Transport is most widely used. Mentioned below are some of the advantages of using MQTT:
• MQTT is robust, as we can encrypt the data even with unsecured TCP messaging. The partial or
complete encryption is possible with the help of TLS/SSL security. Factors affecting the encryption
depend on system resources and the security mandate.
• MQTT provides a central broker to minimize the packets strength in the internet. This is achieved
with broker acting as server. It also helps in memory reduction required by the clients.
• MQTT provides three different types of Quality of Service(QoS) depending on importance and
repetitiveness of messages, i.e.,
○ At Most Once: Client publishes the messages only once and is configured with level 0.
○ At least Once: Client publishes the messages more than once and is configured with level 1.
○ Exactly Once: Client publishes the messages just once and is configured with level 2.
• MQTT can predict on the availability of the client using ‘Last Will’. Therefore, the extra time of
waiting for a client who is actually not present is avoided. Listeners check on the availability of the
publisher.
• MQTT can also help in receiving old message from the subscribers. And there is a flexible subscription
pattern, i.e., depending on a particular pattern, the client can subscribe to the topics published.
21
MQTT v3.1.1 - http://docs.oasis-open.org/mqtt/mqtt/v3.1.1/mqtt-v3.1.1.pdf
326 Building Enterprise IoT Applications
MQTT Highlights
Here are the highlights of MQTT:
• It is an open source and royalty-free protocol.
• It is standardized by the OASIS technical committee.
• The MQTT protocol is designed for transferring messages reliably between devices that are on low
bandwidth.
• It uses TCP/IP to establish a secure connection.
• It is a client-server, publish/subscribe model that enables one-to-one and one-to-many distributions.
• •It supports three qualitiesof
Many applications ofMQTT
service:can
(1) fire and forget, (2) atusing
be accomplished least only
once and (3) exactlyPUBLISH,
CONNECT, one.
○ “Fire and forget” does not use constant device storage—it uses only one transmission to send or
receive a publication.
SUBSCRIBE and DISCONNECT packets.
○ “At least once” and “Exactly once” require persistent device storage to maintain the protocol state
FortoSUBSCRIBE
• and save a messageand
untilCONNECT, the protocol
an acknowledgement uses 12-byte variable headers and for
is received.
• It has built-in support for loss of contact between client and server. The server is informed when a
PUBLISH,
client connectionitbreaks
uses abnormally,
only 2-byteallowing
variabletheheaders.
message to be re-sent or preserved for later delivery.
• The MQTT message headers are kept as small as possible. The fixed header is just two bytes with 12
MQTT
•bytes is adaptable
of additional variablefor a wide variety of devices, platforms and operating systems
headers.
• Many applications of MQTT can be accomplished using only CONNECT, PUBLISH, SUBSCRIBE
and inside an enterprise
DISCONNECT network since it connects to a message sight inside an enterprise
packets.
• For SUBSCRIBE and CONNECT, the protocol uses 12-byte variable headers and for PUBLISH, it
network.
uses only 2-byte variable headers.
• •MQTT
It isisvery
adaptable
easy for a wide
to use andvariety
can be of implemented
devices, platforms
withand operating
a simple setsystems inside anmessages.
of command enterprise
network since it connects to a message sight inside an enterprise network.
• It is very easy to use and can be implemented with a simple set of command messages.
Installation of Paho library results in the following Python Installation Package UI (see Figure
Connectivity 327
Install Paho
pip3 install paho-mqtt python-etcd
Installation of Paho library results in the following Python Installation Package UI (see Figure 36).
Once installed, you can see the library under your Python IDE (see Figure 37):
Figure
Once 234: Install Paho
installed, Library
you can see the library under your Python IDE (see Figure 235):
Once installed, you can see the library under your Python IDE (see Figure 235):
:
Figure 235: Install Files
Once installed, you can see the library under your Python IDE:
:
Once installed, you can see the library under your Python IDE:
328 Building Enterprise IoT Applications
Code:
Once installed, you can see the library under your Python IDE:
Code:
The following modules connect to MQTT Server and subscribe/publish messages.
mqtt_subscribe.py
# Import package
import paho.mqtt.client as mqtt
# Define Variables
MQTT_BROKER=”broker.hivemq.com”
MQTT_HOST = “iot.eclipse.org”
MQTT_PORT = 1883
MQTT_KEEPALIVE_INTERVAL = 45
MQTT_TOPIC = “helloTopic”
MQTT_MSG = “hello MQTT”
# Define on connect event function
# We shall subscribe to our Topic in this function
def on_connect(mosq, obj, rc):
mqttc.subscribe(MQTT_TOPIC, 0)
# Define on_message event function.
# This function will be invoked every time,
# a new message arrives for the subscribed topic
def on_message(mosq, obj, msg):
print (“Topic: “ + str(msg.topic))
print (“QoS: “ + str(msg.qos))
print (“Payload: “ + str(msg.payload))
def on_subscribe(mosq, obj, mid, granted_qos):
print(“Subscribed to Topic: “ +
MQTT_MSG + “ with QoS: “ + str(granted_qos))
# Initiate MQTT Client
mqttc = mqtt.Client(“client-001”)
# Assign event callbacks
mqttc.on_message = on_message
mqttc.on_connect = on_connect
mqttc.on_subscribe = on_subscribe
# Connect with MQTT Broker
mqttc.connect(MQTT_HOST, MQTT_PORT, MQTT_KEEPALIVE_INTERVAL)
print(“Listening”)
# Continue monitoring the incoming messages for subscribed topic
mqttc.loop_forever()
Connectivity 329
mqtt_publish.py
The following code publishes to MQTT broker and receives a message on subscribe.
# Import package
import paho.mqtt.client as mqtt
# Define Variables
MQTT_BROKER=”broker.hivemq.com”
MQTT_HOST = “iot.eclipse.org”
MQTT_PORT = 1883
MQTT_KEEPALIVE_INTERVAL = 45
MQTT_TOPIC = “helloTopic”
MQTT_MSG = “hello MQTT”
# Define on connect event function
# We shall subscribe to our Topic in this function
def on_connect(mosq, obj, rc):
mqttc.subscribe(MQTT_TOPIC, 0)
# Define on_message event function.
# This function will be invoked every time,
# a new message arrives for the subscribed topic
def on_message(mosq, obj, msg):
print (“Topic: “ + str(msg.topic))
print (“QoS: “ + str(msg.qos))
print (“Payload: “ + str(msg.payload))
def on_subscribe(mosq, obj, mid, granted_qos):
print(“Subscribed to Topic: “ +
MQTT_MSG + “ with QoS: “ + str(granted_qos))
# Initiate MQTT Client
mqttc = mqtt.Client(“client-001”)
# Assign event callbacks
mqttc.on_message = on_message
mqttc.on_connect = on_connect
mqttc.on_subscribe = on_subscribe
# Connect with MQTT Broker
mqttc.connect(MQTT_HOST, MQTT_PORT, MQTT_KEEPALIVE_INTERVAL)
print(“Listening”)
# Continue monitoring the incoming messages for subscribed topic
mqttc.loop_forever()
330 Building Enterprise IoT Applications
Client.py
The Client.py code is the central to establishing MQTT on Python platform. It uses systems resources and
OS platform capabilities to establish socket, subscribe socket, and publish socket.
In order to perform packet exchange, every message payload has to be time stamped. In the case of
Paho Python implementation, the time function used is time monotomic.
Under the Windows, the time tick for the time.monotomic is derived from an on board processor
timer and it’s the most accurate.
Connectivity 331
“””
This is an MQTT v3.1 client module. MQTT is a lightweight pub/sub messaging
protocol that is easy to implement and suitable for low powered devices.
“””
import collections
import errno
import os
import platform
import select
import socket
try:
import ssl
except ImportError:
ssl = None
import struct
import sys
import threading
import time
import uuid
import base64
import string
import hashlib
import logging
try:
# Use monotonic clock if available
time_func = time.monotonic
except AttributeError:
time_func = time.time
try:
import dns.resolver
except ImportError:
HAVE_DNS = False
else:
HAVE_DNS = True
from .matcher import MQTTMatcher
if platform.system() == ‘Windows’:
EAGAIN = errno.WSAEWOULDBLOCK
else:
EAGAIN = errno.EAGAIN
MQTTv31 = 3
MQTTv311 = 4
if sys.version_info[0] >= 3:
# define some alias for python2 compatibility
unicode = str
basestring = str
22
PEP 418 -- Add monotonic time, performance counter, and process time functions - https://www.python.org/dev/peps/
pep-0418/#rationale
23
Python Clocks Explained - https://www.webucator.com/blog/2015/08/python-clocks-explained/
332 Building Enterprise IoT Applications
2. time.monotonic()
3. time.perf_counter()
4. time.process_time()
5. time.time()
Attribute Description
Adjustable True if the clock can be changed automatically (e.g., by a NTP daemon) or
manually by the system administrator, False otherwise
Implementation The name of the underlying C function used to get the clock value. Refer to
Clock ID Constants for possible values.
Monotonic True if the clock cannot go backward, False otherwise
Resolution The resolution of the clock in seconds (float)
25
List of hardware clocks - https://www.python.org/dev/peps/pep-0418/#rationale
334 Building Enterprise IoT Applications
• Cyclone: The Cyclone timer uses a 32-bit counter on IBM Extended X-Architecture (EXA) chipsets
which include computers that use the IBM “Summit” series chipsets (ex: x440). This is available in
IA32 and IA64 architectures.
Source: https://www.dhgate.com/product/altera-cyclone-iv-ep4ce6-fpga-development/392819262.html
• PIT (programmable interrupt timer): Intel 8253/8254 chipsets with a configurable frequency in range
18.2 Hz–1.2 MHz. This uses a 16-bit counter.
• RTC (Real-time clock). Most RTCs use a crystal oscillator with a frequency of 32,768 Hz.
Source: https://www.maximintegrated.com/en/products/digital/real-time-clocks.html
26
Linux Clock Sources - https://www.python.org/dev/peps/pep-0418/#rationale
program can be used to change the timecounter. Example [19]:
Connectivity 335
kern.timecounter.choice lists available hardware clocks with their priority (see Figure 39). The sysctl
program can be used to change the timecounter. Example [19]:
ter "ACPI-safe"
• “HPET”: High Precision Event Timer
frequency 3579545 Hz qualit
• “ACPI-fast”: ACPI Power Management timer (fast mode)
• “ACPI-safe”: ACPI Power Management timer (safe mode)
• “i8254”: PIT with Intel 8254 chipset
rn.timecounter.choice
ounter.choice: TSC(800) HPET(900) ACPI-safe(850) i825
▪ "i8254": PIT with Intel 8254 chipset
Clock Resolution
Figure 238: Hanumayamma IoT Scale
Please check Appendix A: bench_time.C for C program version of Clock resolutions computed.
The following code has Python version [20] (see Table 9):
Connectivity 337
Reference: PEP0418
https://www.python.org/dev/peps/pep-0418/#rationale
Code: https://hg.python.org/peps/file/tip/pep-0418/clock_resolution.py
”’”
import time
try:
from time import timeout_time
except ImportError:
from time import time as timeout_time
def compute_resolution(func):
resolution = None
points = 0
timeout = timeout_time() + 1.0
previous = func()
while timeout_time() < timeout or points < 3:
for loop in range(10):
t1 = func()
t2 = func()
dt = t2 - t1
if 0 < dt:
break
else:
dt = t2 - previous
if dt <= 0.0:
continue
if resolution is not None:
resolution = min(resolution, dt)
else:
resolution = dt
points += 1
previous = func()
return resolution
def format_duration(dt):
if dt >= 1e-3:
return “%.0f ms” % (dt * 1e3)
if dt >= 1e-6:
return “%.0f us” % (dt * 1e6)
else:
return “%.0f ns” % (dt * 1e9)
Table 9 contd. ...
338 Building Enterprise IoT Applications
...Table 9 contd.
The application call time function for each time features and take snap shot at time 1 and time 2 and
difference the performance.
clock():
- resolution in Python: 365 ns
- implementation: QueryPerformanceCounter()
- resolution: 365 ns
perf_counter():
- resolution in Python: 365 ns
- implementation: QueryPerformanceCounter()
- resolution: 365 ns
process_time():
- resolution in Python: 16 ms
- implementation: GetProcessTimes()
- resolution: 100 ns
monotonic():
- resolution in Python: 15 ms
- implementation: GetTickCount64()
- resolution: 16 ms
time():
- resolution in Python: 441 us
- implementation: GetSystemTimeAsFileTime()
- resolution: 16 ms
Please see Figure 41:
- resolution: 16 ms
time():
- resolution in Python: 441 us
- implementation: GetSystemTimeAsFileTime()
- resolution: 16 ms
Connectivity 339
Please see Figure 239:
Figure 239: Clock resolution output Figure 41: Clock resolution output
Message Types
Connection Acknowledgement Codes
Sockets
Base 62 Conversion (please see Table 10)
Payload
if len(local_payload) > 268435455:
raise ValueError(‘Payload too large.’)
MQTT Signals
The publish and subscribe messages distinguishes a publisher sending a message from the subscriber that
receives the message.
MQTT uses topics to identify which message reaches which client. A broker uses topic (UTF-8 string)
to filter messages for each client which is connected. A topic is of very light weight.
340 Building Enterprise IoT Applications
Example: hospitalRurual/floorone/bedroomtwo/temperature
MQTT Client
A publisher and a subscriber make an MQTT client. An MQTT can be any device that has its
library running and should be able to connect to an MQTT broker on any network. MQTT libraries
support a huge variety of programming languages, for example android, C, C++, iOS, java,
JavaScript, etc.
During the client construction, the following constructor parameters are set:
def __init__(self, client_id=””, clean_session=True, userdata=None,
protocol=MQTTv311, transport=“tcp”):
Parameters:
client_id: is the unique client id string used when connecting to the broker. If client_id is zero length or
None, then the behaviour is defined by which protocol version is in use. If using MQTT v3.1.1, then a
zero-length client id will be sent to the broker and the broker will generate a random for the client. If us-
ing MQTT v3.1 then an id will be randomly generated. In both cases, clean_session must be True. If this
is not the case a ValueError will be raised.
clean_session is a boolean that determines the client type. If True the broker will remove all information
about this client when it disconnects. If False, the client is a persistent client and subscription information
and queued messages will be retained when the client disconnects. Note that a client will never discard
its own outgoing messages on disconnect. Calling connect() or reconnect() will cause the messages to be
resent. Use reinitialise() to reset a client to its original state.
userdata is user-defined data of any type that is passed as the “userdata” parameter to callbacks. It may be
updated at a later point with the user_data_set() function.
The protocol argument allows explicit setting of the MQTT version to use for this client. Can be paho.
mqtt.client.MQTTv311 (v3.1.1) or paho.mqtt.client.MQTTv31 (v3.1), with the default being v3.1.1 If
the broker reports that the client connected with an invalid protocol version, the client will automatically
attempt to reconnect using v3.1 instead.
Set transport to “websockets” to use WebSockets as the transport mechanism. Set to “tcp” to use raw TCP,
which is the default.
General usage flow
• Use connect()/connect_async() to connect to a broker
• Call loop() frequently to maintain network traffic flow with the broker
• Or use loop_start() to set a thread running to call loop() for you.
• Or use loop_forever() to handle calling loop() for you in a blocking function.
• Use subscribe() to subscribe to a topic and receive messages
• Use publish() to send message
• Use disconnect() to disconnect from the broker
Data returned from the broker is made available with the use of callback functions as described below
(see Figure 42) [21].
Connectivity 341
Client Broker
Subscribe(topic=sensor/temp)
Subscription
Suback
Unsubscribe(topic=sensor/temp)
Unsuback
Disconnect
F286
Figure 42: MQTT Sequence flow
Callbacks
• A number of callback functions are available to receive data back from the broker. To use a callback,
define a function and then assign it to the client.
def on_connect(client, userdata, flags, rc):
print(“Connection returned “ + str(rc))
client.on_connect = on_connect
All of the callbacks as described below have a “client” and an “userdata” argument. “client” is the
Client instance that is calling the callback.
“userdata” is user data of any type and can be set when creating a new client
instance or with user_data_set(userdata).
The callbacks:
On_connect(client, userdata, flags, rc): Called when the broker responds to our connection request.
flags is a dict that contains response flags from the broker:
flags[‘session present’] - this flag is useful for clients that are
using clean session set to 0 only. If a client with clean
session=0, that reconnects to a broker that it has previously
connected to, this flag indicates whether the broker still has the
session information for the client. If 1, the session still exists.
The value of rc determines success or not:
0: Connection successful
1: Connection refused - incorrect protocol version
2: Connection refused - invalid client identifier
3: Connection refused - server unavailable
4: Connection refused - bad username or password
5: Connection refused - not authorised
6-255: Currently unused.
4: Connection refused - bad username or password
5: Connection
342 Building refused
Enterprise - not authorised
IoT Applications
6-255: Currently unused.
Please
Pleasefind
findMQTT
MQTTpublish/subscribe code code
publish / subscribe (see Figure 43). 241).
(see Figure
Figure 241: MQTT Pub/Sub method Figure 43: MQTT Pub/Sub method
on_disconnect(client, userdata, rc): Called when the client disconnects from the broker. The rc parameter
indicates the disconnection state. If MQTT_ERR_SUCCESS (0), the callback was called in response to
on_disconnect(client, userdata, rc): Called when the client disconnects from the broker.
a disconnect() call. If any other value the disconnection was unexpected, possibly caused by a network
The rc parameter indicates the disconnection state. If MQTT_ERR_SUCCESS
error.
(0), the callback was called in response to a disconnect() call. If any
other value theuserdata,
on_message(client, disconnection wasCalled
message): unexpected, possiblyhas
when a message caused by a network
been received error.
on a topic that the cli-
ent subscribes to. The message variable is a MQTTMessage that describes all of the message parameters.
on_message(client,
on_publish(client, userdata,
userdata, message):
mid): Called whenCalled when
a message thata was
message has been
to be sent using received on acall has
the publish()
topic that the client subscribes to. The message variable is a
completed transmission to the broker. For messages with QoS levels 1 and 2, this means that the appro-
MQTTMessage
priate that describes
handshakes have completed. ForallQoS
of the message
0, this simply parameters.
means that the message has left the client. The
mid variable matches the mid variable returned from the corresponding publish() call, to allow outgoing
on_publish(client,
messages userdata,
to be tracked. This mid):isCalled
callback importantwhen a message
because even ifthat
the was to becall
publish() sentreturns success,
using the it
doespublish()
not alwayscall hasthat
mean completed transmission
the message to the broker. For messages
has been sent.
with QoS levels 1 and 2, this means that the appropriate handshakes have
on_subscribe(client,
completed. For userdata, mid,simply
QoS 0, this granted_qos): Called
means that thewhen the broker
message has leftresponds
the to a subscribe re-
quest. The mid variable matches the mid variable returned from the corresponding subscribe() call. The
client. The mid variable matches the mid variable returned from the
granted_qos variable is a list of integers that give the QoS that level the broker has granted for each of
corresponding publish() call, to allow outgoing messages to be tracked.
the different subscription requests.
This callback is important because even if the publish() call returns
success, it does not
on_unsubscribe(client, alwaysmid):
userdata, meanCalled
that the message
when has responds
the broker been sent.
to an unsubscribe request. The
mid variable matches the mid variable returned from the corresponding unsubscribe() call.
on_subscribe(client, userdata, mid, granted_qos): Called when the broker responds to a
on_log(client, userdata, level, buf): Called when the client has log information. Define to allow de-
subscribe
bugging. request.
The level Thegives
variable mid variable matches
the severity of the the mid variable
message and will returned
be one of MQTT_LOG_INFO,
from the corresponding subscribe() call.
MQTT_LOG_NOTICE, MQTT_LOG_WARNING, MQTT_LOG_ERR, The granted_qos variableoris aMQTT_LOG_DEBUG.
list of integers that give
The message itself is in buf. the QoS that level the broker has granted for each
of the different subscription requests.
on_socket_open(client, userdata, sock): Called when the socket has been opened. Use this to register the
socket with an external event loop for reading.
on_socket_open(client, userdata, sock): Called when the socket has been opened. Use this
to register the socket with an external event loop for reading.
MQTT Control
Below are the partsPackets
of MQTT protocol [22]:
Below are the parts of MQTT protocol [22]:
1. Fixed Header:
1. Fixed The length
Header: of this packet
The length of thisinpacket
MQTTinisMQTT
fixed (see Figure(see
is fixed 44) Figure 242)
2. Variable header: The header contains some variable length components and depends on the packet
type. Most variables have packet identifiers in them. Both client and broker can have a separate packet
2. Variable
identifier header
that helps : The
them header contains
to maintain some
concurrent variable
message length
transfer components
(see Figure 45). and depends on
the packet type. Most variables have packet identifiers in them. Both client and broker
can have a separate packet identifier that helps them to maintain concurrent message
Figure 243: MQTT Variable Header Figure 45: MQTT Variable Header
3. Payloads: Generally, it is the last part of a control packet. For Publish packets, payloads act as an
application (see Figure 46).
3. Payloads: Generally, it is the last part of a control packet. For Publish packets, payloads
CONNECT Required
CONNACK None
PUBLISH Optional
PUBACK None
PUBREC None
PUBREL None
PUBCOMP None
SUBSCRIBE Required
SUBACK Required
UNSUBSCRIBE Required
UNSUBACK None
PINGREQ None
PINGRESP None
DISCONNECT None
Figure 46: MQTT Packet and Payload
F290
Install Wireshark to capture protocol level messages. Installation of Wireshark (see Figure 245
MQTT Wireshark Captures
).
Install Wireshark to capture protocol level messages. Installation of Wireshark (see Figure 47).
Figure 245:
Successful install enables capture Wireshark
of MQTT Installation
(see Figure 48)
Figure 249: Wireshark Subscribe Ack Figure 51: Wireshark Subscribe Ack
348 Building Enterprise IoT Applications
LoRa
LoRaWAN is a long range, low power, wireless protocol that is intended for use in building IoT networks.
IoT devices (“nodes”) send small data packets to any number of “gateways” that may be in the several-
kilometer range of a node via the LoRaWAN wireless protocol. The gateways then use more traditional
communications, such as wired Internet connections ,to forward the messages to a network-server which
validates the packets and forwards the application payload to an application-server.27
• LoRa Gateway Bridge: The LoRa gateway bridge takes the Packet forward message (UDP) and
translates it into MQTT. The advantage of using MQTT is:
○ It makes debugging easier
○ Sending downlink data only requires knowledge about the corresponding MQTT topic of the gateway,
the MQTT broker will route it to the LoRa Gateway Bridge instance responsible for the gateway
○ It enables a secure connection between your gateways and the network (using MQTT over TLS)
• LoRa Server: The LoRa Server manages the WAN and provides the network. It also maintains registry
of active devices on the network. The LoRa Server performs one more additional functionality: When
data is received by multiple gateways, the LoRa Server will de-duplicate this data and forward it once
to the LoRaWAN application-server. When an application-server needs to send data back to a device,
the LoRa Server will keep these items in queue, until it is able to send to them one of the gateways.
• LoRa Geo Server: An optional component that provides geo resolution of Gateways.
• LoRa App Server: The LoRa App Server component implements a LoRaWAN application-server
compatible with the LoRa Server component. To receive the application payload sent by one of your
devices, you can use one of the integrations that the LoRa App Server provides (e.g., MQTT, HTTP
or directly write to an InfluxDB database).
IoT device
UDP UDP
MQTT
MQTT
Application
MQTT geo server gRPC LoRa server
gRPC
gRPC JSON rest
MQTT
F298
27
LoRa - https://www.loraserver.io/overview/architecture/
Connectivity 349
Data Flow
On the left side of LoRa implementation, the sensor connects to the LoRa Gateway via UDP protocol.
The LoRa Gateway connects to the LoRa Gateway bridge and relays the connection to using UDP. The
LoRa gateway bridge translates the UDP into either MQTT or HTTP and sends the data on MQTT or
HTTP respectively. Finally, the LoRa Server processes the pay load and executes the business application.
Code: https://github.com/Lora-net/packet_forwarder
F299
The protocol exchange is in the following sequences (see Figure 55):
UDP to UDP [21]
UDP to MQTT
MQTT and Application Process
Configuration (see Table 11) for important socket and LoRa.
{
“SX1301_conf”: {
“lorawan_public”: true,
“clksrc”: 1, /* radio_1 provides clock to concentrator */
“lbt_cfg”: {
“enable”: false,
“rssi_target”: -80, /* dBm */
“chan_cfg”:[ /* 8 channels maximum */
{ “freq_hz”: 867100000, “scan_time_us”: 128 },
{ “freq_hz”: 867300000, “scan_time_us”: 5000 },
{ “freq_hz”: 867500000, “scan_time_us”: 128 },
{ “freq_hz”: 869525000, “scan_time_us”: 128 }
],
“sx127x_rssi_offset”: -4 /* dB */
},
Thread Up
The Thread Up routine receives data packets from downstream and sends the data to the Upstream.
At the core, the thread_up routine uses set socket and open the socket option till the data is read. As
part of the routine, the payload buffer is populated with headers and data details.
#include <sys/socket.h>
int setsockopt(int socket, int level, int option_name,
const void *option_value, socklen_t option_len);
The setsockopt() function shall set the option specified by the option_name argument, at the protocol
level specified by the level argument, to the value pointed to by the option_value argument for the socket
associated with the file descriptor specified by the socket argument.28
SO_RCVTIMEO29— Sets the timeout value that specifies the maximum amount of time an
input function waits until it completes. It accepts a timeval structure with the number of seconds
and microseconds specifying the limit on how long to wait for an input operation to complete (see
Table 12). If a receive operation has blocked for this much time without receiving additional data, it shall
return with a partial count or errno set to [EAGAIN] or [EWOULDBLOCK] if no data is received. The
default for this option is zero, which indicates that a receive operation shall not time out. This option takes
a timeval structure. Note that not all implementations allow this option to be set.
/* --- ---------------------- */
void thread_up(void) {
int i, j; /* loop variables */
unsigned pkt_in_dgram; /* nb on Lora packet in the current datagram */
/* allocate memory for packet fetching and processing */
struct lgw_pkt_rx_s rxpkt[NB_PKT_MAX]; /* array containing inbound packets
+ metadata */
struct lgw_pkt_rx_s *p; /* pointer on a RX packet */
int nb_pkt;
/* local copy of GPS time reference */
bool ref_ok = false; /* determine if GPS time reference must be used or
not */
struct tref local_ref; /* time reference used for UTC <-> timestamp
conversion */
/* data buffers */
uint8_t buff_up[TX_BUFF_SIZE]; /* buffer to compose the upstream packet */
int buff_index;
uint8_t buff_ack[32]; /* buffer to receive acknowledges */
/* protocol variables */
uint8_t token_h; /* random token for acknowledgement matching */
uint8_t token_l; /* random token for acknowledgement matching */
/* ping measurement variables */
struct timespec send_time;
struct timespec recv_time;
/* GPS synchronization variables */
struct timespec pkt_utc_time;
struct tm * x; /* broken-up UTC time */
struct timespec pkt_gps_time;
uint64_t pkt_gps_time_ms;
/* report management variable */
Table 12 contd. ...
28
Set_socket http://pubs.opengroup.org/onlinepubs/009695399/functions/setsockopt.html
29
So_rcvtimeo - http://pubs.opengroup.org/onlinepubs/009695399/functions/setsockopt.html
Connectivity 353
...Table 12 contd.
...Table 12 contd.
p = &rxpkt[i];
/* Get mote information from current packet (addr, fcnt) */
/* FHDR - DevAddr */
mote_addr = p->payload[1];
mote_addr |= p->payload[2] << 8;
mote_addr |= p->payload[3] << 16;
mote_addr |= p->payload[4] << 24;
/* FHDR - FCnt */
mote_fcnt = p->payload[6];
mote_fcnt |= p->payload[7] << 8;
/* basic packet filtering */
pthread_mutex_lock(&mx_meas_up);
meas_nb_rx_rcv += 1;
switch(p->status) {
case STAT_CRC_OK:
meas_nb_rx_ok += 1;
printf( “\nINFO: Received pkt from mote: %08X (fcnt=%u)\n”, mote_
addr, mote_fcnt );
if (!fwd_valid_pkt) {
pthread_mutex_unlock(&mx_meas_up);
continue; /* skip that packet */
}
break;
case STAT_CRC_BAD:
meas_nb_rx_bad += 1;
if (!fwd_error_pkt) {
pthread_mutex_unlock(&mx_meas_up);
continue; /* skip that packet */
}
break;
case STAT_NO_CRC:
meas_nb_rx_nocrc += 1;
if (!fwd_nocrc_pkt) {
pthread_mutex_unlock(&mx_meas_up);
continue; /* skip that packet */
}
break;
default:
MSG(“WARNING: [up] received packet with unknown status %u
(size %u, modulation %u, BW %u, DR %u, RSSI %.1f)\n”, p->status, p->size,
p->modulation, p->bandwidth, p->datarate, p->rssi);
pthread_mutex_unlock(&mx_meas_up);
continue; /* skip that packet */
// exit(EXIT_FAILURE);
}
meas_up_pkt_fwd += 1;
meas_up_payload_byte += p->size;
pthread_mutex_unlock(&mx_meas_up);
/* Start of packet, add inter-packet separator if necessary */
if (pkt_in_dgram == 0) {
buff_up[buff_index] = ‘{‘;
++buff_index;
} else {
buff_up[buff_index] = ‘,’;
buff_up[buff_index+1] = ‘{‘;
buff_index += 2;
}
Table 12 contd. ...
Connectivity 355
...Table 12 contd.
...Table 12 contd.
Thread Down
The Thread down (see Table 13) functionalities are (a) polling the server and enqueuing packets in the
JIT (Just in Time) Queue to send them to the server. Thread down uses a Radio Frequency channel and
sends one PPS pulse. A pulse per second (PPS or 1PPS) is an electrical signal that has a width of less
than one second and a sharply rising or abruptly falling edge that accurately repeats once per second. PPS
signals are output by radio beacons, frequency standards, other types of precision oscillators and some
GPS receivers. The goal of the PPS is to time the signals.
The 1 PPS output has a much lower jitter than anything a Microcontroller can do. In
some more demanding applications this pulse can be used to time things very accurately.
With some scientific grade GPS’s this 1 PPS output might be accurate to better than 1 nS.
Thread JIT
Checks Packets from the Thread Queue and sends them (see Table 14 and Table 15). In order to send the
packets, first, it acquires the lock to then collects the data and sends it (see table).
/* hardware access control and correction */
pthread_mutex_t mx_concent = PTHREAD_MUTEX_INITIALIZER; /* control access
to the concentrator */
Connectivity 357
/* --- ---------- */
void thread_down(void) {
int i; /* loop variables */
/* configuration and metadata for an outbound packet */
struct lgw_pkt_tx_s txpkt;
bool sent_immediate = false; /* option to sent the packet immediately */
/* local timekeeping variables */
struct timespec send_time; /* time of the pull request */
struct timespec recv_time; /* time of return from recv socket call */
/* data buffers */
uint8_t buff_down[1000]; /* buffer to receive downstream packets */
uint8_t buff_req[12]; /* buffer to compose pull requests */
int msg_len;
/* protocol variables */
uint8_t token_h; /* random token for acknowledgement matching */
uint8_t token_l; /* random token for acknowledgement matching */
bool req_ack = false; /* keep track of whether PULL_DATA was acknowledged
or not */
/* JSON parsing variables */
JSON_Value *root_val = NULL;
JSON_Object *txpk_obj = NULL;
JSON_Value *val = NULL; /* needed to detect the absence of some fields */
const char *str; /* pointer to sub-strings in the JSON data */
short x0, x1;
uint64_t x2;
double x3, x4;
/* variables to send on GPS timestamp */
struct tref local_ref; /* time reference used for GPS <-> timestamp
conversion */
struct timespec gps_tx; /* GPS time that needs to be converted to
timestamp */
/* beacon variables */
struct lgw_pkt_tx_s beacon_pkt;
uint8_t beacon_chan;
uint8_t beacon_loop;
size_t beacon_RFU1_size = 0;
size_t beacon_RFU2_size = 0;
uint8_t beacon_pyld_idx = 0;
time_t diff_beacon_time;
struct timespec next_beacon_gps_time; /* gps time of next beacon packet */
struct timespec last_beacon_gps_time; /* gps time of last enqueued beacon
packet */
int retry;
/* beacon data fields, byte 0 is Least Significant Byte */
int32_t field_latitude; /* 3 bytes, derived from reference latitude */
int32_t field_longitude; /* 3 bytes, derived from reference longitude */
uint16_t field_crc1, field_crc2;
/* auto-quit variable */
uint32_t autoquit_cnt = 0; /* count the number of PULL_DATA sent since the
latest PULL_ACK */
/* Just In Time downlink */
struct timeval current_unix_time;
struct timeval current_concentrator_time;
enum jit_error_e jit_result = JIT_ERROR_OK;
enum jit_pkt_type_e downlink_type;
/* set downstream socket RX timeout */
Table 13 contd. ...
358 Building Enterprise IoT Applications
...Table 13 contd.
void thread_jit(void) {
int result = LGW_HAL_SUCCESS;
struct lgw_pkt_tx_s pkt;
int pkt_index = -1;
struct timeval current_unix_time;
struct timeval current_concentrator_time;
enum jit_error_e jit_result;
enum jit_pkt_type_e pkt_type;
uint8_t tx_status;
while (!exit_sig && !quit_sig) {
wait_ms(10);
/* transfer data and metadata to the concentrator, and schedule TX */
gettimeofday(¤t_unix_time, NULL);
get_concentrator_time(¤t_concentrator_time, current_unix_time);
jit_result = jit_peek(&jit_queue, ¤t_concentrator_time, &pkt_index);
if (jit_result == JIT_ERROR_OK) {
if (pkt_index > -1) {
jit_result = jit_dequeue(&jit_queue, pkt_index, &pkt, &pkt_type);
if (jit_result == JIT_ERROR_OK) {
/* update beacon stats */
if (pkt_type == JIT_PKT_TYPE_BEACON) {
/* Compensate breacon frequency with xtal error */
pthread_mutex_lock(&mx_xcorr);
pkt.freq_hz = (uint32_t)(xtal_correct * (double)pkt.freq_hz);
MSG_DEBUG(DEBUG_BEACON, “beacon_pkt.freq_hz=%u (xtal_
correct=%.15lf)\n”, pkt.freq_hz, xtal_correct);
pthread_mutex_unlock(&mx_xcorr);
/* Update statistics */
pthread_mutex_lock(&mx_meas_dw);
meas_nb_beacon_sent += 1;
pthread_mutex_unlock(&mx_meas_dw);
Table 14 contd. ...
Connectivity 359
...Table 14 contd.
/* --------------------------------------------------------------------------
*/
/* --- ----------------- */
static void gps_process_sync(void) {
struct timespec gps_time;
struct timespec utc;
uint32_t trig_tstamp; /* concentrator timestamp associated with PPM pulse */
int i = lgw_gps_get(&utc, &gps_time, NULL, NULL);
/* get GPS time for synchronization */
if (i != LGW_GPS_SUCCESS) {
MSG(“WARNING: [gps] could not get GPS time from GPS\n”);
return;
}
/* get timestamp captured on PPM pulse */
pthread_mutex_lock(&mx_concent);
i = lgw_get_trigcnt(&trig_tstamp);
pthread_mutex_unlock(&mx_concent);
if (i != LGW_HAL_SUCCESS) {
MSG(“WARNING: [gps] failed to read concentrator timestamp\n”);
return;
}
/* try to update time reference with the new GPS time & timestamp */
pthread_mutex_lock(&mx_timeref);
i = lgw_gps_sync(&time_reference_gps, trig_tstamp, utc, gps_time);
pthread_mutex_unlock(&mx_timeref);
if (i != LGW_GPS_SUCCESS) {
MSG(“WARNING: [gps] GPS out of sync, keeping previous time reference\n”);
}
}
Thread Valid
Checks the time reference and calculate XTAL correction. In simple form, it performs validation.
/* --------------------------------------------------------------------------
*/
/* --- --------- */
void thread_valid(void) {
/* GPS reference validation variables */
long gps_ref_age = 0;
bool ref_valid_local = false;
double xtal_err_cpy;
/* variables for XTAL correction averaging */
unsigned init_cpt = 0;
double init_acc = 0.0;
double x;
/* main loop task */
while (!exit_sig && !quit_sig) {
wait_ms(1000);
/* calculate when the time reference was last updated */
pthread_mutex_lock(&mx_timeref);
gps_ref_age = (long)difftime(time(NULL), time_reference_gps.systime);
Connectivity 361
xtal_correct_ok = true;
pthread_mutex_unlock(&mx_xcorr);
++init_cpt;
} else {
/* tracking with low-pass filter */
x = 1 / xtal_err_cpy;
pthread_mutex_lock(&mx_xcorr);
xtal_correct = xtal_correct - xtal_correct/XERR_FILT_COEF + x/XERR_
FILT_COEF;
pthread_mutex_unlock(&mx_xcorr);
}
}
(a) You need UNIX libraries to compile the code (see Figure 57) [23]
(b) Install Cygwin or Install UNIIX Support on Windows
362 Building Enterprise IoT Applications
LoRalmpl.vcxproj
lora_plt_fwd.c
loragw_hal.h
Externals
Cygwin Install
F290
Download the latest version of Cygwin (see figure Cygwin) from https://www.cygwin.com/
Installing and Updating Cygwin for 64-bit versions of Windows
https://cygwin.com/install.html
Installation Notes30
• When installing packages for the first time, setup*.exe does not install every package. Only the minimal
base packages from the Cygwin distribution are installed by default, taking up about 100 MB.
• Clicking on categories and packages in the setup*.exe package installation screen allows you to select
what is installed or updated.
• Individual packages, like bash, gcc, less, etc., are released independently of the Cygwin DLL, so
the Cygwin DLL version is not useful as a general Cygwin release number. The setup*.exe utility
tracks the versions of all installed components and provides the mechanism for installing or updating
everything available from this site for Cygwin.
30
Cygwin Installation Notes: https://cygwin.com/install.html
:
Once you've installed your desired subset of the Cygwin distribution, setup*.exe will
Connectivity 363
remember what you selected, so rerunning the program will update your system with any new
Installation Steps
package releases.
Once you’ve installed your desired subset of the Cygwin distribution, setup*.exe will remember what you
selected, so rerunning the program will update your system with any new package releases.
Cygwin Setup
Continue totoaccept
Continue default
accept default Cygwin
Cygwin inputs:inputs: (see
(see Figure 59)Figure 257)
FigureFigure
259:61:
Cygwin desktop
Cygwin desktop Icon Icon
31
Github Cygwin references - https://github.com/openunix/cygwin
concentration, EMG and ECG.
In the next sections, we will explore a practical example: A low-cost IoT ECG system, which
enables doctors to have live remote access to a patient’s ECG. Connectivity 365
is what is called Electrocardiogram (also known as ECG or EKG). Figure 62 below illustrates what an
ECG looks like.
We
can capture a person’s ECG by placing electrodes in different positions on the body.
As you may have noted from Figure 62, the ECG is a wave that has a pattern that repeats itself. The
shape of that pattern will vary depending on the position of the electrodes on the body, but a very common
pattern
Our heartis thehas
oneone
known
mainasobjective:
PQRST complex,
Make theshown
bloodbelow
flowFigure
inside63.our body. It achieves that by
By measuring some characteristics of that shape (and also between consecutives shapes) we can have
contracting
access to dataandthat expanding its chambers
provides information about with the passing
our heart, of an
such as heart rateelectrical
and heart current. The
health condition.
Therefore, monitoring a person’s ECG can provide extremely useful information, such
measurement of that current is what is called Electrocardiogram (also known as ECG or EKG). as when a person
is having a heart attack or is showing some abnormal condition that can lead to severe outcomes if not
Figure 260
treated below illustrates what an ECG looks like. We can capture a person's ECG by placing
quickly.
ECG data,
electrodes due to itspositions
in different person uniqueness, can also be used as a biometric identification, the same way
on the body.
that fingerprints and the iris are used today.
ST
PR segment
segment T
P
Q
PR interval
S
QT interval
Analog-to-Digital converter connected between the AD8232 and the Raspberry Pi. We will be using an
ADS1115 for that purpose. Figure—Sensor component wiring illustrates the sensor component wiring
Table 16 below describes all items used in the sensor component.
The cloud component will receive the data sent by the Raspberry Pi, store it (for posterior access)
and forward it so the front-end component for visualization. The data can also be processed (transformed)
in order to remove noise and identify desired characteristics of the signal (such as normal/abnormal heart
beat). In this example, to make it simple for academic purposes, the server will receive the data and
forward it to the front-end.
The front-end is where the ECG can be visualized by the user. Our front-end will be a mobile app
that shows the data in a graphic.
Code
The code used in the Raspberry Pi and the Server (see Table 17 and Table 18) was created using Python
3.6 and requires RPi.GPIO and Adafruit-ADS1x15 libraries (which can be easily installed using pip).
The mobile app was developed using Lua language and Corona SDK framework.
Server Code
SERVER_PORT = 3421 # UDP port to be used on this server to receive the data
MOBILE_APP_IP = ‘192.168.1.59’ # IP of the mobile app that will receive the data
MOBILE_APP_PORT = 4532 # UDP port being used in the mobile app
# loading libraries
import socket
# initialization
s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
s.bind((‘’, SERVER_PORT))
while True:
# receiving data
data, address = s.recvfrom(1024)
value = data.decode()
print(“Received=”, value)
# saving data in database (not implemented in this example)
# add code to persist data here
# forwarding the data to the front end
byt=str(value).encode()
try:
s.sendto(byt, (MOBILE_APP_IP, MOBILE_APP_PORT))
except:
print(“Failed to send data to mobile app. Please check address/port and if it is
reachable.”)
Connectivity 367
RaspberryPi Code
Table 18: RaspberryPi Code
# Server information
SERVER_IP = ‘192.168.1.51’ # IP of the server that will receive the data
SERVER_PORT = 3421 # UDP port being used in the server
# loading libraries
import time
import Adafruit_ADS1x15
import RPi.GPIO as GPIO
import socket
# initialization
GPIO.setmode(GPIO.BCM)
GPIO.setup(4, GPIO.IN,GPIO.PUD_DOWN)
adc = Adafruit_ADS1x15.ADS1115()
gain = 2/3
bitToMilivoltRatio = 0.1875 # this value depends on the gain used.
adcChannel = 0
samplingRate = 60 # number of samples taken per second
s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
while True:
# Reading ECG data
value = adc.read_adc(adcChannel, gain=gain, data_rate=860) * bitToMilivoltRatio
print(value)
try:
# Sending data to server using UDP
byt=str(value).encode()
s.sendto(byt, (SERVER_IP, SERVER_PORT))
except:
print(“Failed
server. The to send. the
server then redirects Please
data check server address/port
to the front-end andSee
(a mobile app). if Figure
it is reachable.”)
262 below
# Pause for before continuing the loop
time.sleep(1/samplingRate)
illustrates the mobile app showing a data acquired from a real person using this system.
The communication between the components were done using UDP socket.
Due to academic purposes, the code and system were designed to be minimal and as simple as
UI
possible in order to facilitate its understanding. Several improvements can and should be made
The system presented shows a simple and low-cost option to remotely measure a person’s ECG. A person
connected to for
theactual deployment.
sensors would have the ECG data acquired and submitted to a cloud server. The server
then redirects the data to the front-end (a mobile app). See Figure 64 below illustrates the mobile app
showing a data acquired from a real person using this system.
Due to academic purposes, the code and system were designed to be minimal and as simple as possible
in order to facilitate its understanding. Several improvements can and should be made for actual deployment.
References
1 Bernard Marr. Why only one of the 5 Vs of big data really matters, MARCH 19, 2015, https://www.ibmbigdatahub.
com/blog/why-only-one-5-vs-big-data-really-matters, Access Date: July 2018
2 Yosi Fait. How The 5G Revolution Will Drive Future Innovations Of IoT, Sep 7, 2018, https://www.forbes.com/sites/
forbestechcouncil/2018/09/07/how-the-5g-revolution-will-drive-future-innovations-of-iot/#4b83e79d637e, Access
Date: December 2018
3 Samsung. IoT Solutions, 2018, https://www.samsung.com/global/business/networks/solutions/iot-solutions/Access
Date: December 2018
4 Mark Nottingham, RFC 7230, Hypertext Transfer Protocol (HTTP/1.1): Message Syntax and Routing, June 2014,
https://datatracker.ietf.org/doc/rfc7230/?include_text=1, Access Date: August 2018
5 Jesse James Garrett, Ajax: A new approach to Web Applications, 18 Feb 2015, https://courses.cs.washington.edu/
courses/cse490h/07sp/readings/ajax_adaptive_path.pdf, Access date: 08 Aug 2018
6 Eclipse Foundation, MQTT, CoAP and IoT Protocols, 2014, https://www.eclipse.org/community/eclipse_
newsletter/2014/february/article2.php, Access Date 18 Sep 2018
7 Carsten Bormann, CoAP Technologies, Implementations, 2016, http://coap.technology/impls.html, Access Date: 08
Nov 2018
8 H. Urunov, The constrained application protocol (coap) part 2, 01 June 2016, https://www.slideshare.net/
HamdamboyUrunov/the-constrained-application-protocol-coap-part-2?from_a ction=save, Access Date: 18 Sep 2018
9 Robert Davidson, Akiba, Carles Cufí, Kevin Townsend, Getting Started with Bluetooth Low Energy, May 2014, ISBN:
9781491900550, https://www.oreilly.com/library/view/getting-started-with/9781491900550/
10 Bluetooth, Protocol Specification, https://www.bluetooth.com/specifications/protocol-specifications, 2018
11 Dag Grini, RF Basics, RF For Non-Engineers, 2006, http://www.ti.com/lit/ml/slap127/slap127.pdf, Access Date:
12/02/2018
12 Texas Instruments, IoT Made Easy, http://www.ti.com/ww/en/wireless_connectivity/sensortag/
13 Android, Bluetooth Overview, https://developer.android.com/guide/topics/connectivity/bluetooth
14 Carol Geyer, OASIS, OASIS MQTT Internet of Things Standard Now Approved by ISO/IEC JTC1, 19 July 2016,
https://www.oasis-open.org/news/pr/oasis-mqtt-internet-of-things-standard-now-approved-by-iso-iec-jtc1, Access
Date: 08 Nov 2018
15 Carol Geyer,OASIS, MQTT Version 3.1.1 Plus Errata 01, 10 December 2015, http://docs.oasis-open.org/mqtt/mqtt/
v3.1.1/mqtt-v3.1.1.pdf, Access date: 30 Apr 2018
16 Python Software Foundation, PEP 418, Add monotonic time, performance counter, and process time functions,
26-March-2012, https://www.python.org/dev/peps/pep-0418/#rationale, Access Date: 06 Aug 2018
17 Nat Dunn, Python Clocks Explained, Aug 14, 2015, https://www.webucator.com/blog/2015/08/python-clocks-
explained/, Access Date: 06 Aug 2018
18 Peter Bright, Intel still beats Ryzen at games, but how much does it matter?, 17 Mar 2017, https://arstechnica.com/
gadgets/2017/03/intel-still-beats-ryzen-at-games-but-how-much-does-it-matter/, Access Date: 08 Nov 2018
19 John Ackermann, The TICC Timestamping/Time Interval Counter, 06-Feb-2017, https://www.febo.com/pages/TICC/,
Access Date: 08 Nov 2018
20 Maximum Integrated, Real-Time Clocks (ICs), 2018, https://www.maximintegrated.com/en/products/digital/real-time-
clocks.html, Access Date: 08 Nov 2018
21 LoRa Server, System Architecture, https://www.loraserver.io/overview/architecture/, Access Date: 08 Nov 2018
22 GITHub, LoRa Packet Forward, https://github.com/Lora-net/packet_forwarder, Access Date: 06 Aug 2018
23 Mark Funkenhauser, Pthread Support in Microsoft Windows Services for UNIX Version 3.5, 12/04/2007, https://docs.
microsoft.com/en-us/previous-versions/tn-archive/bb463209(v=technet.10), 06 Aug 2018
Chapter 10
Middleware
Real time processing deals with streams of data that are captured in real-time and processed with minimal
latency. The processing of the streams data is split on a distance basis: Closer to the source, Edge level,
and traditional cloud or high compute levels. Nevertheless, both processing architectures need a message
ingestion store to act as a buffer for messages, and to support scale-out processing, reliable delivery, and
other message queuing semantics.
For IoT events, IoT Data sources are ingested to Cloud systems for processing at Cloud level. The
Data sources are ingested into either topic based middle ware, such as Kafka, or inserted into database
for processing (see Figure 1).
In this chapter, we will go through the creation of simple Kafka based message system that ingests
data into and is processed by Spark or Scala based systems.
SQL A
()
SQL ()
F309
Figure 1: Data Ingestion
Message Architectures
The Message Event architectures use central messaging stream Hubs, such as the IoT Hub, to ingest
data in real-time. The events ingested into the IoT Hub are relayed to Stream servers such as Kafka (see
Figure 2) to be queued in the event architecture.1
1
Azure Reference Architecture - https://azure.microsoft.com/en-us/services/hdinsight/apache-kafka/
370 Building Enterprise IoT Applications
kafka
cars building
Azure gateway
service
STORM
Clickstream analytic Real-time applications
leads for trending now Azure VNet APACHE
F314
Figure 2: Message Event Architectures
The data from the Kafka topics are consumed by backend processors such as Spark to route analytics
engine and thereafter to database or insights delivery to the client.
Streaming Patterns
Streaming patterns relay on high throughput ingestion and Complex event processors. Events are ingested
into Stream processors at a high frequency and the events are processed through Complex Event processors
with very low latency. The subsequent operations results in event processing and analytics (see Figure 3).
Long term
Business storage
ents
Apps Ev
High throughput
Low latency
event ingestion
Events Events complex Events
(~million
event processing
events/sec)
Costom Real-time
Apps applications
Ev
en
ts
Sensors
and devices
F315
Real-time
dashboards
Purpose Technology
Apache Kafka
High throughput Event
Azure Event Hubs
Ingestion
Amazon Kinesis Firehose
Apache Storm
Apache Heron
Apache Spark Streaming
Azure Stream Analytics
Microsoft Orleans
Complex Event
Apache Samza
processing
Apache Flink
Apache Kafka Streams
Google Millwheel
Google Cloud Dataflow
Amazon Kinesis Analytics
Apache Kafka
Apache Kafka is a distributed streaming platform. A Streaming platform has the following characteristics
(see Figure 4) [1]:
• Publish and Subscribe to stream of records. For instance, a central message topic publishes restful
services to be consumed by clients. In our case, Hanumayamma Dairy IoT Sensor uses Kafka to
publish real-time events.
• Persistent of Stream records in a fault-tolerant durable way.
• Process stream of records as they occur.
Long term
Business ts storage
Azure n
Apps Eve
Stream Analysis
Event hubs
Sensors
and devices
F316
Real-time
dashboards
Figure 4: Kafka Role
372 Building Enterprise IoT Applications
Anatomy of a topic
Partition 1 1 1
0 1 2 3 4 5 6 7 8 9
0 0 1 2
Partition
0 1 2 3 4 5 6 7 8 9 Writes
1
Figure 268: Kafka Topic
Partition 1 1 1
Partition and offset
2
0 1 2 3 4 5 6 7 8 9
0 1 2
F318
records that are continually added to. The records are identified by a unique ID, known as an
Partition and offset
offset (see Figure
Partition has two269).
unique attributes: (1) it is ordered and (2) it has an immutable sequence of records that
are continually added to. The records are identified by a unique ID, known as an offset (see Figure 7).
ǣ
• Download Server JRE according to your OS and CPU architecture
ʹͳ͵͵ͳͷͷǤ
374 • Building
Download and install
Enterprise 7-zip fromǣȀȀǤǦǤȀǤ
IoT Applications
Zookeeper Installation3
Apache ZooKeeper is an effort to develop and maintain an open-source server which enables highly reliable
distributed coordination.4 ZooKeeper is a centralized service for maintaining configuration information,
naming, providing distributed synchronization, and providing group services. Distributed applications,
for instance Kafka, use some or all forms of Zookeeper. Each time they are implemented, there is a lot
of work that goes into fixing the bugs and race conditions that are inevitable. Because of the difficulty of
implementing these kinds of services, applications initially usually skimp on them, which make them brittle
3
Zookeeper installation: https://dzone.com/articles/running-apache-kafka-on-windows-os
4
Zookeeper Web reference: https://zookeeper.apache.org/
Middleware 375
in the presence of change and difficult to manage. Even when done correctly, different implementations
of these services lead to management complexity when the applications are deployed.
Please follow the steps to install Zookeeper:
1. Download Zookeeper from http://zookeeper.apache.org/releases.html
After successful download, please extract zookeeper-3.4.13.tar.gz file.
2. Go to your Zookeeper config directory. For instance, C:\zookeeper\zookeeper-3.4.13\conf
3. Rename file “zoo_sample.cfg” to “zoo.cfg”
4. Open zoo.cfg in any text editor (see Table 2), like notepad, but preferbly notepad++.
5. Find & edit dataDir=/tmp/zookeeper to :\zookeeper-3.4.7\data
Congratulations, your Zookeeper is up and running on port 2181 (see Figure 271)!
Setting Kafka
1. Download Kafka Binaries from http://kafka.apache.org/downloads.html
a. Download and Unzip Kafka tarzip file.
b. Go to your Kafka config directory. For me its C:\kafka\kafka_2.12-2.0.0\config
2. Edit file “server.properties” (see Table 3)
...Table 3 contd.
...Table 3 contd.
Figure 272: Start Kafka Server Figure 10: Start Kafka Server
4. If everything went fine, your command prompt will look like Figure 273. It will start
Kafka Server.
Figure 272: Start Kafka Server
4. If everything went fine, your command prompt will look like Figure 273. It will start
380 Building Enterprise IoT Applications
Kafka Server.
Figure 273: Kafka Server (running) Figure 11: Kafka Server (running)
prompt.
1. Go to your Kafka installation directory C:\kafka\kafka_2.12-2.0.0\
2. Open a command prompt here by pressing Shift + right click and choose “Open command window
here” option, Now, enter comman:
3. Now type .\bin\windows\kafka-server-start.bat.\config\server.properties and press Enter (see
Figure 10).
.\bin\windows\kafka-server-start.bat .\config\server.properties
4. If everything went fine, your command prompt will look like Figure 11. It will start Kafka Server.
5. Now your Kafka is up and running, you can create topics to store messages. Also, we can produce or
consume data from Java or Scala code or directly from the command prompt.
Creating Topic
1. Now create a topic with name “ent_iot_middleware” and replication factor 1, as we have only one
Kafka server running. If you have a cluster with more than 1 Kafka server running, you can increase
the replication-factor accordingly , which will increase the data availability and act like a fault-tolerant
system.
2. Open a new command prompt in the location C:\kafka_2.11-0.9.0.0\bin\windows
3. Type the following command and hit Enter (see Figure 12):
have only one Kafka server running. If you have a cluster with more than 1 Kafka
server running, you can increase the replication-factor accordingly , which will
increase
Figure 274: the data
Kafka Topic Figure
availability and act12: Kafka
like Topic
a fault-tolerant system.
2. OpenaaConsole
Creating new command prompt inand
Producer the location
ConsumerC:\kafka_2.11-0.9.0.0\bin\windows
to Test Server
1. 3. Type
Open thecommand
a new following command
prompt and hit Enter
in the location (see Figure 274):
C:\kafka\kafka_2.12-2.0.0\bin\windows
1. Open a new command prompt in the location C:\kafka\kafka_2.12-2.0.0\bin\windows
2. To start a producer, type the following command:
2. To start a producer, type the following command:
kafka-topics.bat --create --broker-list
--zookeeperlocalhost:9092
localhost:2181 --replication-factor 1 --partitions 1 --
kafka-console-producer.bat --topic ent_iot_middleware
topic ent_iot_middleware
The producer is ready! (see Figure 13)
kafka-console-producer.bat --broker-list localhost:9092 --topic ent_iot_middleware
5. Now type anything in the producer command prompt and press Enter, and you should be able to see
The producer is ready! (see Figure 275)
the message in the other consumer command prompt.
3. Again, openis aasnew
There old command prompt(0.8.2
Kafka consumer in theand
same location
earlier) and as C:\kafka\kafka_2.12-
a new Kafka consumer (0.9
2.0.0\bin\windows
and above). For a great description of how the new consumer works see the original
announcement blog here
4. Nowhttps://www.confluent.io/blog/tutorial-getting-started-with-the-new-apache-kafka-0-9-
start a consumer by typing the following command (see Figure 276):
consumer-client/
kafka-console-consumer.bat --bootstrap-server
The old consumer would localhost:9092
connect to zookeeper --topic
but still would fetch ent_iot_middleware -
all messages from Kafka.
-from-beginning
The new consumer has no zookeeper dependency and does not connect to zookeeper at all.
The console-producer and console-consumer supports both the old an new apis depending
on which options you give it. The example console-consumer you have provided is the old
consumer because it specifies --zookeeper instead of --bootstrap-server
5. Now type anything in the producer command prompt and press Enter, and you should
be able to see the message in the other consumer command prompt.
Middleware 383
Installing
Installingcollected
collectedpackages: kafka-python
packages: kafka-python
Successfully
Successfullyinstalled kafka-python-1.4.4
installed kafka-python-1.4.4
@author: cvuppalapati
"""
384 Building Enterprise IoT Applications
class Producer():
producer = KafkaProducer(bootstrap_servers=’courtsnapdemo.
cloudapp.net:9092’)
producer.send(‘ent_iot_middleware’, b”Hello World”)
time.sleep(1)
producer.close()
def main():
Producer()
Python Code—Consumer
Please see Table 4 for Kafka consumer code. The output of the code, see Figure 15.
print(“Connection estalished”)
for message in consumer:
print(“inside message”)
# message value and key are raw bytes -- decode if necessary!
# e.g., for unicode: `message.value.decode(‘utf-8’)`
print (“%s:%d:%d: key=%s value=%s” % (message.topic, message.partition,
message.offset, message.key,
message.value))
Middleware 385
...Table 5 contd.
time.sleep(1)
producer.close()
class Consumer(multiprocessing.Process):
def __init__(self):
multiprocessing.Process.__init__(self)
self.stop_event = multiprocessing.Event()
def stop(self):
self.stop_event.set()
def run(self):
consumer = KafkaConsumer(bootstrap_servers=’courtsnapdemo. cloudapp.net:9092’,
auto_offset_reset=’earliest’,
consumer_timeout_ms=1000)
consumer.subscribe([‘ent_iot_middleware’])
if __name__ == “__main__”:
logging.basicConfig(
format=’%(asctime)s.%(msecs)s:%(name)s:%(thread)d:%(levelname)s:%(process)d:%(message)s’,
level=logging.INFO
)
main()
Apache Spark
Apache Spark is a unified analytics engine for big data processing. Apache Spark extends the MapReduce
model in order to provide efficient support for computing, interactive queries and streaming process. The
computing is platform designed to provide high speed computation and general purpose.
One of the main features that Spark offers for speed is the ability to run competition in memory and
avoid unnecessary I/O operations with disk.
Middleware 387
On the generality side, Spark offers is the ability to chain the tasks even at an application programming
level without writing onto the disks at all or minimizing the number of writes to the disks. In addition, it
reduces the management burden of maintaining separate tools.
The driveratprogram
Spark Core creates the DAG (directed acyclic graph) or execution plan (job) for your
program. Once
Spark comes thea DAG
with is created,
very advanced the driver
Directed divides
acyclic this DAG
graph(DAG) data into severalengine.
processing tasks. The
TheDAG
driver
in
mathematical idiom consists of a set of vertices and directed edges connecting them. The tasks are executed
as per theisDAG
program layout. The
responsible forin-memory
convertingdata processing,
a user program combined withof
into units itsphysical
DAG-based data processing
execution called
engine, makes Spark very efficient.
tasks. Every
Thesespark
tasksapplication
are givenconsisting of a driver
to executors program launches
for execution. various
At a high level,parallel operations
all Spark on a
programs
cluster. Driver programs access Spark through a Spark Context Object (which establishes a connection
between
follow application
the and computing cluster. In the shell, a Spark Context is automatically created for you
same structure.
as the variable called sc).
The driver program creates the DAG (directed acyclic graph) or execution plan (job) for your
program. Once the DAG is created, the driver divides this DAG into several tasks. The driver program is
responsible for converting a user program into units of physical execution called tasks. These tasks are
The following are the steps to install spark and run spark through python, using jupyter
given to executors for execution. At a high level, all Spark programs follow the same structure.
The following are the steps to install spark and run spark through python, using jupyter notebook
notebook
and PySparkand(see
PySpark
Figure (see
16) Figure 278)
Figure278:
Figure 16: Spark
Spark Context
Context
WinUtils
Download winutils.exe from https://github.com/steveloughran/winutils/blob/master/hadoop 2.6.0/bin/
winutils.exe?raw=true
To setup HDFS
Environment Variables Setup
Create environment variables (see Table 6) for SPARK_HOME and HADOOP_HOMEand related PATH
variables. You can do this in the Command Prompt
setx SPARK_HOME C:\opt\spark\spark-2.1.0-bin-hadoop2.7
• setx HADOOP_HOME C:\opt\spark\spark-2.1.0-bin-hadoop2.7
• setx PYSPARK_DRIVER_PYTHON ipython
• setx PYSPARK_DRIVER_PYTHON_OPTS notebook
Name Value
SPARK_HOME D:\spark\spark-2.2.1-bin-hadoop2.7
HADOOP_HOME D:\spark\spark-2.2.1-bin-hadoop2.7
PYSPARK_DRIVER_PYTHON jupyter
PYSPARK_DRIVER_PYTHON_OPTS notebook
6) Activate your Anaconda virtual environment with the version of Python that you’d like to use. You
could make a new environment (recommended!) to try things out, or YOLO just > conda install
pyspark into your main Python environment.
7) You need to enable access to the default scratch directory for Hive. First, make sure the directory C:\
tmp\hive is created; if it doesn’t exist, create it.
Second, you need to give it permission to access winutils.exe. Navigate back to where you put this
.exe file, then run the permission command
> cd c:\hadoop\bin
> winutils.exe chmod -R 777 C:\tmp\hive
8) (Optional, if see Java related error in step C) Find the installed Java JDK folder from step A5, for
example, D:\Program Files\Java\jdk1.8.0_121, and add the following environment variable
Name Value
JAVA_HOME D:\Progra~1\Java\jdk1.8.0_121
9) Running PySpark in Jupyter Notebook
a. To run Jupyter notebook, open Windows command prompt or Git Bash and run jupyter notebook.
If you use Anaconda Navigator to open Jupyter Notebook instead, you might see a Java gateway
process exited before sending the driver its port number error from PySpark in step C. Fall back
to Windows cmd if it happens.
b. Once inside Jupyter notebook, open a Python 3 notebook (see Figure 17)
Standalone Application
Spark Standalone cluster (aka Spark deploy cluster or standalone cluster) is the default distribution of
Apache Spark and it is the easiest way to run your Spark applications in a clustered environment in many
cases. Spark can be linked into standalone application is either using java, Scala, or Python. The main
might see a Java gateway process exited before sending the driver its port number error from
b. Once inside Jupyter notebook, open a Python 3 notebook (see Figure 279)
Middleware 389
difference from using it in the shell is that you need to initialize your own Spark Context. After that, the
API is the same.
Initializing a SparkContext:
The first step to use spark is configuring the spark by importing spark packages in your program and
create a SparkContext. It allows your Spark Application to access Spark Cluster with the help of Resource
Manager. The resource manager can be one of these three—Spark Standalone, YARN, Apache Mesos.
If you want to create SparkContext, first SparkConf should be made. The SparkConf has a configuration
parameter that our Spark driver application will pass to SparkContext. Some of these parameters defines
properties of Spark driver application, while some are used by Spark to allocate resources on the cluster,
like the number, memory size, and cores used by the executor running on the worker nodes.
Example: Initializing Spark in Python
from pyspark import SparkConf, SparkContext
conf = SparkConf().setMaster(“local”).setAppName(“My App”)
sc = SparkContext(conf = conf)
1) setMaster API allows us to connect to the cluster. Local runs Spark on the local machine, without
connecting to a cluster.
2) An application name will identify your application on the cluster manager’s UI.
Spark Context provides the parallelize () method. It is a quick way to create a your own RDDs in spark
shell and perform operations on them. This method is rarely used outside testing and prototyping because
it requires having the entire dataset on one machine.
import pyspark
from pyspark.sql import SparkSession
spark = SparkSession.builder.getOrCreate()
df = spark.sparkContext.parallelize([(“user1”,52),(“user2”,75),(“us
er3”,82), (“user4”,65),(“user5”,85)])
df.collect()
Output:[(‘user1’, 52), (‘user2’, 75), (‘user3’, 82), (‘user4’, 65),
(‘user5’, 85)]
csvRDD = spark.read.csv(“path/of/csv/file”).rdd
textRDD = spark.read.textFile(“path/of/text/file”).rdd
jsonRDD = spark.read.json(“path/of/json/file”).rdd
DataFrame
DataFrames generally refer to a data structure, which is tabular in nature. DataFrames are designed to
process a large collection of structured and semi-structured data. Observations in Spark DataFrame are
organized under named columns, which helps Apache Spark understand the schema of a Dataframe. This
helps Spark optimize the execution plan on these queries. It can also handle petabytes of data.
DataFrame provides different operations similar to a table in a relational database. DataFrame supports
operations like insert, create, update, delete, join, group by, filter, Sort and different mathematical operations.
import pyspark
from pyspark.sql import SparkSession
spark = SparkSession.builder.getOrCreate()
l = [(‘Alice’, 1)]
df = spark.createDataFrame(l, [‘name’, ‘age’])
df.show()
treated as a continuous series of batch computations on small batches of data. Spark Streaming
receives data from various input sources and groups it into small batches. New batches are
created at regular time intervals. The size of batches is determined by a parameter called batch
Middleware 391
interval. The batch interval is typically 500 milliseconds and several seconds. DStreams
How Spark Streaming Works?
support output
Sparkoperations. Output
Streaming is Spark’s operations
model for acting on are like
data as soonRDD actions
as it arrives. and output
For example, is periodically
if you want to
track real time behavior of a user based on sensor data and provide recommendations about his/her health
in real time.
written to the external
Like spark,system.
spark streaming uses an abstraction called DStreams or discretized streams. A DStream
is a sequence of data arriving over time. Internally, each DStream is represented as a sequence of RDDs
arriving at each time step. When we apply a transformation on Dstreams, this yields a new DStream, and
For each input source, Spark Streaming launches task running components called receivers,
output operations, which write data to an external system. DStreams provide many of the same operations
available on RDDs, plus new operations related to time, such as sliding windows.
which run within the application’s executors that collect data from the input source and save it
Architecture and Abstraction
as RDDs. These
Spark receive
Streaming the inputadata
implements and
“batch” replicate
architecture, it (by
where default)computation
the streaming to another executor
is treated as a for fault
continuous series of batch computations on small batches of data. Spark Streaming receives data from
various
tolerance. This input
data issources
storedandingroups it into small of
the memory batches. New batches are
the executors and created
the atdriver
regular program
time intervals.then Spark
The size of batches is determined by a parameter called batch interval. The batch interval is typically 500
milliseconds and several seconds. DStreams support output operations. Output operations are like RDD
periodicallyactions
runs and
jobs to process
output thiswritten
is periodically datatoand combine
the external it with RDDs from previous time steps
system.
For each input source, Spark Streaming launches task running components called receivers, which
run within the application’s executors that collect data from the input source and save it as RDDs. These
(see Figure 280).
receive the input data and replicate it (by default) to another executor for fault tolerance. This data is stored
in the memory of the executors and the driver program then Spark periodically runs jobs to process this
data and combine it with RDDs from previous time steps (see Figure 18).
References
1. The Apache Software Foundation, Apache Kafka Documentation, 2016, https://kafka.apache.org/documentation/
Access Date12/25/2018
2. Jay Kreps. Benchmarking Apache Kafka: 2 Million Writes Per Second (On Three Cheap Machines). April 27 2014,
https://engineering.linkedin.com/kafka/benchmarking-apache-kafka-2-million-writes-second-three-cheap-machines,
Access Date12/25/2018
3. Raghav Mohan. Streaming Big Data on Azure with HDInsight Kafka, Storm and Spark. September 2018, https://www.
google.com/url?sa=t&rct=j&q=&esrc=s&source=web&cd=4&ved=2ahUKEwi_2P-W75jeAhWoITQIHcimAcoQFjA
DegQIBxAC&url=https%3A%2F%2Ffanyv88.com%3A443%2Fhttps%2F8gportalvhdsf9v440s15hrt.blob.core.windows.net%2Fignite2017%2Fsession-
presentations%2FBRK3320.PPTX&usg=AOvVaw2i9Of6LtC9g7qpPmfnSENG , Access Date12/25/2018
4. Michael Galarnyk. Install Spark on Windows (PySpark). Apr 2, 2017, https://medium.com/@GalarnykMichael/install-
spark-on-windows-pyspark-4498a5d8d66c, Access date: August 06, 2018
5. Lauren Oldja. Installing Apache Spark (PySpark): The missing “quick start” guide for Windows, Jan 28, 2018, https://
medium.com/@loldja/installing-apache-spark-pyspark-the-missing-quick-start-guide-for-windows-ad81702ba62d,
Access Date12/25/2018
6. Chang Hsin Lee. How to Install and Run PySpark in Jupyter Notebook on Windows. December 30, 2017, https://
changhsinlee.com/install-pyspark-windows-jupyter/, Access date: December 27, 2018
7. Dataflair Team. Spark Streaming Tutorial for Beginners. MARCH 11, 2017, https://data-flair.training/blogs/apache-
spark-dstream-discretized-streams/, January 08, 2018
Chapter 11
Cloud and IoT
Cloud computing is a model for enabling ubiquitous, convenient, on-demand network access to a shared
pool of configurable computing resources (e.g., networks, servers, storage, applications, and services) that
can be rapidly provisioned and released with minimal management effort or service provider interaction
[1] (please Figure 1). This cloud model is composed of five essential characteristics, three service models,
and four deployment models.1
Cloud provider
Cloud
Cloud Service orchestration broker
consumer
Service layer Cloud service
management
SaaS
Service
intermediation
Cloud PaaS Business
Auditor support
Security
IaaS
Privacy
Service
Security aggregation
audit Resource abstraction and Provisioning/
control layer configuration
Privacy Service
Physical resource layer
impact audit arbitrage
Hardware Portability/
interoperability
Performance Facility
audit
Cloud carrier
1
F329
NIST Cloud Reference models - https://ws680.nist.gov/publication/get_pdf.cfm?pub_id=909505
394 Building Enterprise IoT Applications
Public clients
accessing the cloud
over a network
A cloud provider
Boundary
controller
F F
OF OF
F F
OF OF
New hardware
Inside
Outside
Old or defective
hardware Consumer’s facility
F330
2
Cloud Computing Synopsis - https://nvlpubs.nist.gov/nistpubs/Legacy/SP/nistspecialpublication800-146.pdf
3
Fog Compute - https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.500-325.pdf
Cloud and IoT 395
Contextual location awareness, and low latency: Fog/Edge computing offers the lowest-possible latency
due to the fog nodes’ awareness of their logical location in the context of the entire systems and of the
latency costs for communicating with other nodes. The origins of fog computing can be traced back to
early proposals supporting endpoints with rich services at the edge of the network, including applications
with low latency requirements [3]. Because fog nodes are often co-located with the smart end-devices,
analysis and response to data generated by these devices is much quicker than from a centralized cloud
service or data center. For IoT Data Analytics platform, the Cloud platform should match the compute and
response standards as required by Edge compute (please see Figure 3).
Centralized
Services
(Cloud)
Tens
Latency
Data mining
Fog computing
analytics
Thousends
Mist computing
Sensing
Cerrelation Control
Geographical distribution: In sharp contrast to the more centralized cloud, the services and applications
targeted by the fog computing demand widely, but geographically-identifiable, distributed deployments.
For instance, the fog computing will play an active role in delivering high quality streaming services to
moving vehicles, through proxies and access points geographically positioned along highways and tracks.
Heterogeneity: Fog computing supports the collection and processing of data of different form factors,
acquired through multiple types of network communication capabilities.
Interoperability and federation: Seamless support of certain services (real-time streaming services are a
good example) requires the cooperation of different providers. Hence, fog computing components must
be able to interoperate, and services must be federated across domains.
Real-time interactions. Fog computing applications involve real-time interactions rather than batch pro-
cessing
The following IoT Capabilities4 management is required for connecting IoT with the Cloud:
Device to Cloud Message: Device to Cloud message involves sending constant messages from IoT de-
vices to the Cloud. For example, Dairy IoT Sensor posting messages every hour to the Cloud platform.
Telemetry time series and alerts. For example, 256-KB sensor data batches sent every 5 minutes. Devices
to Cloud message feature expects the cloud messaging to be reliable and available 24×7, 365 days.
4
IoT Capabilities - https://docs.microsoft.com/en-us/azure/iot-hub/iot-hub-compare-event-hubs
396 Building Enterprise IoT Applications
Protocols: HTTPS, AMQP, AMQP over web Sockets: Cloud Service management has to handle HTTPS,
AMQP and Web Sockets seamlessly in order to support various devices and device form factors with
constrained or non-constrained operating environments.
• HTTPS: Hypertext transfer Protocol Secure—this is for securely transferring data between Web
Servers and Web Clients on a Secure channel over port number 443 and firewall friendly.
• AMQP: AMQP, which stands for Advanced Message Queuing Protocol, was designed as an open
replacement for existing proprietary messaging middleware. Two of the most important reasons to use
AMQP are reliability and interoperability. As the name implies, it provides a wide range of features
related to messaging, including reliable queuing, topic-based publish-and-subscribe messaging,
flexible routing, transactions, and security. AMQP exchanges route messages directly, in fanout form,
by topic, and based on headers.
• Web Sockets: WebSocket makes real-time communication much more efficient. You can always
use polling (and sometimes even streaming) over HTTP in order to receive notifications over HTTP.
However, WebSocket saves bandwidth, CPU power, and latency. WebSocket is an innovation in
performance. WebSocket makes communication between a client and server over the Web much
simpler.
Protocols MQTT and MQTT Web Sockets: Message Queue Telemetry protocol is for the IoT device com-
munication purposes with limited footprint and processing capacities needed.
Per-device identity: IoT Cloud and Data Analytics platform should enable support for per device identity.
This includes device catalogue, master key management, authentication, authorization, PKI and other
security processes.
File Upload from Devices: This is particularly important for device operation, diagnostics and remote
management purposes. Many embedded devices maintain state machine operation semantics and having
per device upload helps in solving device provisioning and operational challenges.
Device Twin and device management: Device twin is a sensor connected physical asset that is studied
and processed for improving design. Device Twin requires huge data and analytics support in order to be
successful.
IoT Edge: IoT Edge performs data collection and analytics on data in motion. IoT Edge needs to be fast
and must support low latency operations.
• Data Storage
o In-memory
o Traditional
• Advanced Analytics
o Predictive
o Prognostic
• Visualization
Visualization &
Data sources Data collection Data ingestion Data storage Advanced analytics consumption
Machine Visual
Transactional data Batch learning dashboards
systems collection
Batch mode Raw data
flow Batch data processing store
topic n job n
Predictive
analytics API
IOT systems Backup and recovery Data catalogue Data lineage and quality
Data processing
(Feature engineering)
Processing engine
ERP
databases Preprocessing Sample Training
Stream data selection testing set
processing
platform
f(x) f(x)
Clustering Learning
F333
Ecosystem
Simulation IT stack management
Operating model
5
Achieving business impact with the data - https://www.mckinsey.com/~/media/mckinsey/business%20functions/
mckinsey%20analytics/our%20insights/achieving%20business%20impact%20with%20data/achieving-business-
impact-with-data_final.ashx
Cloud and IoT 399
Data must be thought of as the entire process of collecting, linking, cleaning, enriching, and augmenting
internal information (potentially with additional external data sources). In addition, the security and privacy
(e.g., GDPR) of the data throughout the process are fundamental.6
Analytics describes the set of digital methodologies (e.g., software) deployed to extract insights from
data as well as the talent (e.g., data engineers and data scientists) capable of developing and applying
these methods.
IT is the technical layer enabling the storing and processing of data, e.g., data lakes and two-speed
IT architecture.
People from the front lines of sales to deep within the business are needed in order to run an analytics
operation that turns data into insights and successfully implements those insights in the business. The
crucial capability in today’s Big Data world is being able to “translate” analytics- and data-driven insights
into business implications and actions.
Processes must be assessed for their ability to deliver at scale. Some old processes might need to be
adapted, some might need to be fully automated, and others might need to be made more agile.
Capturing value from data requires excellence in each element of each link of the “insights value chain”.
After reading this chapter, you should able to include and integrate:
• Cloud and IoT Systems
• Design Fault tolerant IoT
References
1. Fang Liu, Jin Tong, Jian Mao, Robert Bohn, John Messina, Lee Badger and Dawn Leaf, NIST Cloud Computing
Reference Architecture, Sep 2011, https://ws680.nist.gov/publication/get_pdf.cfm?pub_id=909505, Access Date: 18
Sep 2018
2. Lee Badger, Tim Grance, Robert Patt-Corner, and Jeff Voas, Cloud Computing Synopsis and Recommendations, May
2012, https://nvlpubs.nist.gov/nistpubs/Legacy/SP/nistspecialpublication800-146.pdf, Access Date: April 2018
3. Michaela Iorga, Larry Feldman, Robert Barton, Michael J. Martin, Nedim Goren and Charif Mahmoudi, Fog Computing
Conceptual Model, March 2018, https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.500-325.pdf, Access
Date: Sep 2018
4. Kelly Gremban, Reza Sherafat and et al., Connecting IoT Devices to Azure: IoT Hub and Event Hubs, March 2018,
https://docs.microsoft.com/en-us/azure/iot-hub/iot-hub-compare-event-hubs, Access Date: Sep 2018
5. Carlton E. Sapp, Preparing and Architecting for Machine Learning, 17 January 2017, https://www.gartner.com/binaries/
content/assets/events/keywords/catalyst/catus8/preparing_and_architecting_for_machine_learning.pdf, Access Date:
Feb 2018
6. Niko Mohr and Holger Hürtgen, Achieving business impact with data, April 2018, https://www.mckinsey.com/~/
media/mckinsey/business%20functions/mckinsey%20analytics/our%20insights/achieving%20business%20impact%20
with%20data/achieving-business-impact-with-data_final.ashx, Access Date: Sep 2018
6
Business Impact with the data
Chapter 12
Future
Appendix A: bench_time.c
Reading a hardware clock has a cost. The following table compares the performance of different hardware
clocks on Linux 3.3 with Intel Core i7-2600 at 3.40GHz (8 cores). The bench_time.c program was used
to fill these tables1 [PEP0418].
/*
* Benchmark program written for the PEP 418.
*
* gcc bench_time.c -O3 -lrt -o bench_time && ./bench_time
*/
#include <time.h>
#include <stdio.h>
#include <sys/time.h>
#ifdef CLOCK_REALTIME
# define HAVE_CLOCK_GETTIME
#else
typedef int clockid_t;
#endif
#define NRUN 5
#define NLOOP 100000
#define UNROLL(expr) \
expr; expr; expr; expr; expr; expr; expr; expr; expr; expr
#define NUNROLL 10
#ifdef HAVE_CLOCK_GETTIME
typedef struct {
const char *name;
clockid_t identifier;
} CLOCK;
CLOCK clocks[] = {
#ifdef CLOCK_REALTIME_COARSE
{“CLOCK_REALTIME_COARSE”, CLOCK_REALTIME_COARSE},
#endif
#ifdef CLOCK_MONOTONIC_COARSE
{“CLOCK_MONOTONIC_COARSE”, CLOCK_MONOTONIC_COARSE},
#endif
#ifdef CLOCK_THREAD_CPUTIME_ID
{“CLOCK_THREAD_CPUTIME_ID”, CLOCK_THREAD_CPUTIME_ID},
#endif
1
PEP0418 - https://www.python.org/dev/peps/pep-0418/#rationale
402 Building Enterprise IoT Applications
#ifdef CLOCK_PROCESS_CPUTIME_ID
{“CLOCK_PROCESS_CPUTIME_ID”, CLOCK_PROCESS_CPUTIME_ID},
#endif
#ifdef CLOCK_MONOTONIC_RAW
{“CLOCK_MONOTONIC_RAW”, CLOCK_MONOTONIC_RAW},
#endif
#ifdef CLOCK_VIRTUAL
{“CLOCK_VIRTUAL”, CLOCK_VIRTUAL},
#endif
#ifdef CLOCK_UPTIME_FAST
{“CLOCK_UPTIME_FAST”, CLOCK_UPTIME_FAST},
#endif
#ifdef CLOCK_UPTIME_PRECISE
{“CLOCK_UPTIME_PRECISE”, CLOCK_UPTIME_PRECISE},
#endif
#ifdef CLOCK_UPTIME
{“CLOCK_UPTIME”, CLOCK_UPTIME},
#endif
#ifdef CLOCK_MONOTONIC_FAST
{“CLOCK_MONOTONIC_FAST”, CLOCK_MONOTONIC_FAST},
#endif
#ifdef CLOCK_MONOTONIC_PRECISE
{“CLOCK_MONOTONIC_PRECISE”, CLOCK_MONOTONIC_PRECISE},
#endif
#ifdef CLOCK_REALTIME_FAST
{“CLOCK_REALTIME_FAST”, CLOCK_REALTIME_FAST},
#endif
#ifdef CLOCK_REALTIME_PRECISE
{“CLOCK_REALTIME_PRECISE”, CLOCK_REALTIME_PRECISE},
#endif
#ifdef CLOCK_SECOND
{“CLOCK_SECOND”, CLOCK_SECOND},
#endif
#ifdef CLOCK_PROF
{“CLOCK_PROF”, CLOCK_PROF},
#endif
{“CLOCK_MONOTONIC”, CLOCK_MONOTONIC},
{“CLOCK_REALTIME”, CLOCK_REALTIME}
};
#define NCLOCKS (sizeof(clocks) / sizeof(clocks[0]))
void bench_clock_gettime(clockid_t clkid)
{
unsigned long loop;
struct timespec tmpspec;
for (loop=0; loop<NLOOP; loop++) {
UNROLL( (void)clock_gettime(clkid, &tmpspec) );
}
}
#endif /* HAVE_CLOCK_GETTIME */
void bench_time(clockid_t clkid)
Appendix 403
{
unsigned long loop;
for (loop=0; loop<NLOOP; loop++) {
UNROLL( (void)time(NULL) );
}
}
void bench_usleep(clockid_t clkid)
{
unsigned long loop;
for (loop=0; loop<NLOOP; loop++) {
UNROLL( (void)usleep(1000) );
}
}
void bench_gettimeofday(clockid_t clkid)
{
unsigned long loop;
struct timeval tmpval;
for (loop=0; loop<NLOOP; loop++) {
UNROLL( (void)gettimeofday(&tmpval, NULL) );
}
}
void bench_clock(clockid_t clkid)
{
unsigned long loop;
for (loop=0; loop<NLOOP; loop++) {
UNROLL( (void)clock() );
}
}
void benchmark(const char *name, void (*func) (clockid_t clkid), clockid_t
clkid)
{
unsigned int run;
double dt, best;
#ifdef HAVE_CLOCK_GETTIME
struct timespec before, after;
#else
struct timeval before, after;
#endif
struct timeval tmpval;
best = -1.0;
for (run=0; run<NRUN; run++) {
#ifdef HAVE_CLOCK_GETTIME
clock_gettime(CLOCK_MONOTONIC, &before);
(*func) (clkid);
clock_gettime(CLOCK_MONOTONIC, &after);
dt = (after.tv_sec - before.tv_sec) * 1e9;
if (after.tv_nsec >= before.tv_nsec)
dt += (after.tv_nsec - before.tv_nsec);
else
dt -= (before.tv_nsec - after.tv_nsec);
404 Building Enterprise IoT Applications
#else
gettimeofday(&before, NULL);
(*func) (clkid);
gettimeofday(&after, NULL);
dt = (after.tv_sec - before.tv_sec) * 1e9;
if (after.tv_usec >= before.tv_usec)
dt += (after.tv_usec - before.tv_usec) * 1e3;
else
dt -= (before.tv_usec - after.tv_usec) * 1e3;
#endif
dt /= NLOOP;
dt /= NUNROLL;
if (best != -1.0) {
if (dt < best)
best = dt;
}
else
best = dt;
}
printf(“%s: %.0f ns\n”, name, best, NLOOP);
}
int main()
{
#ifdef HAVE_CLOCK_GETTIME
clockid_t clkid;
int i;
for (i=0; i<NCLOCKS; i++) {
benchmark(clocks[i].name, bench_clock_gettime, clocks[i].identifier);
}
#endif
benchmark(“clock()”, bench_clock, 0);
benchmark(“gettimeofday()”, bench_gettimeofday, 0);
benchmark(“time()”, bench_time, 0);
return 0;
+
−}
Appendix 405
Sensors
Query Interface
Query Interface
http://cdec.water.ca.gov/dynamicapp/QueryF?RCS
Scaremento Stations
Scaremento Stations
Source: http://cdec.water.ca.gov/cdecstation2/?sta=KLG
Source: http://cdec.water.ca.gov/cdecstation2/?sta=KLG
Appendix 409
Source:
http://cdec.water.ca.gov/jspplot/jspPlotServlet.jsp?sensor_no=6063&end=11/23/2018+21:11&geom=small&interval=2&co
okies=cdec01
Source: http://cdec.water.ca.gov/jspplot/jspPlotServlet.jsp?sensor_no=6063&end=11/23/2018+21:11&g
eom=small&interval=2&cookies=cdec01
SNOW Sensors
http://cdec.water.ca.gov/jspplot/jspPlotServlet.jsp?sensor_no=5239&end=&geom=small&interval=730
&cookies=cdec01
ǦǦ
To build the SQLite for embedded projects, one can create an amalgamation project that can create a lite weight
SQLite database.
Appendix
Developers sometimes experience trouble debugging the 185,000-line-long amalgamation source 411 some
file because
debuggers are only able to handle source code line numbers less than 32,768. The amalgamation source code runs
Appendix - SQLite Build - Amalgamation
fine. One just cannot single-step through it in a debugger152.
To build the SQLite for embedded projects, one can create an amalgamation project that can create a lite
weight SQLite database.
Developers sometimes experience trouble debugging the 185,000-line-long amalgamation source
file because some debuggers are only able to handle source code line numbers less than 32,768. The
To compile153: source code runs fine. One just cannot single-step through it in a debugger.2
amalgamation
To compile:3
2
SQLite Amalgamation - https://www.sqlite.org/amalgamation.html
3
153 To Compile SQLite - https://www.sqlite.org/howtocompile.html
412 Building Enterprise IoT Applications
SEEK_SET
Seek relative to start-of-file.
TMP_MAX
Minimum number of unique filenames generated by tmpnam(). Maximum number of times an
application can call tmpnam() reliably. The value of TMP_MAX will be at least 10,000.
The following macro name is defined as a negative integral constant expression:
EOF
End-of-file return value.
The following macro name is defined as a null pointer constant:
NULL
Null pointer.
The following macro name is defined as a string constant:
P_tmpdir
default directory prefix for tempnam().
The following macro names are defined as expressions of type pointer to FILE:
stderr
Standard error output stream.
stdin
Standard input stream.
stdout
Standard output stream.
The following data types are defined through typedef:
FILE
A structure containing information about a file.
fpos_t
Type containing all information needed to specify uniquely every position within a file.
va_list
As described in <stdarg.h>.
size_t
As described in <stddef.h>.
The following are declared as functions and may also be defined as macros. Function prototypes must
be provided for use with an ISO C compiler.
void clearerr(FILE *);
char *ctermid(char *);
char *cuserid(char *);(LEGACY)
int fclose(FILE *);
FILE *fdopen(int, const char *);
int feof(FILE *);
int ferror(FILE *);
int fflush(FILE *);
int fgetc(FILE *);
int fgetpos(FILE *, fpos_t *);
char *fgets(char *, int, FILE *);
int fileno(FILE *);
void flockfile(FILE *);
FILE *fopen(const char *, const char *);
int fprintf(FILE *, const char *, ...);
int fputc(int, FILE *);
int fputs(const char *, FILE *);
size_t fread(void *, size_t, size_t, FILE *);
FILE *freopen(const char *, const char *, FILE *);
int fscanf(FILE *, const char *, ...);
414 Building Enterprise IoT Applications
Copyrights reserved to Hanumayamma Innovations and Technologies Inc., Contact: (510) 754 – 6269 http://www.hanuinnotech.com
Copyrights reserved to Hanumayamma Innovations and Technologies Inc., Contact: (510) 754 – 6269 http://www.hanuinnotech.com
416 Building Enterprise IoT Applications
Hanumayamma�Innova ons�and�
Technologies�Inc.,�
h p://www.hanuinnotech.com��
Dairy�Analy cs�
Electronic Monitoring
Dairy�Analy cs�(DA)�monitor�Dairy�cows�electronically�to�make�sure�the�cows�are�always�in�the�peak�of�health.�The�DA�will�help�to�iden fy�Dairy�cows�related�health�issues�
such�as�Heat�Stress�and�Bovine�Respiratory�Disease�(BRD).�The�Heat�stress�(HS)�causes�cows�to�produce�less�milk�with�the�same�nutri onal�input,�which�effec vely�increases�
Our Approach
p e r fo r m e d� o n� i n- precipitous� drop� in� ca le�
memory�data�cube.� 1222�
12221� 121223�
121223� Ca le� 70� Temp� 122� Humadity�90� Amb.T�140� Amb.H�
temperature�or�b)�sudden�
change� in� the� ambient�
12298� 122298� humidity.�
122298� 121223�80� 70� 145� 122� 100� 90� 170� 140�
SMS�
122121�
1222211� 122298�99� 80� 100� 145� 90� 100� 101� 170�
R e a l - m e�
no fica ons� enable�
efficient� opera onal�
122211�
122121�89� 99� 109� 100� 99� 90� 120� 101�
The ‘Smart Connected Objects”, aka, ‘the Internet of
Things (IoT)’, that enables dairies to minimize the
122211� 89� 109� 99� 120�
insights.���
Reduce medication
Machine�Learning� p r o v i d e� p a e r n� F o o d � o p m i z a o n ,�
d e t e c o n � a n d� Medica on� Sugges ons,�
Applica on�Machine�Learning�(Supervised�first)�enables�to�develop�Decision�Model� recommend� Dairy� Op mal�Dairy�se ngs�per�
Dairy�Analy cs�provides�heat�map�of�Dairy�facility.�The�Heat�map�provides�360�degree�of�Temperature�spread�and�will�enable�to�control�the�Heat�Stress.�
sick cattle from death.
WSJ: High-Tech
Tagging Comes to the
Ranch
Dairy�Analy cs�will�help�automate�facili es�to�automa cally�control�Heat�Stress�issues.�The�automa on�include:�a)�auto�control�of�water�sprinklers,�b)�
control�of�cooling�system�–�fans�&�a/c.�Heat�Stress�and�Historical�analysis�on�water�in-take�will�provide�ac onable�insights�to�control�water�in-take�and�
milk�produc on.��
CURRENT�WATER�IN-TAKE��
2014�WATER�IN-TAKE��
R
e
s
u
l
t
s�
Contact details:
Dairy�Analy cs�will�yield�huge�opera onal�efficiencies,�cost�
savings,�and�ac onable�insights�to�address�Dairy�ca le�
Hanumayamma Innovations and Technologies Inc.,
related�cri cal�issues.�Connected�dairy,�importantly,�is�a�
data� enabled� insigh ul� tool� that� facilitates� be er�
management�of�Dairy�ac vi es.�Finally,�connected�dairy�
628 Crescent Terrace,
provides�forecas ng�insights�that�provides�window�of� me�
opportunity�to�dairy�opera onal�management�so�that�they�
can�be er�plan�to�handle�any�un-expected�weather�related�
Fremont, CA 94536
Phone: (510) 791 – 5759
abnormali es,�Dairy��
Email: [email protected]
Hanumayamma�Innova ons�and�
Technologies�Inc.,�
Fax: (510)-857-5794
Sources:�
�
1. Juliano�Calil,Alexander�Silvester,Katharina�Stelzl,�Christopher�Wissel-�Tyson,�“The�Effect�of�Climate�Change�on�the�Produc on�Costs�of�the�Dairy�Industry�in�the�United�States”,�[Online],�
Website: http://www.hanuinnotech.com
Available:�h p://www.bren.ucsb.edu/research/2012Group_Projects/documents/gotmilk_report.pdf��
2. �Chandrasekar�Vuppalapa ,�Anitha�Ilapakur ,�“Building�an�IoT�Framework�for�Connected�Dairy”,�
h p://ieeexplore.ieee.org/xpl/login.jsp?tp=&arnumber=7184891&url=h p%3A%2F%2Fieeexplore.ieee.org%2Fiel7%2F7182812%2F7184847%2F07184891.pdf%3Farnumber%3D7184891��
Copyrights reserved to Hanumayamma Innovations and Technologies Inc., Contact: (510) 754 – 6269 http://www.hanuinnotech.com
Appendix 417
5
PThread Support for Windows - https://docs.microsoft.com/en-us/previous-versions/tn-archive/bb463209(v=technet.10)
418 Building Enterprise IoT Applications
Step
Step1:1:Go
Goto
toWindows
WindowsControl
ControlPanel
Panel
A aircraft, 29-30
airflow, 29
ABM, 178, 192-193 airnow, 130, 132
Abnormal, 39, 155, 365-366 Ajana, 131
abnormalities, 39, 134, 415 AJAX, 281-282, 285, 287, 368
AboutAppSandbox, 210 AL, 38, 40, 42, 80
abs, 65, 94, 126-127, 270, 276 Alameda, 121
abuse, 8 Alarm, 19-20
Accelerometer, 2, 56, 57, 60, 65, 67, 74, 78, 79, 84, 87-90, alert, 20, 124-125, 129, 135, 230-231, 283-284, 286, 416
93, 95, 105, 108, 111-113, 115, 175, 214-216 algebra, 161-162
accelerometerData, 115 algorithm, 10-11, 30, 42, 140, 150-151, 154, 178, 214-218,
AccelerometerPlay, 95, 131 220-221, 230-231, 246, 249-250, 252-255, 258-259,
AccelerometerVCC, 43 398
Accuracy, 11, 260, 262-265, 269, 272-273, 279 alias, 331
ACI, 58, 60-64, 149-150 Alice, 390
ACID, 193 aligned, 4, 7
ACK, 288-289, 310, 357 alize, 298
acknowledgement, 339, 232, 346, 352, 357, 375-376 allheaders, 285-287
Acoustic, 77-78, 260, 276 alloc, 203, 207, 209, 302
Acquisition, 71, 135-136, 215, 365, 397, 398 allocate, 143, 144, 247, 302, 352, 389
across, 1, 11, 28, 36, 219, 278-281, 308, 378, 395, 416 alone, 8, 69, 216
ActionListener, 312 alpha, 271
activation, 263-264, 266-272 altera, 334
activity, 8, 25, 33, 43, 56, 65-66, 74, 77, 81-82, 85, 90, 92- Alternate, 171, 294
93, 97-99, 101-105, 107, 117-119, 178, 181, 184-185, Altitude, 30, 112, 113
187-188, 191, 196-198, 212, 214, 249-250, 256-258, aluminum, 129
282-283, 310-311, 314, 323 alyntiaclsy, 134
activityCount, 65, 181 AM, 178, 192, 193
activityManager, 119 amalgamation, 411
Actuators, 4, 16, 35, 37, 395 amazing, 129
acyclic, 387 Amazon, 27, 191, 215, 325, 371
AD, 281, 298-299, 365-366 ambient, 43, 56, 60, 65, 77-79, 87, 88, 89, 96, 122, 178,
AdaBoost, 215 181, 192-193, 416
Adafruit, 33, 44, 59-60, 366-367 ambientHumd, 180-181
Adam, 44, 260, 262-266, 269-270, 272, 279 ambientTemp, 179-181
adapter, 46, 307 American, 8, 34, 102
adaptive, 7, 17, 38-40, 42, 56, 222, 228-229, 281, 368 AMP, 5, 294-296, 333
adaptiveEdgeCoefficent, 229-230 amplifier, 125, 152, 153, 261
addCallback, 293 amplitude, 127, 268, 270
addErrback, 293 AMQP, 396
ADDR, 51-53, 182 aMQTT, 342
Advertisement, 299 Anaconda, 290, 291, 387, 387-389
Agency, 406-407 analog, 20, 33, 45, 49, 68, 124, 365, 366
Agglomerative, 11, 217 analogous, 281
Agile, 398, 399 ANAlysis, 217
agricultural, 137 analytical, 4, 5, 7, 14-15, 17, 39, 40, 398
agriculture, 6, 59, 122-123, 137, 400, 416 Anand, 44
agroeconomics, 400 ananlytic, 5
AI, 2, 211, 213, 254, 257-259 Anatomy, 108, 373
AIR, 62 Ancillary, 36
Airborne, 412
422 Building Enterprise IoT Applications
chocolates, 137 closed, 4, 5, 7, 16, 37, 72-75, 167, 258, 343, 372-373
choice, 2, 281, 307, 335 closer, 4-5, 7-8, 38, 40, 134-135, 214, 251, 277, 369, 416
choose, 25, 38, 43, 223, 258, 380 closest, 215, 217, 251
Christian, 218 Closing, 2, 18, 166-167
Christopher, 416 Cloud, 4-9, 13–20, 26-28, 35-44, 82-83, 124-125, 129, 134,
chroma, 126, 270 149, 157, 220, 275, 287, 365-367, 369, 371, 393-400,
chrome, 88 416
chronic, 1 cloudapp, 384-386
chroot, 379 cloudenterprise, 7
chunks, 201-202, 317-318 cluster, 37, 217-218, 249-255, 376, 379-381, 387-389, 395
Circles, 253-254 clustered, 218, 249, 388
Circuit, 16, 48-49, 60, 67, 75, 124-125, 333 Clustering, 11, 211, 216-219, 249, 252-253, 255, 276, 398
circular, 38, 40, 42, 133, 137–149, 155, 175-176 CM, 112-113
CircularBuffer, 141-142, 147 CMAccelerometerData, 112-113
CisBPeripheral, 304 Cmalelsesda, 342
Cisco, 2, 12, 43, 68, 74, 131, 155 cmd, 51, 53, 61-62, 66, 149-150, 179, 374, 388-389
cities, 15-16, 74, 246, 275 CMDerviceMotion, 112-113
citing, 35 CMGyroscopeData, 112-113
Citivoitwy, 129 CMMagnometerData, 112
citizen, 2, 28, 122, 400 CMMotionActivity, 118-119
City, 38, 74, 124-125, 129-130, 132, 158-159, 235, 246- CMMotionActivityHandler, 118
247, 406-407 CMMotionActivityManager, 112, 118-119
civilization, 400 CMMotionManager, 112, 115
Clark, 325 CMPedometer, 112-113, 119
class, 12, 55, 76, 83, 86, 92-93, 98-99, 101, 104, 107, 112, CMPedometerData, 112-113, 117-118
114-115, 117-118, 141, 185-187, 189, 198-202, 214, CMPedometerEvent, 112-113
216, 221-222, 228-229, 235, 237-239, 263, 268, 271, CMRecordedAccelerometerData, 113
292, 300, 302-305, 307, 312-313, 316, 319, 322, 324, CMSensorData, 113
372, 384-386 CMSensorDataList, 112-113
classes, 11, 12, 112, 201-202, 222, 272, 299 CMSensorRecorder, 112
classic, 2, 34, 150, 191, 282, 283, 297-298, 307 CNN, 261-273, 276
classical, 74, 129, 398 CoAP, 4, 37, 287-294, 368
classification, 10, 55, 130, 193, 211, 212, 214-216, 219, COARSE, 310, 336, 401
221, 260-261, 266-267, 269-270, 272, 275, 276 coavnem, 212
classified, 15, 77 coBnLneISctHio, 326
classifier, 11, 17, 214-215, 217, 261, 263 COBWEB, 217
classifies, 215 Code, 36, 45, 50, 51, 55, 58, 59, 61, 63-67, 84-86, 89-90,
classify, 12, 214, 221, 260, 264 92-93, 95, 97-99, 101, 104, 106-110, 112-115, 118,
classifying, 77 125-126, 140-141, 143, 149, 151, 158, 161, 167-169,
Clean, 9-10, 15, 17, 340, 341 171-172, 179, 180, 185, 187, 194, 197, 200, 202, 203,
cleaning, 14, 17, 30-32, 38, 40, 42, 398, 399 206, 207, 211, 227, 229-231, 243, 247, 252, 255,
cleaningData, 9, 15 262, 267, 269-270, 281-282, 284, 285, 287, 289-293,
cleanly, 170 301, 310-312, 316, 319, 322, 328–330, 336, 337, 339,
cleanse, 10 349–351, 357-358, 361, 366-368, 379, 380, 382, 384,
Cleansed, 30, 41-42 385, 411, 412
clear, 8, 66, 108, 178 coefficients, 17, 152, 228, 238-239, 261-262, 276
ClearCowActivity, 178 Cognitive, 44, 156, 398
Click, 71, 108-110, 417-419 Coin, 306
Clickstream, 370 Cold, 35
Client, 191, 194, 279-283, 288, 289, 291-293, 298, 299, collaborative, 4, 10, 102
313, 314, 322, 324-326, 328-331, 333, 339-343, 370- collection, 9, 15, 17, 36, 72-73, 92, 99, 193, 212, 214, 220,
372, 375-376, 382, 394, 396 222, 249, 300, 389-390, 395-397, 417
clientside, 281 Collector, 15, 18, 39-41, 133, 135-137, 144-146, 149, 151,
Climate, 72-73, 137, 400, 416 155, 176-177, 222
clinic, 125, 152, 261 colliding, 96
clinical, 103 collisions, 95
Clinton, 13 color, 130, 233, 248, 252, 253, 255
clock, 49, 58, 60, 67, 178, 246, 331-339, 349, 401-404 commerce, 1, 29, 38
close, 4-5, 38, 44, 48, 68, 69, 133-134, 137, 170, 185, 187, Commission, 322
189, 199-200, 207-209, 240-241, 272, 314, 343, 384, commit, 82, 186, 189, 199, 384
386 communicate, 18, 60, 277-278, 299, 307, 324-325
428 Building Enterprise IoT Applications
communication, 4-5, 7, 19, 20, 36, 49, 60, 135, 136, 166, contiguous, 137, 145
177, 211, 278, 280, 287-289, 294, 295, 298, 325, 348, contingencies, 9, 14-15, 17
367, 372, 395-396 continuous, 39-40, 58, 105, 120, 130, 150, 223, 230, 391
Community, 394 continuously, 32, 55, 109, 157
companies, 8, 42, 211, 277, 324-325 ContinuousMonitoring, 120
compare, 56-57, 191, 245, 251, 395, 399 control, 2-5, 7, 9, 14-15, 17, 60, 71, 151, 177, 216, 219,
Compatibility, 278, 331 244, 255-257, 295, 343, 356, 378, 393, 416
compatible, 19, 278, 348 conundrum, 400
competitiveforces, 6 convenient, 212, 235, 393
compile, 194, 269, 272, 361, 411 conventional, 173-174, 245
compiler, 173, 174, 195, 413 convergence, 266
Compiling, 193 converging, 36
compliance, 377, 397 conversion, 68, 339, 352, 357
Compliant, 282 convert, 30, 72, 77, 154-155, 181, 249, 253-254, 310, 355
complicated, 130 converted, 75, 170, 215, 229, 357
complimentary, 130 converter, 215, 366
components, 4-7, 36, 48-49, 79, 233, 246, 280-281, 343, convey, 124-125, 129
355, 362, 365, 367, 391, 395-396 convol, 265
computation, 36, 137, 372, 386, 389, 391 cookbook, 247
compute, 2, 15, 17, 36, 41, 95, 127, 135, 136, 149, 154, CoPP, 288
220, 229, 274-275, 278, 337-338, 369, 390, 393-395, Copyright, 50, 52, 203, 206-207, 377, 415, 416
400 CoreMotion, 111, 115, 118, 132
computeAdaptiveEdgeCoefficent, 229 CoreMotionExample, 113-115
computer, 36, 48, 57, 67, 170, 193, 209, 211, 278 CoreMotionPost, 112-113
Conceptual, 163, 210, 217, 399 Corona, 366
condition, 6, 30, 102, 132, 134, 151, 155, 217, 257, 365 corporate, 275
conditional, 214 Corporation, 209-210
conf, 349-350, 375, 389 Corpus, 12
Conference, 132, 155-156, 276 correct, 66, 249, 358, 361
configuration, 35, 37, 89, 97, 135-136, 280, 312-313, 349, correcting, 244
357, 374, 375, 378, 379, 389, 393 correction, 244-245, 356, 360-361
ConfigurationListener, 312 corresponding, 19, 60, 77, 120, 159, 267, 270, 309, 332,
configurationSpinner, 314 342-343, 348, 379
configure, 83, 84, 194, 309, 378 Cosine, 262
configured, 25, 109-110, 112, 175, 325, 377 cosmos, 178, 192-193
Congratulations, 376 cost, 1, 28, 134, 137, 211, 216-217, 294, 364-365, 367,
connect, 1-2, 4, 15, 42, 49, 61, 64, 66, 131, 176, 213, 278, 401, 416
297, 299, 301, 303-304, 307, 309, 323, 325, 328-330, COUNTER, 87, 104, 107-108, 186-189, 198-199
340-341, 345, 347, 351, 375-376, 379, 382, 389, 400 covariance, 244-247
connections, 7, 19, 157, 279-280, 294, 307, 322, 348, coverage, 277
375-376 Cow, 5, 55, 58, 65, 66, 76, 149, 178, 179, 181, 308-311,
connectPeripheral, 303-304 320, 416
consider, 29, 73, 152, 191, 223, 224, 235, 250, 290-291 cowActivity, 181-182
console, 142, 159, 169, 234, 293, 381-382 cowHumd, 180-182
consortium, 322 COWMANAGER, 311, 319-320
const, 158, 207-209, 243, 352, 357, 401, 403, 413-414 CowManagerModel, 319-320
constrained, 96, 137, 149, 156-157, 183, 193, 211, 274, CPU, 82, 105-106, 149, 193, 211-213, 374, 396
288, 290, 368, 396 CRC, 354-356
constructs, 31, 158, 217, 282, 292, 321 CRCBook, 243, 289-291, 382
consume, 16, 372, 379-380, 384, 400 create, 1, 7, 20, 22, 26, 35, 37, 82-83, 119, 141-146, 149,
consumed, 137, 175, 370-371 151, 162-165, 169-170, 172, 177, 192, 195-197, 200,
Consumer, 69, 144-146, 149, 151, 177, 382, 384-386, 391, 208-209, 215, 249, 252, 255, 277, 320, 324, 330, 365,
394 368, 379-381, 388-390, 411
Contacts, 79, 207-209, 319-320 createDataFrame, 390
contain, 35, 51, 68-69, 133, 214, 216, 245, 295, 299-300, createFileAtPath, 202, 204
373 criteria, 9, 14-15, 17, 120, 135, 216, 378
container, 36, 192, 314 critical, 29, 95, 122, 150, 152, 175, 219, 238, 246, 412
context, 4, 7, 16, 31, 33, 35-37, 42, 82, 90, 92, 93, 98-99, crossentropy, 269, 272
101, 104, 107, 136, 183, 187, 197, 199-201, 210, 216, Crowdedness, 235, 243, 276, 420
259, 316, 319, 325, 387, 389, 390, 395 crowdsourcing, 215
Contextual, 4, 7-8, 395 Cteopu, 117
Index 429
digital, 1-8, 12, 13, 19, 20, 42-45, 49, 60, 65-68, 74-76, EKG, 364-365
95, 125, 152-153, 213, 219, 261, 276, 299, 334, 366, Elderly, 8, 13
368, 399 electric, 7, 13, 70, 131, 216
Dispatches, 106, 110 electricity, 2-3
DispatchMessage, 103, 106, 110-111 electronic, 2-3, 7, 72, 103, 123, 125, 276, 294, 308, 416
DispatchQueue, 119 elegant, 214
dispenser, 213, 220, 256, 258-259 element, 137-140, 143, 162-163, 230-231, 399
dispensing, 220, 257-258 else, 50, 52, 55, 59, 61, 64, 94, 96, 100-101, 104, 107, 111,
disperser, 213 119, 179, 207-209, 229-230, 232, 286-287, 308, 318,
DLL, 362 321, 323, 331, 337, 351, 353-355, 359, 361, 401,
doctors, 364-365 403-404
DOCTYPE, 283, 285 Email, 20, 26, 27, 79-80, 319, 321, 416
document, 30, 34, 202, 213-214, 218, 282-284, 286-287, embedded, 4-5, 7, 38, 40, 51, 56-57, 137, 157, 165, 166,
412 173-175, 183, 191-195, 209, 211, 216, 219, 246, 274,
dogs, 124-125, 129 278, 325, 396, 411
Doha, 16 emotional, 213
dollar, 298 emphasis, 259, 262
domain, 36, 152, 191, 194, 221, 261 Emphasize, 42
double, 38, 40, 42, 88, 102, 137, 150-151, 156, 229, 355, empirical, 266
357-358, 360-361, 403 empirically, 255
DOW, 38 employ, 38, 102, 281
downloads, 109-110, 124, 132, 374, 376-377, 387 empty, 137, 139-141, 143-145, 147-148, 163, 217, 308, 313
downstream, 280, 350-352, 357 Energy, 2-5, 7, 57-60, 67, 144-146, 149, 151-152, 154, 174,
drift, 35, 217, 333 177, 220, 261, 277, 288, 294, 296-300, 302, 306-308,
drilling, 68-69 368
drills, 123 enforcement, 124-125, 129, 219, 274, 276
driver, 7, 80, 82-83, 195-196, 274, 387-391 Engagement, 71, 193, 212-213
duplicate, 19, 348 engine, 4, 5, 7, 15, 20, 26, 32, 44, 74-76, 152, 191, 281-
Durability, 378 283, 370, 386-387, 398, 416
durable, 193, 371 engineering, 10, 30, 38, 40, 42, 72-73, 125, 392, 397, 398
duration, 26, 199, 337-338 engineers, 9, 12, 296, 325, 368, 399
dynamic, 36, 75, 275, 280, 282 enormously, 211
enough, 11, 30, 81, 97, 102, 114, 212, 274
E enqueue, 137-138, 141-142, 318
Enrichment, 31
Earth, 29-30, 89, 96 ensemble, 215
Eastern, 125, 152, 261 Enter, 61, 159, 161, 167-168, 186, 195, 259, 380-382
ECG, 364-367 Enterprise, 2, 4-8, 10, 12-16, 18, 20, 22, 24, 26, 28, 30, 32,
Eclipse, 194-195, 288, 328-330, 368 34-38, 40-42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62,
economic, 1, 12, 16, 73, 219, 416 64, 66, 68-72, 74, 76-78, 80, 82, 84, 86, 88, 90, 92,
economy, 1, 12, 43 94, 96, 98, 100, 102, 104, 106, 108, 110, 112, 114,
Edge, 4-5, 7-9, 14-18, 20, 24, 26, 28, 37-41, 51, 56, 68-69, 116, 118, 120, 122, 124, 126, 130, 132, 134, 136, 138,
77, 133-137, 150, 152, 155, 157, 183, 192, 211-213, 140, 144, 146, 148, 150, 152, 154, 156-158, 160, 162,
215, 217-223, 225, 227, 229, 231, 233, 235, 237, 239, 164, 166, 170, 172, 174, 176, 178, 180, 182, 184, 186,
241, 243, 245, 247, 249-251, 255, 257, 259, 261, 263, 188, 190, 192, 194, 198, 200, 202, 204, 206, 208, 210,
265, 267, 269, 271, 273-276, 278, 336, 356, 368, 369, 212, 214, 216, 218, 220, 222, 224, 226, 228, 230, 232,
394-396, 416 234, 238, 240, 242, 244, 246, 248, 250, 252, 254, 256,
edgecomputing, 134, 136 258, 260, 262, 264, 266, 268, 270, 272, 274, 276, 278,
edit, 166, 186-188, 199, 312-313, 319, 375-377, 379 279, 282, 284, 286, 288, 290, 292, 294, 296, 298, 300,
Edition, 209 302, 304, 306, 308, 310, 312, 314, 316, 318, 320, 322,
effects, 5, 6, 8, 73, 95, 126, 241, 247, 270, 376 324, 326, 328, 330, 332, 334, 338, 340, 344, 346, 348,
Efficacy, 29 350, 352, 354, 356, 358, 360, 362, 364, 366, 368, 370,
efficiencies, 416 372, 376, 378, 380, 382, 384, 386, 388, 390, 392, 394,
efficiency, 36, 144-146, 149, 151, 177 396, 398, 400, 402, 404, 406, 408, 410, 412, 414, 416,
efficient, 124-125, 129, 175, 211, 244, 246, 322, 372, 386- 418, 420
387, 396, 416 entrepreneurs, 68
efficiently, 178, 211, 246 entropy, 216, 221
effort, 10, 105, 298, 374, 393 environment, 4-7, 36, 45, 72-73, 75, 124-125, 129, 133,
eight, 412 167-168, 205, 211, 213, 254, 258, 259, 364-365, 388-
either, 15-16, 18, 30, 36, 82-83, 130, 157, 201, 235, 244, 389, 412, 417
246, 285, 298, 310, 318, 323, 349, 369, 377-378, 388, Environmental, 77, 267, 269-270, 276
390, 397 eonft, 16, 372, 415
Index 431
getFahrenheitHundredths, 51-52 Hanumayamma, 5, 56, 76, 126, 129, 133, 175, 203, 206,
getFarmer, 320 220, 243, 268, 271, 289-291, 308, 336, 371, 382,
getFarmname, 320 415-416
getFifoMaxEventCount, 86 Happy, 416
getFilterUUID, 315 hardware, 4-5, 16, 36, 45, 47, 49, 51, 53, 55-57, 59, 61, 63,
getHumidityAndTemperature, 51, 55 65, 67, 68, 78-80, 82-84, 86-90, 92-93, 96-99, 101,
getHumidityBasisPoints, 51, 53, 55 103-105, 107, 111, 131, 175, 178, 220, 235, 256, 277,
getHumidityPercent, 51, 53, 55 310, 333-335, 356, 368, 393, 394, 401
getLocalAuthorityLogger, 312 harmful, 38
getLocation, 320 harmonic, 126-127, 270
getLoggerProfileTitle, 312 Harmonious, 275
getLogSession, 323 harness, 219-220
getLong, 313-314 harvesting, 400
getMaximumRange, 86 hashlib, 331
getMenuInflater, 185, 188, 198 HashMap, 86
GetMessage, 103, 106, 110-111 Haytham, 276
getMinDelay, 86 HBase, 390
getMinutes, 181 HCI, 294-295
getMobile, 320 health, 1-2, 7, 8, 13, 36, 55, 102-103, 106, 110, 122-123,
getMonths, 181 125, 129, 133-136, 250, 310, 364-365, 391, 397,
getName, 86, 322 415-416
GetProcessTimes, 333, 338-339 healthcare, 1-2, 8, 102, 125, 263, 324-325
Git, 364, 388-389 healthy, 129, 260
github, 28, 44, 49, 53, 59, 95, 105, 126-127, 131, 153-154, Hearing, 124-125, 129, 276
156, 267, 269-270, 274, 291, 349, 364, 368, 388 heart, 51, 63, 89, 299-300, 307, 364-366
gleaned, 213 heat, 33, 73, 137, 415-416
global, 1-2, 12, 43, 72-73, 130, 178, 216-217, 279, 368, 400 heavily, 38
GMT, 287 heavy, 8, 123, 213, 235
goal, 15, 39-40, 200, 218, 232, 235-236, 238-239, 245, help, 2-3, 9, 34, 36, 72-73, 105, 118, 175, 214, 219-220,
248-250, 256, 258, 260, 262, 264-265, 279, 356 242, 325, 379, 389, 416
Goo, 418 helped, 73
Good, 9, 69, 103, 106 Heterogeneity, 395
gov, 120, 122, 130, 132, 393-394, 399, 405, 408-410 hidden, 82, 143, 263, 265
governance, 398 hierarchical, 11, 217-218, 259
governing, 28, 256, 377 histogram, 31, 38, 40, 42, 129, 154-155
government, 28, 38, 72-73, 120, 274 Historic, 8, 35, 37, 120
GPIO, 366-367 historical, 4-5, 7-8, 28, 60, 71, 112, 245, 416
GPP, 288 Historically, 333
GPS, 8, 71, 74-76, 214, 216, 351-353, 355-358, 360-361 history, 8, 34, 233, 249, 269, 272, 279, 372
Graphic, 150 Hive, 388-389
Great, 70, 131, 193, 212-213 holiday, 33, 235-236, 241-243, 246
greedy, 258-259 home, 109, 124-125, 129, 188, 198, 376, 388-389
Grini, 368 Horizontal, 29-30, 78, 164-165, 398
Growth, 219, 276 horizontally, 165-166
guarantees, 37, 412 Hospital, 125, 152, 261
guide, 5, 13, 36, 74, 78-79, 108, 131, 276, 307, 368, 375- hospitality, 213
376, 392 hospitalRurual, 340
Gupta, 155 host, 150, 191, 294-296, 298, 328-329, 377, 379
Gym, 276 hot, 35
Gyro, 115 Hotel, 275
gyroscope, 78, 87, 88, 108, 111, 112, 175, 302 hour, 57, 120, 178, 235-236, 241-243, 246, 355, 395
html, 26-28, 37, 44, 56, 60, 67, 84, 126-127, 129, 151,
H 153-154, 156, 188, 191, 193-194, 198, 210, 246-247,
275-276, 283-287, 291, 332, 334, 352, 362, 368, 374-
hackernoon, 43 377, 387, 411-412
hadoop, 387-389 huawei, 7, 13
HAL, 80, 82-83, 105, 351, 353, 358-360 Hub, 28, 105, 369, 399
handle, 11, 36, 55, 70, 79, 142-143, 145-147, 185, 218, Humadity, 416
284, 325, 340, 375-376, 390, 396, 411, 416 human, 2, 5, 8, 12, 16, 103, 106, 110, 124-125, 129, 211-
handshake, 275, 288, 291-292, 342 212, 215, 262, 300, 400
hanuinnotech, 5-6, 26, 56, 90, 92-93, 98-99, 101, 129, 220, humanity, 2, 72-73, 103, 400
308, 415-416
434 Building Enterprise IoT Applications
humidity, 25, 30, 33, 43, 45, 49, 51, 52, 55-56, 58-60, 62, industry, 1-3, 5, 6, 8, 10, 12, 13, 29, 36, 43, 65, 213, 218,
65, 67-69, 71, 73, 76-79, 87, 89, 175, 178, 179, 181, 275, 400, 416
192, 193, 220-230, 235, 238, 239, 244, 302, 416 influence, 1, 5-6, 30, 175
HVAC, 193, 213 Influencer, 2
HYD, 178, 192-193 information, 4, 7, 30, 36, 73, 83, 114, 117-118, 120, 124-
Hysteresis, 34, 74-76 125, 129, 133, 214, 216, 221-223, 235, 244, 262, 266,
Hz, 89, 124-125, 127, 129, 152-153, 260-262, 264-265, 278-280, 298-300, 332, 340-341, 343, 354, 367, 374,
279, 333-335 377, 399, 413
infused, 8, 73, 137
I Injector, 144-146, 149, 151, 176-177
Input, 11, 165-166, 192, 247, 260, 262, 264-265, 279, 282-
IaaS, 393-394 283, 412
IBAction, 204, 206, 208 insertSQL, 207-208
iBeacon, 308-309 install, 201, 289-291, 326-327, 344-345, 362-364, 375,
IBinder, 323 387-389, 392
IBM, 8, 13, 325, 334 instance, 5-7, 12, 19, 29-30, 33, 37-38, 48, 68-69, 73, 75,
IBOutlet, 206 82-83, 105, 108-110, 118, 119, 130, 133, 135, 140,
icmla, 156 175, 183, 214-215, 222, 235, 256, 294, 299-300, 302,
ICMLC, 132 341, 348, 371-372, 374-375, 380, 395
icmompmruonviceatse, 220 Intel, 15, 37, 44, 333-336, 368, 401
icon, 2, 3, 90, 98, 103, 109-110, 183, 310, 312, 363, 364 intelligence, 2-5, 7-8, 12, 14-16, 39-40, 43, 137, 211, 277
IDE, 45-46, 49, 51, 59, 67, 85, 91, 142, 171, 184-185, 194- intelligent, 73, 133, 213, 220, 256
195, 327-328 Interface, 4-5, 7, 19-20, 31-32, 57, 58, 60, 72, 83-84, 108,
identification, 28, 215, 365 110, 114, 150, 173-174, 176, 196-197, 203, 206, 207,
idiom, 387 214, 279-284, 289-291, 294, 312, 408
Idle, 109-110 internal, 56-57, 224-226, 244, 308, 333, 378, 399
IEEE, 132, 152, 156, 211, 276, 288, 292 Internet, 1-3, 6, 9, 12, 14-15, 17, 19, 32, 37, 43-44, 51, 70,
ifgram, 127 129, 131, 149, 155, 175-177, 213, 219, 276, 278, 287,
IIOT, 70-72 289, 290, 292, 306, 322, 325, 348, 368, 400, 416
Ilapakur, 416 interoperability, 36, 393, 395, 396
ilze, 265 interoperate, 288, 395
images, 69, 74, 131, 173, 209, 220, 250, 267, 270 interpret, 249
imagine, 322 interpreted, 130
imagVeC, 129 interrupt, 51, 55, 181, 334
immediate, 16, 20, 32, 74, 219, 357, 397 interval, 23, 28, 40, 61, 63-64, 73, 133, 135, 230, 231, 245,
immediately, 135, 357, 378 297, 306, 350, 365, 375, 378-379, 391, 409-410
Immutability, 389 Interweaving, 8, 103
impact, 7, 12, 16, 35, 37, 125, 136-137, 175, 219, 393, 398- intrinsic, 68-69
399, 415-416 intrinsically, 10
Imperatives, 134, 136, 155, 219, 276 Introduction, 1, 3, 5, 7-9, 11, 13, 67, 209, 247, 276
implement, 6, 19, 151, 233, 262, 275, 324-325, 330-331, intuition, 265
416 intuitively, 244
implicitly, 280 Investment, 72-73, 416
import, 86, 92-93, 98-99, 101, 104, 107, 114-115, 126-127, IO, 165-166
153, 163-165, 185, 187, 197, 199-200, 203, 206-207, IoE, 77, 131
227, 233, 247, 255, 267, 269-270, 289-292, 316, 319, iOS, 51, 60, 68-69, 78, 108-113, 118, 157, 166, 201-203,
322, 328-332, 337, 366-367, 382, 384-385, 389-390 205, 274, 294, 299, 301, 340
importance, 12, 35, 44, 263, 325, 364-365 IoT, 2, 4-10, 12-20, 22, 24, 26, 28, 30-34, 36-40, 42-46,
impossible, 37, 351 48, 50-52, 54-56, 58-60, 62, 64, 66, 68-84, 86-127,
impression, 216 129-138, 140-158, 160, 162, 164, 166, 170, 172,
Inc, 5, 56, 155, 308, 415-416 174-178, 180, 182-184, 186, 188, 190, 192-194, 198,
Incremental, 217 200, 202, 204, 206, 208, 210-214, 216, 218-220, 222,
index, 130-132, 137-139, 144-146, 149-151, 157-158, 161, 224, 226, 228, 230, 232, 234, 238, 240, 242, 244, 246,
177-178, 257, 275-276, 350, 352-356, 358 248, 250, 252, 254, 256, 258, 260, 262, 264-266, 268,
Indexer, 144-146, 149, 176-177 270, 272, 274, 276-279, 282, 284, 286-288, 290, 292,
India, 73 294, 296, 298, 300-302, 304, 306, 308, 310, 312, 314,
indian, 34 316, 318, 320, 322, 324-326, 328-330, 332-334, 336,
Indianapolis, 16 338, 340, 344, 346, 348, 350, 352, 354, 356, 358, 360,
indicate, 124-125, 129, 240-241, 285 362, 364-366, 368-372, 378, 380-382, 384-386, 388,
Industrial, 2-3, 5, 13, 35, 44, 68-72, 74, 131, 277, 296 390, 392-400, 402, 404, 406, 408, 410, 412, 414, 416,
industrialiot, 131 418, 420
industries, 1, 7-8, 13, 70, 131, 275 iPhone, 201
Index 435
iris, 365 L
ISO, 322, 325, 355, 368, 413
Isolation, 8, 13 label, 29, 85, 90, 98, 103, 127, 184, 214, 222, 235, 248-
issues, 6, 28, 35, 37, 53, 125, 129, 137, 211, 287, 400, 416 249, 266-268, 270-271, 310-311
items, 4, 19, 120, 145-146, 182, 185, 188, 192-193, 198, Laboratiroes, 276
221, 247, 348, 366 lacation, 300
iterations, 249, 252, 254 Lat, 121, 297
Iterative, 218 latency, 36, 72-73, 75, 89, 277-278, 369-370, 378, 395-396
Latitude, 30, 71, 130, 357, 406-407
J lative, 129
latter, 278, 334
jack, 45-46, 48 launch, 36, 114, 278
Jacques, 12, 276 Lauren, 392
Jacues, 43 law, 124-125, 129, 144-146, 149, 151, 177, 274, 377
James, 12, 43, 276, 368 layer, 36, 80, 82-83, 134, 137, 259, 262-264, 266-273, 279-
janakirammsv, 7, 13 280, 287-288, 294, 393, 399
java, 45, 79-80, 86, 92, 98-99, 101, 183, 185, 187, 197, LBP, 129-130, 154-155
282, 307, 316, 340, 374, 376, 377, 379, 380, 388, 389 leadership, 219, 276
JavaScript, 281-283, 340 LeakyReLU, 263-264, 266, 269-271
Jay, 372, 392 Learning, 3, 9, 11, 13, 17, 31, 39, 102, 132, 156, 193, 211-
Jeff, 13, 399 215, 217-219, 221, 250, 258, 260-264, 266, 275-276,
Jeffrey, 43-44 279, 398-399, 416
Jennifer, 13 LED, 57, 73, 124, 211
Jesse, 368 LeF, 39
JGaova, 374 len, 64, 66, 126, 233, 252, 255, 267-268, 270-271, 339,
job, 259, 387, 397 352, 357
John, 34, 368, 399 LENGTH, 100-101, 104, 107, 194, 199
journey, 325 Lessons, 6
JSON, 19-20, 281, 348, 353, 357, 390 libraries, 9, 14-15, 17, 49, 51, 59, 80, 199, 334, 340, 361,
July, 12, 43-44, 122, 132, 156, 218, 368 364, 366-367
jump, 173-174 librosa, 125-127, 153-154, 156, 261, 262, 267-271
Jumper, 366 licenses, 377
June, 13, 43-44, 68, 131, 133, 135, 155, 209-210, 276, 368 licnaotito, 342
jupyte, 387 liczleodu, 134
jupyter, 387-389, 392 lieu, 364
Just, 5, 356-357 light, 77-79, 87, 89, 152, 194, 219, 246, 274-276, 339
lineage, 298, 397-398
K linear, 11, 161-162, 234-235, 238-239, 242-243, 245, 262,
266
Kafka, 37, 369-374, 376-382, 384-385, 391-392 Linearity, 242
KafkaConfig, 377 Linearizability, 37
KafkaConsumer, 384, 386 LinearRegression, 243
kafkalogs, 376 lined, 35
KafkaProducer, 382, 384-385 LineGraph, 311
kaggle, 235, 276, 420 lines, 9, 57, 399
Kalman, 38-40, 42, 173-174, 219, 235, 244-248, 275 ling, 265
Kaufmann, 44 Linguistic, 256, 257
Kayla, 44 link, 51, 62-64, 109-110, 120, 188, 198, 295, 296, 298, 323,
KDD, 2, 30-31, 41 398-399
keep, 19, 46, 217, 279, 348, 357 linked, 118, 388
keepalive, 328-329, 350 LinkedIn, 38, 392
Kelly, 399 list, 43, 79, 85-88, 112, 137, 141, 152, 162, 233, 252, 255,
keras, 262, 267, 269-270 342, 378, 381, 413-414
kfkaaf, 383 ListActivity, 307
KMeans, 249, 252-255 listener, 83-84, 92, 99, 106, 262, 312, 377
KNN, 214 location, 2, 4-8, 30, 31, 35, 37, 51, 57, 59, 71, 80, 120, 130,
know, 59, 79, 112, 118, 244, 259 144-145, 147, 170, 174-175, 182, 189, 191, 204, 214,
knowhow, 256 220, 246, 300, 310, 319, 320, 374, 380-382, 395
knowledge, 8-9, 19, 30-32, 36, 43, 44, 218, 221, 348 Logarithmic, 260, 262, 264-265, 279
KPIs, 7, 12 Logic, 2-5, 7, 48, 89, 97, 212, 219, 255-256
Kubernetes, 36 LoRa, 18-20, 44, 260, 262, 265, 277, 279, 333, 348-353,
Kurtosis, 243 361-362, 368
436 Building Enterprise IoT Applications
loss, 16, 259, 260, 266, 269, 272, 326 memory, 8, 16, 30, 38-40, 42, 57, 80-83, 97, 137, 144, 149,
loudness, 152-153, 261 150, 161, 163, 169-170, 173-176, 178, 201, 209, 211,
loudspeaker, 123 217-218, 246, 266, 274, 323, 325, 352, 386, 389, 391,
LoWPAN, 288, 306 397-398, 416
loyalty, 213 MEMS, 1, 4
MentalHealth, 8, 13
M Merced, 121
Merkofer, 13
MAC, 292, 294, 296 METADATA, 124-125, 129
machine, 1-5, 8-11, 13, 17, 26-28, 30, 31, 37, 39-40, 58, 69, MFCC, 152, 260-263, 267, 270, 276
71, 73-78, 102, 131-133, 137, 156, 191, 193, 211-213, Michael, 12-13, 276, 392, 399
215-219, 220, 221, 235, 250, 259, 261, 266, 276, 287, micro, 89, 96, 211, 213
308, 364-365, 376, 379, 389-390, 392, 396-399, 416 microchip, 67, 420
MachineLearning, 243 Microcontroller, 4, 16, 45, 48, 56-57, 65, 67, 155, 209, 211,
machinelearningmastery, 161, 209 274, 356, 365
magenic, 77-78 Microphoan, 258
Magic, 61 microphone, 77, 122-125, 129, 152-153, 256-258, 261
magnetic, 81, 89, 93, 96-97, 100 Microsoft, 28, 44, 109-110, 138, 167-168, 194, 325, 368,
MagneticFieldAccuracy, 116-117 369, 371, 395, 399, 417
magnetometer, 81, 89, 91-93, 96-102, 111, 113, 215 Middleware, 333, 369, 371-373, 375, 377, 379-387, 389,
magnetometerData, 115 391, 396
MainActivity, 86, 90, 92-93, 98-99, 101, 103-104, 107, milli, 336
184-185, 189, 199, 310 mimosa, 155
Malloc, 143, 147 Mina, 67
malnourished, 137 Ming, 195
malware, 214 MinGW, 194-195
man, 35, 73, 85, 130, 381 mlleesds, 342
management, 4, 7, 16, 20, 27-28, 35-37, 74, 80, 82-83, mLogSession, 317-318, 323-324
191, 275, 287, 333, 352, 375, 387, 393, 395-396, 398, Mno, 5
415-416 mnodd, 220
Manifest, 85, 89-90, 97-98, 103, 183, 310 mobile, 2, 5, 7, 12, 29, 43, 51, 56-58, 60, 65, 68, 72, 77,
manufacturer, 46, 48, 68-69 96-97, 102, 122, 150, 157, 178, 211-216, 278, 298,
Mao, 399 325, 366-367
Marcus, 50, 52 model, 1, 4-12, 14-15, 17, 26-28, 36, 38, 40, 42, 68, 73,
Mark, 368 97, 102, 108, 125, 131, 133, 135, 137, 152-153, 155,
Markus, 13 193, 211-215, 217-218, 220-222, 227, 229, 233-239,
Martha, 132 241-246, 253-256, 258-259, 261, 263, 265-274, 277,
MARTIN, 152 282-283, 288, 324, 326, 372, 386, 393-395, 397-399,
Massage, 103, 106, 110 416
Math, 94, 102, 318 modem, 278
matplotlib, 126-127, 153, 233, 247, 255 modify, 32, 183, 256
Matrices, 159-160, 244 Mohammed, 131
matrix, 30, 159, 214, 217, 245-247, 257, 258, 269-270, 272 Mohan, 392
Matthews, 44 Mohr, 399
Maxpooling, 268, 271-273 moisture, 1, 77-78
McAfee, 325 MOM, 372
McKinney, 44 monetization, 4-7, 9
McKinsey, 1, 7, 12, 13, 36, 42-44, 70, 131, 219, 276, 398- Monetize, 6, 7, 15
399 monitor, 6, 10, 16, 25, 55, 58, 129, 189, 190, 211, 216, 230-
MCU, 48, 60, 211 231, 299-300, 324-325, 365, 366, 409, 416
MDC, 216 motion, 9, 14-15, 17, 19, 20, 29, 31, 32, 35, 37, 39, 41, 43,
measured, 34, 75, 78 58, 60, 65, 77-78, 89, 95, 108, 111-113, 115, 118, 131,
Megnetometer, 81, 97, 102 132, 157, 250, 256, 257, 396
mel, 126-128, 152-154, 261-263, 267, 270, 276 mouser, 67, 247, 276
Melfrequency, 262 MQTT, 4, 18-20, 35, 37, 70, 277, 288, 322, 324-326, 328-
melspec, 267-268, 270 331, 333-334, 339-340, 342-344, 348-349, 368, 396
melspectrogram, 126-127, 153-154, 156, 261, 267, 270 multidimensional, 215, 218
mely, 416 multiple, 5, 7, 19, 49, 67, 133, 201, 215-217, 238-239, 243,
memcpy, 149-150, 353, 356 261, 263, 280-281, 297, 307, 311, 322, 348, 389, 395
memorable, 213 multivariate, 216-217
Memorial, 125, 152, 261 municipalities, 28
memories, 8, 16 music, 124-125, 129, 276
MVVCC, 109
Index 437
N onCharacteristicNotified, 318
onCharacteristicWrite, 317
nAccuracy, 269, 272 onclick, 94, 95, 286
NACK, 310 OnClickListener, 93
nano, 336 onready, 284
Native, 80 onreadystatechange, 283-284, 286
natural, 7, 13, 70, 130, 235, 400 OnRestart, 81, 82, 97, 102
NC, 254, 257-259 onRestoreInstanceState, 315
needs, 5, 7, 18-19, 41, 60, 70, 82-83, 118, 120, 135, 137, onResume, 81, 82, 92, 94, 97, 99-102, 104, 107, 185, 187,
145, 157, 175, 205, 212, 217, 281, 322, 333, 348, 357, 189, 198
396-397, 416 onSensorChanged, 83, 94, 104, 105, 107
nels, 260, 262, 264-265, 279, 297 onServiceBinded, 313, 323
Neoplasm, 125-126, 152, 268, 271 onServiceConnected, 323
Neural, 8, 125, 152, 156, 211-212, 215, 218-219, 222, 259- onServiceDisconnected, 323
267, 269-272, 275-276 onServicesDiscovered, 315
neuralnetwork, 152 onServiceStarted, 315
neurons, 261, 266 onServiceUnbinded, 313, 323
news, 129, 132, 156, 322, 368 OpenBSD, 336
newsletter, 288, 368 OperationQueue, 118-119
newsroom, 2, 13, 219, 276 operations, 4-5, 7, 10, 35, 37, 105, 120, 161-162, 165-166,
Nexus, 88-89 169-170, 181, 199-202, 280-281, 307, 319, 322, 350-
NFC, 310 352, 370, 386, 390-391, 396
Nison, 103, 106 optimizer, 259-260, 262-266, 269, 272, 279
NIST, 393-394, 399 organically, 249
NLP, 261 organizations, 1, 9, 10, 70, 102, 219-220, 322, 325, 398
nodes, 14-15, 17, 19, 38, 214, 216, 221, 224-225, 263-264, organized, 390
266, 272, 348, 389, 395 organizes, 175, 178
Nordic, 67, 316 OXIDATION, 405
NORMAL, 83-84, 92, 94-95, 100-101 oXl, 125
normalization, 4, 7 oymoupr, 380
North, 89, 96, 135-136, 247, 406-407, 409
Norway, 28 P
Note, 137, 179, 310, 323, 340, 352
NSArray, 202-204, 207 PaaS, 4-5, 7, 393-394
NSASCIIStringEncoding, 202-204 package, 85-86, 90, 92-93, 98-99, 101, 103-104, 107, 183,
NSData, 201-204 185, 187, 197, 310, 316, 319, 322, 328-329, 362-363
NSDocumentDirectory, 202-204, 207 packet, 19, 63, 135, 235-236, 287-288, 297, 299, 308, 316,
NSFileHandle, 201-202 318, 330, 343, 344, 348, 349, 351-359, 368
NSFileManager, 201-204, 208 pandas, 233, 249, 252-254, 267, 269-270
NSLog, 202-204, 208, 305 Pathological, 125-126, 268, 271
NSMotionUsageDescription, 118 pattern, 108, 124-125, 129-130, 152, 154-155, 188, 198,
NSNumber, 117-118 214, 216, 230, 265, 325, 365, 370
numberOfSteps, 117-119 patterns, 9, 14, 17, 36, 124-125, 129-130, 188, 198, 214,
numbers, 11, 170, 244, 256, 259, 309, 411 289, 325, 370
Numerator, 239 Paulo, 16
numpy, 126, 153, 161-165, 209, 227, 233, 247, 255, 267, payload, 19, 150, 279, 280, 293, 328-330, 339, 343, 348,
269-270 352-354
NYC, 71-72, 131 Pedometer, 111-113, 117-119
pedometerData, 119
O Pedro, 44
peek, 358-359
observations, 36, 217, 232-233, 244, 247 people, 8, 102, 220, 222, 235-236, 241, 243, 246-247, 256-
observeCallback, 293 257, 263, 278
offer, 2, 5-7, 15, 69, 74, 131, 151, 294, 299-300, 304, 331, PEP, 331, 337, 368, 401
386, 387, 390, 395 percentage, 11, 43, 65, 263
offering, 15 performance, 1, 6, 11, 56-57, 81, 88, 97, 102, 134, 136,
offerlso, 15 152, 175, 215, 258, 263, 266, 331, 333, 338, 368,
Office, 406-407 396, 401
official, 292 performancenot, 81, 97, 102
offline, 36, 217 period, 76, 83-84, 307, 378
offset, 149-150, 349-350, 373, 384, 386 periodic, 33, 55, 59, 157
OK, 112-113, 207-209, 289, 354-355, 357-358 periodically, 18, 177, 391
438 Building Enterprise IoT Applications
PeriodUs, 88-89 profile, 193, 212-213, 249, 294, 296, 298, 309, 311, 322,
Peripheral, 48, 62, 173-174, 298-301, 303-305, 307, 311 398
permanent, 169-170 profitability, 6
permission, 214, 276, 307, 310, 312, 388-389 profitable, 416
Persistence, 39, 389 prognosis, 4, 5, 7, 103, 157
phase, 8-10, 12, 36, 127, 217, 375-376 Prognostic, 134-136, 397
phenomenon, 72 protocol, 19, 36, 37, 49, 57, 63, 177, 277, 279-280, 287-
Philipp, 13 293, 295-298, 322, 324-326, 330-331, 334, 340-341,
philosophy, 15 343-347, 348-349, 352, 357, 368, 372, 377, 396
Phono, 261 provide, 2, 5-7, 20, 26, 36, 48, 68-69, 73, 103, 134, 137,
Phonotrauma, 152, 268, 271 183, 211, 214, 216, 218, 274, 277-278, 288, 300, 307,
phycological, 8 364-365, 372-373, 386, 391, 416
physical, 1, 3, 6-7, 70, 72, 75, 77, 79, 89, 96, 103, 149, 205, Pthread, 151, 368, 417
216, 219, 259, 276, 288, 294, 297, 325, 393, 396 public, 1, 7-8, 13, 50, 54, 77, 84, 86, 92-96, 98-102, 104,
pixel, 130, 154-155 107, 183, 185-189, 191, 194, 198-201, 307-308, 312-
Platform, 2, 4-5, 7, 14-15, 18, 20, 29-30, 43, 68-70, 108, 323, 349, 394
131, 393-394, 396-397 Punjab, 73
point, 11, 34, 74, 76, 79, 82, 112, 114, 123, 130, 137-138, pyplot, 127, 233, 247, 255
143, 145, 163, 170, 182, 189, 211, 214, 216, 218-221, PySpark, 388-389, 392
223, 249, 262, 285, 307, 340 Python, 125-126, 140-141, 155, 157, 161-163, 209, 227,
police, 274-276 229, 232-233, 242-243, 247, 252, 267, 290-292, 326-
polling, 16, 55, 297, 356, 396 328, 330-334, 336-339, 366, 368, 382, 384, 387-389,
Pollution, 130 401
position, 5-6, 78-79, 138, 145, 175-177, 189, 201-202, 214, pythoncentral, 140, 155
230-231, 365, 412-413
positive, 7-8, 12, 48, 125, 239, 256-257, 412 Q
positively, 240-241, 265
POSIX, 417 QoS, 288, 325, 328-329, 342
possible, 5-6, 9, 13, 33, 83-84, 125, 130, 133, 169-170, 179, QRS, 365
216, 223, 278, 300, 325-326, 333, 367-368, 372, 395 Qualcomm, 278
POST, 51, 53, 280-281, 288 qualified, 26, 202
posteri, 240, 246-248 qualitatively, 249
posterior, 366 quality, 9, 14-15, 17, 35, 37, 41, 120, 122, 125, 152-153,
PostMessage, 103, 106, 110 213, 217, 261, 277, 335, 395, 397
power, 2-3, 5, 7, 13, 19, 36, 45-46, 48, 51, 56-57, 70, 105, query, 200, 209, 288, 307, 321
126-127, 131, 149, 154, 175, 179, 193, 211, 216, 220, QueryCPLeOrfoCrKm, 336
238, 262, 294, 297, 307, 322, 324-325, 348, 350, 358, QueryPerformance, 333
396 QueryPerformanceCounter, 336, 338-339
predict, 4, 122-123, 134, 216, 235-236, 243-244, 248, 263, Queue, 37, 105, 109-110, 137, 140, 144-146, 149-151, 155,
269, 272, 325, 416 176-177, 356, 396
prediction, 28, 35, 37, 157, 211, 215, 216, 233, 243, 245, quick, 82, 137, 157, 212, 390, 392
260, 262, 264-266, 279
primitive, 151 R
principal, 74 Radar, 13
principle, 29, 130, 133, 151, 202, 256, 280 Radio, 58, 63, 74, 296, 356
print, 34, 61-64, 115, 124, 126-127, 141-142, 153, 163-165, rage, 75
194-195, 233, 243, 267, 269-270, 272, 274, 292-293, Rain, 221-223, 225-227, 229
321, 328-330, 332, 338, 341, 359, 366-367, 384, 386, Rajaraman, 44
396 range, 19, 48, 57, 68, 75-77, 124-125, 129, 155, 178, 216,
probability, 214, 222, 258-259, 263 233, 248, 266-268, 270-271, 294, 324-325, 334, 337,
process, 1, 4, 6, 8-10, 12, 14-15, 17, 20, 26-28, 30-33, 36, 339, 348, 396
39, 41-42, 58, 77, 81-83, 97, 102, 109-111, 129, 134, Raspberry, 365-366
137, 144-146, 149, 157, 169-170, 177, 179, 190, 191, RBAC, 4
194, 211, 213, 216, 219, 221, 244-247, 256, 258-259, Rbaucmkgirnouantido, 129
266, 274, 277, 281, 291-292, 330-333, 338-339, 349, Rcoengrtiensusoiounsly, 213
360, 368, 371, 386, 388-391, 399, 412 Read, 60, 81, 97, 171, 178-182, 203, 323, 389
processInterrupts, 55 readHumidity, 181
processor, 144-146, 149, 176-177, 220, 229, 330, 333, 335 ReadSensorsAndStore, 178, 181
Producer, 145-146, 149-151, 177, 381, 382, 384-386, 391 ReadyActivity, 311
professional, 125 readyState, 284-287
Professor, 155, 256 recognition, 35, 37, 124-125, 129, 152, 212, 214-215, 261,
325
Index 439
360-362, 365, 367-372, 374, 378-379, 384, 386, 391, USB, 45, 48-49, 80, 173-174
395-397, 400-404, 415 UUID, 298, 309, 315-317
timeclocks, 368
timecollection, 397 V
Timecounter, 335
timeDateData, 179, 181 valid, 57, 145, 178, 238, 248, 268, 271, 310, 350-351, 353-
timeDateString, 181 354, 360-361
timeInterval, 115 Value, 93, 100, 104, 138-140, 221-229, 238-239, 245, 249,
timersync, 351 253-254, 258-259, 277, 285, 301, 357, 388-389, 398
tinycircuits, 49, 60, 67 VCC, 43, 56, 65, 124-125, 129
TinyDuino, 49 VECTOR, 87
tinyshield, 49, 60, 67 Velocity, 14, 33, 35, 37, 277
TLS, 19, 325, 348 VenueAnalytics, 220
Toast, 92, 98-101, 104, 107, 197, 199 Venues, 193, 213
Toolbox, 324 versatility, 45
torque, 77-78 video, 30, 33, 68-69, 129, 132, 277
tourism, 213, 214, 218 view, 5, 15, 18, 41-42, 85, 93, 95, 98, 109-110, 185-189,
towards, 2, 6, 44, 218, 325 197, 199, 275, 324, 368
towardsdatascience, 276 ViewController, 115
Towers, 213 viewDidLoad, 115, 203, 207
TTY, 351 viewed, 25, 120
tuple, 162-164, 222, 227-229 Visual, 77, 138, 167-168, 171, 397
twodimensional, 157 Visualization, 365, 397
twofold, 350-351 voice, 5, 20, 33, 38, 40, 42, 124-125, 129, 152, 215, 261,
Type, 77-78, 86-88, 285-287, 380-381, 413 269, 398
Vuppalapati, 132, 156, 203, 206
U
W
UART, 59, 179-180, 311-312, 314-317
UARTActivity, 311-312 wait, 53, 151, 282, 352-353, 358-360
UARTBinder, 312-313 warehouse, 13, 31-32, 398
UartConfiguration, 312-313 Warehouse, 30, 32
UARTConfigurationsAdapter, 312-313 warming, 72-73, 130, 400
UARTConfigurationSynchronizer, 312-313 WARNING, 343, 351, 354, 359-360
UARTInterface, 312 washington, 281, 368
UARTLocalLogContentProvider, 311-312 water, 1-3, 16, 28, 43, 44, 73, 120-122, 132, 405-410, 416
UARTLogFragment, 314-315 Wearable, 7, 36, 55, 71, 213, 312, 313
UARTManager, 316 Weather, 4, 5, 7, 25, 109-110, 216, 220, 235, 415, 416
UARTManagerCallbacks, 316 WeatherApiClasses, 319
UARTNewConfigurationDialogFragme, 312 web, 31-32, 69, 74, 131, 163, 209, 213, 281-283, 288, 368,
UARTService, 311-313 392, 396
UDP, 18-20, 287-288, 292, 348-349, 366-367 Webkit, 80
UI, 15, 25-26, 28, 83-84, 90-91, 98, 100, 104-108, 110, website, 120, 249, 387, 416
113, 118-119, 186, 189, 196-197, 282-283, 302, 323, WebSocket, 396
326-327, 367, 389 weighed, 7
UIApplication, 114 wikibon, 219, 276
UIApplicationDelegate, 114 wikipedia, 333, 372, 412
UIApplicationMain, 114 WINAPI, 111
UIKit, 114-115, 206 window, 38-40, 42, 114, 154, 157, 177, 193, 205, 216, 230-
UILabel, 206 234, 265, 267, 270, 380, 415-416
UIViewController, 115, 206 won, 123
UIWindow, 114 work, 5-6, 9-10, 12, 36, 51, 109-110, 137, 211, 266, 279,
UNIIX, 361 325, 364-365, 374, 377, 417
United, 8, 16, 412, 416 workouts, 218
University, 8, 44, 247 world, 1, 5-6, 16, 28, 33, 68-70, 72-73, 77, 194, 211, 216,
UNIX, 355, 361, 368, 417 219, 230-231, 276-277, 325, 364-365, 399
UnRegisterListener, 84 worldwide, 2, 73, 137, 308
unsupervised, 11, 39-40, 218, 220-221, 249 worth, 222
URI, 281, 292, 312, 324 write, 19, 37, 45, 51, 53, 57, 64, 66, 151, 170-171, 173,
USA, 276, 296 180, 182, 187, 189, 191-192, 199, 202, 307, 317-318,
USART, 57, 173 343, 348, 391
WSJ, 416
442 Building Enterprise IoT Applications
X year, 1, 73, 102, 133, 137, 216, 219, 235, 306, 355, 416
Yes, 43, 56, 65, 82, 249, 252-254, 306
Xcode, 118
XGBoost, 261 Z
xml, 85, 90, 98, 103, 183, 214, 281-283, 310, 313
XMLHttpRequest, 283-286 Zenith, 29-30
XTML, 283 zero, 57, 66, 157-158, 163-164, 174, 179, 244-245, 256-
257, 265-266, 310, 340, 352
Y Zigbee, 4, 36, 260, 262, 264, 279, 288, 306, 325
zip, 252, 255, 374
yao, 305 Zookeeper, 369, 374-376, 379-382
YARN, 389 zookeeperAdmin, 375