The WTF Series: Triple constraint

March 10, 2016  |  Ben Kittrell

triple constraint scope cost time

One of the hardest parts of software development is managing stakeholder expectations.

Of course, everyone wants as much as they can get, as fast as possible, for the lowest price.  Why wouldn’t you?  

Ben Kittrell

Ben Kittrell

The problem is that most programmers get frustrated when a stakeholder asks for too much too fast, and don’t know how to push back. Some of us aren’t exactly social butterflies. That’s why we borrowed a project management term called the triple constraint.

This is usually explained by drawing a triangle and writing one word at each corner: “scope”, “cost” and “time.” These corners represent what will be included in the project, how much it will cost and how long it will take, respectively.  Triple Constraint


With the triple constraint, you can’t change one corner without affecting the others. If you add features, it’s either going to cost more or take more time. If you want to get it done faster, you have to remove features or pay more. It’s a handy way to explain that you can’t get something for nothing. The model, of course, can be applied to many different industries.

Another popular way of using the triple constraint is to say “Among the three options of fast, good and cheap, you can choose two.” If you want it fast and good, it’s not going to be cheap. If you want it cheap and fast, it’s probably not going to be very good.

This not only helps the developer set guidelines for what’s possible, it helps stakeholders understand what their options are. Usually, after I explain this to a client, they’re happy to say something like “Well we have to get this done in two months and this is our budget, so what features can we cut?”


Ben Kittrell is the co-founder of Doodlekit and an advisor for startups and small businesses. Kittrell also is host of Spare Room Radio, a podcast that features Kansas City entrepreneurs.

startland-tip-jar

TIP JAR

Did you enjoy this post? Show your support by becoming a member or buying us a coffee.

Tagged , ,
Featured Business
    Featured Founder

      2016 Startups to Watch

        stats here

        Related Posts on Startland News

        1MC Recap: PerfectCube, Mission Academy help customers take action

        By Tommy Felts | July 8, 2015

        Two local startups took the 1 Million Cups stage to discuss their solutions — each with a goal of helping their customers take action. PerfectCube started the entrepreneurial program by presenting their data analytics web tool designed for small retail stores and franchise systems. “We’ve pivoted a half dozen times on what we offer,” said…

        Schukman: Authenticity is the ultimate currency for millennials

        By Tommy Felts | July 8, 2015

        The facts are in. Millennials prefer cause based products, are willing to pay more for them, and demonstrate strong brand loyalty to companies who weave social good into their stories. On the surface, these stats should be enough for any company to dive head first into branding themselves as social entrepreneurs. But, cause-based marketing is…

        Brad Feld contest offering a startup free rent in KC

        By Tommy Felts | July 7, 2015

        A prominent venture capitalist is launching an international competition in Kansas City that will offer a startup free office space in one of the area’s tech hotbeds. Brad Feld, co-founder of the Boulder-based Foundry Group, kicked off a contest Tuesday that will allow a startup to live in his Kansas City, Kan., home for one-year…

        Digital Sandbox partners with Olathe to lift startups

        By Tommy Felts | July 6, 2015

        Business incubator Digital Sandbox KC is widening its reach to suburban Kansas City. Digital Sandbox is partnering with the City of Olathe, Kan., to help launch businesses and boost entrepreneurship with its proof-of-concept model. The organization invests up to $25,000 in businesses for specific projects that help them secure additional funding. “Digital Sandbox has done…