Dillon Rose
The Effective Engineer
by Edmond Lau
Part 1 : Mindset
Chapter 1: Focus on High-Leverage Activities
Effectiveness = Value per time unit of work
Leverage = Impact produce / time invested
80-20 rule : 80% of impact comes from 20% of work
Increase Leverage in 3 Ways
- Reducing time to complete an activity
- Complete the activity with less time
- Increase output of an activity
Learnings
- Reducing time for others is high leverage
- Focus on improving others' leverage
Chapter 2: Optimise for learning
Optimizing for learning is one of the highest leverage things you can do
Failures are growth opportunities
What to look for/promote
- Fast growth
- Training
- Openness
- Pace
- People
- Autonomy
- Exposure to adjacent disciplines
How to force grow
- Study Code
- Write code
- Go through technical documentation
- Master the programming language
- Send code reviews to harshest critics
- Enroll in classes
- Participate in design discussion - ask to be invited
- Work on a diversity of projects
- Make sure your team has some people for you to learn from
- 20% time to develop new skills
- Be fearless
Chapter 3: Prioritise regularly
Prioritizing is a high leverage task because it determines the leverage of your other tasks
Track to-dos in a singular accessible list
To-do list should be
- Canonical list of work
- Accessible
- Prioritized
- Visited
Focus on what directly produces value and the important non-urgent Examples of important non-urgent
- Planning
- Building relationships
- Personal development
Limit the amount of in progress work
Limit context switching
Say NO to work
Increasing work linearly increases the failure rate exponentially
If-Then Plans = Identify ahead of time a situation where you plan to do the task
Part 2 : Strategies for progress
Chapter 4: Invest in iteration speed
Increasing iteration speed has cascading effects. Completely changes workflow. Less time planning. Less time creating studies. Just ship it.
Building tools. Faster build times. Less time reading code. Now you can just try to build. Repo builds need to be fast.
New tools may speed up others but there is a switching cost. Invest in reducing the switching cost. Julia’s refactor.
Proving your tool saves time buys you leeway in the future to do bigger changes. You need to build trust. Long term impact is hard to quantify but. Short term cost is known.
Chapter 5: Measure what you want to improve
What to measure and what not to measure
Measuring influences employee behavior. Optimizing for speed and cut quality
Measurement should be actionable and responsive
Actionable metrics movements can be casually explained
Vanity metrics are just numbers
Be skeptical of metrics. Try to validate your metrics by arriving at them from a different angle. Back of an envelope
When a number looks off, dig into it early
Chapter 6: Validate your ideas early and often
Ship something small early and get feedback.
Iterate a little. Validate. Course correct. Loop.
A/B tests help you understand what is better and ideally you can quantify how much better. Which helps you decide whether to keep trying to improve. Only 1% better. Probably not. Way betterlet’s do more.
Beware of 1 person teams. You can get bused. No shared knowledge. No oversight project lows are more demoralizing alone. No shares pain. No way to get help
Decisions need feedback loops
Chapter 7: Improve your project estimation skills
Large project slips are most often due to many minor unforeseen issues than 1 major issue
Creating specific goals, you can easily decide what work is not in scope. Creates alignment between stakeholders. Hold people accountable for local traders that impact global goals
Concrete milestones with target dates create accountability
Mitigate risk early by tackling risky problems early
Code complexity grows with interactions between lines of code more than lines of code. Sub systems interacting in complex ways create clean touch points/ contracts between components
Approach rewrite projects with extreme caution
Use a series of incremental behavior preserving transformations
Don’t sprint. An effective engineer is planned ahead
Part 3 : Long term value
Chapter 8: Balance Quality with Pragmatism
Good abstraction should be
- Easy to learn
- Easy to use even without docs
- Hard to misuse
- Satisfy the requirements
- Easy to extend
- Appropriate to the audience
Determining how to balance how much tests to write vs agility is a high leverage task
Tech debt needs to be repaid
Chapter 9: Minimize operational burden
Find simple solutions
Fail fast
Easier to debug
Failing slow removes the error context. Muddies the source of the error
Report errors to engineers while being graceful forusers
Automate team processes
Being able to rerun your scripts more often reduces false alarms and allows more nuanced issues to be raised
Recover quickly
We will break. Learn to mitigate major drawn out failures
Create plans. TSGs before things are broken
Chapter 10: Invest in Teams growth
Interviewing
- Ask questions which have High signal to noise ratio
- Iterate on hiring process
- Reflect on current hiring process
- Rapid fire easy questions to cover a wide surface area to filter out
Create a good onboarding process
Have good docs
Onboarding should
- Ramp up new engineers
- Impart team culture and values
- Expose new engineers to fundamentals/tools needed to succeed -Socially integrate the new employee
Peer programming and code labs are great tools
Assigning a mentor to new employees that help ramp and assign initial starter tasks
Reflect on what docs I would want available for my team if I were the manager
Share ownership of code
Being a sole owner of code doesn’t increase your value. It makes you a liability
Becoming the bottleneck of a project reduces your flexibility to pursue other tasks. In order to scale, you need to be able to release ownership successfully
Hold post mortems
Don’t blame
Increase shared knowledge
Document learnings
Keep docs simple and accessible
Create a good engineering culture
- Optimize for iteration speed
- Push relentlessly for automation
- Build the right abstractions
- High code quality
- Good code review process
- Respectful work environment
- Shared ownership of code
- Automated testing
- Allot time for experimentation
- Foster a culture of learning and improvement
- Hire the best
Create systems early in your career to create a foundation for your career