final-project-shorts-and-sparks

Review Assignment Due Date

final-project-skeleton

* Team Name: Shorts and Sparks
* Team Members: Tim Zhang and James Steeman
* Github Repository URL: https://github.com/upenn-embedded/final-project-shorts-and-sparks
* Github Pages Website URL:  https://upenn-embedded.github.io/final-project-shorts-and-sparks/ (full repo) or https://jamessteeman.github.io/t19ese5190f24/ (final report only repo)
* Description of hardware: Atmega328PB, M2 Macbook Pro

Final Project Report

Don’t forget to make the GitHub pages public website! If you’ve never made a Github pages website before, you can follow this webpage (though, substitute your final project repository for the Github username one in the quickstart guide): https://docs.github.com/en/pages/quickstart

1. Video

Google Drive Video

2. Images

Demo Day picture: alt text Left Center: James, Right Center: Tim

Annotated image of components placed above the ceiling: alt text

Annotated image of turret below the ceiling: alt text

Final Hardware Diagram: alt text Note: Camera damage prevented camera code from implementation in final integration (see below for more infomation)

Final Code Diagram: alt text Note: Camera damage prevented camera code from implementation in final integration (see below for more infomation)

3. Results

The turret features 2 degrees of freedom, one azimuth rotation and one elevation rotation. This combined motion allows it to point anywhere in a half sphere below the ceiling. The azimuth control uses a NEMA 17 motor with a 4:1 internal gear reduction and acceleration control to prevent step skipping and enable greater top speed. This allows the platform itself to easily hit over 3 rotations every second, well beyond our expected maximum of 1 rps. The elevation control uses a high torque servo with a barrel connected to the arm to direct the water jet.

Water is pumped using a 12V gear pump that is both self priming and reversible. A rotary union and tubing is used to transport water across the rotating element. A nozzle attachment enables powerful water jets over 10m.

On board buzzers are programmed to produce an obnoxious fire alarm.

This final solution/result was essentially the same as the proposed; however, due to the damage to the camera’s themopile array, autonomous mode is currently not available for the turret. We are planning to complete this implementation with a replacement camera after the course.

For demonstration purposes, the turret is pre-programmed to known directions of the targets, and is able to consistently hit targets at various distances up to a 2 meters radius, over 4 times the original design requirements. This is shown in the video demo where the turret easily blasts mock “fire” targets.

3.1 Software Requirements Specification (SRS) Results

SRS 01 – Motor control functionality shall be implemented to enable smooth, fast and accurate motion over the complete range of turret motion.

SRS 02 - Thermal imaging data shall be acquired repeatedly as the turret rotates (azimuth).

SRS 03 – In seeking/pointing state, the control logic shall account projectile motion so that the water lands on the flame.

SRS 04 – Image processing functionality shall locate pixels above threshold temperature upon each collection of thermal imaging data.

SRS 05 – The system shall switch correctly between sensing state, seeking/pointing state, and firing state.

SRS 06 – The system shall follow timing requirements by referencing properly scaled timers/counters.

3.2 Hardware Requirements Specification (HRS) Results

HRS 01 – Project shall be based on ATmega328P microcontroller

HRS 02 – A thermal imaging type sensor shall be used for flame detection. The sensor shall detect min temperature range 0 ~ 300˚C (higher temperatures definitely signifies abnormal heating, potentially flame), a frame rate over 15FPS, and a resolution above 16x16.

HRS 03 – Servo Motors shall be used for turret positioning. They shall be able to handle the load of the barrel + camera.

HRS 04 – pump motor shall be used for shooting water. They shall be able to at least fire jets of water within the specified 0.5m operational radius.

HRS 05 – A Buzzer shall be used for sounding an alarm. It shall be internally driven.

HRS 06 (new) – Turret shall be able to continuously rotate, while preventing any leakage/bad electrical contact.

HRS 07 (new) – The turret shall not leak water through the nozzle when in the off state.

4. Conclusion

