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

#80 — Top 93.4%

berthubert

bert hubert

C

Getting there

Overall

0.0

/ 100

01 · Roasts

The 59% Graveyard Curator

With a staleRepoRatio of 0.59, over half your repos haven't been touched in 2+ years. You're not maintaining a portfolio — you're maintaining a cemetery. At least the headstones have READMEs.

164 Commits, 538 Fans

538 followers for 164 commits this year works out to roughly 3.3 fans per commit. You're living off googerteller's 2.2k-star glory days while coasting on one bursty afternoon a month.

Tests Are Optional (Apparently)

Three scored repos, zero test suites. HAS_TESTS=no across the entire board. You have CI in two of them — so the pipeline runs, it just runs nothing. Bold strategy.

Solo Artist, Hard Mode

80% solo commits and only 5 outgoing PRs all year. You've built tools used by the Dutch parliament, yet somehow the open-source community exchange is more of a monologue.

Following 3 People

You follow exactly 3 people on GitHub. Not 30, not 300 — 3. At this point your social graph is less a network and more a very exclusive club that probably hasn't met.

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
    73B
  • Consistency
    20% weight
    60C
  • Quality
    20% weight
    64C
  • Depth
    15% weight
    65C
  • Breadth
    10% weight
    55D
  • Community
    10% weight
    55D

03 · Stats

365-day commit heatmap

68 active days

Less
More

Language distribution

7 langs
  • C++70%
  • Jupyter Notebook13%
  • C10%
  • JavaScript4%
  • HTML1%
  • TeX1%
  • Other1%

04 · Numbers

Owned repos

non-fork

32

Commits

last 12 months

164

Followers

538

Joined GitHub

Jul 2020

05 · Top repos

06 · Timeline

  1. Jul 9, 2020
    Joined GitHub
  2. Jun 17, 2021
    Created audience-minutes — generate statistics on the number of audience minutes your site is generating, and if readers make it to the end of your screeds
  3. Aug 21, 2022
    Created googerteller — audible feedback on just how much your browsing feeds into google
  4. Aug 23, 2024
    Created tkconv — convert dutch lower house of parliament data
  5. May 24, 2026
    Most recent push to tkconv

07 · Compare

github.com/
berthubert · 6dmedian coder

08 · Rubric

How this score was produced

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

CategoryWeightScoreContrib.
Raw total63.8
Top-end curve+5.5
Final overall69.3

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.
berthubert · 69.3/100 — Rate My GitHub