|
|
||
Philip Brittan's BlogAugust 2003 ArchivesJava vs. .NET, part 5 - Rich thin clientsPosted by pbrittan on August 26, 2003 at 06:37 AM | Permalink | Comments (12)Let Java play to its strengths and co-opt Microsofts advantages In the previous parts of this series on Java vs. Microsoft .NET, I lay out the threat that .NET poses to the Java ecosystem and the advantages on which Microsoft is relying to carry out that threat. So what is the response to this threat? Those of you who know me already know what Im going to say: rich thin clients. In fact, a month ago java.net readers byronsebastian and d_bleyl forshadowed this entry. The concept of rich thin client technology is to deliver the user experience of native locally-installed desktop software (co-opting Microsofts strength) from server-based applications (playing to Javas strength). With this approach, Java gives developers a cross-platform method for delivering applications that feature the desktop benefits that users want with the deployment and administration benefits that CIOs are looking for. Im not talking about Java Applets, Flash, or other disguised fat-clients. In order to deliver on the full benefits of the server-based model, and to avoid walking into a Microsoft trap, rich thin client technologies must leave 100% of application code on the server. Putting code on the client means putting it in hostile territory where it can be attacked and thwarted by Microsoft. Additionally, rich thin clients need to be browser deliverable, but must also be able to operate independently of the browser. It may, in fact, be necessary to use Microsofts own technology to implement the generic client-side piece of a successful rich thin client framework on Windows PCs/devices. I know that there is a feeling in the purist Java community that applications must be 100% pure Java to be acceptable, but I believe that the most important piece of the chain is that the applications themselves are written in Java -- thats the part that builds a developer community. If those applications are then displayed by Microsoft technology on the desktop so that they can take advantage of all the desktop benefits, so be it. If Microsoft really does banish Java from the PC, it just wont matter to rich thin client Java apps running safely on the server. On non-Windows desktops and devices, J2SE, J2ME, or even native technology can be used for the generic client. The desktop technology doesnt matter -- in the rich thin client world, its invisible to the application. I am also not talking about terminal server technology, like Citrix or X-Windows. Todays rich thin clients can offer an immediate, responsive native desktop user experience, with no lagging remote mouse and with very high server scalability and super low bandwidth usage. They can offer the user experience that Microsoft promises with Smart Clients. The Java platform must offer compelling benefits beyond simply matching Microsoft. Rich thin clients can do this:
Rich thin client frameworks are also architecturally amenable to supporting a variety of languages. As I argued in the last part of this series, the Java platform needs to recognize the huge investment companies have in legacy systems and provide a way forward for those companies without requiring that they rewrite their apps in Java. Rich thin clients bring that legacy code into a server-based, network-centric environment and then give developers a way to add new features to those legacy apps in Java. Since all the code is on the server, its architecturally easy to deal with big piles of spaghetti (without having to disentangle them) and to mix and match languages and technologies, all under the covers and away from users and hard-to-manage desktop computers. If rich thin client technology takes off, then it has the effect of marginalizing the desktop PC, a big strategic win for the Java camp. Rich thin client apps dont generally care what kind of client hardware is displaying them. Customers can go with whatever is cheap and convenient, not with the platform that happens to support their favorite apps. This paves the way for non-Windows desktop proliferation. I believe that our industry is shaping up for an epic battle between the Microsoft ecosystem, wielding .NET, and the non-Microsoft vendors, championing Java. The battle will be very hard fought and Microsoft will give no quarter. Already they have put Java into a difficult position. The best way out of the trap is not to fight them on their terms, but to redefine the battlefield. This opportunity is available because the world is moving towards being always connected. Microsoft realizes this and is trying to use our increasing connectedness as a way to drive their platform from the desktop to the server room. The Java world needs to head them off at the pass and make real the fear that Bill Gates had of the Internet in 1995. Java vs. .NET, part 4 - Java is a language, .NET is notPosted by pbrittan on August 22, 2003 at 09:09 AM | Permalink | Comments (5)Java takes a language-specific approach to solving problems, .NET takes a platform-specific one One of the striking differences between Java and .NET is that Java is, fundamentally, a programming language and .NET is not. .NET is a framework that supports many languages. There has been a lot of identification of C# with .NET, but C# does not equal .NET, and you don’t need to use C# in order to build .NET applications. You can use one of the 20+ other programming languages currently supported by .NET. .NET’s view of the world is from the platform. It is designed from the ground up to leverage specific aspects of the Windows platform to its advantage. Java, on the other hand, has a language-centric view of the world. Yes, with J2EE, Java has started to create a framework around itself, and extension technologies like Jini and JXTA certainly strengthen Java’s platform, but the way in which Java attacks problems is from a language point of view. One immediate result of this difference is that it leaves Microsoft with the opportunity to surround Java with other languages. Not only does Microsoft already control the enormously popular Visual Basic and have the ability to make C# very popular, but it can appeal to companies that already have large code-bases in COBOL, C++, Smalltalk, Fortran, and other legacy languages. Java’s answer to those folks is: port your legacy apps to Java or use some kind of awkward connector bridge between the legacy code and Java. It is not natively tolerant of legacy code. There have been attempts in the past to support other languages with the JVM. Eiffel can compile to Java bytecode. But those efforts have not gained any real support in the Java community. Bertrand Meyer, the creator of Eiffel, writes this in a paper describing his successful efforts to connect Eiffel to .NET: This ability to mix languages offers great promise for the future of programming languages, as the practical advance of new language designs has been hindered by the library issue: Though you may have conceived the best language in the world, implemented an optimal compiler and provided brilliant tools, you still might not get the users you deserve because you can't match the wealth of reusable components that other languages are able to provide, merely because they've been around longer. Building bridges to these languages helps, but it's an endless effort if you have to do it separately for each one. In recent years, this library compatibility issue may have been the major impediment to the spread of new language ideas, regardless of their intrinsic value. Language interoperability can overturn this obstacle.Java’s language-oriented approach to solving problems can be a hindrance. For instance, when communicating over networks, a wire protocol like HTML or SNMP is going to be much more efficient than a language method call like RMI or JMX. Of course you want a nice clean API for dealing with protocols (1. to make it easy to program, 2. to make it possible to replace protocols without recoding), but the implementation should not look like a method invocation. Java’s inherent lack of support for Web Services is shocking. But the answer to that should probably not be a language API. .NET can simply expose any object as a Web Service or treat any Web Service as an object. Generators like GLUE can do this for Java, but are not integrated into the Java language (as import statements) or the compilers that would need to implement this to make it seamless and non-brittle. In summary, .NETs multi-language support is another threat to Java. Java needs to blunt this threat. Specifically:
(To be continued. And yes, I am about to offer some hope…) The Internet Has Been Good to Microsoft OfficePosted by pbrittan on August 21, 2003 at 02:32 PM | Permalink | Comments (11)Standards, and corresponding monopolies, can occur naturally Believe it or not, there are times when I feel some empathy for Microsoft. After all, I myself was once a small-time monopolist. My first company, Astrogamma, had a product called FENICS that provided foreign exchange (FX) options pricing and risk management functions for traders. FX options are a particular kind of financial contract that banks and corporations trade as a way of taking bets on the fluctuations in the exchange rates between currencies or to protect themselves from those fluctuations (if you want a full primer in FX options, feel free to write me :) ). The important thing for this discussion is that trading FX options turned out to be much, much easier if the traders on both sides of the transaction were using the same software. Our system caught on initially because of our focus on the user experience, our aggressive pricing, and the fact that we were able to seed our product into the brokerage houses (who were important market influencers) early on. But once we started to see widespread adoption of our software, the FX options market started to realize the benefits of having everyone use a standard system, which in turn drove further sales of our product until we had cornered over 80% of the global market of banks, brokerage houses, and large corporations that traded actively in FX options. We became, in effect, a monopoly. There was nothing nefarious about it. We didn’t set out to become a monopoly; we just wanted to create the best system on the market. We didn’t engage in any uncompetitive practices (we were actually a much smaller company than all of our competitors, starting out). It just happened that way. This is an example of the network effect, where the network is of people trading on FENICS-calculated prices. The more people joined the network, the more valuable it became, and the more important it was for everyone else to join. In discussing Microsoft, people like to point out their monopolies on desktop operating systems and Web browsers. But these are really by-products of their most interesting monopoly: Office. As David Kennedy pointed out this morning, Office is what drives the Microsoft desktop which in turn drives Internet Explorer. A couple years ago, there was lots of speculation that Microsoft’s monopoly would be severely threatened by the Internet. Even Microsoft bought into this, which launched them into a furious and ultimately victorious battle to control the browser. The great irony is that, far from hurting Microsoft, the Internet has cemented its desktop domination. The further irony is that winning the browser war probably hasn’t helped Microsoft that much (except that it now allows them to keep Java off the client). The part of the Internet that helped Microsoft the most has been email. As email became more widespread, people began to email documents to one another (rather than printing and faxing or snail-mailing). This of course brought the network effect into full swing, and Office moved from being a “nice to have” (because of feature set) and an “easy to have” (because bundling arrangements Microsoft forged with PC makers) to a “must have” (because of file compatibility). I doubt that Microsoft really set out to achieve this, but now it has happened, and I’m sure they are extremely thankful for it. Sun has made the strongest attempt yet at breaking the Microsoft Office hold by offering StarOffice, which has a high degree of file compatibility with MSOffice. It’s a bold strategy on Sun’s part, but so far has not really had widespread success. It will be very hard/impossible to compete effectively on Microsoft's own turf of the Windows desktop. Price doesn't seem to have been a big motivator for customers so far (StarOffice was free for a long time). StarOffice does help to make Linux desktops a little more realistic as an alternative to Windows, but really Windows and MSOffice now have such a strong symbiotic relationship that they are likely impervious to direct attack. The best strategy may be to try to change the rules of the game. Java vs. .NET, part 3 - Open StandardsPosted by pbrittan on August 21, 2003 at 07:33 AM | Permalink | Comments (6)Javas traditional weapon of choice The concept of open standards has been the primary weapon of the non-Microsoft camp (which includes the Java community) against Microsoft. And it is a reasonable weapon. Open standards are meant to ensure interoperability between products from different vendors so that customers have the flexibility to put together best of breed solutions and, at least in theory, can swap out one vendors products for anothers if they become disenchanted with the first vendor on product quality or price. This means that all vendors are competing on a flatter playing field, and therefore customers and smaller vendors get the benefit of a more efficient market. Cliff Schmidt offers a very nice overview of the why, what, where, who, when, and how of standards. Major vendors in the non-Microsoft camp push hard on the idea that Microsoft is proprietary and closed, meaning that Microsoft technology interoperates only with other Microsoft technology. A customer who goes down the Microsoft route is locked in and cant choose to swap in non-Microsoft products. The ideas behind the open standards movement are laudable, and I believe in them. Product standardization -- of electric outlets, of audio equipment connections, of bolt sizes, of fuel types, etc. -- has greatly benefited customers in general. It should certainly do the same in the world of software. However, as a weapon against Microsoft, it has several weaknesses:
(To be continued) BlackoutPosted by pbrittan on August 19, 2003 at 07:05 AM | Permalink | Comments (5)Single points of failure can be entire systems. Prevention may lie in "fencing in". For those of you on the West Coast, I can assure you that it was pretty dark here in New York last Thursday evening. A little after 4pm, suddenly all our lights, air-conditioners, phones, etc., in our office shut down. The UPS alarms started ringing, letting us know we were operating on battery power. We soon realized that the power was going to take a long time to come back on, hours if not days, and we didn’t have enough battery life for that, so all we could do was execute an orderly shut down of our servers and wait. The effects of a loss of power are devastating, especially in an overcrowded city. No light, no A/C, thousands of people trapped in subways and on commuter railways, no ventilation in roadway tunnels, no ATMs, no credit card processing, no cell towers to relay our phone calls, no phone systems in our offices, no answering machines, no PCs, no refrigeration, very limited cooking, etc. Life as we know it completely on hold. We are utterly dependent on electricity and the systems that deliver it to us. The power system -- something I admittedly don’t know a lot about -- seems pretty well distributed. There are a multitude of power plants, operating independently but interconnected through a singular power grid. This grid is supposed to be able to handle changes in local supply and demand, routing extra energy to a hot region where too many people are cooling off in front of the A/C, and seamlessly covering for a downed plant. But apparently, these independent plants are also susceptible to each other, through the grid. I read that 21 major power plants spread out over 9,000 square miles all shut down within 3 minutes of each other, as a defensive response to some type of surge in the grid, leaving roughly 50 million people without power. Although the grid is supposed to nicely handle failures at any particular power plant, which I assume it does all the time and of which I am thankfully oblivious, it apparently can be a single point of failure itself, leading to catastrophic shut-down of the entire system. So how can we prevent systems from being single points of failure? The answer may lie in the concept of "fencing in" instead of "fencing out". In my home state of Montana, the law of the land is "fence out". That means that it is incumbent upon any ranch to keep his neighbors’ livestock out of his fields – he is not responsible for keeping his own livestock in. This mechanism dates from the time when most of Montana was open range land, and the occasional farms were responsible for keeping that free-range livestock out of their fields. In this day, when all the land has been claimed and cut up into contiguous ranches, this "fence out" rule seems a little anachronistic, but it remains the rule. I think that that same rule is used in numerous distributed systems. In our recent blackout, each power station acted entirely in its own self-interest and shut down to protect itself from the surge running across the grid, i.e. they each fenced the menace out. If instead, there were cooperation across the grid to isolate the surge, i.e. fence it in, then catastrophic system failure could have been avoided. Currently viruses are handled by “fence out” methodology. Every individual system attempts to fence viruses out leaving the viruses free to run around the network looking for just one system that fails to fence them out so that they can propagate. If they were fenced in, they would not have the ability to look for a weak node to attack. The only way to fence viruses in is to make sure that they have no medium for transmission. As we move towards a model of “utility computing” in which compute resources are served up like electricity from a distributed grid, the risks of a systemic failure become greater. However, since servers tend to operate in strictly managed environments, it should be easier to isolate destructive code (viruses and bugs) and its effects. And by connecting to desktop environments without sending executable content to them, we can make sure that destructive code never gets to leave that rigorously managed server grid. Mark Williamson at HP in the UK has been experimenting with using innovative "fence in" techniques to combat viruses. It is consistent with game theory that the benefit of the whole is maximized by each constituent pursuing their own self-interest and cooperating to pursue the interest of the group. That is what fencing in requires. XP, User Champions, and Software VendorsPosted by pbrittan on August 13, 2003 at 06:28 AM | Permalink | Comments (2)Software vendors are in a better position than enterprises to have the full-time user champions that Extreme Programming requires In his post, Fundamental Problem with Extreme Programming, Greg Vaughn argues that getting the level of business person involvement in software projects that XP demands is not realistic in practice. I have to agree with Greg's pessimistic view on how hard it is to get business people to set aside large chunks of their working time to help set requirements and provide a constant user feedback loop. However, I also fully agree with everyone who has responded to Greg's post by saying that without that involvement and feedback look, projects are likely to fail. My own experience has been that for simple projects, this is not a huge problem - somehow the requirements get dragged from the business users and enough feedback iteration takes place to ensure that the project really does meet its requirements. This all happens far less efficiently than it optimally would, but if the project is small, that inefficiency doesn't add up to a lot of time in absolute terms. But if the project is large and/or complex, a lot of focused user involvement is critical. The most successful projects that I have seen all had a user champion who felt that the successful completion of the software project would positively impact their own job performance, and so they are willing to sacrifice time spent doing their normal job in order to spend more time on the software project. Just as important as the time they spend is the focus of their attention. An effective user champion will be thinking about the project all the time, and will therefore bring better insights and more attention to detail to the project. Finding a user champion can be difficult within a normal enterprise. It is rare that a company will assign a business user to be the full-time champion of a project. And even if they do, that user may not be fully engaged on the project (may see it as a distraction or as a tour of duty in the gulag). It is often a matter of luck for a successful project to find a willing champion who truly cares about the project and thinks that their career will be advanced by their involvement with it. And of course it is critical, but not always controllable, that that user champion know what he or she is doing. This is a problem that software vendors can much more easily handle (if they choose to). One: since the developers of a package at a vendor tend to work for very long stretches on a particular piece of software, it is much easier for them to become fairly expert themselves in the underlying business that their software supports, which Greg states is the ideal (and I agree with him). Two: a vendor can hire professional user champions who will be dedicated full time to their software products. In my first company, which developed a package for currency options traders at banks, fully one third of our employees were former traders whom we had recruited to be those user champions. They walked the walk and talked the talk and they were all ours. The reason we chose the traders we did was that they had a fundamental interest in software, so much so that they were willing to leave their trading jobs to pursue a career in software. They were not necessarily the best traders, but they knew the business of trading inside-out and in time, with lots of practice, they became very adept at translating that business into software product requirements that our development team could work with. We called some of our ex-traders “Product Managers”, and they worked full-time on requirements specification and design testing. Others had different jobs in our company, mainly sales and customer support. All these activities kept them intensely involved with our product and the needs of our customers and thus allowed them to be effective participants in the product planning, design, and testing activities of our company. Good professional services firms can have similar advantages. One: the development team may have had the opportunity to work on solutions for a particular business segment and thus built up expertise in that business. Two: good services firms become adept (since it is their main business) at drawing requirements from users efficiently. So, in this respect, vendors generally have a better situation in which to attain the user involvement of XP successfully than enterprises. Because developing software is their main business, not a distraction from it, and because development costs are spread over fees paid by many customers, vendors are in a position to make the heavy investment in proper requirements gathering, design, user feedback, and QA that large complex software requires. ASP.NET and Smart ClientsPosted by pbrittan on August 12, 2003 at 06:54 AM | Permalink | Comments (6)Microsoft makes money from Windows desktops, not from browsers In response to the the latest installment of my Java vs. .Net series, a number of you responded with a focus on ASP.NET. ASP.NET is Microsoft's way of delivering browser-based DHTML applications. Yes, ASP.NET is an important part of .NET, but I actually do not think that Microsoft is interested in promoting browser-based DHTML clients very heavily. Strategically, they need to continue to lock in Windows on the desktop, and fat clients are the strongest way to do that. I believe that Microsoft's main strategic thrust will be around "Smart Clients". Smart Clients are .NET fat clients that rely on Web Services (served up by Windows Servers) and that can be trickeled to the client machine byte-by-byte (by Windows Servers), to make installation much more seamless to the end user. But they are still locally-installed Win32 applications. Usability will be a primary driver for Microsoft to promote Smart Clients. Usability doesn't just mean the quality of the GUI or the richness of the controls (although those are very important). It also includes the ability to interact with other applications on the desktop (a big problem for browser-based apps) to provide an overall superior user experience (anyone remember the "Are you experienced?" campaign?). Here is an excerpt from a newsletter that Microsoft sent around to ISVs this morning: "ISVs: Get Ready to Deliver Smart Client Applications The Smart Client Readiness Program for ISVs gives you the software, tools, and technical resources you need to start building smart client applications. If your customers aren't asking for them yet, they will soon see the need for the next generation of anywhere, anytime data access. Enroll in the program today! http://go.microsoft.com/?linkid=215945" Paradigm ShiftsPosted by pbrittan on August 08, 2003 at 07:48 AM | Permalink | Comments (2)Two articles recently got me thinking about the fact that paradigm shifts can be born out of convenience or necessity. In his post, Another paradigm change is taking place right now..., Michael Nascimento Santos talks about the paradigm shift from Object-Oriented Programming (OOP) to Aspect-Oriented Programming (AOP) that he sees unfolding. AOP has very interesting features that may well advance the way we think about programming. It got me thinking back to when I was first introduced to C++ and OOP. At the time, my team and I were all hard-core C programmers. We had already stumbled across the need for dynamic data binding and we so we used a lot of void* and function pointers, along with explicit type variables passed around in parallel to the data values, to simulate the effect you get with base classes and dynamic binding. We even implemented our own exception mechanism. That all seems pretty scary looking back on it now, but it actually worked very well in practice (don’t worry, I’m not recommending it). When we were exposed to OOP via C++, our initial thinking was that C++ was simply a pre-processor on C that added some features that we had already implemented anyway in straight C, and that the main effect of C++ was to bloat and slow down our ripping fast code. And so we spurned it for a while. But the industry moved forward and C++ became more widely adopted, and eventually we too started using it seriously. Once we did that, we quickly came to realize that the really interesting part of OOP is not in the specific mechanics of classes, inheritance, polymorphism, etc., but rather in the fact that it gives you a whole new way of thinking about software design and development. Once our minds had made the shift to the OOP way of thinking, there was no turning back. Today, it’s difficult for me to conceive of sitting down to write an application of any complexity using a non-OOP language. So the paradigm shift I experienced with C++ was much subtler but much more powerful than what I had initially imagined, and it took a while to sink in. This was a paradigm shift of ‘convenience’ – we could write software without OOP, but OOP gave us a better way to do it that opened up all sorts of possibilities. There are also paradigm shifts of ‘necessity’. Water rising in a reservoir is going to experience a sudden paradigm shift when it starts overflowing the dam. The second article I read recently states that if China achieves the growth in individual personal wealth and standard of living that it projects to by 2020, the world’s natural resources would not be able to sustain it. For instance, if every person in China owned a car, the way that every American (on average) does, we would immediately exhaust the Earth’s supplies of metal and oil. If this is true, and accepting for the moment that China actually can reach that standard of living, then it’s clear that a major paradigm shift will have to take place. Either people in 2020 (in the US and Europe as well as in China) won’t have nearly as many cars as they do today, even if they have the same level of personal wealth, or we will have a completely different conception of what a car is. It will have to be something that does not consume metal and oil the way they do today. So sometimes paradigm shifts take place because they provide excellent marginal benefits, sometimes they take place because there is no other way to address a looming problem. Java vs. .NET, part 2 - The Nature of the BeastPosted by pbrittan on August 06, 2003 at 11:35 AM | Permalink | Comments (17)What is Microsoft trying to do? Microsoft is the uncontested champion of the desktop. In the business world, they own essentially the entire client-side market. This is a huge advantage for them. But it is also a limitation. In order to fuel its growth, Microsoft must find new, less-tapped-out markets to go after. The server room is one such market. Microsoft is already strong there, but they still have a lot of share to grow into, and it is a lucrative market. In my previous post in this series, I claimed that Microsoft has the upper hand when it comes to the quality of the user experience. Microsoft’s user experience leadership is completely bound up with their domination of the desktop. It makes sense for Microsoft to use their hegemony on the desktop to their advantage. The client PC is their solid base, and .NET is the lever to get back to the target. .NET is an expansive strategy with many interlocking parts, and these parts come into play at various stages in Microsoft’s siege of the server room. The UI layer of .NET is the tip of Microsoft’s spear. Microsoft leverages its usability advantage, combined with its very strong tools offering, to convince developers to adopt .NET as their platform for application development and deployment. .NET apps are delivered either as ASP.NET Web pages or as managed CLR fat clients. The thing is, in order to deploy and power .NET apps on the client or in the browser, you really need to install Windows servers, preferably Windows Server 2003 (formerly known as Windows .NET Server), in the server room. Ideally, you’ll also finally upgrade to XP on the desktops to boot! One of the barriers to entry that Microsoft has faced in the server room is the skill set of the systems administrators who run those rooms. Many enterprises have standardized on UNIX and/or Linux in the data center, and their sys admins do not have Windows server skills. However, once a company takes the plunge to install even a few Windows servers in order to power .NET applications, that company will have to hire Windows-trained personnel or train their existing sys admins to run Windows boxes. Once that happens, there is no longer a barrier for a company to add even more Windows Servers, displacing UNIX and even Linux boxes from competitors like IBM and Sun. From there, Microsoft uses the expansiveness of the .NET strategy to push out Oracle in favor of SQL Server and gets companies to install BizTalk and other Microsoft server technologies. The fact that so many companies already rely on Exchange for email helps in this. Microsoft will demonstrate the power and ease of using a pre-integrated stack from a single vendor to get customers to adopt more and more of their technology. This is the threat that non-Microsoft vendors and the whole Java community faces. This plan is ambitious, but it is by no means easy, even for a company with the resources and advantages of Microsoft. Its success hinges largely on Microsoft’s ability to convince developers to adopt .NET. Therefore, the Java community’s challenge is to keep the tip of Microsoft’s spear from getting in by convincing developers and sys admins (and the companies that employ them) that Java has a more compelling answer for applications delivery than .NET. (to be continued) Docs >> Forms >> AppsPosted by pbrittan on August 05, 2003 at 10:10 AM | Permalink | Comments (5)There is a natural evolution of platform technologies from document publishing to forms processing to application delivery. The Web is the leading example of this, but Adobe Acrobat PDF and Microsoft InfoPath are on their way. The W3C has finally published its specification for XForms 1.0, after much delay and without the participation of Microsoft (not surprisingly). XForms is intended to make Web-based forms more usable by doing a better job of separating data values from form description and supporting cascading style sheets. The main benefit of these improvements is to make forms more reusable and easier to change and maintain with less re-coding. There is an interesting evolution of platform technologies that start out as simple document publication frameworks (displaying read-only text and graphics to users), then, presumably under pressure from users, these platforms get extended to support forms (meaning that users can enter data which is then written back to a database on the server). The next logical step is to make these forms increasingly dynamic until they come to resemble full-fledged application delivery platforms. This is exactly the evolution that the Web itself has undergone over the past 10 years. Most people agree that the Web does a fine job for publishing documents -- the truly revolutionary paradigm shift that the Web has delivered to date has been allowing all businesses to have universally accessible marketing materials on-line and to let anyone in the world do research through Google rather than the much, much more tedious means available before the Web. Web forms have allowed e-commerce to start to get a firm foothold. But Web technology is not as strong at forms processing as it is at doc publishing, as evidenced by the need for XForms at all. In the past few years, companies have tried hard to shoehorn full-blow applications into browsers using Web technologies, but these efforts have had very mixed results. Many vendors and standards groups have come out with a large stack of add-on technologies designed to patch up the problems that HTTP/HTML present for application developers. Other companies, like my own, have tried to rethink the application delivery problem from the ground up. Now both Adobe and Microsoft are headed down the same road with the new forms-processing capabilities in Acrobat and XDocs/InfoPath. The question on everyone’s tongue now is how these products will compete with each other. A deeper question is how they will compete with HTML/XForms and whether they will indeed progress towards being full application delivery platforms. It seems that there is market pressure for a platform to provide a continuum of capabilities from document publishing to application delivery. Maybe docs, forms, and apps are really all meant to be the same thing. But how we’ll achieve that is still far from clear. Software Usability Case Study: Novices and Power UsersPosted by pbrittan on August 04, 2003 at 05:31 PM | Permalink | Comments (2)Yes, you can support both In his post, Widgets follow form follows function, Chris Adamson ably describes the dilemma many software designers face when trying to design applications that support both novices and power users. In my post, Brittans Rules of Software Usability, I introduce the idea that software usability strategies can be seen through the application of three concepts: perspicuity, alignment to personal workflow, and style. The dilemma that Chris describes stems from the fact that novices need more perspicuity (so they can figure out what to do) and power users care only about workflow efficiency (they already know all the functions by they just want to work fast). And this is a problem because perspicuity and workflow can interfere with each other in application design (wizards are an example of this). But there does not have to be a conflict between perspicuity and workflow. I cant resist offering up a case study from my own experience on an approach we took to support both novices and power users. My first company, Astrogamma, developed and sold single product called FENICS which performed pricing calculations and risk management analysis for foreign exchange options traders in large banks and brokerage houses. FENICS was able to capture 80%+ market share of institutional FX options traders around the world. We sold the company in 1995 but it continues its market domination today, in large part because of the quality of its user experience. Traders are a very tough group to design software for. They are incredibly demanding. Speed of execution is critical for their business. They certainly have no patience to read a manual and learn how to use obtuse software. FX traders are very international (our customers were spread across dozens of countries) and many spoke very shaky English at best, so long explanations were lost on them. But traders also engage in a pretty narrow set of activities all day long, day after day, so they are prime candidates to become power users quickly. Our software was core to their ability to do their jobs, and most traders used only FENICS during their day. In order to support a quick learning curve for impatient users, we used a fairly typical perspicuous GUI layout. All the fields were visible on the screen at once. All the functions were clearly labeled and visible at all time on a toolbar. The goal of our layout was to make sense of a traders world and present them with a full dashboard of fields and functions that would seem intuitive to them the first time they used our software. So handling novices was pretty straightforward (we also had very complete but wildly underutilized documentation). But how did we handle power-users (the bulk of our user population) in that same interface? For that, we used a variety of strategies including the ones below, some of which admittedly took us a little astray from what is standard Windows GUI behavior today:
The main screen of this application was incredibly reactive. The user could move around the screen very rapidly, could enter values as they wanted to enter them, and the system was constantly interpreting what he user was doing to try to remove any unnecessary steps. These concepts proved so useful in FENICS that we carried them forward into subsequent products. They are even supported in our current product, Droplets. To wrap up, this case study was intended to illustrate that there are ways that the seemingly conflicting usability needs of different types of users can be addressed at the same time, and to provide a description of what we did so that others can build on those ideas. Brittans Rules of Software UsabilityPosted by pbrittan on August 01, 2003 at 07:39 AM | Permalink | Comments (2)I am not going to pretend that I am a usability guru. There are plenty of folks who have studied the issues of software usability far, far more rigorously than I have, people like Jakob Nielsen, Tog, and Alan Cooper, among many others: Joel has solid advice on User Interface Design for Programmers, the Interface Hall of Shame is very entertaining as well as educational. However, usability has long been a central interest of mine, and it has been a hallmark of all my companies. For the first two companies, it was the usability of our software products that helped set us apart. In my current company, its about enabling developers to deliver highly usable software to their customers. I believe that usability matters big time. If users cant use software, theres no point in writing it. I think this comes from simply caring about what I do and wanting to do a good job. Quality is caring, as Bob Waterman points out. The experience that I and my colleagues have had in these three companies has led me to boil down good usability into three rules about what really matters most:
Having rules helps, but dont get me wrong developing highly usable software is darn hard. My colleagues and I struggle with it all the time. Even with the guidance of rules, the correct path is often difficult to discern, and we find ourselves sweating to make the right decisions. But that sweat is well worth it. | ||
|
|