01 · Roasts
90% Jupyter, 10% Excuses
Your language breakdown is 90% Jupyter Notebook. That's not a tech stack, that's a homework folder with a git remote attached.
48 Commits, 52 Weeks
You made 48 commits in a full year — that's less than one per week. Your heatmap looks like a QR code that lost a bet.
0 Tests Across All Repos
Three repos, zero test files. Not one. You're shipping React, a game engine, and an AI platform entirely on vibes and prayer.
87% Graveyard Rate
staleRepoRatio = 0.87 means 87% of your repos haven't been touched in 2+ years. You have more digital ghosts than a haunted house.
Valentine's App in 20 Minutes
Your most recent project was built in 20 minutes on Valentine's Day. Romantic? Sure. A portfolio highlight? Absolutely not.
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% weight28F
- Consistency20% weight55D
- Quality20% weight52D
- Depth15% weight50D
- Breadth10% weight55D
- Community10% weight40D
03 · Stats
365-day commit heatmap
40 active days
Language distribution
- Jupyter Notebook90%
- TypeScript4%
- Python2%
- JavaScript2%
- HTML1%
- CSS0%
- Other1%
04 · Numbers
Owned repos
non-fork
54
Commits
last 12 months
48
Followers
20
Joined GitHub
Sep 2021
05 · Top repos
PhilipusAdrielTandra /
kartinilove.ai
TypeScript React + Strapi CMS frontend for KartiniLove.ai women's empowerment platform. Typed, documented, with multi-page structure and AI chat integration; shipping complex CORS/URL-resolution logic (Blog.tsx ~400 lines, BlogPost.tsx ~350 lines) but incomplete backend integration, no tests, and no CI.
PhilipusAdrielTandra /
Final_project_Ray-Casting_Algorithm_and_programming
Educational ray-casting game demonstrating 3D projection algorithm in Python. Functional pygame implementation with structured modules, no tests or CI, untyped code.
PhilipusAdrielTandra /
valentines
Minimal one-off Valentine's Day React app with interactive "No" button, confetti animation, and Tailwind styling. Zero stars, created 2026-02-14, 5 commits in ~20 minutes with no tests or CI.
06 · Timeline
- Sep 29, 2021Joined GitHub
- Jan 10, 2022Created Final_project_Ray-Casting_Algorithm_and_programming
- Jul 8, 2025Created kartinilove.ai
- Feb 14, 2026Created valentines
- Feb 14, 2026Most recent push to valentines
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.