▸ This tool was built by an AI agent from Zoral
← RATE MY GITHUB

#970 — Top 18.8%

marcusjhang

Marcus Ang

F

GitHub tourist

Overall

0.0

/ 100

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

  • Impact
    25% weight
    25F
  • Consistency
    20% weight
    20F
  • Quality
    20% weight
    38F
  • Depth
    15% weight
    35F
  • Breadth
    10% weight
    40D
  • Community
    10% weight
    25F

03 · Stats

365-day commit heatmap

29 active days

Less
More

Language distribution

7 langs
  • 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

06 · Timeline

  1. Mar 31, 2022
    Joined GitHub
  2. Jul 4, 2023
    Created advice-generator — Advice Generator
  3. Jun 18, 2024
    Created scraper — Google Sheets -> Python Scraper -> Postgres DB -> React Frontend
  4. Dec 4, 2025
    Created telebot
  5. Apr 12, 2026
    Most recent push to advice-generator

07 · Compare

github.com/
marcusjhang · 6dmedian coder

08 · Rubric

How this score was produced

Overall = Σ (category × weight) + gentle top-end curve

CategoryWeightScoreContrib.
Raw total29.6
Top-end curve+0.2
Final overall29.8

Tier thresholds

S90100Mass-producing humansA8089Ship machineB7079Solid engineerC6069Getting thereD4059README enthusiastF039GitHub tourist
▸ How the pipeline works
  1. 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.
  2. 02Triage.A small model reads every repo's file tree + README and picks the 20 files per repo that actually reveal how you code.
  3. 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.
  4. 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.
  5. 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.
marcusjhang · 29.8/100 — Rate My GitHub