Making sense of agile modelling

Daily Newsletters

Sign up to ZDNet UK's daily newsletter.

ANALYSIS

It's common for many programmers to be suspicious of modelling, but it doesn't have to be that way. We talk to IBM's Scott Ambler about how you can use agile modelling for any project, and why you probably already are without realising it.

Q: What does agile modelling mean to developers in the Web 2.0 world?
A: The goal of agile modelling is to describe a collection of principles and practices for modelling and documentation, preferably on agile projects, but, if they're not so agile, then that's OK too. What we've seen is that the major use was in XP [extreme programming] to make modern documentation more explicit, or with the RUP [Rational Unified Process] to sort of ramp down some of the bureaucracies and make it as streamlined as possible.

It just describes ways for you to be effective with thinking through some of the things you're doing without taking a hit from needless documentation. From an agile point of view, it gives some explicit strategies for how to protect yourself from the bureaucrats who want you to do way too much documentation, and provides some advice to govern some of the things you're doing.

Some of the more extreme rhetoric in the agile community really motivates some people to do the wrong thing; not picking on agile fans, but that's probably the wrong way.

What do you think the general opinion from programmers is on modelling in business?
I think that a lot of programmers struggle with modelling, for a lot of reasons.

First, they haven't got good training in it. I don't think that schools do modelling justice at all. They might never for all I know, but they certainly don't do it well now.

A lot of the time developers will show up to their first job and, the first time they do modelling, they'll almost always be put into one of two dysfunctional situations. Either they'll be put into a project team where you're given all this modelling up front, and then you ignore it towards the back-end. So they see all this wasted effort around modelling documentation and then they say: "Hey, I did all this modelling and it didn't have any effect on the product whatsoever, what a waste!" And so they get bitter about modelling.

A lot of modelling will happen on whiteboard and it will happen on paper, and that's perfectly fine

Scott Ambler, IBM Rational Software

Or worse yet, they'll do the work, they'll successfully deploy the project into production and then someone will come along and say: "Well, now we need to spend the next two months writing all the documentation we should have to make it look like we followed the process." That is a complete waste of effort. That's just somebody justifying their job; it has nothing to do with delivering value. A lot of developers get bitter about this sort of stuff.

Another common issue is that they struggle to distinguish between modelling and documentation. If I'm doing a sketch on a whiteboard, then that's a model, but it's not a very good document. What will happen — and in a way the fault lies with the vendors because we want to sell Case tools — is that we try to convince developers that modelling has to be done with these heavy tools.

Well, no, not all of it — and let's just observe the fact that a lot of modelling will happen on whiteboard and it will happen on paper, and that's perfectly fine. When you want to get more sophisticated though, you need more sophisticated tools. For example, I've got pretty good modelling skills, so I'm far more effective using a tool like RSA [Rational Software Architect] or RSM [Rational Software Modeler] to do my modelling, and then generate my code and generate my database stuff than I am "hand-jamming" it.

It's just crazy writing code when I can generate it — I'm assuming that the tools generate decent code here. The problem is, though, that it requires a heck of a lot of skill — if you don't have that skill, and haven't taken the time to get it or…

Talkback

I think the author is talking out of both sides of his mouth here.

The fact is: Software developers today are really designers and not coders.

The reason that business anlaysts exist today to model solutions is because they understand the value of designing software before writing it.

All too often developers create code that has little value because they do not understand that business classes interact with other classes within the confines of a working model or pattern.

Effective software cannot be created without somebody designing a solution first.

I have delivered OO models and other design specifications for years to software developers who were shocked at how effective coding became after learning design and modeling skills.

1000165269 11 July, 2007 15:47
Reply

When I were a lad we had to flowchart the project up front and comment everything we wrote while putting it into binary, Assembler, Algol, FORTRAN or whatever - so WE knew what was going on afterwards, never mind those who came after us. The code was simply the mechanics of execution of the flowchart logic on a computer, a computer should have been able to do it - now I gather one does?

The problem throughout my career in ICT product management has been software written by coders who don't do either before they start, its called job security , contract renewal or a support contract at EDS et al. Maybe you can be this sloppy with higher level languages? What say you, professionals?

Is old grey ACE/Deuce best practice any different with today's much higher level languages?

..... on a credibility note its hard to take anyone seriously who wears a white sunhat for his bio pic in a serious professional column.

Hello Coder!

Brian

Brian Catt 12 July, 2007 18:05
Reply

This post has been removed by a moderator.

Well stated!

1000165269 12 July, 2007 19:36
Reply

Post your comment

In order to post a comment you need to be registered and logged in.

You can also log in with Facebook. Log in or create your ZDNet UK account below

  • Login

Will not be displayed with your comment

By signing up for this service, you indicate that you agree to our Terms and Conditions and have read and understood our Privacy Policy. Questions about membership? Find the answers in the Community FAQ

