Skip to content
IoT Smart Parking Metering system with IBM Bluemix & PubNub
Java JavaScript Python Batchfile Other C Other
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
MobileApp
device/hcsr04
parking-meter
testApp
yun_pubnub
.gitignore
BUILD.md
LICENSE
Makefile
README.md
schematic.png

README.md

IoT enabled Smart Parking Meter with IBM Bluemix & PubNub

Smart Parking System based on IBM Buemix hosted Parking Meter & hardware controlled by an Arduino YUN along with PubNub as the communication middleware.

OVERVIEW

This project demonstrates how we can build an application server on IBM Bluemix that allows users to reserve parking spaces and automatically handles their parking bills as well. The Hardware for this is based on Arduino YUN which can control a set of HC-SR04 ultrasonic sensors, to detect the availability of a parking slot and update this information on a mobile app using the PubNub's realtime data stream network.

INTRODUCTION

This application is assumed to be installed in a public parking space where each parking space is monitored using a HC-SR04 ultrsonic sensor connected to Arduino YUN board.

Refer Circuit Diagram

The application has three parts

  1. Parking Management Server - This is the application server written in Python which manages the parking reservations, billing and broadcasts parking status updates to all Apps. For hosting this on IBM Bluemix, refer the "APPLICATION SERVER HOSTING" section below.

  2. Hardware - This is the master controller module which runs on Arduino YUN. It periodically gets the status of parking slots within its jurisdiction, from the ultrasonic sensors.

  3. Mobile App - This is a cordova based simple mobile app which displays a map of the entire parking lot with color coded status indicators. It provides an instant update to the driver about the current availablity of free parking slots. It also allows the user to reserve a vacant parking space and additionally handles the parking billing.

BUILD AND INSTALL

Refer Build & Install Steps

APPLICATION SERVER HOSTING

For hosting the Parking Management Server on IBM Bluemix, follow the steps as given below

  1. Signup to create your trial IBM Bluemix account.

  2. Follow the Bluemix Documentation to create your bluemix container

  3. Install the PubNub service and attach it to your container.

  4. Install and initialize the buildpacks for python application runtime

  5. Deploy the application server package under ""parking-meter" folder, on your Bluemix container and start the application from Bluemix console.

WORKING

  1. Deploy the Parking management Server application on IBM Bluemix

  2. Install the Mobile app in an android phone and ensure that the phone has access to internet.

  3. Power up the hardware setup and make sure that Arduino YUN has access to internet. And then run the Master controller program.

  4. Make sure that the ultrasonic sensors are not obstructed

  5. Launch the mobile app. Upon launching, it will ask the user for entering his vehicle registration ( license plate ) number. Feed in the number and proceed.

  6. The app will now display the parking map with color coded status indicators for all parking spaces. Check that the initial status of all the parking spaces is green, which indicates that all parking spaces are free.

  7. Obstruct one or more ultrasonic sensors with an object to simulate the presence of a vehicle.

  8. Observe the display of mobile app. After a few seconds the color for the corrosponding slot numbers should turn red to indicate that the space have been occupied. If the mobile app indicates grey status for any of the parking slot then this means that the sensor has a fault or is malfunctioning and the space is currently unavailable for parking.

  9. For reserving a parking space, tap on a vacant (green) parking slot on the mobile app. The app will display a message indicating that the parking space has been reserved for the user. Also the color of the slot, on the map, will change to red.

  10. Subsequently, obstruct the corrosponding sensor to simulate the parking of car. If this is not done within one minute then the app will assume that user reserved the parking space but never parked and hence it will cancel the reservation and charge a minimum bill.

  11. After sometime , remove the obstruction from the ultrasonic sensor to simulate pulling out of the car from the parking space. This indicates end of praking time.

  12. The mobile app will automatically detect end of parking and display a message to user providing the details of his parking session along with the outstanding bill amount.

You can’t perform that action at this time.