01 · Roasts
The Graveyard Gardener
71% of your repos haven't been touched in over 2 years. ApolloRaytracer wrapped up in October 2021 and hasn't heard from you since — even the raytracer is still waiting for you to come back.
Zero PRs, Zero Issues
12 followers, 5 following, 0 external PRs this year, 0 issues filed. You're shipping in a sealed room. GitHub is a social network — someone else's code exists and they'd probably appreciate a PR.
CI? Never Heard of Her
Not a single CI pipeline across all three analyzed repos. You've got a Makefile with -O3 optimization flags in ApolloRaytracer but apparently couldn't add a GitHub Actions workflow file.
65 Commits and Counting (Slowly)
The heatmap has more empty green squares than a dead lawn in August. Weeks 18–25 are completely blank. 65 commits in a year from a CS Oxford student — the university presumably demands more keystrokes than that.
Raw Pointer Connoisseur
ApolloRaytracer is C++17 with -O3 optimization, yet still has 'delete scene' and 'delete output' in main. You know what std::unique_ptr is — the evidence is literally in your build flags.
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% weight31F
- Consistency20% weight55D
- Quality20% weight50D
- Depth15% weight50D
- Breadth10% weight65C
- Community10% weight40D
03 · Stats
365-day commit heatmap
61 active days
Language distribution
- C++74%
- Rocq Prover15%
- C9%
- Rust2%
- OCaml1%
- Fortran0%
04 · Numbers
Owned repos
non-fork
14
Commits
last 12 months
65
Followers
12
Joined GitHub
Jul 2013
05 · Top repos
ndm767 /
ApolloRaytracer
A personal hobby raytracer with Blinn-Phong shading, octree acceleration, and JSON scene loading. Well-structured C++ codebase demonstrating solid graphics fundamentals and clean architecture, but limited scope and audience.
ndm767 /
glGraph
2D graphing calculator built in C++17 with OpenGL rendering. Functional parser and equation evaluator with basic trigonometric and arithmetic operations, but minimal documentation, no tests/CI, and abandoned after initial development burst.
ndm767 /
ctl-rs
Rust CTL model checker weekend project with parser, model-checking algorithm, and test cases. Typed, documented, and structured but brand-new (6 days old), minimal audience, no CI/license.
06 · Timeline
- Jul 17, 2013Joined GitHub
- Jun 2, 2021Created glGraph — A 2d Graphing Calculator written in C++ using Modern OpenGL
- Jul 8, 2021Created ApolloRaytracer — A hobby Blinn-Phong shaded ray-tracer written in C++
- Mar 7, 2026Created ctl-rs
- Mar 7, 2026Most recent push to ctl-rs
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.