01 · Roasts
Commit Hermit
113 commits in a year with a heatmap that's mostly empty for the first 8 weeks and goes dark again around weeks 30–32. You commit in seasonal bursts like a squirrel hoarding acorns before winter.
Test Averse
Zero tests across all three analyzed repos — not one, not a stub, not even a vitest.config.ts gathering dust. You've got CI in ukoly but nothing to run in it. Bold strategy.
One-Hit Wonder
Your entire impact story rests on ukoly's 13 stars. The other 13 public repos collectively couldn't outrun a private gist. Impressive concentration of effort, concerning concentration of risk.
License Dodger
ukoly has no license, BIO-2023-Round-1 has no license. You're shipping open code that legally can't be reused. The British Informatics Olympiad community thanks you for the legal grey zone.
Graveyard Curator
staleRepoRatio = 0.57 — over half your repos haven't been touched in 2+ years. Your GitHub is equal parts active workshop and digital cemetery.
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% weight43D
- Consistency20% weight35F
- Quality20% weight57D
- Depth15% weight50D
- Breadth10% weight65C
- Community10% weight40D
03 · Stats
365-day commit heatmap
151 active days
Language distribution
- TypeScript49%
- JavaScript27%
- C++8%
- Python7%
- Java6%
- CSS2%
- Other1%
04 · Numbers
Owned repos
non-fork
14
Commits
last 12 months
113
Followers
33
Joined GitHub
Apr 2021
05 · Top repos
myst-6 /
ukoly
Educational platform for British Informatics Olympiad offering editorials, code examples, and WebSocket-based auto-grader. TypeScript monorepo with Cloudflare Workers backend, Next.js frontend, and 30+ problems with test data.
myst-6 /
portfolio
Personal portfolio website built with React+TypeScript+Vite; typed, documented, structured, but limited scope—early-stage personal project without tests, CI, or published audience reach.
myst-6 /
BIO-2023-Round-1
BIO 2023 Round 1 competition solutions in C++. Solves 4 olympiad problems with working implementations but minimal documentation, no tests, no CI, and sparse project structure.
06 · Timeline
- Apr 4, 2021Joined GitHub
- May 9, 2023Created BIO-2023-Round-1
- Aug 22, 2024Created ukoly
- Dec 28, 2025Created portfolio
- Feb 20, 2026Most recent push to portfolio
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.