01 · Roasts
The Python Monastery
93% Python. Your language diversity is so thin that GDScript at 3% is basically your second language — and that's a Godot scripting language most people have never heard of. Branch out.
Test? Never Heard Of Her
Zero tests across all three repos. You've got a spaced-repetition quiz engine, multiple Wordle solver algorithms, and a breathing timer — all completely untested. You're shipping vibes, not software.
The README Minimalist
'7 lines' for wordle-solver's README. 'Boilerplate' for box-breathing. 'Minimal' for 3bld-letter-pairs. You document your projects like you're being charged per word.
Personal Use Only
3 total stars, 3 total forks, soloPct=100% — your repos are so self-contained that even you might be the only fork. The 14 PRs/year suggest you CAN engage externally; you just choose not to on your own projects.
Bursty But Brilliant
Your heatmap looks like a student's exam schedule: intense bursts in certain weeks, then complete silence for 2–3 weeks straight. Weeks 7–13 were carrying the entire year's momentum.
Built using
Zoral
Shadows one worker for a week, then takes over their job with zero extra setup. Behaves exactly like the original.
zoral.ai
02 · Category breakdown
- Impact25% weight30F
- Consistency20% weight55D
- Quality20% weight48D
- Depth15% weight50D
- Breadth10% weight40D
- Community10% weight40D
03 · Stats
365-day commit heatmap
153 active days
Language distribution
- Python93%
- GDScript3%
- TypeScript3%
- Java1%
- JavaScript0%
- CSS0%
04 · Numbers
Owned repos
non-fork
29
Commits
last 12 months
131
Followers
10
Joined GitHub
Nov 2020
05 · Top repos
christianharris-3 /
box-breathing
Personal breathing exercise tool (box & Wim Hof) built with Next.js. TypeScript + Tailwind UI, functional animations, but minimal distribution or adoption signal. Boilerplate README and no tests/CI pipeline.
christianharris-3 /
3bld-letter-pairs
Personal learning tool for 3x3 Rubik's cube memorization pairs, built as a Streamlit app with Docker CI/CD. Demonstrates solid Python structure and deployment setup, but lacks tests and has no type hints.
christianharris-3 /
wordle-solver
Personal Wordle solver in Python with pygame UI, multiple solver algorithms, and state management. Fresh project with functional game mechanics but thin documentation, no tests/CI, and flat file structure.
06 · Timeline
- Nov 11, 2020Joined GitHub
- Jan 31, 2026Created wordle-solver — basic wordle solver in pygame
- Feb 26, 2026Created 3bld-letter-pairs — A basic tool to help learn letters pairs when solving a 3x3 blind
- Mar 26, 2026Created box-breathing
- Apr 17, 2026Most recent push to box-breathing
07 · Compare
08 · Rubric
How this score was produced
Overall = Σ (category × weight) + gentle top-end curve
Tier thresholds
▸ How the pipeline works
- 01Scrape.Pull every non-fork repo pushed in the last 90 days, plus your contribution calendar, followers, and language byte counts — straight from GitHub's REST & GraphQL APIs.
- 02Triage.A small model reads every repo's file tree + README and picks the 20 files per repo that actually reveal how you code.
- 03Grade each repo. All repos run in parallel through a fast scoring model that reads the picked files and rates each one independently on Impact, Quality, and Depth — with evidence citations.
- 04Aggregate. A larger reasoning model combines the per-repo scores with server-computed stats (heatmap, commit cadence, language entropy, follower count) to produce the 6-dimension profile score + roasts.
- 05Correct.Deterministic server-side checks enforce anchor-scale floors (e.g. a profile with 2,000+ public commits can't score 30 Consistency) and recompute the final verdict.
~90 seconds per profile, ~$0.25 in compute. Total of ~240 files read across your top-12 repos. One rating per GitHub account per day.
▸ Data sources & caveats
- Heatmap & commit totals: GitHub GraphQL
contributionsCollection— covers the last 365 days, includes private repos when the user has opted in (default). - Language %: byte totals across the top 30 owned non-fork repos.
- Curve: a small upward nudge centered on raw score ≈ 70, capping at 100. Prevents specialists from being unfairly penalised for narrow breadth.
- Anchor corrections: when server-measured signals (e.g. privateWorkLikely, multiRepoVolume, follower count) mandate a minimum category score, the aggregation step enforces it. These are signal-conditional, not identity-based floors.