I frequently asked for advice on how to estimate tasks or projects. It’s a question architects get asked by project managers as we’re often in the best position to provide a realistic estimate. Estimation is as much art as science, but there are some things you can do to reduce error over time. Some may argue that it’s not the architect’s job to estimate; it’s the project manager’s job. In my experience, it’s common to combine the architect and project manager roles, so the line between the two is blurry in some organizations.
I typically determine estimates in terms of the number of labor hours or days required. Calculating delivery dates and working different scenarios (e.g. different numbers of developers, altering the items delivered, etc.) is just math after that.
I typically determine estimates in terms of the number of labor hours or days required. Calculating delivery dates and working different scenarios (e.g. different numbers of developers, altering the items delivered, etc.) is just math after that.
Tactic 1: Keep a history log for past estimates
For the projects I manage as well as fill the architect role, I track hours spent on tasks as well as the estimate I provided for them. For estimates that were largely different than the time actually taken, I do a private post-mortem. This is valuable feedback that you can use to refine estimates for future projects. I realize that tracking this information is boring.
Tactic 2: Look for comparable projects
I price (a.k.a. estimate) projects the same way people price real estate. When an assessor determines the value of your home, they measure the square footage and take various specifics (e.g. number of bedrooms, bathrooms, etc.) and compare them to recent sales in your area with about the same square footage and features. They get a range of sales prices back and they use those to derive the value of your home. We can use the same tactic for technology projects.
If you follow tip one, over time you will have a history record of labor used for different tasks and projects. You can mine that library for “comparables” for the project or task you are estimating. For example on a recent assignment, the average amount of work required to create, format, and deploy a new report took approximately 24-36 hours depending on the complexity of the report. We’re I still at that assignment, that’s the time frame I used for the report components of projects I needed to estimate. You can apply the same tactic to estimating other types of tasks.
Tactic 3: Turn the “big” problem into several little problems
We apply this tactic when designing applications all the time. It can help you with providing estimates as well.
You might not have a comparable for the entire project. However, if you separate that project into smaller portions, you might have history for comparable projects/tasks for at least some of the smaller components. At the very least, you’ll have a better feeling for which portions of your estimate are likely to have the largest variance.
Sir in a real java application, the cost determination depends on which key components/area of the application.....as you have given the eg. of real estate....so in a actual application development scenario which are the components on which the estimates varies for the pricing, resource and duration estimation...?
ReplyDelete