Feeds

The ICONIX Process in pieces: Domain modelling

Keep refining

Boost IT visibility and business value

Book extract, part I Reg Developer regular and Agile Iconoclast Matt Stephens admits to being something of a code fiend since he was 11.

Recently, Matt and his colleague Doug Rosenberg decided to commit the experiences of their youths spent coding software rather then jetting around the park on their BMX bikes to their latest book explaining the best ways for developers to use domain modeling to roll out a solid foundation for Object Oriented Analysis and Design (OOAD).

Their book, Use Case Driven Object Modeling with UML: Theory and Practice, is packed full of illustrative diagrams and helpful exercises for readers to undertake, and features a useful set of top 10 to do lists in each chapter that take you through the construction of a model – in this case for a sample internet bookstore application.

Each chapter opens with a "you are here" diagram of the ICONIX Process that shows in glorious red the area covered by that chapter to keep you orientated.

In this, the first in a series of four excerpts from Use Case Driven Object Modeling with UML: Theory and Practice Matt and Doug introduce domain modeling and challenge you to think in models.

Domain modeling

The following chapter introduces the domain model aspect of the ICONIX Process.


The domain model - you are here...

Imagine if everyone on your team was talking a different language. Let's say you're speaking German, your team mate is speaking French, and someone else is speaking Swahili.

Every time someone speaks, people glean whatever slivers of meaning they can, and then nod as if they've understood perfectly. They then walk away with a completely wrong interpretation of what the speaker was really trying to say.

In virtually all IT projects, the problem of miscommunication is rampant, but it's rarely noticed because everybody thinks they're speaking the same language. They're not. One person says "book review" and some people interpret this as meaning "editorial review" (a review written by an editorial team), whereas others might interpret it as meaning "customer review" (a review written by a customer and posted to the site).

The results can be - and often are - catastrophic, as the system gets developed with everyone interpreting the requirements and the design differently.

Domain modeling aims to solve the problem of miscommunication on projects by establishing a common vocabulary that maps out the problem space. The domain model is a live, collaborative artifact. It is refined and updated throughout the project so it always reflects the current understanding of the problem space.

Application security programs and practises

More from The Register

next story
HIDDEN packet sniffer spy tech in MILLIONS of iPhones, iPads – expert
Don't panic though – Apple's backdoor is not wide open to all, guru tells us
Do YOU work at Microsoft? Um. Are you SURE about that?
Nokia and marketing types first to get the bullet, says report
Microsoft takes on Chromebook with low-cost Windows laptops
Redmond's chief salesman: We're taking 'hard' decisions
Cheer up, Nokia fans. It can start making mobes again in 18 months
The real winner of the Nokia sale is *drumroll* ... Nokia
EU dons gloves, pokes Google's deals with Android mobe makers
El Reg cops a squint at investigatory letters
Chrome browser has been DRAINING PC batteries for YEARS
Google is only now fixing ancient, energy-sapping bug
prev story

Whitepapers

Seven Steps to Software Security
Seven practical steps you can begin to take today to secure your applications and prevent the damages a successful cyber-attack can cause.
Consolidation: The Foundation for IT Business Transformation
In this whitepaper learn how effective consolidation of IT and business resources can enable multiple, meaningful business benefits.
Designing a Defense for Mobile Applications
Learn about the various considerations for defending mobile applications - from the application architecture itself to the myriad testing technologies.
Build a business case: developing custom apps
Learn how to maximize the value of custom applications by accelerating and simplifying their development.
Consolidation: the foundation for IT and business transformation
In this whitepaper learn how effective consolidation of IT and business resources can enable multiple, meaningful business benefits.