Taking technical decisions for your side projects

Taking decisions for technical projects

How to take technical decisions for your side projects?

Some people allocate a sizable amount of time to this. My approach is much more simple.

Taking decisions for technical projects

First, categorise this decision. Is it a one-way door decision or a two-way door decision? Most of the time it is the latter. Being that the case, I dedicate 30-45 minutes to research what are my options. What analysis of the options already exist out there, medium, .dev, Reddit… If I think it might be relevant, ask in one of my core chat groups for an opinion. Most of the time it falls on one of two buckets, a) no opinion / educated guesses or b) extremely polarised opinions (pro or against particular options). People might reveal big hurdles or advantages for a particular choice.

By then I should be able to narrow it down to 2-3 options. Then I prioritise based on a series of factors that can be interpreted as gut feelings, but they are not. Does it look great and polished? Indicator of care and commitment behind it. Abundant documentation? lots of posts about it? great examples? good indicators of an existing community, up-to-date docs, easiness to find help when finding any blocker down the road,…

The next step is to pick the most appealing one and build a (VERY) rough version of whatever I need. Sometimes that means writing a basic script to test being able to solve a sample of the problem or a limited aspect of it. Sometimes means quickly integrating it with an existing project in a branch and seeing how it goes. The goal is to get a rough idea of how difficult will be to actually implement it at a production level, a proof of concept. As a rule of thumb, if I am not able to get a positive outcome in a short time, I discard it. The time can go from two hours to a morning, but no more than that.

The moment I hit a visible wall, I park that one and move to the next possible option. If I find a solution that is “good enough”, I just go for it, without exploring the next ones. My goal is to identify as fast as possible a viable solution for a particular problem I am looking to solve, minimising potential friction down the road. My process for not easily reversible decisions looks different (MECE, etc, but the reality is that those are indeed pretty scarce.

Avoid analysis paralysis with an approach that works for you.

To summarise this little piece of advice:

1. Simplify it and identify what type of decision you are taking

2. time-box your process

3. have a clear understanding of what success looks like before starting your analysis

How do you make your choices out there?

A better approach to launching products

A better approach to launching

Lately I have been considering if there is a better approach to launching products. My time is limited because of my freelance consulting, other projects, etc. I have committed to launch new experiments during the next months though. I have many ideas I want to test. Problems I want to address. Potential solutions that could help people tackle those problems. Being my time & energy limited, optimising what and how launch those is paramount. But more importantly, launching means moving things forward. Not so easy.

A kindly reminder on the importance of launching was this article, Why Developers Are Building So Many Side Projects. From Future, the a16z newsletter. I had another one yesterday, with my friend launching Magic Board AutoPaste Keyboard. He has a toddler. Has organized two weddings in different countries in the last month and went on his honeymoon… and still delivering like that!

Launching a product is always scary. There are ways to understand why it is scary and why it should be a priority. Rationalise the need of fast shipping. Minimise risks and take advantage of ways of launching faster. I have never regretted launching too soon, but I have had the feeling of launching too late.

The blockers to launch fast would be, in this particular order:

  1. Insecurity, fears
  2. Viability
  3. Launch execution

Fears

The problem with launching is 90% of the times, self confidence. I have a very few examples of product launches where the quality of the product was the issue. On the other hand, I have tons of examples were a fast launch would have solved myriads of problems and wasted resources.

My way to approach it now is a) think in terms of potential outcomes and b) minimise risks.

Mapping potential outcomes. What are they potential outcomes of a launch? Lack of interest is number one. The one thing you really want to know as soon as possible. Face that is the case and deal with that possible outcome mentally. Finding out soon is not a bad outcome, finding out down the road is. Customers dealing with a buggy solution? if they have interest, they will stick around. Take a look at how many terrible products people use for years.

Minimising risks is even easier. Does your product put lives or business at risk? If so, you should not be using a quick launch methodology, sorry to break the news to you. Otherwise, what would be a catastrophic result of things going wrong with your product? Plan for that outcome

Just launch. Put your product in people’s hands and listen. That’s your lifeline.

Viability

I probably spend too much time validating something can be done. I am a perfectionist, so I like to be 100% sure something is possible before launching. The problem with that approach is that sometimes you discover there are more important variables that should have been resolved before tackling the technical aspects. From having an unaffordable CAC to being a type of market I am not really interested in being part of. Launching would have helped solve those questions beforehand.

Building it is just the first step. The faster you reach it, the better.

My new approach to this the last months has been to have a side track to experiment with technical validation of ideas. Think in terms of “For me to solve problem X, I should be able to use Y technology in Z way”. Go and test that is possible in a barebones, pure technical environment. Tinkering with the technology. If I am not able to validate the technical side of a side project by playing with it a few days, it is probably not something I should be attacking.

Execution

A key aspect. Tightly tied with the fears point. In the past I have worked with teams where this was the main issue. “We want to launch, but when the product is ready. If the product is not really there, how would we know people really want it?”. That is a catch 22. Another friend sent me this meme not too long ago, to remind us about it.

The startup need users loop

There is a lot I could write about this mentality or issue. How that is a red flag that signals a poor product direction or a display of lack of experience launching products. It all can be summarised: launching fast and imperfect triumphs a too-slow-too-late perfect launch.

There are exceptions of course, but be sure that the odds of you being in the former are massively higher than you being an exception.

I am not pleading for bad execution. Neither a proponent of throwing best practices through the window (this article, A development process startup founders should use to ship features weirdly fast is a good example, although it makes a couple good points). I am a firm believer of execution being exponential. I believe in making smart choices as a competitive advantage. Embracing constrains and trimming unnecessary weight is the best possible way to fast execution.

Ship like there is no tomorrow. Focus on what is important, the rest will take care by itself.

Sense of Agency

Sense of agency

Some concepts are pretty powerful. In the sense, that just being aware of them provide higher odds of succeed in life. Some are non obvious or even counter-intuitive. One of those is the sense of agency.

So, what is sense of agency and why is it important to have a strong sense of agency? it refers to the feeling of control over actions and their consequences. It is the feeling of being an agent, of a connection between our actions and the outcomes, when not explicitly thinking about it. Experiencing control over the outcomes. There are different theories that explain how it works and how we measure it. My take away for you is that its impact is transformational.

Your sense of agency is intrinsically connected with your context. In my case, moving from working in a big tech company to operating independently. As consultant and founder, provided a higher and deeper sense of agency. I had it before, I am not saying you can not have leverage in a company. My point that the output of your leverage; The extent of impact. As well as your perception of control are influenced by your environment.

It is literally one of the secrets of life according to Steve Jobs, “When you grow up you tend to get told that the world is the way it is and your life is just to live your life inside the world-try not to bash into the walls too much, try to have a nice family life, have fun, save a little money. But life-that’s a very limited life. Life can be much broader once you discover one simple fact. And that is everything around you that you call life was made up by people that were no smarter than you. And you can change it-you can influence ityou can build your own things that other people can use.”

It is important for you. It is paramount when you work in a product development team. Instilling it in your team mates. Nurturing the feeling ownership in the different stakeholders. The impact they make, it is the way to succeed creating great products. It took me some time to learn this. How crucial is to create space. To encourage providing inputs for less vocal members of the teams. Cultivating that sense of agency and autonomy. For all the participants in the production process.

There are relatively extensive research around it from a psychological point of view. The mechanisms in play as well as the different evolutive motivations for it. One of my favourite concepts!

Previously oorei dot com | Comments are disabled