You’ve reached out to a few different vendors. Based on your statement of work and requirements, they’ve submitted their proposals. How do you go about evaluating the different vendors and picking a winner?

You’ve reached out to a few different vendors. Based on your statement of work and requirements, they’ve submitted their proposals. How do you go about evaluating the different vendors and picking a winner?

One way is to use the Software Engineering Institute’s Capability Maturity Model (SW-CMM). Yes, it’s a mouthful, but what is it for? It provides a way to measure the maturity and effectiveness of a software organization. It evaluates an organization's ability to deliver quality software on budget time after time.

You can leverage the model to create a decision matrix. The matrix will rely on the evaluation criteria of your choosing. But how do you use the matrix?

You might use it to exclude some vendors because of low scores. You might exclude others due to poor scores in specific categories. For example, you might remove any vendor with low scores in project management. Remember the goal of picking a vendor is not to choose the lowest bid. Instead, it is to choose the vendor that will provide the best value.

All scores are subjective based on your team's opinion. Evaluation criteria ideas include:

Requirements Management

How will the vendor establish and manage the requirements for the project?

Project Planning

What processes do they have in place to establish a plan for carrying out and managing the project. This involves developing estimates, and defining the plan to perform the work. It also includes steps to estimate the size of the software, and the resources needed. Other steps include creating a schedule, identifying and assessing software risks.

Project Tracking

How will they provide visibility into the project's progress? So that both parties can take action should the project deviate from the plan.

Subcontract

How qualified are they to select subcontractors and manage them?

Quality Assurance

How will the team review and audit the product to ensure it complies with standards?

Configuration Management

How is the integrity of the product’s configuration established and maintained?

Training / Scaling

How does the vendor develop the skills and knowledge of individuals so they can perform their roles to a standard? How will they assess their current and future skill needs? How will they fill their missing skills?

Product Engineering

Does the organization have a well-defined engineering process to produce correct, consistent software products. For example, analyzing the system requirements, developing the requirements, developing the architecture, designing the software, implementing it, integrating components, and testing it.

Defect Prevention

How is the organization setup to identify the cause of defects? How do they prevent them from recurring? Do they use peer reviews to remove defects from the software?

Software Quality Management

How is the organization prepared to understand and achieve specific quality goals?