Computer Science

Machine Learning

Using Unity Game Engine and MLAgents package, created a soccer setting and set training parameters such as rewards to iterate on the training process and quickly train agents to push objects together. Fastest training for this process was 5 hours, with 128 hidden layers, split between two training sessions. A 30 minuet training session where the agent was rewarded for touching the blue block, and an four and a half hour session where he was rewarded only for bringing the two blocks together. This agent achieved 98% success rates after this time. 

Further expanded this project to 3D, and iterated on the training parameters to reach a relatively fast training with low end hardware. Started with a base case of scoring = reward, but then moved on to a curriculum approach as the task was to hard to build on its own. Transitioned from curriculum to having all the rewards pre baked into the code, with staying in bounds for a full episode == .01 reward, touching the ball == 1 reward, and scoring == 100 reward for that episode. Scoring was not cumulative in these episodes, so the only 4 score outputs possible from a session were 0, .01, 1 and 100. Have a x100 scale would create a large incentive to learn the new behaviors. Originally I tried this process with a 5x scale, but the Bee would spend far longer just hitting the ball randomly, drastically slowing that training. I assume my approach is not novel, but it works for this project better then the curriculum based training runs, and I have not seen it elsewhere. 

The end results show extremely similar results between my process and a standard curriculum process, but mine seems easier to implement. Both processes reached higher scoring (above 60% success) much faster than a "raw" process that only rewards the end goal. However, over the long term, the raw process did achive higher results overall. 

TenserBoard Outputs

Javascript and API Calls Project

ChatGPT generates responses in the discord app Roasting Ryan.
Ryan agrees to let me make a ryan roaster

I used a combination of JavaScript, Discord API calls, and OpenAI API calls to CONSENUALLY collect all of my conversation history with my brother Ryan as a string, clean up that string by removing things like timestamps, then break it up into chunks of under 2000 characters. Whenever the RyanRoaster is called, it gives chatGPT a prompt involving one of these chunks and the message it is responding to, and attempts to create an original roast of Ryan using a combination of his message history and the phrase given. 

Even when fed random letters, GPT3 has really clever things to say.

More images of Ryan getting roasted by my bot

The power of GPT3 is amazing, In real time it associates being better with winning, win-loss record formats, and then combines the fact that Ryan loses more then he wins, and turns that into a reference to the alleged size of his big toe to create an ultimate roast.

The backend for this project is handled by Node.js and Glitch.com.

Each example is more jaw dropping then the last, and my freind group was engaging with the roaster for hours! 

Python and Algorithms

A certificate of achievement from AlgoExpert

Completed the AlgoExpert Questions Library using Python. Can complete 90% of questions in under 30 minuets with clear O(n) spacetime explainations. 

Scratch- 3 years of 1 week student led Game design projects. 

An image showing all of my Scratch repos

Java (Game Engine)

A very sloppy game design project, but it works! Multiple armies are placed on a hexgrid board for turn based combat.

Built a Java Applet Game Engine from scratch, only using the system clock and the Java applet Graphics Class to draw points. 

Used this engine to build a functional 2 person turn based strategy game.

https://www.youtube.com/watch?v=AheMgfaA2Ik

https://www.youtube.com/watch?v=Q5191kdaQ3E

Robotics

7 students stand with Luke holding battlebots

Have created a wide range of Lego robots, from competition bots to hobby bots like crawlers and mock Roombas. Worked with Carnegie-Mellon Robotics Acadamy (Vu Nygen) to test and improve on tools to simulate Lego robots virtually for an online learning environment.