Thursday, 7 January 2010

Software Re-Engineering for Real : Legacy Information Systems

Reference:  Legacy Information System
                  By George Bakehouse & Tony Wakefield


A legacy information system (LIS) represents a massive, long-term business  investment. Unfortunately, such systems are often brittle, slow, and non-extensible. Capturing legacy system data in a way that can support organizations into the future is an important but relatively very difficult and expensive. Generally the system which developed in 60’s, 70’s and 80’s are considered as legacy system but these systems are still running in businesses and more  reliable, secure and have lot of priceless information about the business. However owners of these systems are unable to compete in the market due to restricted characteristics.

Organization which are using legacy systems, are unable to invest money on new  project and  technologies, as they have to invest a lot in maintaining legacy  systems. In other hand replacement for legacy systems also very high risk and  high investment project, as they have hold valuable business information with  them. The decision to replace the existing legacy systems is derived by number of  factors such as lack of openness and non-extendable characteristics, they  doesn’t allow to integrate with new systems, and very difficult to adopt new  changes as they have been  deteriorated by continues changes and lack of documentation leads to maintenance programmers to spend more on understanding the system. To be an competitor in market, owners of these  systems should update their systems to meet the new challenges and demands, otherwise they will be affected negatively. Mergers and acquisition of organizations have also impacted on development of legacy system, M&As can result in the need to integrate two or more incompatible legacy systems or to upgrade the systems in the dominant partner to meet the requirements of the new acquisition which cause further replacement of legacy  systems. It is always better to replace the legacy systems when they are no longer productive or beneficial, replacement will give more benefit such as reduced   maintenance costs, improved productivity, and reduced number of staff dealing with system, reduced training time and ability to compete effectively.  Software re-engineering is the methodology to update / replace the legacy systems in more efficient way without lost of information data, document the system by understanding the code and then design and develop the new system with the data gathered. But still it costs a lot as; it is difficult and expensive to find people who are excellent in old technologies as well as newer.

Thanks
TS

Wednesday, 6 January 2010

Software Re-Engineering for Real : Software Aging

Software Aging

Reference :


Software Aging By By David Lorge Parnas

Software industry is like other industries, customer requirements are changing, technologies improves everyday and new technologies and products are introduced and users attracted towards new products with newer technologies and better performances. Older products are getting old and unable to compete with new. Software systems also get old with years when technology improves and changes made to meet the challenges and changing requirements. This is not new, but getting into more significant as demand for software system increases as with economic growth and software systems play major role in high-tech firms. So preventing software from early aging and keep up the existing legacy software systems, owners of this software have to take some actions.

Software aging is caused by two main factors, first is failure to modify the software to meet challenges other one is continuous changes made to the software by maintenance engineers without knowledge of actual design of the system, they do changes in code, it will degrade the quality of the software. Aging software are become hard to keep up with market, as there are lot of new competitive product with new technologies and with better performance and aging software often degrade it’s performance because of gradually deteriorating structure due the changes made that introduce new problems and bugs into the system.

Software aging is inevitable and un-avoidable, but still we need to take some preventive measures to decay or limit this issue. So software professionals should think in advance and enforce these preventive measures such as Design for Success / Design for Changes, Keep up better and updated documentation from beginning of the project, compulsory software reviews. As stated above, software aging is inevitable, design for changes is not an easy task as predicting the future changes is not easy, anyhow designers approximately predict the future changes and challenges that might slow down the software aging but cannot completely avoid it.

Even we do take preventive actions to slowdown aging of new software, but still we have got lots of legacy software which are being used and maintained without aware of this aging issue. Owners of such software have do take some immediate actions to keep up the system running and slowdown aging. Stopping more deterioration due to the changes made into the system in past, upgrade the documentation that can serve as good reference to future maintenance programmers, retroactive incremental modularization, amputation and restructuring the system with in appropriate way will help to decay the aging issue at least for some period.

It is always better consider software aging as a major problem and plan early to avoid or slowdown the aging issue. It is obviously important to deliver the first release of running software on date to the customer but deliver a running first release is not a only matter, delivering better quality software with imposing standards and documentation, plan for future changes by well documentations and reviews design before actual coding starts and document and review the changes made the software after release will help to avoid deterioration of system that will lead to limit aging issue. If software is not documented well then it is assumed that it is not done. Owners of software have to plan for future replacement both financially and technologically, like other products software is also has to be replaced with new design and technology to keep up the existing customer and attract new customers as well.

If we start act to prevent software aging there factors as barriers to the actions taken. Software crisis issue addressed long time ago, quick and easy solutions have never work in futures, it is lead software aging very quickly and software profession is not standardized like other professions like electrical engineers, aeronautical engineers...etc. Software profession has to be standardized by forming a professional body and software products should be checked for their quality by enforcing some industry standards.

Finally it is not true, if we assume that old software will not be running in future, if they don’t run, we need find out root cause of the problem, and try out something to sort out that. There are new ideas and techniques evolving to decay the software aging but they have to be put into real product to reach intended audience.

Thanks
TS

Software Re-Engineering for Real

Software Re-Engieering
"The examination and alteration of an existing subject system toreconstitute it in a new form. This process encompasses a combination of sub-processes such as reverse engineering, restructuring, redocumentation, forward engineering, and retargeting."

Aside: The new form of the subject system could be structured code - from "spaghetti" code; design information in graphical form - from input code; or the translation of the source code from one language to another while preserving the system's functionality."



As a Engineering student, I am really attracted to Software Re-engineering which we don't study in acadamic period , used to work when we get into industry. I recently started studying about software re-engineering techiques which involes migrating legacy systems which was developed ages ago but still in operations as well as refactoring and replacing new objected oriented legacy systems which developed using new, high level technologies but not with proper design and maintance.
In this blog, I am planned to write about software re-engineering , the main content of this articles are abstracted from some good research papers and journels about software re-engineering.
You can refer the main resources if you want to learn more about these technigues.

Thanks
TS