Get ZDNet UK's daily newsletter

Enter your email address to sign up

ZDNet UK Live

Paul Smyth

Is this classic FUD? One thing I would definitely have notice is a Mozilla threat to stop supporting GNU/Linux.

1 hour ago by Paul Smyth via Facebook on Firefox rapid release improves Fedora Linux
UnderINK

I agree with the previous commenter wholeheartedly. I couldn't say it better myself. This is very 'Big Brother'. And while I agree with protecting...

5 hours ago by UnderINK on European e-identity plan to be unveiled this month
Simon Bisson and Mary Branscombe

Nice to see that Turing's idea of a general purpose computer doing once-hardware-powered tasks in software is now universal ;-) Mary

11 hours ago by Simon Bisson and Mary Branscombe on Software with everything
Jason Burchell

seriously now. I've only bothered to read a small bit of the comments. do me and the rest of the world a favour. stop saying it does not work or...

14 hours ago by Jason Burchell via Facebook on Music industry negotiating over 24-bit downloads
Philip Charles Cohen

Read about it and weep, John Donahoe ... In addition to Visa’s V.me, there is now MasterCard’s PayPass digital wallet soon to arrive; another...

19 hours ago by Philip Charles Cohen via Facebook on PayPal takes phone-based payments to the high street
apexwm

Leslie Satenstein : Where have you ever seen Mozilla even mention this? Firefox is the most popular browser in the GNU/Linux OS, so I don't see...

19 hours ago by apexwm on Firefox rapid release improves Fedora Linux
songmaster

SHleG: Do you remember building a clockwork scorpion kit (I'm pretty sure I have a photo of it somewhere) — I think it was called something like...

21 hours ago by songmaster on Software with everything
Chris Wortman

Good I love Yahoo! Their search engine is getting better than Google as of late. I find more of what I want on the first page, and usually within...

22 hours ago by Chris Wortman via Facebook on Linux Mint 13 ramps up for KDE release
PatrickG

openhgs has made the point for Windows 8 multiple monitors without realising it! With Windows 7 you have to switch the mouse and so your focus...

23 hours ago by PatrickG on Windows 8 could speed multi-monitor uptake
Leslie Satenstein

Mozilla has threatened to stop supporting Linux. I guess that UBUNTU is going with another browser. I indicated that if Mozilla stops supporting...

1 day ago by Leslie Satenstein via Facebook on Firefox rapid release improves Fedora Linux
Andy Bolstridge

Much as I abhor Microsoft's licensing practices, this is almost certainly down to purchasing IT equipment via 3rd party consultants - you get the...

1 day ago by Andy Bolstridge via Facebook on 6 million wasted licences and £1,200 PCs: welcome to government IT
Jack Schofield

@openhgs Windows users have had multiple desktops since Linus started writing Linux. They just haven't shipped as standard because not enough...

2 days ago by Jack Schofield on Windows 8 could speed multi-monitor uptake
Jack Schofield

@Phil at Cloud4 What, Microsoft gets £1,200 per PC and £1,622 per server? Gosh, I'm amazed....

2 days ago by Jack Schofield on 6 million wasted licences and £1,200 PCs: welcome to government IT
craigsc

You guys have no idea what is going on at Autonomy. Autonomy could have been a much more profitable organization. The sales operations at Autonomy...

2 days ago by craigsc on HP cuts 27,000 staff as Autonomy chief Lynch leaves
Moley

How does this impact on dual or multi booting? Seems to me to more or less prohibit this, from Windows 8 anyway. Will Grub 2 recognise Windows 8,...

2 days ago by Moley on Windows 8 start-up speed forces USB boot workaround
apexwm

I don't understand why there cannot be a slight pause during the boot process so the user can press a key. Many operating systems do this, even if...

2 days ago by apexwm on Windows 8 start-up speed forces USB boot workaround
Gavin Goodman

You can now buy the Xi3 modular computer in the UK at http://www.ocdistribution.com . This can be bought with the Tand3m software, pricing and...

2 days ago by Gavin Goodman on CES 2012: Xi3 microSERV3R
Phil at Cloud4

I agree: Mike Lynch can clearly build a business and manage strategy. I suspect the exit of Mike is more likely the end of a planned handover...

2 days ago by Phil at Cloud4 on HP cuts 27,000 staff as Autonomy chief Lynch leaves
Phil at Cloud4

This is unbeleivable government wastage with only one winner... Microsoft 1 - Tax payer Nil!

2 days ago by Phil at Cloud4 on 6 million wasted licences and £1,200 PCs: welcome to government IT
Mispam

So what do you do when you can't boot into windows? Why can't I just hold Shift while I power up instead of having to boot into windows and click a...

2 days ago by Mispam on Windows 8 start-up speed forces USB boot workaround