This project provoked a significant amount of learning, as running into issues, troubleshooting, and finding solutions not only cemented topics from this course, but also concepts from prior courses and engineering experiences. We learned about mechanical prototyping, electrical prototyping, using datasheets, component selection, product design, bare metal coding, I2C, image processing, python scripting, servo motors, stepper motors, dealing with the limitations of an MCU, dealing with unnexpected mechanical and electrical issues and failures, using github, and more.

While we would have liked the final result of this project to include a functional thermal camera implementation, the learning process from all of the issues involved with the camera spurred significant improvement in understanding and implementing efficient code for embedded contexts. Similar learning took place through all of the issues we faced through our iterative design and testing processes.

We are certainly proud of coming from essentially zero experience in embedded systems at the beginning of the project to having a well made prototye (with successful non-camera functionality) and a much greater understanding of embedded systems. Despite falling a bit short on our naive intentions for the final outcome of this project, we both feel quite confident in our ability to complete future projects from start to finish, beginning with selecting compatible components and MCUs.

For this project, we are plannning on purchasing a new thermal camera so we can update the turrent with the intended autonomous functionality. Additionally, there is a chance we will take this project idea and update it for our ESE 5160 project next semester.

Final Demo (Writeup)

1. Three class topics you covered

2. Input device

3. Output Device

4. Complexity (what was difficult in your project and on what things did you spend a large amount of time?)

5. Integration (what things broke when you put them together and how did you deal with it?)

MVP Demo

Show a system block diagram & explain the hardware implementation. the main actuators are the stepper for azimuth control and the servo for elevation control. slip ring and rotary union are used to ensure 360 degree continuous rotation. pump used to shoot water, connected to an H-Bridge. This H-bridge is crucial since the pump normally experience siphoning, by reversing the flow shortly, this issue is bypassed. buzzers used to sound an alarm

alt text

Explain your firmware implementation, including application logic and critical drivers you’ve written. main logic is a loop that scans the area by rotating the turret around 360 degrees, stopping every 30 degrees to scan for a heat signature. Once heat signature is acquired, the motors will work together to aim at target roughly. After this, images are rapidly taken and processed to facilitate precise aiming of the actual target. At this point, the pump would be activated and the flame will be (hopefully) extinguished.

the main drivers include: I2C for camera-atmega communication Servo library that automatically set PWM dutycycle based on desired angle Stepper library that automatically accelerates and decelerate the stepper according to the set target steps, or free spinning continuously at some set speed.

alt text

Have you achieved some or all of your Software Requirements Specification (SRS)? Show how you collected data and the outcomes.

SRS 01 – Motor control functionality shall be implemented to enable smooth, fast and accurate motion over the complete range of turret motion.

SRS 02 – Thermal imaging data shall be acquired repeatedly as the turret rotates (azimuth).

SRS 03 – In seeking/pointing state, the control logic shall account projectile motion so that the water lands on the flame.

SRS 04 – Image processing functionality shall locate pixels above threshold temperature upon each collection of thermal imaging data.

SRS 05 – The system shall switch correctly between sensing state, seeking/pointing state, and firing state.

SRS 06 – The system shall follow timing requirements by referencing properly scaled timers/counters.

Have you achieved some or all of your Hardware Requirements Specification (HRS)? Show how you collected data and the outcomes.

HRS 01 – Project shall be based on ATmega328P microcontroller

HRS 02 – A thermal imaging type sensor shall be used for flame detection. The sensor shall detect min temperature range 0 ~ 100C (higher temperatures definitely signifies abnormal heating, potentially flame), A frame rate over 15FPS, and a resolution above 16*16.

HRS 03 – Servo Motors shall be used for turret positioning. They shall be able to handle the load of the barrel + camera.

HRS 04 – pump motor shall be used for shooting water. They shall be able to at least fire jets of water within the specified 0.5m operational radius.

HRS 05 – buzzer shall be used for sounding an alarm. It shall be internally driven.

Show off the remaining elements that will make your project whole: mechanical casework, supporting graphical user interface (GUI), web portal, etc.

