Skip to content

MikaRanAway/Shusher

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Shusher

Table of Contents

  1. Shusher Showcase Video
  2. Introduction
  3. Description
  4. Hardware and Software Architecture
  5. Visuals
  6. Installation
  7. Purpose
  8. Benefits
  9. License
  10. Support
  11. Roadmap
  12. Authors and acknowledgment

Shusher Showcase Video

Capture

Click on video above ^^^^


Introduction

Are you susceptible to waking up your neighbours late at night? Do you wish for an easy solution to keep your noise levels at a minimum? Well look no further! With the Shusher, a technical marvel at voice level detection, will you not only be able to easily visually detect when your noise levels are getting out of hand, but you are also able to say you finally made a worthwhile purchase.


Description

The Shusher is a device that visually shows a User when they are crossing a given noise level threshold. (Thresholds can be changed in the settings) Lights ranging from green to red (In the default theme) will display low to high audio levels respectively. The sensitivity of the device changes based on how far away you are from it ranging from less sensitive when you are close and more sensitive when you are far away.


Hardware and Software Architecture

Welcome to the hardware and software architecture section of the README. In this section, we will provide an overview of the system's architecture, both in terms of hardware and software components.

System design

The system diagram illustrates the connections and roles of the different parts of the system. It provides a visual representation of how the hardware components interact with each other and the application to support the functionality of the Shusher system.

Version1.0_System_Design

Software Architecture

The integration of the WIO Terminal and sensors into the system involves the use of the C programming language. By utilizing C, we have been able to establish seamless communication and data exchange between the WIO Terminal and the sensors, ensuring accurate and reliable readings.

The application itself is built using JavaFX, a framework for creating desktop and mobile applications with a rich user interface. Leveraging capabilities and advantages of scene-builder within JavaFX, we have developed a user-friendly and visually appealing interface for the Shusher application. The software architecture is shown in the class diagram below. This diagram offers a detailed view of the software components, their relationships, and the overall structure of the application.

shusherGUIClassDiagram There were issues when exporting the application to an executable jar file, therefore a 'FakeMain' class was created. The 'FakeMain' class brings no functionality to the system design. It is only used to call the 'MainApplication' class. By having a 'FakeMain', we were able to export the application as an executable jar file and make the program customer friendly.

Visuals

Shusher detecting audio

ezgif.com-video-to-gif

Shusher changing themes

ezgif.com-video-to-gif__1_

Shusher alerting that the user is being too loud

ezgif.com-video-to-gif__2_


Installation

Prerequisites

System setup

Step 1: Set up local Eclipse mosquitto message broker

The system uses a combination of sensors and actuators that communicate with a Java application through MQTT. This system uses the Eclipse Mosquitto message broker. If you have installed and know how to launch your own local message broker, move to step 2.

  • Locate the mosquito directory.
  • Open "mosquitto.conf".
  • Under "General configuration", add two new lines [1] "listener 1883 0.0.0.0", [2] "allow_anonymous true"
  • Open terminal and navigate to the Mosquitto directory.
  • Launch local broker by typing "mosquitto -c mosquitto.conf -v".

Step 2: Edit configuration files

The Shusher device and the application both need to connect to the same network that the local broker is running on. Therefore, configuring your network settings is required to use the application. In the Version1.0 folder, you will find two folders. You need to specify your network settings in both folders. Starting with the "Shusher App" folder:

  • Open "config.txt".
  • The first line indicates your WiFi SSID. Use the default configuration (tcp://localhost:1883) if you're running a local message broker. Otherwise, specify the IP address of the network the broker is connected to instead of "localhost".
  • The second line is the client name of the application. This name will be seen in the message broker.

Moving on to the configuration file inside the "ShusherCode" folder:

  • Plug in the WIO terminal to your computer.
  • Open "shusherCode.ino".
  • Click on the WiFiSetup.h tab.
  • Follow the instructions provided in the file.
  • Compile and upload the program to the WIO terminal.

Step 3: Launch application

The required configurations are now complete, and the application is ready to launch. To launch the application:

  • Navigate to the Shusher App folder.
  • Launch the application by double-clicking the executable jar file named "ShusherApplication".

Common Problems

Eclipse mosquitto broker

If you receive an error message saying "port already in use" when launching the Eclipse Mosquitto message broker.

  • Open terminal as an administrator and type "netstat -ano | findstr "1883"".
  • Note the numbers after "Listening:"
  • Type "taskkill /F /PID XXXX". Replace XXXX with the four numbers.
  • Re-run mosquitto.
Launching Shusher Application

If you can't run the application by double clicking the executable jar file.

  • Open terminal and navigate to the jar file directory.
  • Run "java -jar ShusherApplication.jar" and the application should run.
  • If you're still having issues launching the application, try downloading Java 17.0.5.

Purpose

The Shusher's main purpose is to be of great support to those in need of audio visualizers to be wary of how loud they are being. Whether you find yourself in a intense match of a video game, a heated debate over discord, or a book club on teams, having trouble volume control is an universal problem.

This is where the Shusher comes in. Being composed of an ultrasonic ranger, a rgb light strip, and a microphone, the Shusher uses all these sensors to collaberatively detect and visualize how loud an user is. With addition of a GUI responding differently to your volume, the Shusher actively educates and warns the user on their current volume. This, hopefully, will keep a user's voice in check and consequentively save his/her neighbours from a loud disturbance in the area.


Benefits

  • Compact Device
  • Easy Setup
    • The Shusher only requires a user to plug in the device and have a WiFi connection.
  • Customizable
    • The Shusher can be extensively customized upon three different themes
  • Open Source
    • The Shusher Code is licensed under MIT and is open source for all to manipulate and grow the product even further

License

Shusher project is licensed under MIT

Copyright (c) 2023 courses / DIT113 / 2023 / Group-14


Support

Any further assistance and questions with the Shusher can be forwarded to:

[email protected]


Roadmap

1.1 ShusherVibbo (2025)

  • Added vibration to generate haptic feedback for the User

1.2 ShusherHome (2032)

  • Added connectivity between ShusherHome and house lights (sponsered companies only)

Authors and acknowledgment

A standing ovation to the following board members who all contributed in their respective ways on every sprint delivery and the final product with special mentions to:

  • Mika Rannisto: For designing and implementing the Wio gui, setting up automated build and CI/CD. Helping with ultrasonic ranger code and refactoring. Doing crucial work on connecting sensors and merging files. User manual and ReadMe text contributions as well.
  • Hashem Ibrahim: For implementing the functionality of inputting data from the wio mic and recording sound, converting it into usable values to display and be used around the code and implementing ultrasonic ranger functionality. Doing minor work on a wio gui MVP. Doing major work on backend structuring, debugging and modularisation.
  • Johan Engstrom: For implementing the displaying of the data using the LED strip and implementing mqtt into the Arduino code and making sure it publishes and subscribes values. Doing backend formatting. For working closely on connecting the Java gui to the Arduino code.
  • Ashor Abraham: For project management such as management of the readme, sprint deliveries, code review rules, and handling merge requests and code reviewing.
  • Isaac Lindegren Ternbom: For being project manager and keeping the team on track throughout the project. Doing extremely vital work on the whole front end and single handedly developing the JavaFX gui. Setting up mqtt and teaching the team how to use mqtt. Managing issue tracking and sprint planning. Created all diagrams and the installation guide. Contributed to wiki and readme documentation.
  • Abdullahi Mahamed For Initial work on the loudness sensor and automated build. Working on the wiki pages and formatting the home page.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages