SlideShare a Scribd company logo
1 of 55
BUILDING A SMART
SECURITY CAMERA WITH
A PI ZERO, NODE.JS &
THE CLOUD
MARK WEST
@markawest
Kraków, 17-19 May 2017
Who Am I?
• IT Consultant at Bouvet Oslo.
• Hacker and Maker.
• Java, JavaScript, AI, Cloud & IoT.
• Active member of javaBin - the
Norwegian JUG.
@markawest
Talk Outline
Motivation and
Requirements
Building a
Motion
Activated
Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Lessons Learned
@markawest
Motivation and Requirements
Input from Stakeholder
Motivation and
Requirements
Building a Motion
Activated Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Lessons Learned
@markawest
Initial Motivation
@markawest
Project Requirements
Functional
• Monitor activity in the
garden.
• Send warning when activity
detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
Functional Design
1. Activity
in garden
2. Camera
detects
movement
3. Camera sends
alert email with
snapshot
@markawest
Building a Motion Activated
Camera
Motivation and
Requirements
Building a Motion
Activated Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Lessons Learned
@markawest
Pi Zero W Essentials Kit: 127 zł
Camera Module: 118 zł
Camera Adapter: 27 zł
ZeroView: 36 zł
Total Cost: 308 zł
Hardware Shopping List
@markawest
Assembled Camera
Rear View Front View
@markawest
Implementing the Functional Design
1. Activity
in garden
2. Camera
detects
movement
3. Camera sends
alert email with
snapshot
@markawest
Motion
(https://motion-project.github.io)
• Open source motion detection software.
• Excellent performance on the Raspberry Pi Zero.
• Built-in Web Server for streaming video.
• Detected activity or ‘motion’ triggers events.
• Works out of the box. No need for additional programming.
@markawest
Motion
Streaming
Demo
@markawest
Example
Alert Email
1 2
1
@markawest
How the Motion Software works
1 2 3 4
@markawest
1 2 3
How the Motion Software works
1 2 3 4
1 2 3
@markawest
1 2 3
How the Motion Software works
1 2 3 4
1 2 3
@markawest
1 2 3
Alarm Snapshots from Web Camera
@markawest
Project Requirements : Evaluation
Functional
• Monitor activity in the
garden.
• Send warning when activity
detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
False Alarms from Web Camera
cat
cloud
@markawest
The Motion Software
focuses on the amount of
changed pixels, and not the
cause of the changed
pixels!
@markawest
Adding Smart Image Analysis
with AWS
Motivation and
Requirements
Building a Motion
Activated Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Lessons Learned
@markawest
Improving Alarm Accuracy with
Smart Image Analysis
person
@markawest
cat
Project Requirements Reloaded
Functional
• Monitor activity in our
garden.
• Send warning when activity
detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
Project Requirements Reloaded
Functional
• Monitor activity in our
garden.
• Send warning when human
activity detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
Finding an Image Analysis Solution
OpenCV
• Use Face Detection to find out if
a human was in the snapshot.
• Problem: What if the subject
was facing away from the
camera, or wearing a mask?
TensorFlow
• Train and use a Neural Network
to find humans in the snapshot.
• Problem: Potentially a fun
project, but would take more
time than I had available.
@markawest
@markawest
AWS Rekognition
• Part of Amazon Web Services suite of Cloud based services.
• Image Analysis as a Service, offering a range of API’s.
• Built upon Deep Neural Networks.
• Officially launched in November 2016.
• Alternatives: Google Vision, MicroSoft Computer Vision, Clarafai.
@markawest
AWS Rekognition Demo
@markawest
Adding AWS to the Web Camera
Amazon Web Services (AWS)
Send warning
email (if snapshot
contains a person)
Snapshot analysed
via AWS
Rekognition
@markawest
Camera pushes
snapshot to AWS
Email alert sent
(with snapshot)
AWS IAM
AWS
Rekognition
AWS Simple
Email Service
AWS S3
(storage)
Amazon Web Service Flow
Overview
AWS Step Function
(workflow)
Upload
Trigger
1
2
4
5
6
calls
3
uses
uses
@markawest
AWS IAM
AWS
Rekognition
AWS Simple
Email Service
AWS S3
(storage)
AWS Lambda Functions
Code Building Blocks (aka Microservices)
AWS Step Function
(workflow)
Upload
Trigger calls
uses
uses
@markawest
AWS Lambda Functions
• Code units, based on Java, C#, Python or Node.js
• Serverless.
• High availability out of the box.
• Pay as you go model, with a generous free tier.
• Native AWS SDK gives easy access to other AWS services.
@markawest
AWS Lambda Demo
@markawest
AWS IAM
AWS S3
(storage)
AWS Step Functions
Orchestration of Lambda Functions
AWS Step Function
(workflow)
Upload
Trigger calls
AWS
Rekognition
AWS Simple
Email Service
uses
uses
@markawest
AWS Step Functions
• Coordinate and orchestrate Lambda Functions into Workflows or
State Machines.
• Launched in December 2016.
• Defined via JSON files, displayed as visual workflows.
• Provide the same benefits as AWS Lambda (High Availability,
Serverless, Scalable, “Pay as you go” pricing model).
@markawest
Step Function for Image Processing
Error
Handler
(sends
Error
Email via
AWS
SES)
Sends snapshot to AWS Rekognition
Evaluate AWS Rekognition response
Send Alert Email?
Send Alert Email
via AWS SES
Archive image in AWS S3
1
2
3
4
5
6 1
2
3
4
5
6
@markawest
Smart Camera
(plus AWS Step Function)
Demo
@markawest
Evaluation and Lessons
Learned
Motivation and
Requirements
Building a Motion
Activated Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Lessons Learned
@markawest
Project Requirements : Evaluation
Functional
• Monitor activity in the
garden.
• Send warning when human
activity detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
AWS Rekognition : Positives
• Consistent results.
• Good results from 'partial’ images.
• Handles poor quality images (motion
blur, poor lighting).
• No more false alarms from the camera!
@markawest
AWS Rekognition : Negatives
• Black box.
• Unable to provide feedback.
• Struggles with ‘noisy’ pictures.
• Results are only as good as the pictures
you upload.
@markawest
Activity Timeline
Improving AWS Rekognition Results
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Activity Timeline
Improving AWS Rekognition Results
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Most
Pixels
Changed
Activity Timeline
Improving AWS Rekognition Results
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Most
Central
Activity
Activity Timeline
Improving AWS Rekognition Results
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Upload all snapshots
Improving AWS Rekognition Hit Rate
Upload One Snapshot
when activity detected
• Lower cost, due to less calls
to the AWS stack.
• Potentially lower hit rate.
Upload Many Snapshots
when activity detected
• Higher cost due to
increased calls to the AWS
stack.
• Potentially higher hit rate.
@markawest
Benefits of Using AWS
• Very easy to get started with, due to Free Tier, automated
infrastructure and good documentation.
• Large ecosystem with a broad range of services.
• Serverless - so hot right now!
@markawest
Drawbacks of Using AWS
• It’s not free.
• So many services!
• Step Functions need a graphical editor.
• Potential for vendor lock-in.
@markawest
AWS Monthly Cost
Actual AWS Cost March
2017
$1.07
(under free tier)
Estimated AWS Cost After
Free Tier Expiration
$8.00
(same usage as March 2017)
@markawest
“Fun project, but has it
caught any real criminals?”
@markawest
@markawest
S3 for Web Hosting
• Created a HTML Report listing all
False Alarm snapshots.
• Report updated by a Lambda
Function triggered by a timer.
• Hosted on S3 as a static website.
@markawest
Would you like to know more?
markwest1972/
smart-security-
camera
utbrudd.bouvet.no
@markawest
slideshare.net/
markawest
Slides Blog Code
Thanks for
listening!
@markawest

More Related Content

What's hot

What's hot (20)

To Serverless And Beyond!
To Serverless And Beyond!To Serverless And Beyond!
To Serverless And Beyond!
 
AWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the CloudAWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the Cloud
 
AWS re:Invent 2016: Building Complex Serverless Applications (GPST404)
AWS re:Invent 2016: Building Complex Serverless Applications (GPST404)AWS re:Invent 2016: Building Complex Serverless Applications (GPST404)
AWS re:Invent 2016: Building Complex Serverless Applications (GPST404)
 
Serverless Workflows on AWS - A Journey from SWF to Step Functions
Serverless Workflows on AWS - A Journey from SWF to Step FunctionsServerless Workflows on AWS - A Journey from SWF to Step Functions
Serverless Workflows on AWS - A Journey from SWF to Step Functions
 
AWS re:Invent 2016: Open-Source Resources (DCS201)
AWS re:Invent 2016: Open-Source Resources (DCS201)AWS re:Invent 2016: Open-Source Resources (DCS201)
AWS re:Invent 2016: Open-Source Resources (DCS201)
 
Serverless
ServerlessServerless
Serverless
 
Serverless Culture
Serverless CultureServerless Culture
Serverless Culture
 
AWS Lambda Presentation (Tech Talk DC)
AWS Lambda Presentation (Tech Talk DC)AWS Lambda Presentation (Tech Talk DC)
AWS Lambda Presentation (Tech Talk DC)
 
(SPOT302) Availability: The New Kind of Innovator’s Dilemma
(SPOT302) Availability: The New Kind of Innovator’s Dilemma(SPOT302) Availability: The New Kind of Innovator’s Dilemma
(SPOT302) Availability: The New Kind of Innovator’s Dilemma
 
Sloppy Little Serverless Stories
Sloppy Little Serverless StoriesSloppy Little Serverless Stories
Sloppy Little Serverless Stories
 
Serverless Computing: build and run applications without thinking about servers
Serverless Computing: build and run applications without thinking about serversServerless Computing: build and run applications without thinking about servers
Serverless Computing: build and run applications without thinking about servers
 
Design Patterns for Developers - Technical 201
Design Patterns for Developers - Technical 201Design Patterns for Developers - Technical 201
Design Patterns for Developers - Technical 201
 
Distributed Serverless Stack Tracing and Monitoring
Distributed Serverless Stack Tracing and MonitoringDistributed Serverless Stack Tracing and Monitoring
Distributed Serverless Stack Tracing and Monitoring
 
Using AWS Lambda for Infrastructure Automation and Beyond
Using AWS Lambda for Infrastructure Automation and BeyondUsing AWS Lambda for Infrastructure Automation and Beyond
Using AWS Lambda for Infrastructure Automation and Beyond
 
Enterprise Serverless Adoption. An Experience Report
Enterprise Serverless Adoption. An Experience ReportEnterprise Serverless Adoption. An Experience Report
Enterprise Serverless Adoption. An Experience Report
 
Building serverless app_using_aws_lambda_b4usolution
Building serverless app_using_aws_lambda_b4usolutionBuilding serverless app_using_aws_lambda_b4usolution
Building serverless app_using_aws_lambda_b4usolution
 
Workshop : Wild Rydes Takes Off - The Dawn of a New Unicorn
Workshop : Wild Rydes Takes Off - The Dawn of a New UnicornWorkshop : Wild Rydes Takes Off - The Dawn of a New Unicorn
Workshop : Wild Rydes Takes Off - The Dawn of a New Unicorn
 
Thinking Asynchronously Full Vesion - Utah UG
Thinking Asynchronously Full Vesion - Utah UGThinking Asynchronously Full Vesion - Utah UG
Thinking Asynchronously Full Vesion - Utah UG
 
(ISM309) Efficient Innovation:High-Velocity Cost Management at Netflix
(ISM309) Efficient Innovation:High-Velocity Cost Management at Netflix(ISM309) Efficient Innovation:High-Velocity Cost Management at Netflix
(ISM309) Efficient Innovation:High-Velocity Cost Management at Netflix
 
How LEGO.com Accelerates With Serverless
How LEGO.com Accelerates With ServerlessHow LEGO.com Accelerates With Serverless
How LEGO.com Accelerates With Serverless
 

Similar to GeeCon 2017 : Building a Smart Security Camera with Raspberry Pi Zero, Node.js and The Cloud

Similar to GeeCon 2017 : Building a Smart Security Camera with Raspberry Pi Zero, Node.js and The Cloud (20)

IoT Meetup Oslo - AI on Edge Devices
IoT Meetup Oslo - AI on Edge DevicesIoT Meetup Oslo - AI on Edge Devices
IoT Meetup Oslo - AI on Edge Devices
 
IoT Tech Day Smart Camera slides. Utrecht, April 2017.
IoT Tech Day Smart Camera slides.  Utrecht, April 2017.IoT Tech Day Smart Camera slides.  Utrecht, April 2017.
IoT Tech Day Smart Camera slides. Utrecht, April 2017.
 
AWS Summit Auckland - Getting Started with AWS Lambda and the Serverless Cloud
AWS Summit Auckland - Getting Started with AWS Lambda and the Serverless CloudAWS Summit Auckland - Getting Started with AWS Lambda and the Serverless Cloud
AWS Summit Auckland - Getting Started with AWS Lambda and the Serverless Cloud
 
AWS Lambda: Event-Driven Code in the Cloud
AWS Lambda: Event-Driven Code in the CloudAWS Lambda: Event-Driven Code in the Cloud
AWS Lambda: Event-Driven Code in the Cloud
 
Getting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudGetting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless Cloud
 
Build an App on AWS for Your First 10 Million Users
Build an App on AWS for Your First 10 Million UsersBuild an App on AWS for Your First 10 Million Users
Build an App on AWS for Your First 10 Million Users
 
Surviving Serverless Testing: The ultimate Guide
Surviving Serverless Testing: The ultimate GuideSurviving Serverless Testing: The ultimate Guide
Surviving Serverless Testing: The ultimate Guide
 
Ohio Devfest - Visual Analysis with GCP
Ohio Devfest - Visual Analysis with GCPOhio Devfest - Visual Analysis with GCP
Ohio Devfest - Visual Analysis with GCP
 
Accelerate your Cloud Success with Platform Services
Accelerate your Cloud Success with Platform ServicesAccelerate your Cloud Success with Platform Services
Accelerate your Cloud Success with Platform Services
 
Iot meets Serverless
Iot meets ServerlessIot meets Serverless
Iot meets Serverless
 
AWS Lambda and Serverless Cloud
AWS Lambda and Serverless CloudAWS Lambda and Serverless Cloud
AWS Lambda and Serverless Cloud
 
AWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the CloudAWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the Cloud
 
AWS Lambda - Event Driven Event-driven Code in the Cloud
AWS Lambda - Event Driven Event-driven Code in the CloudAWS Lambda - Event Driven Event-driven Code in the Cloud
AWS Lambda - Event Driven Event-driven Code in the Cloud
 
Building a Real Time Dashboard with Amazon Kinesis, Amazon Lambda and Amazon ...
Building a Real Time Dashboard with Amazon Kinesis, Amazon Lambda and Amazon ...Building a Real Time Dashboard with Amazon Kinesis, Amazon Lambda and Amazon ...
Building a Real Time Dashboard with Amazon Kinesis, Amazon Lambda and Amazon ...
 
AWS Lambda support for AWS X-Ray
AWS Lambda support for AWS X-RayAWS Lambda support for AWS X-Ray
AWS Lambda support for AWS X-Ray
 
Getting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudGetting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless Cloud
 
AWS Startup Insights Singapore
AWS Startup Insights SingaporeAWS Startup Insights Singapore
AWS Startup Insights Singapore
 
Build an app on aws for your first 10 million users (2)
Build an app on aws for your first 10 million users (2)Build an app on aws for your first 10 million users (2)
Build an app on aws for your first 10 million users (2)
 
AWS re:Invent 2016: Content and Data Platforms at Vevo: Rebuilding and Scalin...
AWS re:Invent 2016: Content and Data Platforms at Vevo: Rebuilding and Scalin...AWS re:Invent 2016: Content and Data Platforms at Vevo: Rebuilding and Scalin...
AWS re:Invent 2016: Content and Data Platforms at Vevo: Rebuilding and Scalin...
 
Build an App on AWS for Your First 10 Million Users
Build an App on AWS for Your First 10 Million UsersBuild an App on AWS for Your First 10 Million Users
Build an App on AWS for Your First 10 Million Users
 

More from Mark West

More from Mark West (10)

A Practical-ish Introduction to Data Science
A Practical-ish Introduction to Data ScienceA Practical-ish Introduction to Data Science
A Practical-ish Introduction to Data Science
 
Explaining the new Java release and licensing models
Explaining the new Java release and licensing modelsExplaining the new Java release and licensing models
Explaining the new Java release and licensing models
 
GeeCon Prague 2018 - A Practical-ish Introduction to Data Science
GeeCon Prague 2018 - A Practical-ish Introduction to Data ScienceGeeCon Prague 2018 - A Practical-ish Introduction to Data Science
GeeCon Prague 2018 - A Practical-ish Introduction to Data Science
 
JavaZone 2018 - A Practical(ish) Introduction to Data Science
JavaZone 2018 - A Practical(ish) Introduction to Data ScienceJavaZone 2018 - A Practical(ish) Introduction to Data Science
JavaZone 2018 - A Practical(ish) Introduction to Data Science
 
NDC Oslo : A Practical Introduction to Data Science
NDC Oslo : A Practical Introduction to Data ScienceNDC Oslo : A Practical Introduction to Data Science
NDC Oslo : A Practical Introduction to Data Science
 
JavaZone 2016 : MQTT and CoAP for the Java Developer
JavaZone 2016 : MQTT and CoAP for the Java DeveloperJavaZone 2016 : MQTT and CoAP for the Java Developer
JavaZone 2016 : MQTT and CoAP for the Java Developer
 
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-FiveJavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
 
Coding Mojo : Node.js Meetup
Coding Mojo : Node.js MeetupCoding Mojo : Node.js Meetup
Coding Mojo : Node.js Meetup
 
IoT Tech Day Coding Mojo slides. Utrecht, April 2016
IoT Tech Day Coding Mojo slides.  Utrecht, April 2016IoT Tech Day Coding Mojo slides.  Utrecht, April 2016
IoT Tech Day Coding Mojo slides. Utrecht, April 2016
 
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
 

Recently uploaded

Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
?#DUbAI#??##{{(☎️+971_581248768%)**%*]'#abortion pills for sale in dubai@
 

Recently uploaded (20)

[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectors
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : Uncertainty
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
Exploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with MilvusExploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with Milvus
 
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdfRising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
 
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 

GeeCon 2017 : Building a Smart Security Camera with Raspberry Pi Zero, Node.js and The Cloud

  • 1. BUILDING A SMART SECURITY CAMERA WITH A PI ZERO, NODE.JS & THE CLOUD MARK WEST @markawest Kraków, 17-19 May 2017
  • 2. Who Am I? • IT Consultant at Bouvet Oslo. • Hacker and Maker. • Java, JavaScript, AI, Cloud & IoT. • Active member of javaBin - the Norwegian JUG. @markawest
  • 3. Talk Outline Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Lessons Learned @markawest
  • 4. Motivation and Requirements Input from Stakeholder Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Lessons Learned @markawest
  • 6. Project Requirements Functional • Monitor activity in the garden. • Send warning when activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 7. Functional Design 1. Activity in garden 2. Camera detects movement 3. Camera sends alert email with snapshot @markawest
  • 8. Building a Motion Activated Camera Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Lessons Learned @markawest
  • 9. Pi Zero W Essentials Kit: 127 zł Camera Module: 118 zł Camera Adapter: 27 zł ZeroView: 36 zł Total Cost: 308 zł Hardware Shopping List @markawest
  • 10. Assembled Camera Rear View Front View @markawest
  • 11. Implementing the Functional Design 1. Activity in garden 2. Camera detects movement 3. Camera sends alert email with snapshot @markawest
  • 12. Motion (https://motion-project.github.io) • Open source motion detection software. • Excellent performance on the Raspberry Pi Zero. • Built-in Web Server for streaming video. • Detected activity or ‘motion’ triggers events. • Works out of the box. No need for additional programming. @markawest
  • 15. How the Motion Software works 1 2 3 4 @markawest 1 2 3
  • 16. How the Motion Software works 1 2 3 4 1 2 3 @markawest 1 2 3
  • 17. How the Motion Software works 1 2 3 4 1 2 3 @markawest 1 2 3
  • 18. Alarm Snapshots from Web Camera @markawest
  • 19. Project Requirements : Evaluation Functional • Monitor activity in the garden. • Send warning when activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 20. False Alarms from Web Camera cat cloud @markawest
  • 21. The Motion Software focuses on the amount of changed pixels, and not the cause of the changed pixels! @markawest
  • 22. Adding Smart Image Analysis with AWS Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Lessons Learned @markawest
  • 23. Improving Alarm Accuracy with Smart Image Analysis person @markawest cat
  • 24. Project Requirements Reloaded Functional • Monitor activity in our garden. • Send warning when activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 25. Project Requirements Reloaded Functional • Monitor activity in our garden. • Send warning when human activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 26. Finding an Image Analysis Solution OpenCV • Use Face Detection to find out if a human was in the snapshot. • Problem: What if the subject was facing away from the camera, or wearing a mask? TensorFlow • Train and use a Neural Network to find humans in the snapshot. • Problem: Potentially a fun project, but would take more time than I had available. @markawest
  • 28. AWS Rekognition • Part of Amazon Web Services suite of Cloud based services. • Image Analysis as a Service, offering a range of API’s. • Built upon Deep Neural Networks. • Officially launched in November 2016. • Alternatives: Google Vision, MicroSoft Computer Vision, Clarafai. @markawest
  • 30. Adding AWS to the Web Camera Amazon Web Services (AWS) Send warning email (if snapshot contains a person) Snapshot analysed via AWS Rekognition @markawest Camera pushes snapshot to AWS Email alert sent (with snapshot)
  • 31. AWS IAM AWS Rekognition AWS Simple Email Service AWS S3 (storage) Amazon Web Service Flow Overview AWS Step Function (workflow) Upload Trigger 1 2 4 5 6 calls 3 uses uses @markawest
  • 32. AWS IAM AWS Rekognition AWS Simple Email Service AWS S3 (storage) AWS Lambda Functions Code Building Blocks (aka Microservices) AWS Step Function (workflow) Upload Trigger calls uses uses @markawest
  • 33. AWS Lambda Functions • Code units, based on Java, C#, Python or Node.js • Serverless. • High availability out of the box. • Pay as you go model, with a generous free tier. • Native AWS SDK gives easy access to other AWS services. @markawest
  • 35. AWS IAM AWS S3 (storage) AWS Step Functions Orchestration of Lambda Functions AWS Step Function (workflow) Upload Trigger calls AWS Rekognition AWS Simple Email Service uses uses @markawest
  • 36. AWS Step Functions • Coordinate and orchestrate Lambda Functions into Workflows or State Machines. • Launched in December 2016. • Defined via JSON files, displayed as visual workflows. • Provide the same benefits as AWS Lambda (High Availability, Serverless, Scalable, “Pay as you go” pricing model). @markawest
  • 37. Step Function for Image Processing Error Handler (sends Error Email via AWS SES) Sends snapshot to AWS Rekognition Evaluate AWS Rekognition response Send Alert Email? Send Alert Email via AWS SES Archive image in AWS S3 1 2 3 4 5 6 1 2 3 4 5 6 @markawest
  • 38. Smart Camera (plus AWS Step Function) Demo @markawest
  • 39. Evaluation and Lessons Learned Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Lessons Learned @markawest
  • 40. Project Requirements : Evaluation Functional • Monitor activity in the garden. • Send warning when human activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 41. AWS Rekognition : Positives • Consistent results. • Good results from 'partial’ images. • Handles poor quality images (motion blur, poor lighting). • No more false alarms from the camera! @markawest
  • 42. AWS Rekognition : Negatives • Black box. • Unable to provide feedback. • Struggles with ‘noisy’ pictures. • Results are only as good as the pictures you upload. @markawest
  • 43. Activity Timeline Improving AWS Rekognition Results @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5
  • 44. Activity Timeline Improving AWS Rekognition Results @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5 Most Pixels Changed
  • 45. Activity Timeline Improving AWS Rekognition Results @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5 Most Central Activity
  • 46. Activity Timeline Improving AWS Rekognition Results @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5 Upload all snapshots
  • 47. Improving AWS Rekognition Hit Rate Upload One Snapshot when activity detected • Lower cost, due to less calls to the AWS stack. • Potentially lower hit rate. Upload Many Snapshots when activity detected • Higher cost due to increased calls to the AWS stack. • Potentially higher hit rate. @markawest
  • 48. Benefits of Using AWS • Very easy to get started with, due to Free Tier, automated infrastructure and good documentation. • Large ecosystem with a broad range of services. • Serverless - so hot right now! @markawest
  • 49. Drawbacks of Using AWS • It’s not free. • So many services! • Step Functions need a graphical editor. • Potential for vendor lock-in. @markawest
  • 50. AWS Monthly Cost Actual AWS Cost March 2017 $1.07 (under free tier) Estimated AWS Cost After Free Tier Expiration $8.00 (same usage as March 2017) @markawest
  • 51. “Fun project, but has it caught any real criminals?” @markawest
  • 53. S3 for Web Hosting • Created a HTML Report listing all False Alarm snapshots. • Report updated by a Lambda Function triggered by a timer. • Hosted on S3 as a static website. @markawest
  • 54. Would you like to know more? markwest1972/ smart-security- camera utbrudd.bouvet.no @markawest slideshare.net/ markawest Slides Blog Code

Editor's Notes

  1. But before I go any further I’d like to tell you a couple of things about me. In my day job I am a manager in Bouvet’s Oslo offices, where I work with a range of technologies based upon Java and JavaScript. My current focus is upon AI, Cloud and the Internet of Things. When I’m not at work I can often be found working on a range of hobby projects – often using the Raspberry Pi and Arduino platforms. In addition I am also involved in the organisation of the JavaZone conference, where I primarily work with the program committee. I’m on twitter under the handle @markawest, so feel free to contact me if there is anything you’d like to talk about!
  2. Ok, so lets look at the outline of todays talk. We’ll start in a second with a run through of the motivation for building this camera, along with the requirements. These should always be clear and defined for any project, whether it is a multi million kroner project for NAV, or a hobby project undertaken by an englishman living in Oslo. Then we’ll look at the first version of the camera, evaluate how it worked and discuss it’s weaknesses. The second version of the camera is where we introduce Amazon Web Services to the mix and will take up the majority of the presentation time. Finally I’ll evaluate the project and talk about what I learned.
  3. Ok, so lets get started by looking at why I did this project!
  4. The motivation for creating my camera was simple enough. A large amount of break-ins had recently taken plan in the area where I live. The thieves targeted houses with secluded gardens, as the chance of being spotted by passers by was lower. My garden is not visible from the road, making it a prime target for the thieves.
  5. When undertaking any project you need to identify the stakeholders, or those who will be affected by the project outcome. These stakeholders will have their expectations of the project, and your requirements should always take the stakeholders expectations into account. For this project my wife was my primary stakeholder, so the requirements reflected her wishes. (Go through requirements)
  6. Once I’d gathered the requirements I realized that I needed to implement the above, in a cost effective and speedy manner.
  7. Ok, so lets get started by looking at why I did this project!
  8. We’ll begin by looking at the hardware I used for creating the Camera and how much this costs. The Pi Zero is a cut down version of the Raspberry Pi. They cost about 50kr, but you’ll also need to buy an SD card, power supply and HDMI and USB adapters. Therefore I recommend a starter kit such as the one sold by the Pi Hut. This costs 300 kr, and gives you all you need to get started with the Pi Zero. In addition to the Pi Zero board I needed a camera. I choose the Raspberry Pi Camera module, at around 250 kr. To fit this to the Pi Zero I also had to buy a Pi Zero Camera adapter, which cost an additional 50 kr. The camera I chose was the Pi NoIR, which work better in low conditions. To truly provide night vision it requires an IR light source, which I didn’t buy for this project. Finally I needed a mount for the Camera. I choose the ZeroView at 80 kr. The total cost for all equipment (if bought new) would be therefore approximately 680kr. If this seems a lot of money, remember that you can easily reuse the components for other projects at a later point!
  9. Here you can see the fully assembled camera, from the front and the back. The white cable is a USB Wi Fi adapter and the black cable is for power.
  10. Once I’d gathered the requirements I realized that I needed to implement the above, in a cost effective and speedy manner.
  11. After some consideration, I decided to use the Linux Motion software. Motion is open source, and is purpose built for motion detection. It has excellent performance on the Raspberry Pi Zero, plus a built in web server for streaming video. Detected activity triggers an “event” in Motion, which can be used to send email alerts. Motion works out of the box and is highly configurable. With no need for additional programming it would take no time at all to get up and running.
  12. So how does Motion work? Well it basically monitors the video stream from the camera. Each frame is compared to the previous, in order to find out how many pixels (if any) differ. If the total number of changed pixels is greater than a given threshold, a motion alarm is then triggered.
  13. So how does Motion work? Well it basically monitors the video stream from the camera. Each frame is compared to the previous, in order to find out how many pixels (if any) differ. If the total number of changed pixels is greater than a given threshold, a motion alarm is then triggered.
  14. So how does Motion work? Well it basically monitors the video stream from the camera. Each frame is compared to the previous, in order to find out how many pixels (if any) differ. If the total number of changed pixels is greater than a given threshold, a motion alarm is then triggered.
  15. So how does Motion work? Well it basically monitors the video stream from the camera. Each frame is compared to the previous, in order to find out how many pixels (if any) differ. If the total number of changed pixels is greater than a given threshold, a motion alarm is then triggered.
  16. I was initially very happy with the first version of the Pi Zero Camera. The camera monitored my garden for the whole of July, whilst I was in England with my family. The results from the camera were quite boring, and mostly showed the neighbor's watering our flowers, plus me testing out the camera before we left.
  17. Ok, lets revisit my project requirements. My camera: Would monitor activity in the garden. It would be able to send an email when acitivity was detected. It included a live video stream. It was quick to build and program. It had a one of cost of 680kr. And it was portable. All this led to a happy stakeholder! But was the project completely successful?
  18. False alerts : why problematic? Loads of emails, that’s why!
  19. Ok, let us try a quick demo of the Pi Camera Version 1.
  20. Ok, so lets get started by looking at why I did this project!
  21. You’ll remember these project requirements from earlier on in this presentation. Lets just revisit them all! They are all still just as relevant. But by adding one word to one of the functional requirements we can address the issue of false positives. Any guesses?
  22. Yep. The missing word is “Human”! We only want to send warnings when human activity is detected.
  23. At this point I realised that I had to find an Image Analysis solution. My first idea was to use OpenCV to perform Face Detection on the snapshot images. <click> This type of use of OpenCV is well proven and well documented, and wouldn’t take long to implement. <click> However, it would only work if the subject was facing the camera, and wasn’t wearing a mask! <click> My next idea was to use Googles TensorFlow. This would allow me to create and train a neural network to analyse my images. <click> The downside here is that it would take a considerable investment of time for me to get up and running. This idea was therefore vetoed by my primary stakeholder, who wanted a solution as quick as possible.
  24. Luckily the solution presented itself to me through a random tweet in my twitter feed. <click> It turned out that Arun was talking about Amazon Rekognition, a new Image Analysis solution.
  25. Why cloud based?
  26. Perhaps the best way of understanding what Amazon Rekognition is, is to run a quick demo. DetectLabels use Burglar picture from NTNU folder on my Desktop.
  27. My next challenge was to find out how I would trigger the image processing from my Pi Zero Camera. After some thought I decided to move the whole image processing and email handling to The Cloud, and specifically Amazon Web Services. My planned solution basically looked as follows: The PiZero Camera monitors the garden. On detecting movement, a snapshot is taken and pushed to Amazon Web Services. Amazon web services handles the image analysis and the eventual sending of an alert emails. This solution had some benefits: 1. The Pi Zero could now focus on running the motion software. 2. The Camera and Image Processing would be seperated, making it easy to replace either at a later date. I also tweaked the Motion configuration file to provide multiple snapshots for each detected activity. More pictures would increase the chance of Motion correctly detecting movement.
  28. Ok, so how did the AWS processing work? Here’s a simplified run through. Firstly an image is pushed from the PiZero Camera to Amazon’s s3 storage. A small unit of code or Lambda Function is triggered by the upload. It in turn triggers a Step Function. The Step Function orchestrates further Lambda Functions into a workshop. The first Lambda Function makes a call to Rekognition to evaluate the picture. The second Lambda Function uses the Simple Email Service to send the alert email. Finally, all components in the workflow use Identity Access management to make sure that they have access to the components they need to use. For example, the Lambda Function that sends an email needs access to both the Simple Email Service and to s3 in order to attach the image file to the email
  29. In order to consume the AWS services one uses the AWS SDK.
  30. On upload to s3, a Lambda Function is triggered, which in turn triggers a step function, which contains more Lambda Functions. Lets look at AWS Lambda Functions and their role in our solution.
  31. A Lambda Function is essentially a unit of code. As today it is possible to implement Lambda Function using Java, C#, Python and Node.js. Lamba Functions are serverless. This doesn’t mean that they run without servers, but that the business or person running the code doesn’t have to worry about provisioning or managing the servers. In other word, Amazon has responsibility for making sure that the servers are up and running. Lambda Functions are also stateless. By not storing state they are more easily scaled up and down. This scalability is an important part of the Cloud paradigm, as it allows one to scale Lambda Functions rapidly up and down according to demand. The AWS Lambda platform is engineered to be highly available, making it suitable for running applications that need to be up all of the time. AWS Lambda utilises a Pay as you go model. This means that you pay only for the processing time you use. This means that an application with low traffic will be relatively cheap compared to one with lots of traffic. ASW Lambda also has a free tier for those who want to get started with AWS. This provides free usage up to a given threshold. AWS Lambda also has the SDK natively available, making it simple to call other AWS services and resources.
  32. View Lambda Functions - all I have Select one - Rekognition processing Three types Inline code zip files - used for code with third party dependancies S3 objects – find out more about these!  Lambda Functions can pass information in and out via objects Event - input Callback - allows to one to specify either successful output or error Show configuration options - especially memory - the more memory consumed, the higher the cost. Show how you can test the Lambda Function online: Happy Case Unhappy Case Cloudwatch logs. cd Desktop/NTNU node s3-upload-image-file.js smart-security-camera-upload 
  33. On upload to s3, a Lambda Function is triggered, which in turn triggers a step function, which contains more Lambda Functions. Lets look at AWS Lambda Functions and their role in our solution.
  34. Here is the actual Step Function for my Camera, rendered by the AWS Step Function interface. It’s not necessarily easy to see the flow here, so let me try to shed some light on how this works. The first step submits the snapshot to AWS Rekognition. The second step then evaluates the response from AWS Rekognition. It looks for labels such as “Person” and ”Human” and sets a flag to indicate whether a person has been found. The third step uses this flag to decide whether or not to send an email. Unlike all the other steps this is not calling a Lambda Function. The fourth step sends the alert email if. This will be skipped if the alert flag is set to false. The fifth step archives the snapshot – either in an alert folder or a false positive folder. The final step is an all purpose error handler. Any errors during processing will result in an email being sent to me.
  35. Ok, let us try a quick demo of the Pi Camera Version 2. Show happy case and unhappy case. Show Step Function flow If camera NOT working, try upload from PC : cd '/Users/mark.west/Documents/GitHub Repositories/smart-security-camera/s3-upload/' s3-upload mark.west$ node s3-upload-image-file.js smart-security-camera-upload /Users/mark.west/Desktop/ntnu/burglar.png
  36. Ok, so lets get started by looking at why I did this project!
  37. Ok, lets revisit my project requirements. My camera: Would monitor activity in the garden. It would be able to send an email when human activity was detected. It included a live video stream. It was quick to build and program. It had a one of cost of 680kr. And a yearly cost of 600kr after the first year. And it was portable. All this led to a happy stakeholder! But was the project completely successful?
  38. The first figure is based on usage in March, where approximately 3750 images where processed – approximately 125 a day. During this period I received less than 100 real alarms. The second figure is based on the same usage amounts once the free tier is expired. The extra costs will mostly arise from costs of Step Functions and Rekognition, which as new services come at a premium rate. Other than that, additional costs will be incurred by S3 usage.
  39. Ok, let us try a quick demo of the Pi Camera Version 1.
  40. The first figure is based on usage in March, where approximately 3750 images where processed – approximately 125 a day. During this period I received less than 100 real alarms. The second figure is based on the same usage amounts once the free tier is expired. The extra costs will mostly arise from costs of Step Functions and Rekognition, which as new services come at a premium rate. Other than that, additional costs will be incurred by S3 usage.
  41. Thanks very much for attending my talk! You can find more information about this project at the Bouvet blog. And you’ll find all the code on my GitHub. If anyone wants to have a chat I’ll be on the Bouvet stand for the rest of the day and will be joining some of you for food this evening!