Everything is a prioritisation problem
When it comes to building a product, everything is a prioritisation problem.
We might be building things right, but are we building the right thing?
The journey of prioritisation begins way before the actual process of prioritisation starts.
I would start by asking these key questions to the product leadership team—What does the future state look like? — Vision. What are we trying to achieve? — Mission. What’s our plan to win? —Strategy. How are we measuring progress towards the strategy? — Goals. What are we building to realise the vision? - Roadmap. Once these fundamentals are covered, I would work my way up from there.

I also keep a check on how grounded these are on customer insights. Are we basing our strategy on a one-time discovery activity, or do we have continuous cycles of user research? This ensures that the prioritisation is well calibrated to the latest snapshot of user needs in a dynamic environment.
With this foundation in place, I would proceed to chalk out the current user journey and the expected user journey with the team. While doing so, I consider three key aspects: What do users feel? What do users think/say? What do users do?

I then map out the opportunity solution tree tied to the key goals and business outcomes. For instance, during our discovery, we might uncover that users:
- Struggle to understand the product’s value during onboarding
- Feel frustrated with the time it takes to complete a key action
- Believe that their feedback goes unheard

These insights then become a springboard for feature ideation, prioritisation and subsequent next steps. Before any feature makes it to the development pipeline, we ensure that it aligns to the business outcomes and addresses identified user needs.
While doing so, I ask these key critical questions: Does this feature drive us towards a specific goal? What assumptions are we testing with this feature? Are we building this feature to test assumptions, or testing assumptions to inform the build? These questions act as pickaxes preventing the team from falling into the trap of becoming a ‘feature factory’.

Only after we clear this checkpoint, I proceed to the prioritisation phase. I personally approach this with four levels of increasing fidelity.
Level One — User Impact
Features that affect existing users take precedence over those impacting potential users. If there are business critical flows that affect existing users, they’re prioritised over everything else (eg. payment flows)

Level Two —Impact vs. Effort
I quickly eliminate features that are low impact and high effort.

Level Three — RICE Scoring
I then proceed to evaluate features based on four criteria: Reach- How many users will this impact? Impact- How significantly will it affect those users? Confidence- How certain are we of the estimates? Effort- How much work will this require?

Level Four — A more detailed RICE
Especially for the high impact, low effort features, prioritising the most important work to do this week might be a bit more tricky to gauge with just a RICE score.

For this purpose, I do a more detailed RICE estimating the org costs, development time, and other relevant metrics, helping me prioritise what needs to be built.
While continuing to allocate development effort, I also conceptually categorise the effort into three different buckets: Feature flags, bugs and Experiments. In this way, I try my best to establish a balance between building and learning.

This classification is encouraged in startup environments where the building and learning loops are faster

