Sunday, October 04, 2009
Purposes of A3
Announcing the Bay Area Chef User Meetup
Hi folks, I’d like to announce the Bay Area Chef User Meetup. The first meeting is scheduled for the mid of the this month – on the 14th of Oct. This is just the first meetup, so it will be general – exchanging ideas about what different folks in the valley are cooking using Chef Join the group – and attend, it should be fun!
Thursday, July 30, 2009
Sunday, July 19, 2009
Thursday, June 25, 2009
Be Nice
Well put
I don't care how good you are at programming, finding bugs, whatever. If you're rude, or if you speak poorly to people who don't understand your... quirks.... you will wind up being shunted to the side. No one wants to work with someone who makes them feel beat down all the time, or someone who they simply can't understand, or someone whose reaction to every issue is to start wailing about the end of the world
Monday, June 08, 2009
Automation is Overrated!
Sunday, June 07, 2009
What makes a group of people a team?
A group of people are a team when they,
- Have Common Goal
- Have Mutual Commitment
- Synchronize their effects and
- Trust and Respect Each Other
Tuesday, June 02, 2009
It is the system
"It is the system, not the workers, that creates defects and lowers productivity"
Saturday, May 30, 2009
Make it easier to do the right thing
Monday, May 25, 2009
What is Rack?
Sunday, May 24, 2009
Like movies, your presentations need Editors
Cleaning up your presentation is not that different from editing a feature film. As a director wants her films crisp and clear, you want your presentations to be crisp and clear. In movie industry, they say that director and editor roles should be done by different people. The reason is, for director when she looks at a scene she thinks the hardship that is gone in shooting that scene more than whether that scene is moving the story or not. No wonder Director's Cut is so boring. When an editor looks at the same scene she does not care how much effort has gone to shoot that scene. Editor cares only whether that scene is moving the story along or not. So next time when you are done with your presentation share it with an another person and ask her to edit it. Don't mind if she deletes a slide that took you 30 minutes to put it. Believe me your presentation will be more crisp and clear at the end.
Sunday, May 17, 2009
Skills needed for a trainer to be good
Saturday, May 16, 2009
Random Thoughts about Retrospectives
- Retrospectives are there to surface problems not to analyze root cause of a problem.
- Retrospectives should end with action items.
- Each Action Item should have an Owner.
Wednesday, February 18, 2009
Should Project Managers be technical ?!
I have seen some good project managers who were technical or non technical. I have see some bad project managers who were technical or non technical. I am not sure whether being technical or non technical even matter for being a good project manager. Many of my friends and colleagues have some strong opinion on this subject. I wanted to know how everyone else feels about project managers being technical or non technical. Please share your thoughts as comments.
Friday, February 13, 2009
Simple Procedure for effective meeting
Are you spending lot of time in meetings without much result. Try this simple procedure
1) Invite only needed people
2) Display purpose and Agenda of the meeting
3) Time box your discussions (I will post another blog examining different discussion techniques)
4) Come up with Action Items
5) State the owner and due for each Action item.
6) Send meeting minutes to all attendees
Monday, February 09, 2009
Fresher and Experienced Developers - Friends or Enemies ?
There are many articles written about pair programming. I wanted to write something specific about pair programming between a fresher and experienced programer.
Lets look at some benefits of pairing a fresher with a experienced developer.
Benefits:
- The fresher gets a good a mentor whom he can ask questions and clarify doubts.
- Learn from experienced developer. Learn concepts in minutes which might take years if left alone.
Problems:
- Fresher can slow down experienced developer, so productivity may go down.
- Experienced dev might get frustrated explaining everything to fresher.
- Fresher might be intimated so would not question experience developer's decisions.
- Fresher might feel discouraged as they don't know many things compare to experienced developers.
- Fresher might not get sense of accomplishments as they feel they finished a task because they paired with some experienced developers.
Now we have a good set of problems. Lets see what we can do it avoid these problems.
Solutions:
- Give freshers some tasks that they can do by themselves so they will get a sense of accomplishments.
- Experienced developers can clearly tell freshers where they need to concentrate, like ask them to read a particular technology or practice.
- Create a safe environment where freshers won't hold themselves from questioning experienced developers' decisions.
- Create a culture where people seek feedback.
- Always make sure freshers what is expected out of them that way they can be ready.
- Have One on ones regularly with freshers and experienced developers to get sense how things are going.
- Talk with experienced developers to find how freshers are doing. Ask them what they suggest we can do to improve a productivity.
Tuesday, January 27, 2009
Idea to Implementation
I created a presentation for some of my friends who were planning to start their own business. This presentation is based on "Getting Real" book.
Friday, January 23, 2009
Determine root cause of a problem
Determining root cause of a problem and solve the root cause rather than symptoms is one of important principles of Lean methodology. I have been in situations where we do not have time to determine root cause, so we waste our time just solving symptoms of a problem. I am sure many of you have been in this kind of situation. Unless we solve root cause of a problem, the problem will keep coming back. So it is important for us to determine root cause of a problem and solve it instead of solving symptoms. How do we determine root cause? Lucky for there is a simple technique to determine root cause of a problem.
This technique is called "5 Whys". The technique is to repeatedly ask "why" till we find root cause of a problem.
It is easy to explain with an example.
Problem: QAs take lot of time to test application.
1. Why are QAs taking lot of time to test application?
- Because they find so many bugs in application. They have to wait for developers to fix those bugs, so they can retest.
2. Why are QAs finding so many bugs in application?
- Because the application has lot of bugs.
3. Why is application having many bugs after development is done?
- Because developers did not find these bugs when developing application.
4. Why developers did not find all these bugs during development?
- Because they do not have enough unit tests.
5. Why developers did not write enough unit tests?
- Because developers did not do Test Driven Development.
You can see that QAs taking lot of time to test is not the real problem, it is just a symptom. After applying 5 whys technique we found the root cause of that problem is developers are not doing test driven development. In fact we can repeat why questions some more time to make sure it is root cause.
6. Why developers did not do Test Driven Development?
-Because they don't know how to do Test Driven Development.
Now we have determined the root cause of our problem. It is not QAs taking lot of time to test. It is developers do not know how to do test driven development.So instead of adding more QAs to reduce testing time, we should train developers how to do test driven development.
Sunday, January 18, 2009
Tips for on-boarding new hires in your company
On-boarding new hire to your company is a very important task. Every company needs to have a proper on-boarding strategy. I thought I will share some of good tips that I heard from different people for on-boarding new member to your company.
1) Buddy program: When someone joins your company assign them a buddy. The new person will know that they have someone whom they can ask questions and clarify their doubts.
2) Introduce recent hires to new hires. Recent hires will know what it was to be a new person in a company. They can help new hires in coping up with stress and also guide them.
3) Ask new hires to finish small measurable tasks. This will help you understand new hire's working style. As task could be measured you can give them feedback and guidance to them to finish that task. When they finish a task, their morale will also increase. They will feel a sense of accomplishing something.
4) Socials events. This will ease them and allow them to make friends in company.
5) Have a Mentor program . More than a buddy you also need to assign a mentor. Mentor will help them understand their goals and what they are looking for in this company. Mentor can also help them with their career and goal settings.
6) Weekly feedback sessions - Let them know how they are doing and what they can do differently. Look at my previous post
These tips could be used for on-boarding new member to your team.
Please share your tips on on-boarding new hires.
Friday, January 16, 2009
Feedback
Wednesday, January 07, 2009
Team Development
Tuckman stages of team development is very simple and could be used for building and developing teams. It could also be used for analyzing the current behavior of teams. Knowing these stages will help PMs in creating awesome team.
- Forming : This is team initiation stage. PMs should bring their team members together. Make sure everyone understands the goal of their team. Should create a safety environment for team members to try new things without worrying about failing. It will be helpful if PMs share Tuckman stages to their team. PMs are Directors in this stage.
- Storming : In this stage various personalities in team compete. PMs should not panic and change team members when their teams are in this stage. Instead PMs should coach(regular one on ones) to increase tolerance of each team member and emphasize their differences. PMs are Coaches in this stage.
- Norming : In this stage teams solve problems on their own and achieve harmony. PMs are Participant in this stage.
- Performing : In this stage team is performing as a unit. Teams will be more productive. PMs should allow their teams to make their own decisions. PMs are Delegators in this stage.
- Adjourning : Goal is achieved and team is disassembled.