[Shown during actual demo]

Demo your device.

What is the riskiest part remaining of your project?

Integration, where things just magically break. Currently all of our sub parts can function on its own, but when working together, things may go wrong.

How do you plan to de-risk this?

Test small steps of integration at a time, and also be patient and expect to spend a lot of time debugging.

What questions or help do you need from the teaching team?

moral support and maybe math help on the camera calculations (there is a LOT of math)

Sprint review #2

Current state of project

We tested all electrical components and the mechanical parts that have arrived. We completed third set of orders for power supply, better rotary union, and PU tubes with bonus $50 budget. With our own money we purchased a slew ring as well. Completed a fair ammount of code progress and have begun structural and electrical integration. Prototyping done on OnShape for CAD and using RPL for laser cutting.

Last week’s progress

Next week’s plan

Note: All work expected to be done while in-person together (basically all free time). Specific asyncronous tasks split as sensible (research and datasheet reading).

Code:

Electrical Integration:

Mechanical Integration:

Component Testing:

Sprint review #1

Current state of project

We have sourced all electrical components and most mechanical parts. All sensors and actuators have had functionality tested, aside from the camera that just arrived. We completed second order for a necessary mechanical component (for the water tubing), and have written starting code for working with our servos in bare metal C.

Last week’s progress

Planned progress:

Unplanned progress:

Next week’s plan

Note: All work expected to be done while in-person together (basically all day on weekends and weekday afternoons when no immediately due assignemnts). Specific asyncronous tasks split as sensible.

Code:

Mechanical:

Component Testing:

Sprint review trial

Current state of project

We are currently planning, testing and sourcing components.

Last week’s progress

Read a lot of datasheets and determined component viability.

Scavenged and tested many parts from Detkin:

Submitted First order form:

Planned Future orders:

Planned Mechanical Design

Next week’s plan

Testing Components:

First Iteration Turret CAD

Bare Metal Code:

Find a 5V to 3.3V linear regulator for camera (scavenging from Detkin as usual).

More datasheet reading (Huzzah!!!)

Final Project Proposal

1. Abstract

This project involves the development of an autonomous sentry turret equipped with thermal imaging sensors to detect and respond to fire outbreaks. The turret uses its thermal sensor to identify heat signatures above a certain threshold, deploying a precise waterjet to suppress the flames. This solution aims to augment existing fire suppression systems such as sprinklers to provide a more rapid and targeted response to fires at the earliest stage in areas prone to fire hazards, preventing unnecessary property damage and injuries.

2. Motivation

Fires can happen at any time, anywhere. Having a system to respond to this uncertain situation is important. Our turret would allow us to target any flame within range of operation.

Response time is key to defeating fires. As the fire grows, it becomes more difficult to extinguish. Hence, our system using thermal imaging offers a nearly instantaneous detection and reaction to flames, increasing the success rate of extinguishing.

Current systems such as sprinklers are a last resort tool, usually triggering after significant damage. Our system would detect and extinguish the first hint of fires, before it causes significant damage, if any.

Fire department response times may greatly, leaving us stranded without means of defeating the flame. Our system however aims to act as an autonomous firefighter to contain/extinguish the fire as soon as possible.

3. Goals

Interpreted as checkpoint goals to guide progress.

Complete an I2C library for collecting data from the thermal imaging sensor.

Turret aims at flame based on thermal camera data

Water jet can be shot far enough (0.5m)

Design a neat mechanical enclosure to conceal the device hardware (Limit exposed wires).

Use perf-boards for final electrical implementations ensure electrical connections.

By the end of the final project, a singular elevated turret should be able to detect and extinguish a small candle flame lit anywhere in a 0.5m radius directly below without any human intervention.

4. System Block Diagram

alt text

5. Design Sketches

alt text

6. Software Requirements Specification (SRS)

6.1 Overview

Control turret motors to repeatedly collect thermal imaging data until heat source is detected. Initiate alarms and control the turret motors to point the water cannon at the heat source and activate the water pump until the heat source is eliminated, then return to scanning mode.

