01 · Roasts
Security Intern Horror Story
owl-watch ships with a plaintext MongoDB Atlas password hardcoded in .env and committed to the repo. One star, zero forks, infinite credential risk. At least no one's looking.
88% Jupyter Notebook
Your language breakdown is 88% Jupyter Notebook. GitHub thinks you're an ML engineer. Your repos suggest you're someone who opened a notebook for a class and never closed it.
Zero Public Commits This Year
totalCommitsYear = 0. The heatmap looks like a city after a blackout. Four lonely cells across 52 weeks. The grid is grieving.
The Most Active Repo Is Your Vim Config
nvim is your crown jewel — 15 recent commits, maintained since May 2024. Your most sustained engineering effort is remapping keys and commenting out plugins you'll never use.
AoC One-Month Wonder
aoc has ~35 commits and stops dead after Day 5. Either the puzzles got hard, or December 6th had other plans. Either way, it's been sitting there since 2024 as a monument to good intentions.
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% weight18F
- Consistency20% weight10F
- Quality20% weight25F
- Depth15% weight35F
- Breadth10% weight45D
- Community10% weight40D
03 · Stats
365-day commit heatmap
5 active days
Language distribution
- Jupyter Notebook88%
- JavaScript8%
- CSS1%
- Python1%
- C++1%
- Lua0%
- Other1%
04 · Numbers
Owned repos
non-fork
5
Commits
last 12 months
0
Followers
20
Joined GitHub
Jun 2019
05 · Top repos
nat-hill /
owl-watch
Early-stage student project with basic MongoDB/Express backend structure. Has README and tests, but untyped JavaScript, no CI/license, and exposed credentials in .env. Limited scope and polish for a 1-star, 19-commit RiceApps initiative.
nat-hill /
aoc
Personal Advent of Code 2024 solutions in Python and C++. Bare-bones README, no tests/CI. ~35 commits over one month with mixed quality solutions to AoC puzzle days 1–5.
nat-hill /
nvim
Personal Neovim configuration file with no README, scattered plugin setup, and minimal documentation. About 1.8 MB of Lua code managing lazy-loaded plugins and editor settings, but clearly a one-off dotfiles experiment.
06 · Timeline
- Jun 3, 2019Joined GitHub
- Jul 3, 2022Created owl-watch — riceapps project revolving around timing assignments
- May 24, 2024Created nvim — nat's neovim config
- Dec 1, 2024Created aoc — advent of code,..., 2024
- Jan 5, 2025Most recent push to aoc
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.