01 · Roasts
One Repo, One Day, One Score
Your entire scored portfolio consists of a single repo created and last pushed on the same calendar day (2026-03-01). Three sampled commits. That's not a portfolio — that's a deadline.
44 PRs, 0 Followers
You filed 44 pull requests this year yet have zero followers and zero stars. Either you're submitting course assignments via PRs or you're the most anonymous open-source contributor alive.
The Graveyard is Suspiciously Empty
staleRepoRatio = 0 sounds impressive until you realize it's because there's barely anything here to go stale. Eight public repos and the only one analyzed was born yesterday.
Python + Notebooks: The Most Predictable Stack
65% Python, 35% Jupyter Notebook — not two languages, one language and its diary. Zero web, zero systems, zero CLI. The entire breadth of your GitHub is 'ML homework'.
Step() Method Goes Brrr... Then Stops
task1_agent.py's step() method is literally truncated mid-implementation. If your AI agent can't finish its own code, maybe it needs more training data.
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% weight15F
- Consistency20% weight35F
- Quality20% weight40D
- Depth15% weight30F
- Breadth10% weight25F
- Community10% weight25F
03 · Stats
365-day commit heatmap
79 active days
Language distribution
- Python65%
- Jupyter Notebook35%
04 · Numbers
Owned repos
non-fork
1
Commits
last 12 months
90
Followers
0
Joined GitHub
Jun 2019
05 · Top repos
06 · Timeline
- Jun 22, 2019Joined GitHub
- Mar 1, 2026Created cs2109s-mini-project
- Mar 1, 2026Most recent push to cs2109s-mini-project
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.