Subscribe to get future posts via email (or grab the RSS feed). 2-3 ideas every month across design and tech
Read more
- Breadboarding, shaping, slicing, and steelthreading solutions with AI agentsproduct-management
- How I started building softwares with AI agents being non technicalagentic-engineering
- Legible and illegible tasks in organisationsproduct
- L2 Fat marker sketchesdesign
- Writing as moats for humanswriting
- Beauty of second degree probesdecision-making
- Read raw transcriptsknowledge
- Boundary objects as the new prototypesprototyping
- One way door decisionsproduct
- Finished softwares should existproduct
- Essay Quality Rankerobsidian
- Export LLM conversations as snippetsbrowser-extension
- Flipping questions on its headinterviewing
- Vibe writing maximswriting
- How I blog with Obsidian, Cloudflare, AstroJS, Githubwriting
- How I build greenfield apps with AI-assisted codingai-coding
- We have been scammed by the Gaussian distribution clubmathematics
- Classify incentive problems into stag hunts, and prisoners dilemmasgame-theory
- I was wrong about optimal stoppingmathematics
- Thinking like a ship
- Hyperpersonalised N=1 learningeducation
- New mediums for humans to complement superintelligenceai-coding
- Maxims for AI assisted codingai-coding
- Personal Website Starter Kitai-coding
- Virtual bookshelvesaesthetics
- It's computational and AI everythingai-coding
- Public gardens, secret routesdigital-garden
- Git way of learning to codeai-coding
- Kaomoji generatorsoftware
- Copy, Paste and Citecuriosities
- Style Transfer in AI writingai-coding
- Understanding codebases without using codeai-coding
- Vibe coding with Cursorai-coding
- Virtuoso Guide for Personal Memory Systemsmemory
- Writing in Future Pastwriting
- Publish Originally, Syndicate Elsewhereblogging
- Poetic License of Designdesign
- Idea in the shower, testing before breakfastsoftware
- Technology and regulation have a dance of ice and firetechnology
- How I ship "stuff"software
- Weekly TODO List on CLIcli
- Writing is thinkingwriting
- Song of Shapes, Words and Pathscreativity
- How do we absorb ideas better?knowledge
- Read writers who operatewriting
- Brew your ideas lazilyideas
- Vibescreativity
- Trees, Branches, Twigs and Leaves — Mental Models for Writingwriting
- Compound Interest of Private Notesknowledge
- Conceptual Compression for LLMsai-coding
- Meta-analysis for contradictory research findingsdigital-health
- Beauty of Zettelswriting
- Proof of workproduct
- Gauging previous work of new joinees to the teamleadership
- Task management for product managersproduct
- Stitching React and Rails togetherai-coding
- Exploring "smart connections" for note takingknowledge
- Deploying Home Cooked Apps with Railssoftware
- Self Marketing
- Repetitive Copypromptingwriting
- Questions to ask every decadejournalling
- Balancing work, time and focusproductivity
- Hyperlinks are like cashew nutswriting
- Brand treatments, Design Systems, Vibesdesign
- How to spot human writing on the internet?writing
- Can a thought be an algorithm?product
- Opportunity Harvestingcareers
- How does AI affect UI?design
- Everything is a prioritisation problemproduct-management
- Nowlifestyle
- How I do product roastsproduct
- The Modern Startup Stacksoftware
- In-person vision transmissionproduct
- How might we help children invent for social good?social-design
- The meeting before the meetingmeetings
- Design that's so bad it's actually gooddesign
- Breaking the fourth wall of an interviewinterviewing
- Obsessing over personal websitessoftware
- Convert v0.dev React to Rails ViewComponentsrails
- English is the hot new programming languagesoftware
- Better way to think about conflictsconflict-management
- The role of taste in building productsdesign
- World's most ancient public health problemsoftware
- Dear enterprises, we're tired of your subscriptionssoftware
- Products need not be user centereddesign
- Pluginisation of Modern Softwaredesign
- Let's make every work 'strategic'consulting
- Making Nielsen's heuristics more digestibledesign
- Startups are a fertile ground for risk takingentrepreneurship
- Insights are not just a salad of factsdesign
- Minimum Lovable Productproduct
- Methods are lifejackets not straight jacketsmethodology
- How to arrive at on-brand colours?design
- Minto principle for writing memoswriting
- Importance of Whytask-management
- Quality Ideas Trump Executionsoftware
- How to hire a personal doctor
- Why I prefer indie softwareslifestyle
- Use code only if no code failscode
- Personal Observation Techniquesdesign
- Design is a confusing worddesign
- A Primer to Service Design Blueprintsdesign
- Rapid Journey Prototypingdesign
- Directory Structure Visualizercli
- AI git commitscli
- Do's and Don'ts of User Researchdesign
- Design Manifestodesign
- Complex project management for productproducts
- How might we enable patients and caregivers to overcome preventable health conditions?digital-health
- Pedagogy of the Uncharted — What for, and Where to?education
- Future of Ageing with Mehdi Yacoubiinterviewing
- Future of Equity with Ludovick Petersinterviewing
- Future of Mental Health with Kavya Raointerviewing
- Future of Tacit knowledge with Celeste Volpiinterviewing
- Future of Rural Innovation with Thabiso Blak Mashabainterviewing
- Future of unschooling with Che Vanniinterviewing
- Future of work with Laetitia Vitaudinterviewing
- How might we prevent acquired infections in hospitals?digital-health
- The soul searching yearsentrepreneurship
- Design education amidst social tribulationsdesign
- How might we assist deafblind runners to navigate?social-design