6.2 Users

People who own / run spaces with elevated fire risk and expensive equipment (e.g. Lab Spaces, Warehouses, etc.)

6.3 Definitions, Abbreviations

Currently N/A, may update during implemention process

6.4 Functionality

SRS 01 – Motor control functionality shall be implemented to enable smooth, fast and accurate motion over the complete range of turret motion.

SRS 02 – Thermal imaging data shall be acquired repeatedly as the turret rotates (azimuth).

SRS 03 – In seeking/pointing state, the control logic shall account projectile motion so that the water lands on the flame.

SRS 04 – Image processing functionality shall locate pixels above threshold temperature upon each collection of thermal imaging data.

SRS 05 – The system shall switch correctly between sensing state, seeking/pointing state, and firing state.

SRS 06 – The system shall follow timing requirements by referencing properly scaled timers/counters.

7. Hardware Requirements Specification (HRS)

7.1 Overview

A 2 axis turret controlled using servo motors that would aim a barrel and thermal camera at a flame. A pump would shoot water through the barrel at the targeted flame, while sounding a buzzer.

7.2 Definitions, Abbreviations

Elevation: the angle of the turret’s pithing movement (up and down)

Azimuth: the angle of the turret’s yawing movement (side to side)

7.3 Functionality

HRS 01 – Project shall be based on ATmega328P microcontroller

HRS 02 – A thermal imaging type sensor shall be used for flame detection. The sensor shall detect min temperature range 0 ~ 100C (higher temperatures definitely signifies abnormal heating, potentially flame), A frame rate over 15FPS, and a resolution above 16*16.

HRS 03 – Servo Motors shall be used for turret positioning. They shall be able to handle the load of the barrel + camera.

HRS 04 – pump motor shall be used for shooting water. They shall be able to at least fire jets of water within the specified 0.5m operational radius.

HRS 05 – buzzer shall be used for sounding an alarm. It shall be internally driven.

8. Components

The most important component is the thermal imaging sensor. This is what allows the flame to be detected and located. All other hardware such as motors, buzzers, pump… have less strict requirements, potentially even available in Detkin. Passive components and MOSFETs will be acquired from Detkin.

Thermal Imaging Sensor (Thermopile or Thermal Camera)

Frontrunner (Thermal Camera): MLX90640

While these thermal sensor types are both more expensive than a simple IR flame sensor, both these options collect many data points across the sensor field of view, allowing the precise location of the flame to be acquired (critical functionality).

The links and information for other components can be seen in the Final Project BOM.xlsx

BOM LINK

9. Final Demo

For the final demonstration, we shall exhibit an instance of the elevated turret detecting and firing at a hot object introduced at an arbitrary time and location (within the design specification of 0.5m radius region at 1m height).

Due to restrictions on open flames for testing, we will be using a hot object to simulate the flames. One possibility is a cup of hot water, as shooting additional water into the cup with decrease the temperature of the water, “dousing” the simulated “flame”.

10. Methodology

To avoid being stuck, we plan to approach this problem in small chunks, where each chunk is unaffected by its connecting chunks. I.e. We would work on just the turret control and get it fully functional before using the sensor to feed it data. This would allow us to break down the whole project into smaller, easier to debug steps. This would also be really good if components arrive at different times, so our overall pace is not affected.

Furthermore, we plan to ensure our implementation is future proofed (as best we can), so that if we ever decide to add features/upgrades, the base implementation would need no/minimal change.

11. Evaluation

Test condition: A singular elevated turret at ~1m high with a small flame lit within a 0.5m radius (1m diameter) circle centered directly below.

Minimum success metric: Flames shall be detected and extinguished within 15 seconds for >=50% of instances. 20 seconds for >=90% of instances.

12. Proposal Presentation

Slides have been added to the Final Project Proposal slide deck in the Google Drive.

References

Fill in your references here as you work on your proposal and final submission. Describe any libraries used here.

Github Repo Submission Resources

You can remove this section if you don’t need these references.