Welcome!

Java IoT Authors: Zakia Bouachraoui, Pat Romanski, Elizabeth White, Liz McMillan, Yeshim Deniz

Related Topics: Java IoT, Open Source Cloud

Java IoT: Article

Where Are the High-Level Design Open Source Tools for Java?

I have just finished reviewing the book Open Source Development Tools for Java

I have just finished reviewing the book Open Source Development Tools for Java, which provides excellent coverage of such topics as log4J, CVS, Ant, and JUnit. There is a chapter on UML tools though in which the author almost apologizes for the lack of good open source design tools. There is a plethora of projects on SourceForge.net from J2EE runtime frameworks to IDE plugins, yet there is almost nothing that encroaches upward into the arena of analysis and design tools.

One theory for this is that high-level design tools are the value-add that software vendors hold back from the open source community and sell in high-priced offerings. While this does occur to a certain extent, it can't be the real reason. Open source is a marketplace where useful things become free and commoditized, as witnessed by runtimes such as Tomcat and JBoss or tools such as Eclipse and NetBeans. An open source business model that certainly works is to give away a product and then charge for consultancy and help using it. Is it just a matter of time before a big vendor starts to give away modeling tools? They could benefit if their product became a de-facto standard for developers, potentially quashing the competition in the process and growing the marketplace for a specialized consultancy.

Another reason given by a colleague, whom I posed the question to, was that design tools just aren't that useful. His measure of worth is a product that creates something he can compile, touch, execute, and debug. There will always be those who subscribe to the opinion that high-level modeling is the realm of bluff and fluffware practiced by those who masquerade their inability to write code behind its numerous charts and methodology steps. It's an unfair view though that can be equally leveled at developers who drown themselves in worrying about obtuse coding techniques instead of just writing a program that lets users get their job done more efficiently. The best tools are those that bridge the gap between the high- and low-level software disciplines by seamlessly working with the same artifacts, presenting alternative views for disparate learning styles.

Visual learners prefer to think and work with charts and diagrams to analyze problems and communicate solutions, while I view coders as tactile or kinesthetic stylists who feel happiest with their IDE paused at a breakpoint showing them a stack trace from which they can explore and learn. There is a generation of tools that tended to be one way, where design charts generated code to be compiled and executed; these are probably the ones my colleague spoke about so scathingly. These changes to the source code don't get reflected back in the tool and the code is undoubtedly more bloated and less efficient than if it had been written by hand. The developer who has to debug problems in the spaghetti unfairly stores his or her frustration as a general disdain for all design tools. Such attitudes are unfair and often dated, however, as there are some excellent design tools available that happily round-trip between high-level diagrams and actual code. A good example of this is Sun's Visual Paradigm for Software Development Environment www.visual-paradigm.com/product/sde/nb/index.jsp for NetBeans or Rational Software's Rational Application Developer www-306.ibm.com/software/awdtools/developer/application/ that builds on an Eclipse codebase.

Returning to the plot line: Why then is the open source community starved of good, high-level tools? The reason I subscribe to is that the open source community just hasn't got around to creating them. The stack of open source software out there has been built from the bottom up, with small nimble runtimes and tight extensible IDEs. Such software is often built by those who use it themselves, providing a tight feedback loop between design and implementation that has resulted in the well-baked solutions that we take for granted as being freely available. For the most part, this space is well populated and there are a healthy number of offerings to chose from. I think that the future bodes well for a growth in open source tools that tackle and reach into the higher-level problem arena of software development. This could come about several ways. A tool such as ArgoUML (http://argouml.tigris.org/), a very solid open source UML product currently without an IDE home, might become more integrated with one of the major IDEs like NetBeans or Eclipse to piggyback a larger user base. The Eclipse Foundation has a tools project, Graphical Modeling Framework www.eclipse.org/gmf/, although this currently seems very focused on the Eclipse Modeling Framework as its high-level runtime rather than UML in general.

Another possibility is that a major vendor with a track record in open source tooling throws its product into the ring, or perhaps Borland will rediscover the mindshare it used to have with TogetherJ in one of its designer or architect products.

Whatever occurs with design tools and open source, I hope it's one that marries the best ideas from those with the knowledge of how a good high-level design tool should work with those who know how to code, implement, and manage a successful open source project. The outcome will be that we have a more productive suite of software development tools to choose from. Once this progression is complete, the problem arena will move even higher to open source tools that allow the end users to capture requirements in a form that communicates between their problem domain and the code. The sky's the limit.

More Stories By Joe Winchester

Joe Winchester, Editor-in-Chief of Java Developer's Journal, was formerly JDJ's longtime Desktop Technologies Editor and is a software developer working on development tools for IBM in Hursley, UK.

Comments (4) View Comments

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


Most Recent Comments
Jackie Luppi 02/28/06 12:40:26 PM EST

The fundamental issue I see with modeling tools is the lack of a feedback loop to keep the modeling/design materials up to date with the implementation. Starting from a blank sheet is easy but adding, modifying, and deleting typically requires a huge investment. I would like a streamlined tool that integrates my business analysis work, with my implementation artifacts, and finally with my test suites. I have not found a solution to date.

