The Register® — Biting the hand that feeds IT

Feeds

Microsoft: a successful low-maturity company?

Like a fine wine

Free ESG report : Seamless data management with Avere FXT

In the comments on my blog about the CMMI Made Practical conference here, I quote Microsoft as an example of a very successful low-maturity company. I make no secret of my partiality for CMMI-style process improvement (almost 30 years in IT has convinced me that it’s far from a process-free zone) but it’s not the only way to run software development (only, perhaps, the most effective way in the longer term).

So I was interested in the insight to Microsoft’s development philosophy provided by Tim Anderson, here. In particular, I thought Greenfield’s quoted remark about the OMG’s MDA - “...[it has] CIM [Computation Independent Model], PIM [Platform Independent Model] and PSM [Platform Specific Model]. The same viewpoints apply to everything, whether you're building eBay or a mobile device application. We don't buy that. They're different things” – was just plain silly.

As a fan of MDA, I think, more or less, that both eBay and a mobile phone have a business model that doesn't change when the technology does; a model that represents a subset of this corresponding to the automated system inside the man-machine boundary; and a model corresponding to the implementation on a specific computer/phone platform. That makes perfect sense to me.

When I put this point to Tim, he said that what Greenfield was really saying was that people were forced to extend the UML behind MDA and that this led to chaos. In a hitherto unpublished quote from Tim’s interview, Greenfield says: “What we say is this: look at what people do with it. To be useful, they'll take it, they'll hold their nose and use stereotypes and tags and mark it all up, because what they're really trying to do is to enable the capture of additional information, the tags allow you to add new properties, the stereotypes give you new metaclasses more or less, and in a good tool, you can actually add some additional constraints. What you end up with is this horribly marked up hotchpotch of stuff, which is really a domain-specific language [DSL]. It's a tailoring of the fundamental abstraction of state chart or activity graph or whatever, to solve some specific purpose. Then people will go write a code generator that rummages over that stuff, spews out the code, the SQL or whatever it might be”. Emotive language, but in other words, why not do DSLs properly from the start?

Well, that’s not so silly, it’s a valid approach. But my response would be, that UML 2.0 was designed to be extended, and that a mature organisation using MDA tools from, say, Compuware and with a high-maturity development process can cope with all this rather better than Greenfield envisages. The advantage of high-maturity MDA is that it helps to avoid tying your automated business process into a particular technology platform, and avoids the temptation to build tomorrow’s “legacy”, but very efficiently. I think that a DSL risks ending up as (in MDA terms) just a Platform Specific Viewpoint. Perhaps with a high-maturity process, however, the DSL approach will work as well as MDA.

Which sort-of brings me back to Microsoft as a successful low-maturity company (in the 1990’s at least). It is certainly aware of CMMI now (see here). But Tim also commented: “I respect [Greenfield’s] views but I did get a sense that Microsoft's strategy here is driven excessively by whichever faction happens to be in the ascendant internally. For example, apparently that is how the whole "Design for deployment" thing came about. But I guess this is not uncommon”. Not uncommon, certainly, but “faction-driven development process” is probably a feature of low-maturity organisations.

5 ways to reduce advertising network latency

Whitepapers

Microsoft’s Cloud OS
System Center Virtual Machine manager and how this product allows the level of virtualization abstraction to move from individual physical computers and clusters to unifying the whole Data Centre as an abstraction layer.
5 ways to prepare your advertising infrastructure for disaster
Being prepared allows your brand to greatly improve your advertising infrastructure performance and reliability that, in the end, will boost confidence in your brand.
Reg Reader Research: SaaS based Email and Office Productivity Tools
Read this Reg reader report which provides advice and guidance for SMBs towards the use of SaaS based email and Office productivity tools.
Email delivery: Hate phishing emails? You'll love DMARC
DMARC has been created as a standard to help properly authenticate your sends and monitor and report phishers that are trying to send from your name..
High Performance for All
While HPC is not new, it has traditionally been seen as a specialist area – is it now geared up to meet more mainstream requirements?

More from The Register

next story
Windows 8 fans out-enthuse Apple fanbois
Redmond allows 81 Win 8 devices to use one user ID, solving side-loading shemozzle
'200 million' fanbois using iOS 7 just a week after release - study
Plus: Most US iDevice users are drinking Cupertino's latest Koolaid
No luck at all for BlackBerry as Messenger apps launch stalls
Leaked Android build 'causes issues,' is withdrawn
App Store ratings mess: What do we like? Sigh, we dunno – fanbois
How do I know what to download if I don't know what everyone else is doing?
OUCH: Google preps ad goo injection for Android mobile Gmail app
Don't worry, fandroids, wallet-plumping serum won't hurt a bit
Launchpads, catapults... what a load of - WAIT, there's £15m for grabs?
Quango sprinkles cash on games, animation and trendy meeja types
Apple iOS 7 makes some users literally SICK. As in puking, not upset
'Eye candy really is as bad as classical candy is for the teeth,' writes one
Google reveals its Hummingbird: Fly, my little algorithm - FLY!
Update brings Googleplex one step closer to sentience
prev story