01 · Roasts
12-Minute Degree
Your NUS-CS2109S-MiniProject accumulated all 3 of its commits across a 12-minute window. That's not a project — that's a panic upload. The A* class is still mid-method.
The Graveyard Semester
Your heatmap shows 10 solid weeks of activity then a complete ghost town for roughly 6 months straight. GitHub literally forgot you existed mid-year.
86% Notebook, 0% Production
86% of your codebase is Jupyter Notebooks. That's a great way to learn ML. It's a terrible portfolio. main_agent.py ends mid-function — did the semester end or did your motivation?
65 PRs, 0 Fans
You opened 65 pull requests this year and have exactly 0 followers. Either those PRs were all to your own repos or your code review game needs serious work.
One Repo, One Star (Your Own?)
4 public repos, 1 total star, 0 forks. LockInBuddy has ARCHITECTURE.md and design.md — all that documentation for an audience of none.
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% weight40D
- Consistency20% weight35F
- Quality20% weight62C
- Depth15% weight55D
- Breadth10% weight40D
- Community10% weight25F
03 · Stats
365-day commit heatmap
79 active days
Language distribution
- Jupyter Notebook86%
- Python11%
- JavaScript3%
- CSS0%
- HTML0%
04 · Numbers
Owned repos
non-fork
2
Commits
last 12 months
163
Followers
0
Joined GitHub
Jan 2025
05 · Top repos
jxgohh /
-LockedIn
LockInBuddy is a gamified study assistant web app with multi-feature scope (timer, tasks, leaderboard, dashboard). Ships with tests, docs (design.md, ARCHITECTURE.md), and React+Node stack; unpolished execution with no CI, no license, no TypeScript in frontend.
jxgohh /
NUS-CS2109S-MiniProject
University coursework mini-project for ML course with incomplete AI agent implementation, lacking tests, CI, and production-ready structure. Jupyter notebook + scattered Python files without organized architecture.
06 · Timeline
- Jan 14, 2025Joined GitHub
- May 14, 2025Created -LockedIn
- Feb 1, 2026Created NUS-CS2109S-MiniProject — Introduction to Machine Learning mini project
- Feb 1, 2026Most recent push to NUS-CS2109S-MiniProject
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.