01 · Roasts
20 Commits, 17 PRs — Wrong Direction
You made 17 pull requests to other people's repos this year but only pushed 20 commits to your own. You're a better contributor to strangers than to yourself.
The 2-Hour Masterpiece
scraper's entire commit history spans roughly 2 hours on a single night in June 2024, and it's the only repo with a star. The bar for recognition is apparently 'ship something at 3 AM and typo the word frontend.'
Hardcoded Password Hall of Fame
scraper/backend/index.js has 'password' in plain text. Your 1 star was almost certainly earned before anyone read the source.
38 Repos, 3 Scored
You have 38 public repos but only 3 were substantive enough to score. That's an 8% signal-to-noise ratio. The other 35 are presumably a graveyard of half-finished ideas and CRA boilerplate.
Architecture Without Execution
telebot has ARCHITECTURE.md, design.md, STATUS.md, and Alembic migrations — but no tests, no CI, and 9 total commits. You documented a system you never finished building.
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% weight25F
- Consistency20% weight20F
- Quality20% weight38F
- Depth15% weight35F
- Breadth10% weight40D
- Community10% weight25F
03 · Stats
365-day commit heatmap
29 active days
Language distribution
- Python81%
- QML10%
- Cython3%
- C2%
- Makefile1%
- Jupyter Notebook1%
- Other2%
04 · Numbers
Owned repos
non-fork
28
Commits
last 12 months
20
Followers
6
Joined GitHub
Mar 2022
05 · Top repos
marcusjhang /
telebot
Early-stage personal health tracker: Telegram bot + FastAPI backend + Next.js frontend. Typed Python/TypeScript, structured layout, async DB, but unfinished (HAS_TESTS=no, HAS_CI=no, HAS_LICENSE=no), 9 commits in 6 days, ~198 KB codebase.
marcusjhang /
scraper
Early-stage full-stack scholarship scraper project (1 star, 10 commits over 2 days) with basic Node/Python/React integration but lacking tests, CI, type safety, and production-ready documentation.
marcusjhang /
advice-generator
Tutorial-grade React app fetching advice from external API via AdviceSlip. No tests, CI, license, or type safety (plain JS). Minimal project documentation—README is default Create React App boilerplate. 5 commits in last 30 days suggests occasional work.
06 · Timeline
- Mar 31, 2022Joined GitHub
- Jul 4, 2023Created advice-generator — Advice Generator
- Jun 18, 2024Created scraper — Google Sheets -> Python Scraper -> Postgres DB -> React Frontend
- Dec 4, 2025Created telebot
- Apr 12, 2026Most recent push to advice-generator
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.