01 · Roasts
Archaeologist Required
70% of your 51 repos were last touched over 2 years ago. You're not maintaining a portfolio — you're curating a graveyard. At least put up a tombstone.
Speed-run Developer
chinar was created AND last pushed on 2026-04-10 within a 10-minute window. That's either the fastest physics engine ever built or a very impressive git push --force.
Test? Never Heard of Her
Across every sampled repo — Rust, C++, config — HAS_TESTS=no, HAS_CI=no, every single time. 51 repos and not a single test suite in sight. Brave.
Solo Forever
soloPct=100. Every single commit, completely alone. With 38 followers and 2 people you follow, you've built your own island — and refuse to let anyone dock.
Unsafe and Unashamed
Box::leak + unsafe ptr::read in chinar/src/main.rs:33 on a brand-new project. Most people at least pretend to care about memory safety in Rust for the first week.
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% weight33F
- Consistency20% weight55D
- Quality20% weight46D
- Depth15% weight50D
- Breadth10% weight80A
- Community10% weight40D
03 · Stats
365-day commit heatmap
32 active days
Language distribution
- C35%
- C++32%
- Rust14%
- Java8%
- Python6%
- HTML2%
- Other3%
04 · Numbers
Owned repos
non-fork
46
Commits
last 12 months
54
Followers
38
Joined GitHub
Mar 2020
05 · Top repos
vikram-kangotra /
DentalLiveStream
Proof-of-concept C++17 Qt6 desktop app for dental AI caries detection via OpenVINO, with video streaming/recording and speech recognition. Typed, modular architecture with build scripts and docs, but no tests, CI, or license; early-stage project with 11 weeks of commits.
vikram-kangotra /
vikram-kangotra
Personal GitHub profile config repo with polished README. No source code, no tests, no CI. Profile documentation with 1 star, last push Feb 2026.
vikram-kangotra /
chinar
Experimental Rust physics engine with soft-body simulation, wgpu rendering, and spatial collision grid. Minimal documentation, no tests/CI, ~48 KB codebase created and pushed within 10 minutes.
06 · Timeline
- Mar 4, 2020Joined GitHub
- Mar 31, 2021Created vikram-kangotra — Config files for my GitHub profile.
- Mar 13, 2025Created DentalLiveStream
- Apr 10, 2026Created chinar — chinar engine with soft body simulation
- Apr 10, 2026Most recent push to chinar
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.