Driver Monitoring and Assisting Device
Driver Monitoring and Assisting Device
ABSTRACT
The increasing number of vehicles on Indian roads and low traffic rules
enforcement lead to multiple human-error induced crashes and fatalities. In this
paper, we propose a driver monitoring and assisting device which employs IoT
sensors, like alcohol sensor and air pressure sensor for sobriety check and
machine learning algorithms to detect micro-sleep and frequent yawns for
drowsiness detection. The device turns on and asks the driver to blow into the
mouthpiece. After a clean and proper blow, the driver is allowed to switch the
ignition on. Thereafter, the device constantly monitors the driver using a camera
for signs of fatigue, and uses the vehicle’s sound system or a buzzer to alert the
drowsy driver. The goal of our work is to develop and deploy a device that will
curb drunk and drowsy driving mishaps and inculcate responsible driving
behaviour among drivers.
INTRODUCTION
With the world’s second largest road network, after the US, Indian roads
ply over 250 million registered motor vehicles as of 2017. A rapid urbanization
and motorization have marked a linear growth in vehicles over the last 70 years.
This, unfortunately, increases the road casualties as well, killing sixteen people
every hour and twenty children every day on Indian roads. A recent WHO
report, among many others, enumerated human errors such as drunk driving,
drowsiness and distractions as one of the leading risk factors of road accidents.
Surprisingly, the driving under the influence (DUI) incidents are not limited to a
certain age group or a section of society. Hence, it is not lack of awareness but
disregard for the rules that lead to many DUI casualties. Such incidents strain
the lives of affected and associated people, mentally, physically and financially.
With the unprecedented advancement of technology, we can now leverage the
internet of things (IoT) technology and machine learning (ML) techniques to
effectively design a system that curbs the human errors on the road.
One of the very first recognizably modern embedded systems was the
Apollo Guidance Computer, developed by Charles Stark Draper at the MIT
Instrumentation Laboratory. At the project's inception, the Apollo guidance
computer was considered the riskiest item in the Apollo project as it employed
the then newly developed monolithic integrated circuits to reduce the size and
weight. An early mass-produced embedded system was the Automatics D-17
guidance computer for the Minuteman missile, released in 1961. When the
Minuteman II went into production in 1966, the D-17 was replaced with a new
computer that was the first high-volume use of integrated circuits.
Since these early applications in the 1960s, embedded systems have come
down in price and there has been a dramatic rise in processing power and
functionality. An early microprocessor for example, the Intel 4004, was
designed for calculators and other small systems but still required external
memory and support chips. In 1978 National Engineering Manufacturers
Association released a "standard" for programmable microcontrollers, including
almost any computer-based controllers, such as single board computers,
numerical, and event-based controllers.
1.1.2 Applications
More sophisticated devices that use a graphical screen with touch sensing
or screen-edge buttons provide flexibility while minimizing space used: the
meaning of the buttons can change with the screen, and selection involves the
natural behavior of pointing at what is desired. Handheld systems often have a
screen with a "joystick button" for a pointing device.
Some systems provide user interface remotely with the help of a serial
(e.g. RS-232, USB, I²C, etc.) or network (e.g. Ethernet) connection. This
approach gives several advantages: extends the capabilities of embedded
system, avoids the cost of a display, simplifies BSP and allows one to build a
rich user interface on the PC. A good example of this is the combination of an
embedded web server running on an embedded device (such as an IP camera) or
a network router. The user interface is displayed in a web browser on a PC
connected to the device, therefore needing no software to be installed.
1.2 IOT
The concept of Internet of Things (IoT) started with things with identity
communication devices. The devices could be tracked, controlled or monitored
using remote computers connected through Internet. IoT extends the use of
Internet providing the communication, and thus inter-network of the devices
and physical objects, or ‘Things’. The two prominent words in IoT are
“internet” and “things”. Internet means a vast global network of connected
servers, computers, tablets and mobiles using the internationally used protocols
and connecting systems. Internet enables sending, receiving, or communicating
of information. Thing in English has number of uses and meanings. Dictionary
meaning of ‘Thing’ is a term used to reference to a physical object, an action or
idea, situation or activity, in case when we do not wish to be precise. IoT, in
general consists of inter-network of the devices and physical objects, number of
objects can gather the data at remote locations and communicate to units
managing, acquiring, organizing and analyzing the data in the processes and
services. It provides a vision where things (wearable, watch, alarm clock, home
devices, surrounding objects with) become smart and behave alive through
sensing, computing and communicating by embedded small devices which
interact with remote objects or persons through connectivity. The scalable and
robust nature of Cloud computing is allowing developers to create and host their
applications on it. Cloud acts as a perfect partner for IoT as it acts as a platform
where all the sensor data can be stored and accessed from remote locations.
These factors gave rise to the amalgamation of both technologies thus leading to
the formation of a new technology called Cloud of Things(CoT). In CoT the
things(nodes) could be accessed, monitored and controlled from any remote
location through the cloud. Due to high scalability in cloud any number of node
could be added or removed from the IoT system on a real time basis. In simple
terms IoT can be explained in form of an equation stating:
The ideal of creating a Smart City is now becoming possible with the
emergence of the Internet of Things. One of the key issues that smart cities
relate to are car parking facilities and traffic management systems. In present
day cities finding an available parking spot is always difficult for drivers, and it
tends to become harder with ever increasing number of private car users. This
situation can be seen as an opportunity for smart cities to undertake actions in
order enhance the efficiency their parking resources thus leading to reduction in
searching times, traffic congestion and road accidents. Problems pertaining to
parking and traffic congestion can be solved if the drivers can be informed in
advance about the availability of parking spaces at and around their intended
destination. Recent advances in creating low-cost, low-power embedded
systems are helping developers to build new applications for Internet of Things.
Followed by the developments in sensor technology, many modern cities have
opted for deploying various IoT based systems in and around the cities for the
purpose of monitoring. A recent survey performed by the International Parking
Institute reflects an increase in number of innovative ideas related to parking
systems. At present there are certain parking systems that claim to citizens of
delivering real time information about available parking spaces. Such systems
require efficient sensors to be deployed in the parking areas for monitoring the
occupancy as well as quick data processing units in order to gain practical
insights from data collected over various sources.
Cloud computing and IoT have witnessed large evolution. Both the
technologies have their advantages, however several mutual advantages can be
foreseen from their integration. On one hand, IoT can address its technological
constraints such as storage, processing and energy by leveraging the unlimited
capabilities and resources of Cloud. On the other hand, Cloud can also extend
its reach to deal with real world entities in a more distributed and dynamic
fashion by the use of IoT. Basically, the Cloud acts as an intermediate between
things and applications, in order to hide all the complexities and functionalities
necessary for running the application. Below are some of the factors that led to
the amalgamation of Cloud and IoT.
The devices being used under IoT have limited processing capabilities.
Data collected from various sensors is usually transmitted to more powerful
nodes where its aggregation and processing can be done. The computation
needs of IoT can be addressed by the use of unlimited processing capabilities
and on-demand model of Cloud. With the help of cloud computing, IoT systems
could perform real-time processing of data thus facilitating highly responsive
applications.
1.4.4 Scalability
1.4.5 Availability
1.4.6 Interoperability
IoT involves the use of devices that are heterogeneous in nature. These
devices may have different hardware or software configurations as a result
causing compatibility issues. It becomes very difficult in an IoT environment to
ensure interoperability among these devices. Cloud helps in addressing this
problem as it provides a common platform where various devices can connect
and interact. Devices are allowed to share and exchange data in a format that is
acceptable to them.
CHAPTER 2
LITERATURE REVIEW
BACKGROUND
Hence, the existing sobriety check and fatigue check systems lack
usability in the real world. In this paper, we address the aforementioned
literature gaps by proposing a system that uses IoT sensors, alcohol gas sensor
MQ-3 and air pressure sensor BMP-280 to collect the blow samples from the
driver for sobriety check, 5-megapixel (MP) night vision camera for real-time
drowsiness detection, Raspberry Pi 3B+ (RPi) microprocessor with 1GB RAM
processes this data and
outputs the result on a liquid crystal display (LCD) and alerts the driver as well
as passenger(s) using vehicle’s sound system or a buzzer
2.1 Rico, J., Sancho, J., Cendon, B., & Camus, M. (2013, March).
Parking easier by using context information of a smart city: Enabling fast
search and management of parking resources. In Advanced Information
Networking and Applications Workshops (WAINA), 2013 27th
International Conference on (pp. 1380-1385). IEEE.
2.2 Zheng, Y., Rajasegarar, S., & Leckie, C. (2015, April). Parking
availability prediction for sensor-enabled car parks in smart cities. In
Intelligent Sensors, Sensor Networks and Information Processing (ISSNIP),
2015 IEEE Tenth International Conference on (pp. 1-6). IEEE.
2.3 Zhou, F., & Li, Q. (2014, November). Parking Guidance System Based
on ZigBee and Geomagnetic Sensor Technology. In Distributed Computing
and Applications to Business, Engineering and Science (DCABES), 2014
13th International Symposium on (pp. 268-271). IEEE.
Concerning the phenomenon that common parking service could not satisfy the
increasing demand of the private vehicle owners, an intelligent parking
guidance system based on Zig Bee network and geomagnetic sensors was
designed. Real-time vehicle position and related traffic information were
collected by geomagnetic sensors around parking lots and updated to center
server via Zig Bee network. On the other hand, out-door Liquid Crystal Display
screens controlled by center server can display information of available parking
places. In this paper, guidance strategy was divided into four levels, which
could provide clear and effective information to drivers. The experimental
results prove that the distance detection accuracy of geomagnetic sensors was
within 0.4m, and the lowest package loss rate of the wireless network in the
range of 150m is 0%. This system can provide solution for better parking
service in intelligent cities. With the acceleration of transportation construction
pace, intelligence transportation has become the development direction of urban
traffic management, it is an important way to ease traffic congestion and
improve the efficiency of transportation and management. Current road traffic
information collection technologies mainly include that GPRS wireless
communication technology, infrared detection technology and radio frequency
identification (RFID) technology. GPRS communication technology must pay
extra fee for network using to operators and will easily lead to communication
delay when the network is busy; infrared detection communication distance is
shorter and will be affected by car's thermal radiation; although passive RFID
technology can achieve accurate vehicles' position and anti-jamming
performance is ideal, it only supports star network, the amount of transferred
data and communication distance will be very limited, so it is not easy to mass
deployment and difficult to promote.
2.4 Botta, A., de Donato, W., Persico, V., & Pescapé, A. (2014, August). On
the Integration of Cloud Computing and Internet of Things. In Future
Internet of Things and Cloud (FiCloud), 2014 International Conference on
(pp. 23-30). IEEE.
2.5 Ji, Z., Ganchev, I., O'droma, M., & Zhang, X. (2014, August). A
cloudbased intelligent car parking services for smart cities. In General
Assembly and Scientific Symposium (URSI GASS), 2014 XXXIth URSI
(pp. 1-4). IEEE.
2.7 Ballon, P., Glidden, J., Kranas, P., Menychtas, A., Ruston, S., & Van
Der Graaf, S. (2011, October). Is there a Need for a Cloud Platform for
European Smart Cities?. In eChallenges e-2011 Conference Proceedings,
IIMC International Information Management Corporation.
EPIC - the “European Platform for Intelligent Cities”- is more than just
an IT platform; it is a one-stop-shop where small to medium sized Cities in
Europe can find real, affordable solutions (products and services) to materialize
the “Smart Cities” concept efficiently and cost-effectively. Instead, the EPIC
Smart City roadmap, service catalogue and cloud platform enable every city in
Europe to access and deploy innovative Smart City applications that meet their
budgets and needs. EPIC offers city managers a Roadmap for their journey
towards becoming a smart city in a strategic way. The Roadmap consists of a
short-term assessment exercise covering vision, budget and delivery. EPIC also
uses its cloud platform (currently based on IBM infrastructure) to deliver Smart
City solutions “as a service”. The Roadmap and Cloud Platform provide the
foundations for EPIC's unique selling point: a marketplace for Smart City
services. In this marketplace, EPIC brings together service providers and
information/data providers (from private and public sector) in order to aggregate
“Smart City services” with added value for citizens, city visitors, businesses in
the city and the city itself.
2.8 Suciu, G., Vulpe, A., Halunga, S., Fratu, O., Todoran, G., & Suciu, V.
(2013, May). Smart cities built on resilient cloud computing and secure
internet of things. In Control Systems and Computer Science (CSCS), 2013
19th International Conference on (pp. 513-518). IEEE.
Cloud Computing and Internet of Things (IoT) are currently two of the
most popular ICT paradigms that are expected to shape the next era of
computing. The convergence between cloud computing and IoT has become a
hot topic over the last few years because of the benefits that IoT could have
from the distributed nature of cloud computing infrastructures. This paper
proposes a new platform for using cloud computing capacities for provision and
support of ubiquitous connectivity and real-time applications and services for
smart cities' needs. We present a framework for data procured from highly
distributed, heterogeneous, decentralized, real and virtual devices (sensors,
actuators, smart devices) that can be automatically managed, analyzed and
controlled by distributed cloud-based services.
2.9 Chen, S. Y., Lai, C. F., Huang, Y. M., & Jeng, Y. L. (2013, July).
Intelligent home-appliance recognition over IoT cloud network. In Wireless
Communications and Mobile Computing Conference (IWCMC), 2013 9th
International (pp. 639-643). IEEE.
In recent years, under the concern of energy crisis, the government has
actively cooperated with research institutions in developing smart meters. As
the Internet of Things (IoT) and home energy management system become
popular topics, electronic appliance recognition technology can help users
identifying the electronic appliances being used, and further improving power
usage habits. However, according to the power usage habits of home users, it is
possible to simultaneously switch on and off electronic appliances. Therefore,
this study discusses electronic appliance recognition in a parallel state, i.e.
recognition of electronic appliances switched on and off simultaneously. This
study also proposes a non-invasive smart meter system that considers the power
usage habits of users unfamiliar with electronic appliances, which only requires
inserting a smart meter into the electronic loop. Meanwhile, this study solves
the problem of large data volume of the current electronic appliance recognition
system by building a database mechanism, electronic appliance recognition
classification, and waveform recognition. In comparison to other electronic
appliance recognition systems, this study uses a low order embedded system
chip to provide low power consumption, which have high expandability and
convenience. Differing from previous studies, the experiment of this study
considers electronic appliance recognition and the power usage habits of general
users. The experimental results showed that the total recognition rate of a single
electronic appliance can reach 96.14%, thus proving the feasibility of the
proposed system.
SYSTEM ANALYSIS
3.1.1 DISADVABTAGES
3.2.1 ADVANTAGES
• Cost-effective real-time drowsiness detection system should use
maximum computational resources.
The mobile application acts like an interface for the end users to interact
with the system. The application is developed in Apache Cordova and Angular
Js framework using Javascript as a programming language. The purpose of
using Apache Cordova is to create applications that can run on both android and
iOS platforms with the same source code. The application is connected with the
IBM MQTT server through a secure channel and a 2 factor authorization. The
purpose of this mobile application is to provide information regarding
availability of parking spaces and allowing the end user to book a slot
accordingly. Transfer of data takes place in JSON format between IBM MQTT
server and the mobile application. In order to ensure proper communication
both the Raspberry pi and mobile application must be subscribed to a particular
channel on IBM MQTT server.
The IBM MQTT server is hosted on cloud. Cloud acts as a data base to
store all the records related to parking areas and end users that have access to
the system. It keeps a track of every user connected to the system and maintains
information such as time at which the car was parked, time duration for parking
a car, amount paid by the user and mode of payment.
It is due to the flexible nature of cloud which permits the system to add
any number of users at any time of the day. Continuous backup is made of the
data stored on cloud in order to ensure easy and quick recovery of data in case
of any kind of system failure.
On closely looking at the figure one gets to see that empty parking spaces
are indicated by red light in Lane A whereas green light in Lane B. This is due
to the fact that in case of Lane A although there is no car currently parked but
there still is a red light because the slot has already been booked by some user.
On the other hand, the parking slot in Lane B shows green light because it
neither has a booking nor a car parked in it.
CHAPTER 4
SYSTEM IMPLEMENTATION
EXPLANATION
• The 12V input from vehicle’s battery is converted into 5V using a voltage
regulator and is fed to RPi, which in turn powers all other devices. The
two parts of the system are, sobriety and fatigue check. In the sobriety
check, MQ-3 and BMP-280, comprising a movable mouthpiece, feed data
into RPi. RPi processes this data and outputs the result on the LCD
screen, alerts the driver and passengers and controls the ignition system
of the vehicle through a relay. In the fatigue check, camera sends a live
video feed to RPi, where it uses an ML algorithm to infer the alert and
drowsy states of driver
4.3 METHODOLOGY
A cost-effective real-time driver monitoring and assisting system
employing sobriety and fatigue check with the help of IoT technology and ML
algorithms is a highly usable device for Indian population to curb human-error
on roads and develop a responsible driving behaviour. The proposed system
interfaces with the vehicle closely. A vehicle turns on in 3 steps. First, the driver
inserts the key in the keyhole and turns once, powering up the starter motor.
Second, the driver turns the key further, turning the battery on and
starting the engine cycle. Finally, on the last turn, spark plug fires, turning the
ignition on. Our device takes power from the vehicle and controls its ignition
system; hence it fits right between step 2 and 3.
The proposed system uses Raspberry Pi 3B+ microprocessor, depicted in
figure 1, at its heart. It processes all the data from IoT sensors and camera;
applies small computations and ML algorithms on it to infer the driver’s
behaviour. While RPi provides limited computational resources, they were
sufficient or our use case.
If the driver is found drunk, the microprocessor keeps the relay, depicted
in figure 5, off and power is not supplied to turn on the ignition system of the
vehicle. If the driver is sober, the relay is turned on and the driver is able to start
the vehicle.
The components of the system for sobriety check are alcohol gas sensor
MQ-3, air pressure sensor BMP-280, analogy to digital converter (ADC) ADS-
1115, RPi microprocessor, LCD screen, speaker or buzzer, LED lights and a 5V
relay. The flow diagram of sobriety check is given.
where Pn is the facial landmark point at number ‘n’ in figure 10. EAR for
an open eye is larger than EAR for a closed eye. Hence, a sudden drop in EAR
for 3 consecutive frames or 6 seconds is assumed to be a microsleep. The
threshold for change in EAR was empirically found to be 0.18 in our system.
OVERVIEW OF HARDWARE
Arduino
16x2 LCD
WIFI Chip
Ultrasonic Sensor
5.1.1 OVERVIEW
pinout: added SDA and SCL pins that are near to the AREF pin and two
other new pins placed near to the RESET pin, the IOREF that allow the shields
to adapt to the voltage provided from the board. In future, shields will be
compatible both with the board that use the AVR, which operate with 5V and
with the Arduino Due that operate with 3.3V. The second one is a not connected
pin, that is reserved for future purposes.
Atmega 16U2 replace the 8U2. "Uno" means one in Italian and is named
to mark the upcoming release of Arduino 1.0. The Uno and version 1.0 will be
the reference versions of Arduino, moving forward. The Uno is the latest in a
series of USB Arduino boards, and the reference model for the Arduino
platform; for a comparison with previous version 2.2 Schematic & Reference
Design The Arduino reference design can use an Atmega8, 168, or 328, Current
models use an ATmega328, but an Atmega8 is shown in the schematic for
reference. The pin configuration is identical on all three processors. 2.3
Summary Microcontroller - ATmega328 Operating Voltage - 5V Input Voltage
- 7-12V (Recommended) Input Voltage (limits) - 6-20V Digital I/O Pins - 14
(of which 6 provide PWM output) Analog Input Pins - 6 DC Current per I/O Pin
- 40 mA DC Current for 3.3V Pin - 50 mA Flash Memory - 32 KB
(ATmega328) of which 0.5 KB used by bootloader SRAM - 2 KB
(ATmega328) EEPROM - 1 KB (ATmega328) Clock Speed - 16 MHz 2.4
Power The Arduino Uno can be powered via the USB connection or with an
external power supply. The power source is selected automatically. External
(non-USB) power can come either from an AC-to-DC adapter (wall-wart) or
battery. The adapter can be connected by plugging a 2.1mm center-positive plug
into the board's power jack. Leads from a battery can be inserted in the Gnd and
Vin pin headers of the POWER connector. The board can operate on an external
supply of 6 to 20 volts. If supplied with less than 7V, however, the 5V pin may
supply less than five volts and the board may be unstable. If using more than
12V, the voltage regulator may overheat and damage the board. The
recommended range is 7 to 12 volts.
The power pins are as follows: VIN -The input voltage to the Arduino
board when it's using an external power source (as opposed to 5 volts from the
USB connection or other regulated power source). You can supply voltage
through this pin, or, if supplying voltage via the power jack, access it through
this pin. 5V - This pin outputs a regulated 5V from the regulator on the board.
The board can be supplied with power either from the DC power jack (7 -12V),
the USB connector (5V), or the VIN pin of the board (7-12V). Supplying
voltage via the 5V or 3.3V pins bypasses the regulator, and can damage your
board. We don't advise it. 3V3- A 3.3-volt supply generated by the on-board
regulator. Maximum current draw is 50 mA. GND - Ground pins. IOREF - This
pin on the Arduino board provides the voltage reference with which the
microcontroller operates. A properly configured shield can read the IOREF pin
voltage and select the appropriate power source or enable voltage translators on
the outputs for working with the 5V or 3.3V. 2.5 Memory the ATmega328 has
32 KB (with 0.5 KB used for the bootloader). It also has 2 KB of SRAM and 1
KB of EEPROM (which can be read and written with the EEPROM library).
Input and Output Each of the 14 digital pins on the Uno can be used as an
input or output, using pinMode(), digitalWrite(), and digitalRead ()functions.
They operate at 5 volts. Each pin can provide or receive a maximum of 40 mA
and has an internal pull-up resistor (disconnected by default) of 20-50 kOhms.
In addition, some pins have specialized functions: Serial: 0 (RX) and 1 (TX).
Used to receive (RX) and transmit (TX) TTL serial data. These pins are
connected to the corresponding pins of the ATmega8U2 USB-to-TTL Serial
chip. External Interrupts: 2 and 3. These pins can be configured to trigger an
interrupt on a low value, a rising or falling edge, or a change in value. See the
attach Interrupt () function for details. PWM: 3, 5, 6, 9, 10, and 11. Provide 8-
bit PWM output with the analog Write () function. SPI: 10 (SS), 11 (MOSI), 12
(MISO), 13 (SCK). These pins support SPI communication using the SPI
library. LED: 13. There is a built-in LED connected to digital pin 13. When the
pin is HIGH value, the LED is on, when the pin is LOW, it's off. The Uno has 6
analog inputs, labeled A0 through A5, each of which provide 10 bits of
resolution (i.e., 1024 different values). By default, they measure from ground to
5 volts, though is it possible to change the upper end of their range using the
AREF pin and the analog Reference () function. Additionally, some pins have
specialized functionality: TWI: A4 or SDA pin and A5 or SCL pin. Support
TWI communication using the Wire library. There are a couple of other pins on
the board: AREF. Reference voltage for the analog inputs. Used with analog
Reference (). Reset. Bring this line LOW to reset the microcontroller. Typically
used to add a reset button to shields which block the one on the board 2.7
Communication the Arduino Uno has a number of facilities for communicating
with a computer, another Arduino or other microcontrollers. The ATmega328
provides UART TTL (5V) serial Communication, which is available on digital
pins 0 (RX) and 1 (TX). An ATmega16U2 on the board channels this serial
communication over USB and appears as a virtual com port to software on the
computer. The '16U2 firmware uses the standard USB COM drivers, and no
external driver is needed. However, on Windows, a .inf file is required. The
Arduino software includes a serial monitor which allows simple textual data to
be sent to and from the Arduino board. The RX and TX LEDs on the board will
flash when data is being transmitted via the USB-to-serial chip and USB
connection to the computer (but not for serial communication on pins 0 and 1).
A Software Serial library allows for serial communication on any of the Uno's
digital pins. The ATmega328 also supports I2C (TWI) and SPI communication.
The Arduino software includes a Wire library to simplify use of the I2C bus; see
the documentation for details. For SPI communication, use the SPI library.
The Arduino Uno can be programmed with the Arduino software. The
ATmega328 on the Arduino Uno comes pre-burned with a bootloader that
allows you to upload new code to i without the use of an external hardware
programmer. It communicates using the original STK500 protocol (reference, C
header files). You can also bypass the bootloader an program the
microcontroller through the ICSP (In-Circuit Serial Programming) header; see
these instructions for details. The ATmega16U2 (or 8U2 in the rev1 and rev2
boards) firmware source code is available. The ATmega16U2/8U2 is loaded
with a DFU bootloader, which can be activated by: On Rev1 boards: connecting
the solder jumper on the back of the board (near the map of Italy) and then
resetting the 8U2. On Rev2 or later boards: there is a resistor that pulling the
8U2/16U2 HWB line to ground, making it easier to put into DFU mode. You
can then use Atmel's FLIP software (Windows) or the DFU programmer (Mac
OS X and Linux) to load a new firmware. Or you can use the ISP header with
an external programmer (overwriting the DFU bootloader). See this user-
contributed tutorial for more information. 2.9 Automatic (Software) Reset
Rather than requiring a physical press of the reset button before an upload, the
Arduino Uno is designed in a way that allows it to be reset by software running
on a connected computer. One of the hardware flow control lines (DTR) of
theATmega8U2/16U2 is connected to the reset line of the ATmega328 via a
100 nano farad capacitor. When this line is asserted (taken low), the reset line
drops long enough to reset the chip. The Arduino software uses this capability
to allow you to upload code by simply pressing the upload button in the
Arduino environment. This means that the bootloader can have a shorter
timeout, as the lowering of DTR can be well-coordinated with the start of the
upload. This setup has other implications. When the Uno is connected to either
a computer running Mac OS X or Linux, it resets each time a connection is
made to it from software (via USB). For the Following half-second or so, the
bootloader is running on the Uno. While it is programmed to ignore malformed
data (i.e., anything besides an upload of new code), it will intercept the first few
bytes of data sent to the board after a connection is opened. If a sketch running
on the board receives one-time configuration or other data when it first starts,
make sure that the software with which it communicates waits a second after
opening the connection and before sending this data. The Uno contains a trace
that can be cut to disable the auto-reset. The pads on either side of the trace can
be soldered together to re-enable it. It's labelled "RESET-EN". You may also be
able to disable the auto-reset by connecting a 110-ohm resistor from 5V to the
reset line.
USB Over current Protection the Arduino Uno has a resettable polyfuse
that protects your computer's USB ports from shorts and over current. Although
most computers provide their own internal protection, the fuse provides an extra
layer of protection. If more than 500 mA is applied to the USB port, the fuse
will automatically break the connection until the short or overload is removed.
Physical Characteristics The maximum length and width of the Uno PCB
are 2.7 and 2.1 inches respectively, with the USB connector and power jack
extending beyond the former dimension. Four screw holes allow the board to be
attached to a surface or case. Note that the distance between digital pins 7 and 8
is 160 mil (0.16"), not an even multiple of the 100-mil spacing of the other pins.
Each of the 14 digital pins on the Uno can be used as an input or output,
using pinMode(), digitalWrite(), and digitalRead() functions. They operate at 5
volts. Each pin can provide or receive a maximum of 40 mA and has an internal
pull-up resistor (disconnected by default) of 20-50 kOhms. In addition, some
pins have specialized functions:
Each of the 14 digital pins on the Arduino Uno can be used as an input or
output, using pinMode(), digitalWrite (), and digitalRead() functions. They
operate at 5 volts. Each pin can provide or receive a maximum of 40 mA and
has an internal pull-up resistor (disconnected by default) of 20-50 kOhms.
PWM: 3, 5, 6, 9, 10, and 11. Provide 8-bit PWM output with the analog Write
() function.
LED: 13. There is a built-in LED connected to digital pin 13. When the pin is
HIGH value, the LED is on, when the pin is LOW, it’s off.
The Uno has 6 analog inputs, labelled A0 through A5, each of which provide 10
bits of resolutio n (i.e., 1024 different values). By default, they measure from
ground to 5 volts, though is it possible to change the upper end of their range
using the AREF pin and the analog Reference () function.
TWI: A4 or SDA pin and A5 or SCL pin. Support TWI communication using
the Wire library.
AREF. Reference voltage for the analog inputs. Used with analogReference().
Reset. Bring this line LOW to reset the microcontroller. Typically used to add a
reset button to shields which block the one on the board.
In order to connect LCD to the MCU, you have to first make physical
connections between the pins of LCD and MCU. In order to connect the LCD,
you have to use one PORT of the MCU completely for this purpose. Suppose
you chose a particular PORT.
Select your chip and clock frequency. Then click on LCD tab. Select the
PORT at which you want to make LCD connections.
Set chars/line text box to 16, because you will be using 16*2 LCD. All
the connections of the LCD other than power connections will be displayed in
the wizard. Make other settings and then select generate save, save and exit
from file menu. To save the file, give the file name.
Once this is done, you are ready to use LCD display form your program.
You can now use inbuilt functions to write to the LCD screen.
•Near the center of the area where your computers and other devices
operate, and preferably within line of sight to your wireless devices.
•In an elevated location such as a high shelf, keeping the number of walls
and ceilings between the Wi-Fi modem router and your other devices to a
minimum.
ESP-01 is the one of the most popular ESP8266 module available in the
market. ESP8266 is a self-contained SoC with integrated TCP/IP stack which
helps any microcontroller having UART to access a wifi network. It can act as
both WiFi access point as well as a WiFi client. It is pre-programmed with AT
commands, so we can easily access and configure it using a microcontroller.
ESP8266 runs on 3.3V and its input pins are not 5V tolerant. So we need to
reduce the 5V output of the Arduino Tx pin to 3.3V by using voltage dividing
resistors to connect to Rx pin of ESP8266 module. Arduino TTL input pins will
detect 3.3V as logic high, so we can directly connect 3.3V output of ESP8266
Tx to Arduino Rx pin.
An ultrasonic sensor transmits ultrasonic waves into the air and detects
reflected waves from an object. There are many applications for ultrasonic
sensors, such as in intrusion alarm systems, automatic door openers and backup
sensors for automobiles. Accompanied by the rapid development of information
processing technology, new fields of application, such as factory automation
equipment and car electronics, are increasing and should continue to do so.
Using its unique piezoelectric ceramics manufacturing technology developed
over many years, Murata has developed various types of ultrasonic sensors
which are compact and yet have very high performance. The information
contained in this catalogue will help you to make effective use of our ultrasonic
sensors. Ultrasonic waves are sounds which cannot be heard by humans and are
normally, frequencies of above 20kHz.
CHAPTER 6
OVERVIEW OF SOFTWARE
1.ARDUINO IDE
2.LIBRARIES
3.EMBEDDED C
Arduino boards are able to read analog or digital input signals from
different sensors and turn it into an output such as activating a motor, turning
LED on/off, connect to the cloud and many other actions.
6.2 LIBRARIES
6.3 EMBEDDED C
Embedded Programming
CONCLUSION
REFERENCES
[1] Rico, J., Sancho, J., Cendon, B., & Camus, M. (2013, March). Parking easier
by using context information of a smart city: Enabling fast search and
management of parking resources. In Advanced Information Networking and
Applications Workshops (WAINA), 2013 27th International Conference on (pp.
1380-1385). IEEE.
[2] Zheng, Y., Rajasegarar, S., & Leckie, C. (2015, April). Parking availability
prediction for sensor-enabled car parks in smart cities. In Intelligent Sensors,
Sensor Networks and Information Processing (ISSNIP), 2015 IEEE Tenth
International Conference on (pp. 1-6). IEEE.
[3] Zhou, F., & Li, Q. (2014, November). Parking Guidance System Based on
ZigBee and Geomagnetic Sensor Technology. In Distributed Computing and
Applications to Business, Engineering and Science (DCABES), 2014 13th
International Symposium on (pp. 268-271). IEEE.
[4] Botta, A., de Donato, W., Persico, V., & Pescapé, A. (2014, August). On the
Integration of Cloud Computing and Internet of Things. In Future Internet of
Things and Cloud (FiCloud), 2014 International Conference on (pp. 23-30).
IEEE.
[5] Ji, Z., Ganchev, I., O'droma, M., & Zhang, X. (2014, August). A cloudbased
intelligent car parking services for smart cities. In General Assembly and
Scientific Symposium (URSI GASS), 2014 XXXIth URSI (pp. 1-4). IEEE.
[7] Ballon, P., Glidden, J., Kranas, P., Menychtas, A., Ruston, S., & Van Der
Graaf, S. (2011, October). Is there a Need for a Cloud Platform for European
Smart Cities?. In eChallenges e-2011 Conference Proceedings, IIMC
International Information Management Corporation.
[8] Suciu, G., Vulpe, A., Halunga, S., Fratu, O., Todoran, G., & Suciu, V.
(2013, May). Smart cities built on resilient cloud computing and secure internet
of things. In Control Systems and Computer Science (CSCS), 2013 19th
International Conference on (pp. 513-518). IEEE.
[9] Chen, S. Y., Lai, C. F., Huang, Y. M., & Jeng, Y. L. (2013, July). Intelligent
home-appliance recognition over IoT cloud network. In Wireless
Communications and Mobile Computing Conference (IWCMC), 2013 9th
International (pp. 639-643). IEEE.