Short note on Software Re-engineering

 Software Re-engineering

- Software Re-engineering is a process of software development that is done to improve the maintainability of a software system. 

- Re-engineering is the examination and alteration of a system to reconstitute it in a new form. This process encompasses a combination of sub-processes like reverse engineering, forward engineering, reconstructing, etc.

- Re-engineering is the reorganizing and modifying of existing software systems to make them more maintainable. 


Objectives of Re-engineering: 

  • To describe a cost-effective option for system evolution.
  • To describe the activities involved in the software maintenance process.
  • To distinguish between software and data re-engineering and to explain the problems of data re-engineering.

Steps involved in Re-engineering: 

  • Inventory Analysis 
  • Document Reconstruction 
  • Reverse Engineering 
  • Code Reconstruction 
  • Data Reconstruction 
  • Forward Engineering 


Re-engineering Cost Factors: 

  • The quality of the software to be re-engineered
  • The tool support available for re-engineering
  • The extent of the required data conversion
  • The availability of expert staff for re-engineering

Advantages of Re-engineering: 

  • Reduced Risk: As the software is already existing, the risk is less as compared to new software development. Development problems, staffing problems, and specification problems are lots of problems that may arise in new software development. 
  • Reduced Cost:  The cost of re-engineering is less than the cost of developing new software.
  • The revelation of Business Rules:  As a system is re-engineered, business rules that are embedded in the system are rediscovered.
  • Better use of Existing Staff: Existing staff expertise can be maintained and extended to accommodate new skills during re-engineering.

Disadvantages of Re-engineering: 
  • Practical limits to the extent of re-engineering.
  • Major architectural changes or radical reorganizing of the systems data management has to be done manually.
  • The re-engineered system is not likely to be as maintainable as a new system developed using modern software Re-engineering methods. 

Comments

Popular posts from this blog

Suppose that a data warehouse for Big-University consists of the following four dimensions: student, course, semester, and instructor, and two measures count and avg_grade. When at the lowest conceptual level (e.g., for a given student, course, semester, and instructor combination), the avg_grade measure stores the actual course grade of the student. At higher conceptual levels, avg_grade stores the average grade for the given combination. a) Draw a snowflake schema diagram for the data warehouse. b) Starting with the base cuboid [student, course, semester, instructor], what specific OLAP operations (e.g., roll-up from semester to year) should one perform in order to list the average grade of CS courses for each BigUniversity student. c) If each dimension has five levels (including all), such as “student < major < status < university < all”, how many cuboids will this cube contain (including the base and apex cuboids)?

Suppose that a data warehouse consists of the three dimensions time, doctor, and patient, and the two measures count and charge, where a charge is the fee that a doctor charges a patient for a visit. a) Draw a schema diagram for the above data warehouse using one of the schemas. [star, snowflake, fact constellation] b) Starting with the base cuboid [day, doctor, patient], what specific OLAP operations should be performed in order to list the total fee collected by each doctor in 2004? c) To obtain the same list, write an SQL query assuming the data are stored in a relational database with the schema fee (day, month, year, doctor, hospital, patient, count, charge)

Discuss classification or taxonomy of virtualization at different levels.