What's that thing you're holding?

Hey, my name is Idrees Hassan and after a long delay due to COVID, I was finally able to graduate with the UNC Class of 2020 on October 10th, 2021. To celebrate, I created a grad cap with part of a billboard that can display anything you can think of! And to top it off I let anybody who donated to a charity supporting Afghan refugees submit their own designs to be shown off during the ceremony! After four weeks of fundraising, we raised over $2,000 and received dozens of submissions that I proudly wore on my head during graduation weekend! Check out this video I made about it:

For about a month, I reached out to friends, family, and strangers on the internet asking for their help donating to refugees and decorating my grad cap. And let me tell you, making the hat was nowhere near as difficult as figuring out how to get the word out. But with their generous support, we were able to raise over double the original goal for charities supporting refugees!

How did it go!

It went way better than I expected! We raised $2,274 for Afghan refugees, received 33 submissions, and the project went off without a hitch during the whole ceremony and other events that weekend!


A full write-up is available on my website here, including all of the designs submitted and more links to the source code.

The hardware held up, the battery remained above 50% the whole time, my software didn't let me down, and a billion bobby pins kept it all together on my head. For three days, I was able to rock a glowing graduation cap and finally graduate with the Class of 2020! Thank you for everyone who helped me with this project, and I hope this write-up can help anybody else who wants to do a project like this in the future.

So how did you do it?

With blood, sweat, tears, and craft supplies!

The Hardware

- A Raspberry Pi Zero W
- Dual male headers
- An Adafruit 32x32 LED Matrix w/ 6mm pitch
- An Adafruit RGB Matrix Bonnet
- An overpriced graduation cap that I stole from my girlfriend
- A 20,000 mAh portable battery
- A 6ft USB to DC power cable
- Glittery UNC blue ribbon
- Double-sided tape for the ribbon
- A high-temperature hot glue gun
- So many bobby pins

And here's a general summary of how I built it:

1. First, I soldered the headers onto the Raspberry Pi Zero W. This was necessary so that the LED Matrix Bonnet could attach to it, but not knowing how to solder made it way harder than it should've been (and I may have lead lungs now). I think I'll just buy a Pi with pre-soldered headers in the future.
2. Next, I popped the bonnet on, easy as pie!
3. Then I stripped the screw connectors off of the power cable that came with the LED matrix and stuck the newly stripped wires into the bonnet's screw terminals. Careful to make sure you get the polarity correct!
4. To get the Pi and the cables to stay together nicely, I used some painter's tape for cable management. It wasn't great, but it got the job done. It's important to make sure that the cables don't get in the way of the matrix standing on its pins.
5. Since the matrix was going to be glued onto my cap, I made sure to mark where it would go with a pencil. Remember to make sure that the matrix display is in the orientation you want it before gluing, otherwise your images will be sideways/upside down.
6. I removed the magnets from the matrix's stand-off screws and hot glued them to where I marked on the cap. Again, you really want to be sure you measured and marked correctly, you only have one go at this. Hot glue sticks to the cheap polyester like...glue.
7. With the magnets in place, the matrix can now be popped onto the cap with a satisfying magnetic snap! This allowed me to remove the matrix at will while keeping it on my cap firmly enough so that it wouldn't separate while walking around campus.
8. To make things pretty, I attached a glittery UNC blue ribbon all around the edge of the matrix using double-sided tape. This hides all of the cables and adds some pizzazz. 7/8ths of an inch tape seemed to be the perfect size in my case.
9. Now is the hard part. The cap is pretty heavy with the display on, so to keep it all stuck to my head I used bobby pins. I even had to avoid cutting my hair so that I'd have enough for the bobby pins to attach tightly. I used about 12 bobby pins arranged into 6 "X" shapes on my head. Luckily Miranda and my mum were there to teach me how it's done. The bobby pins kept the cap stuck to my head pretty well (though I made an effort to not swing it around too much).

