Applied Research Notes (July-August 2011)
Contents
Peter Liu's Applied Research Proposal (July - August 2011)
The goal of my research activity is to create a knowledge base at CDOT-Seneca such that new research students can go through a shorter learning curve in working with the huge code base of NexJ Model Server Express. The knowledge base will also benefit the open source community of developers who want to make contributions to the NexJ code base. UML modelling is the foundation of the NexJ approach to model-driven engineering [1] and UML diagrams are concept maps [2]. Thus the focus of my research is to develop a conceptual understanding of the huge code base of NexJ Model Server Express. It is envisioned that some concept maps will be constructed to visualize the architectural aspect of the NexJ code base.
During the process of creating the knowledge base, I would like to build an Eclipse tool to mine useful concepts from the NexJ code base. I will begin with the Eclipse Diver tool as presented by Del Myers at EclipseCon 2011. [3] Later I will try out other open source tools that are built for reverse engineering and program comprehension.
Documents Provided by NexJ
- Introduction To NexJ Studio Express (open sourced, available on Open Health Tools Platform)
- NexJ Studio Fundamentals (confidential and proprietary)
- Working with NexJ Express Source Code (open sourced, available on Open Health Tools Platform)
- NexJ Studio - Integration Fundamentals (confidential and proprietary)
Mining NexJ Concepts From the NexJ Training Tutorial Documents
- Question: Where should one start if one wants to get a conceptual understanding of the code base of NexJ Model Server Express?
- Research Notes
Mining NexJ Concepts From the Practical Experience of Research Students
- a process of knowledge transfer
- discovery of tacit knowledge in software development [4]
- use of qualitative research technique as adopted in software engineering research [5] [6]
- interview with Brian Lim (JSON Integration Adapter)
- interview with Grace Batumbya (JSON RPC Adapter, PostgreSQL Adapter)
- Reference
- An Exploratory Study of How Developers Seek, Relate, and Collect Revevant Informaiton during Software Maintenance Tasks. IEEE Transactions of Software Engineering, 32(12), 2006, pp. 971-987.
Conceptual Comprehension of the Code Base
- Goal: Understand the architecture design of NexJ Framework, especially the Persistence Engine and the Integration Engine.
- Identify class dependencies, manually and automatically (use of open soruce tools)
- Research Question: What concepts have been implemented in the code base?
- first attempt: use of the Eclipse Diver tool
- References
- Lethbridge, T. C., & Anquetil, N. (1997). Architecture of Source Code Exploration Tools: A Software Engineering Case Study. University of Ottawa.
The Integration Engine
- the NexJ Message concept
- the NexJ Channel concept
- the NexJ Transformation concept
The Persistence Engine
Resourcess
Open Source Tools for Reverse Engineering
- Put It In Reverse: Using Eclipse to Understand Code that has Already Been Written (EclipseCon 2011) [7]
- Eclipse plugin or a Open source tool to reverse engineer java code for sequence diagram [8]
Open Source Tools for Modelling Concepts
- From XML to Form to Diagram with Sapphire [9]
- Eclipse Sapphire project [10]
- Free mind mapping software [11]
Concept Maps and Software Engineering
- Concept Map Based Software Engineering (2007) [12] [13]
- Research on the Application of the Concept Map to Software Engineering Teaching (2009) [14]
- Using Concept Mapping to Facilitate Students Understanding Software Testing [15]
- Are concept-mapping tools useful for software analysis and design? [16]
- Mind Mapping and the Software Development Life Cycle (2006) [17]
- Using concept mapping for maintainability assessments (2009) [18]
- The concept maps method as a tool to evaluate the usability of APIs (2011) [19]
- Representing concerns in source code (2007) [20]
- Architectural Element Matching Using Concept Analysis (1999) [21]
- Automatic extraction of framework-specific models from framework-based application code (2007) [22]
- Program representation and behavioural matching for localizing similar code fragments (1993) [23]
- Towards Automatic Establishment Of Model Dependencies Using Formal Concept Analysis (University of Waterloo, 2005) [24]
- model-driven software evolution
- An Ontology-Based Program Comprehension Model (Concordia University, 2007) [25]
- knowledge acquisition and the construction of mental models
- recovery of design patterns
- architecture analysis of InfoGlue (an open source CMS)
- traceability links
- exploration of inline javadoc comments
- use of an Eclipse plugin SOUND
Reverse Engineering (and Design Recovery)
- Reverse Engineering: A Roadmap (2000) [26]
- Rerverse Engineering: From Artifacts to Concepts (2005) [27]
- Code understanding, reverse engineering, best concepts and tools. Java [28]
- A Comparison of Graphs of Concept for Reverse Engineering [29]
- A Unified Meta-Model for Concept-Based Reverse Engineering [30]
- View-Based Reverse Engineering Approach for Enhancing Model Interoperability and Reusability in Process-Driven SOAs [31]
- Reverse Engineering Domain Models from Source Code [32]
Concern-Oriented Software Engineering
- FEAT: An Eclipse Plug-in for Locating, Describing, and Analyzing Concerns in Source Code [33]
- The Eclipse Mylyn Project [34]
- An Agenda for Concern-Oriented Software Engineering (2010) [35]
- Concern Graphs (University of British Columbia) [36]
- Separating Software Engineering Concerns (University of Twente) [37]