Jackie Luppi 02/28/06 12:39:45 PM EST

The fundamental issue I see with modeling tools is the lack of a feedback loop to keep the modeling/design materials up to date with the implementation. Starting from a blank sheet is easy but adding, modifying, and deleting typically requires a huge investment. I would like a streamlined tool that integrates my business analysis work, with my implementation artifacts, and finally with my test suites. I have not found a solution to date.

Tim Cramer 02/27/06 10:08:05 PM EST

Joe,
You make some great points in the article. You should check out the preview release of NetBeans 5.5 available at http://www.netbeans.org
It contains UML tools, a BPEL engine, and XML tools all for free.

Tim Cramer
Director: NetBeans

SYS-CON India News Desk 02/27/06 02:09:36 PM EST

I have just finished reviewing the book Open Source Development Tools for Java, which provides excellent coverage of such topics as log4J, CVS, Ant, and JUnit. There is a chapter on UML tools though in which the author almost apologizes for the lack of good open source design tools. There is a plethora of projects on SourceForge.net from J2EE runtime frameworks to IDE plugins, yet there is almost nothing that encroaches upward into the arena of analysis and design tools.

IoT & Smart Cities Stories
The challenges of aggregating data from consumer-oriented devices, such as wearable technologies and smart thermostats, are fairly well-understood. However, there are a new set of challenges for IoT devices that generate megabytes or gigabytes of data per second. Certainly, the infrastructure will have to change, as those volumes of data will likely overwhelm the available bandwidth for aggregating the data into a central repository. Ochandarena discusses a whole new way to think about your next...
DXWorldEXPO LLC announced today that Big Data Federation to Exhibit at the 22nd International CloudEXPO, colocated with DevOpsSUMMIT and DXWorldEXPO, November 12-13, 2018 in New York City. Big Data Federation, Inc. develops and applies artificial intelligence to predict financial and economic events that matter. The company uncovers patterns and precise drivers of performance and outcomes with the aid of machine-learning algorithms, big data, and fundamental analysis. Their products are deployed...
Dynatrace is an application performance management software company with products for the information technology departments and digital business owners of medium and large businesses. Building the Future of Monitoring with Artificial Intelligence. Today we can collect lots and lots of performance data. We build beautiful dashboards and even have fancy query languages to access and transform the data. Still performance data is a secret language only a couple of people understand. The more busine...
All in Mobile is a place where we continually maximize their impact by fostering understanding, empathy, insights, creativity and joy. They believe that a truly useful and desirable mobile app doesn't need the brightest idea or the most advanced technology. A great product begins with understanding people. It's easy to think that customers will love your app, but can you justify it? They make sure your final app is something that users truly want and need. The only way to do this is by ...
CloudEXPO | DevOpsSUMMIT | DXWorldEXPO are the world's most influential, independent events where Cloud Computing was coined and where technology buyers and vendors meet to experience and discuss the big picture of Digital Transformation and all of the strategies, tactics, and tools they need to realize their goals. Sponsors of DXWorldEXPO | CloudEXPO benefit from unmatched branding, profile building and lead generation opportunities.
Digital Transformation and Disruption, Amazon Style - What You Can Learn. Chris Kocher is a co-founder of Grey Heron, a management and strategic marketing consulting firm. He has 25+ years in both strategic and hands-on operating experience helping executives and investors build revenues and shareholder value. He has consulted with over 130 companies on innovating with new business models, product strategies and monetization. Chris has held management positions at HP and Symantec in addition to ...
Cell networks have the advantage of long-range communications, reaching an estimated 90% of the world. But cell networks such as 2G, 3G and LTE consume lots of power and were designed for connecting people. They are not optimized for low- or battery-powered devices or for IoT applications with infrequently transmitted data. Cell IoT modules that support narrow-band IoT and 4G cell networks will enable cell connectivity, device management, and app enablement for low-power wide-area network IoT. B...
The hierarchical architecture that distributes "compute" within the network specially at the edge can enable new services by harnessing emerging technologies. But Edge-Compute comes at increased cost that needs to be managed and potentially augmented by creative architecture solutions as there will always a catching-up with the capacity demands. Processing power in smartphones has enhanced YoY and there is increasingly spare compute capacity that can be potentially pooled. Uber has successfully ...
SYS-CON Events announced today that CrowdReviews.com has been named “Media Sponsor” of SYS-CON's 22nd International Cloud Expo, which will take place on June 5–7, 2018, at the Javits Center in New York City, NY. CrowdReviews.com is a transparent online platform for determining which products and services are the best based on the opinion of the crowd. The crowd consists of Internet users that have experienced products and services first-hand and have an interest in letting other potential buye...
When talking IoT we often focus on the devices, the sensors, the hardware itself. The new smart appliances, the new smart or self-driving cars (which are amalgamations of many ‘things'). When we are looking at the world of IoT, we should take a step back, look at the big picture. What value are these devices providing. IoT is not about the devices, its about the data consumed and generated. The devices are tools, mechanisms, conduits. This paper discusses the considerations when dealing with the...