01 · Roasts
88% Jupyter, 12% Personality
Your language breakdown is 88% Jupyter Notebook. That's not a programming language — that's a cry for help formatted in JSON cells. Your Go, Haskell, and C++ are drowning under a sea of .ipynb checkpoints.
CI? Never Heard of Her
Zero CI pipelines across all three analyzed repos. You have a full compiler (cluck), a BLE-to-WebSocket firmware stack (olfactml), and a scraper with 38 stars (pypartpicker) — and not a single GitHub Actions workflow to show for it. Living dangerously.
127 Commits, Zero Weeks Straight
Your heatmap looks like a Jackson Pollock painted by someone who codes once a month and then panics. Weeks 6 through 17 are a complete ghost town. The burst at week 44 is impressive — for 4 days.
One PR a Year
totalPRsYear = 1. You built a TinyML nose, a Haskell compiler, and a Python scraper, but contributed to the outside world exactly once in 12 months. Open source is a two-way street, Luc.
olfactml: Most Ambitious, Least Tested
You built a scent-classifying Arduino+Go+React pipeline in a one-month sprint with 30 commits — genuinely cool. Then shipped it with no tests and no CI. The nose knows, but your test runner doesn't.
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% weight43D
- Consistency20% weight60C
- Quality20% weight57D
- Depth15% weight55D
- Breadth10% weight65C
- Community10% weight40D
03 · Stats
365-day commit heatmap
45 active days
Language distribution
- Jupyter Notebook88%
- Python3%
- C3%
- C++2%
- Go1%
- Haskell1%
- Other2%
04 · Numbers
Owned repos
non-fork
23
Commits
last 12 months
127
Followers
12
Joined GitHub
Sep 2023
05 · Top repos
lucwl /
pypartpicker
Active Python web scraper for PCPartPicker data with async support, type hints on classes, comprehensive README, and CI-less test suite. Well-structured for a niche utility.
lucwl /
cluck
A functional subset-C compiler in Haskell with LLVM backend. Demonstrates solid compiler implementation (parsing, semantic analysis, code generation) with structured multi-file architecture, but remains an experimental educational project with 5 stars and minimal adoption.
lucwl /
olfactml
TinyML scent classification system with Arduino firmware (C/C++), Go BLE gateway, and React frontend. Early-stage hobby project with structured multi-language architecture but minimal adoption (3 stars, single creator).
06 · Timeline
- Sep 11, 2023Joined GitHub
- Feb 3, 2021Created pypartpicker — A Python package for PCPartPicker data extraction
- Aug 24, 2024Created cluck — A mini C compiler made in Haskell with LLVM
- Feb 4, 2026Created olfactml — A TinyML scent classification model
- Mar 5, 2026Most recent push to olfactml
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.