The Math Game
I built this math studying game in 2013 for my little brother, Trevor. He loved it! He's played it for hundreds of hours and solved almost 30,000 problems!
data:image/s3,"s3://crabby-images/63cbf/63cbf90f7bddb0a582cd38035b44734bc8800491" alt="Trevor in 2010"
data:image/s3,"s3://crabby-images/d1859/d185987428544ecaff0ad71eab6a98c93ac6f907" alt="a math problem on the problem page"
data:image/s3,"s3://crabby-images/43d3a/43d3a909bba0ce91ed66765ab05c79e94ad197df" alt="charts and graphs of problems completed over time and the distribution of different types of problems"
data:image/s3,"s3://crabby-images/1a0fb/1a0fba463af129ceb7d36cf5d6b1ff4321208f49" alt="a video playing on the rewards page"
1
Solve Math Problems
data:image/s3,"s3://crabby-images/d1859/d185987428544ecaff0ad71eab6a98c93ac6f907" alt="a math problem on the problem page"
2
Choose and Watch Your Video Reward!
data:image/s3,"s3://crabby-images/016ac/016acefba56981131d7ab2156d6923f7c7091692" alt="the video selection page"
data:image/s3,"s3://crabby-images/1a0fb/1a0fba463af129ceb7d36cf5d6b1ff4321208f49" alt="a video playing on the rewards page"
3
Check Your Stats!
data:image/s3,"s3://crabby-images/a4fe3/a4fe361806eb39a1b33a30ca4c37f8225685eee4" alt="how much time Trevor has played the game and a table of the easiest and hardest questions for him"
data:image/s3,"s3://crabby-images/43d3a/43d3a909bba0ce91ed66765ab05c79e94ad197df" alt="charts and graphs of problems completed over time and the distribution of different types of problems"
BREAKDOWN
The Math Game is built on the LAMP stack with some JavaScript for client side features.
Features
Random Choice of Videos - reduce stimming to encourage exposure to a variety of videos while also maintaining choice. |
Sandboxing - reward videos auto-play with no controls and auto-return to the problem page when the video's done playing. |
Detailed Statistics - number of problems solved, usage over time, time spent on work vs. reward, and more! |
Database
User management is done with UserCake 2.0.2 (discontinued since 2017).
Notable game tables in the schema are:
problems - preset problems & answers |
settings(user_id) - operators' input ranges, # of problems to solve |
videos - youtube video id, meta info to display it |
game_state(user_id) - current problem, # of problems remaining |
rewards(user_id) - video watched, # of problems solved, timestamp |
results(user_id) - problem, how long it took, timestamp |
Setup
- Set up a MySQL database with the schema in setup/mathgame.sql.
- Pre-populate the database with a fixed set of problems (source):
<?php
populateProblems(
populateOperators(array(
'+' => 'addition',
'-' => 'subtraction',
'*' => 'multiplication',
'/' => 'division'
)),
0, // minimum input value
99 // maximum input value
);
?>