And that's it! I kept the massive battery pack in my jeans pocket and ran the USB to DC jack up to the bonnet on the Pi to keep it powered. On a full charge, it looks like my cap would get over 15 hours of battery life even on full brightness and while connected to my phone's hotspot. With this hardware and the software I wrote (see below), I was able to run the cap all weekend without issue.

The Software

The software side of the cap is split into two parts, the code that runs on the Raspberry Pi and the command and control center (which I've nicknamed the "relay" server).

The Adafruit LED Matrix Bonnet makes it easy to display individual images on the LED matrix, so I started by using the compatible rpi-rgb-led-matrix library. This library uses C but has bindings for Python and C#, so I decided to embrace the snake and write the on-device code in Python 3.

The on-device program controls what is displayed on the hat, whether it is an image or a message. It has configurable options for the length of time to display each image, the speed of text scrolling, and where to find the submissions to display. The submissions are stored in a separate folder that is a clone of this GitHub repository. The benefits of using a git repo are that I can easily update the submissions through a simple "git pull" as well as upload new submissions through a web browser if necessary. The program is setup to run on boot using crontab, so if a problem came up it'd be easy to restart by just unplugging the cap and plugging it back in.

The relay server was my favorite idea. I realized that I needed some way to control the hat as I walked around campus all graduation weekend, and the changing IP address and inconsistent network connection would make it very difficult to maintain a connection between the server and the client. So instead, I wrote a Node.js relay server that ran on my PC at home and acted as the middle-man between the web client and the Python grad cap program. Each process communicated via the ever-reliable Socket.IO protocol which meant that I didn't have to worry about dropped connections or implementing my own retry logic. To get Socket.IO working with Python, I relied on the well-documented and easy-to-use python-socketio library.

To control the hat from my phone, the relay server runs a simple web server that provides a single-page control panel. When the grad cap connects to the relay server (usually via my phone's hotspot), the web client on my phone allows me to set the brightness and manually select the image to display. Given more time (I only started the web server about two days before graduation) I'd have probably added the ability to display custom text and modify the time per design, but overall it was more than enough to keep me in control all weekend. One thing that I wasn't expecting was for my phone's hotspot to give out near the stadium due to thousands of student's and their families saturating the cell towers. Luckily my cap doesn't need WiFi to function and a quick power reboot removed any manual overrides I had set via my control panel.

Since I couldn't be sure that nothing would go wrong with my cap, I installed ngrok and setup the crontab to forward ssh on startup so that I could connect to the Raspberry Pi while on campus. I never ended up needing to use this as any problems that might have came up could be easily solved by unplugging and plugging the cap back in. I did test it while on campus just to see if it worked and was easily able to SSH through the ngrok tunnel from my phone.

Lastly on the software side, I created an LED matrix web editor that allows people to draw their own custom designs!

Features include a full drawing suite (so you can draw all the 32x32 art you desire), image importing with automatic downscaling, and the ability to export designs as images. This web app made it not only easy to draw your own designs but also allows you to get a better understanding of what your design might look like on my cap. A lot of the people who donated were strangers on the internet which meant they couldn't just stop by and see what their potential design might look like in-person. I tried to take out the guesswork by developing an editor as similar as possible to the actual LED matrix, and in practice I think it turned out pretty good.

All programs developed for this project are open source and are available on GitHub, check them out and give 'em a star if you like what you see!

- Graduation Cap Driver
- Relay Server
- LED Matrix Web Editor

And if you'd like to see how I struggled through each step of the software, check out my dev journal here!

Conclusion

This was easily my favorite project I have ever made yet! The hardware was interesting, the software was fun, and I got the chance to help out a cause I truly believe in. It was also my most exhausting, with many dozens of hours spent after work planning, debugging edge cases, and learning how to be my own social media manager. I'd like to thank my family and friends for their amazing help and for being such great test subjects. I'd especially like to thank my girlfriend Miranda, without whom I would never have been able to complete this project. If you have any questions or comments, feel free to contact me on Twitter @IdreesInc or find my contact details on my website!