Download presentation
Presentation is loading. Please wait.
1
5.1/68 The Tools of The Trade
2
5.2/68 Overview l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
3
5.3/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
4
5.4/68 Stepwise Refinement (SR) … l SR is a basic principle that underlying many SW engineering techniques: –“Postpone decisions as to details as late as possible to be able to concentrate on the important issues.”, Or, –“Decide early on the key point area…”, Or, –“Technique for prioritizing the various problems that have to be solved within a phase“, l Some people are doing it naturally, the rest of us – got to work hard to obtain this.
5
5.5/68 Stepwise Refinement (SR) … l Miller’s law (1956): “A human being can concentrate on 7±2 chunks of information at a time.”, –On how many things do we have to concentrate while developing SW? And good SW?,
6
5.6/68 SR – Case Study … l Problem is simple – concentrate on the SR process, l Design a product to update a sequential master file containing name and address data for monthly magazine “true life SW disasters”, Abel….. Brown….. James….. Jones…. Smith…. Townsend… Abel…. Harris… James.. Smith….. Townsend… Old Master File New Master File,
7
5.7/68 SR – Case Study (Cont’d) l Three types of transactions: –Type 1:INSERT (new subscriber into master file), –Type 2:MODIFY (existing subscriber record), –Type 3:DELETE (existing subscriber record), l Transactions are sorted into alphabetical order, and by transaction code within alphabetical order.
8
5.8/68 Typical File of Input Transactions Delete Insert Update Delete Insert,
9
5.9/68 Decompose Process l No further refinement is possible,
10
5.10/68 First Refinement l Take couple of minutes to define the process algorithm.
11
5.11/68 SR – Case Study (Cont’d) l Assumption –We can produce a record when PROCESS requires it l Separate INPUT and OUTPUT, concentrate on PROCESS l What is this PROCESS?,
12
5.12/68 The Process… l Transaction record key = old master record key: –1: INSERT – print error message, –2: MODIFY – change master file record, –3: DELETE – delete master file record, l Transaction Record Key > Old Master Record Key: –Copy old Master File Record onto new Master File, l Transaction Record Key < Old Master Record Key: –1: INSERT – Write Transaction Record to new Master File, –2: MODIFY – Print error message, –3: DELETE – Print error message.
13
5.13/68 Second Refinement
14
5.14/68 SR – Case Study (Cont’d) l Input and output have been deferred, l No provision for end-of-file, l No specification for error condition.
15
5.15/68 Third Refinement This design has a major fault… Where? …
16
5.16/68 SR – Case Study (Cont’d) l The third refinement is WRONG: –“Modify JONES” followed by “delete JONES”, the modified record is already written to the new master file, l We need to go only one step back, l After the third refinement has been corrected: –Details like opening and closing files have been ignored up to now, –Fix after the logic of the design is complete, –The stage at which an item is handled is vital, l Opening and closing files is: –Ignored in early steps, but, –Essential later.
17
5.17/68 Appraisal of SR l A basic principle used in: –Every phase, –Every representation, l The power of SR: –We may concentrate on the relevant aspects, l Problem –What must be handled now?, –What my be deferred?, l Warning: –Miller’s law is a fundamental restriction on the mental powers of human beings.
18
5.18/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
19
5.19/68 Cost–benefit – Glossary l Payback period, l Return on investment – ROI, l Investment cost (lands, building, equipment, HW, SW…), l Operational costs (salaries, wages, consumable, electricity…), l Tangible benefits: –Measured in $ terms: increase profits, revenue, l Intangible benefits: –Goodwill, confidence, consumer preference, reputation etc.
20
5.20/68 Cost–benefit – Analysis … l Compare estimated future benefits, costs: –Estimate costs, –Estimate benefits, –State all assumptions explicitly especially for intangible benefits!!, l Build or buy the system – or invest elsewhere, l If build/buy – which project to implement first?
21
5.21/68 Cost–benefit – Analysis (Cont’d) … l Indicators: –Time to recover cost? –Average profit per year? –Net profit over life of investment? –Discounted value of future cash flows from investment?, l Cash flow –Given a set of costs and returns: –ADD returns, –SUBTRACT costs.
22
5.22/68 Cost–benefit – Analysis (Cont’d) … l Payback period (P.P.): –If I invest x$ in a project, with an average annual return of y$, how long before I return my investment?, Investment (x$) P.P. = Average Annual Return (y$), l Return On Investment (ROI): –If I invest x$ in a project, with an average annual return of y$, What is the return on my investment?, Average Annual Return (y$) ROI = Investment (x$)
23
5.23/68 Cost–benefit – Example 1 … l KCEC – Krag central electric company (1965), l Manual billing system: –Mailing bills every two month, –Billing department with 80 clerks, l Computerized billing system: –Mailing bills each month (improved cash flow – 875K$), –Buy / lease HW & SW (1,250K$), –Billing department with 11 data capture clerks, –New data processing department (salary savings 1,575K$), –1 st year conversion cost (350K$) –Explaining change to customers (125K$), l 1,725k$ VS. 2,475k$.
24
5.24/68 Cost–benefit – Example 1 (Cont’d) CostsBenefits System cost (7 yr.) 1,250K$ Improved Cash Flow – 875K$ Conversion – 350K$Salary Savings – 1,575K$ Customers support – 125K$ Total – 1,725K$Total – 2,450K$
25
5.25/68 Cost–benefit – Example 2 l A new accounting system costs 80K$. The system will save: 10K$ in the 1 st year, 25K$ in the 2 nd year, 25K$ in the 3 rd year, and 30K$ in the 4 th year. l What is the payback period? YearReturnProfit (Loss) 110K$(70K$) 225K$(45k$) 325K$(20K$) 430K$10K$ Payback 2/3 way into year 4. I.e. 3.67 years
26
5.26/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
27
5.27/68 SW Metrics – The Importance l Without measurement it is impossible to detect problems early in the development process, l To detect problems early, it is essential to measure, l Examples: –LOC per month (coding rate), –Defects per 1000 lines of code (FPKLOC), –Mean Time Between Failures (MTBF), –Staff turnover, –Cost.
28
5.28/68 Different Types of Metrics l Product metrics –Examples: Size of product (e.g. LOC), Reliability of product (MTBF), l Process metrics: –Example: Efficiency of fault detection during development, l Metrics specific to a given phase: –Example: Number of defects detected per hour in specification reviews.
29
5.29/68 The Five Basic Metrics l Size: –In lines of code, l Cost: –In dollars, l Duration: –In months, l Effort: –In person months, l Quality: –Number of faults detected.
30
5.30/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
31
5.31/68 CASE (Computer-aided SW Engineering) l Scope of CASE: –Support the entire SW life-cycle, l Graphical display tools (many for PCs) –Data flow diagrams, –Entity-relationship diagrams, –Module-interconnection diagrams, –Structure charts.
32
5.32/68 CASE – Taxonomy l Uppercase (front-end) versus lowercase (back-end), UpperCASE LowerCASE l Tool versus workbench versus environment,
33
5.33/68 CASE – Graphical Tool l Additional features: –Data dictionary – all data defined within the product, –Consistency checker: The various views are always consistent, –Specifications and design workbench, –Screen and report auto-generators, l Online documentation –Saving trouble with Manuals (tedious work…), Updating, l Essential online documentation –Help information, –Programming standards, –Manuals (UNIX man for example).
34
5.34/68 CASE – Data Dictionary l Data dictionary –RequisitePro® [Rational],Rational
35
5.35/68 CASE – Essential Coding Tools l Products (such as text editors, debuggers, and pretty printers) designed to: –Simplify programmer’s task, –Reduce frustration, –Increase programmer productivity.
36
5.36/68 CASE – Syntax-directed Editor l A structure editor – “understands” language: l Detecting syntax faults – as soon as it keyed, l Speeds up implementation, l User interface of an editor is different to that of a compiler: There is no need to change thinking mode, No mental energy is wasted on these adjustments, l One piece of system SW, two languages: –High-level language of module, –Editing command language, l Pretty-printer.
37
5.37/68 CASE – Online Interface Checker … l Example –The programmer tries to call procedure computeAverage, but the linker cannot find it, –The programmer realizes that the actual name of the procedure is computeMean, l A structure editor must support online interface checking, –Editor must know name of every procedure, l Interface checking is an important part of programming-in-the-large.
38
5.38/68 CASE – Online I/f. Checker (Cont’d)… l Example: –The user enters the call: Average = computeAverage (dataArray, numberOfValues); –Editor immediately responds with a message such as “Procedure computeAverage not known”, l Programmer is given two choices: –Correct the name of the procedure, –Declare new procedure computeAverage and specify its parameters, l Enables full interface checking.
39
5.39/68 CASE – Online I/f Checker (Cont’d) … l Example –Declaration of q is Void q (float floatVar, int intVar, string s1, string s2); –Call (invocation) is q (intVar, floatVar, s1, s2); –Online interface checker detects the fault, l Help facility: –Online information as to parameters of method q : –Or, even better: editor generates a template for the call: Shows type of each parameter, Programmer replaces formal by actual parameter.
40
5.40/68 CASE – Online I/f. Checker (Cont’d) … l Advantages: –No need for different tools with different interfaces, –Hard-to-detect faults are immediately flagged for correction: Wrong number of parameters, Parameters of wrong type, l Essential when SW is produced by a team: –If one programmer changes the interface specification, all modules calling that changed module must be disabled.
41
5.41/68 CASE – Online I/f. Checker (Cont’d) l Remaining problem: –The programmer still has to exit from the editor to invoke the compiler (to generate code), –Then, the linker must be called to link the product, –Must adjust to the JCL, compiler, and linker output.
42
5.42/68 CASE – OS Front-end in Editor … l Single command: –Go or run, –Use of the mouse to choose icon, or menu selection, l Causes editor to invoke the compiler, linker, loader, and execute the product.
43
5.43/68 CASE – OS Front-end in Editor (Cont’d) l Online documentation: –Help information regarding: Operating system, Editor, Programming language, –Programming standards, –Manuals: Editor manuals, Programming manuals.
44
5.44/68 CASE – Source Level Debugger … l Example: –Product executes terminates abruptly and prints: Overflow at 4B06, Core dumped, Segmentation fault
45
5.45/68 CASE – Source Level Debugger (Cont’d) l The programmer works in a high-level language, but must examine: –Machine code core dumps, –Assembler listings, –Linker listings, –Similar low-level documentation, l Destroys the advantage of programming in a high- level language, l We need Interactive source level debugger (like UNIX dbx).
46
5.46/68 CASE – Programming Workbench … l Structure editor with: –Online interface checking capabilities, –Operating system front-end, –Online documentation, –Source level debugger, l Constitutes a simple programming environment … Overflow Error Class:CyclotronEnery Method:performComputation Line6:newValue= (oldValue + temValue)*tempValue; oldValue:3.9583 tempValue:0.0000
47
5.47/68 CASE – Programming Workbench (Cont’d) l This is by no means new! –All the above features are supported by FLOW (1980), –The technology has been in place for years, Surprisingly, some programmers still implement code the old-fashioned way.
48
5.48/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
49
5.49/68 SW Versions l During maintenance, at all times there are at least two versions of the product: –The old version, and –The new version, l Two types of versions (גרסה): revisions מהדורה – and variations שוני –.
50
5.50/68 Revisions and Variations … l Revision: Version to fix a fault in the module, l We cannot throw away an incorrect version: – New version might be erroneous, –It might be that not all sites moved to the latest version, l Perfective and adaptive maintenance also results in revisions.
51
5.51/68 Revisions and Variations (Cont’d) … l Variation: –Version for different operating system–hardware, –Variations are designed to coexist in parallel e.g. Drivers for different printers, Revisions,Variations
52
5.52/68 Revisions and Variations (Cont’d) PrinterDriver(inkJet)10 PrinterDriver(laser)/15, PrinterDriver(laser)/16,PrinterDriver(laser)/17, Two Variations of PrinterDriver() and, Three revisions of PrinterDriver(laser)
53
5.53/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
54
5.54/68 Configuration Control l Every module exists in three forms –Source code; –Object code; –Executable load image, l Configuration: –Version of each module from which a given version of a product is built.
55
5.55/68 Version Control Tool... l Suppose SQA report a failure in version 2.5: –Do you know version of each module?, –Is it feasible?, l Essential for team- programming –First step toward configuration management, l Must handle: –Updates, –Parallel versions.
56
5.56/68 Version Control Tool (Cont’d) l Possible notation: –name( variation) / version –printerDriver (laser) / 13 –printerDriver (inkjet) / 25 –What if a failure in printerDriver (laser) / 13 is to fixed as well in printerDriver (inkjet) / 25 ?, l Problem of multiple variations –Deltas – we define newer code by its ‘deltas’, l Version control is not enough — maintenance issues.
57
5.57/68 Configuration Control and Maintenance l Two programmers, Dan & Ron, are assigned to fix different bugs, l The two programmers tracked the bug to the same module mDual / 15. –Dan made his copy – mDual / 16. –Ron made his copy – mDual / 17. –Both fixed some bugs! –What’s next?
58
5.58/68 CM – Example … mDual15… mDual16… mDual17
59
5.59/68 mDual15 … CM – Example (Cont’d) mDual17 … mDual16
60
5.60/68 CC and Maintenance … l Baselines: –Configuration of all the modules that are in the product, –Programmers work in their private workspaces, –Once accomplished – freezing, –Setting a new baseline, l Configuration control during development: –Many versions through coding/testing, –Informal testing, –SQA… - same as maintenance configuration.
61
5.61/68 CC and Maintenance l Commercial tools: –Rational ClearCase,ClearCase –Unix: RCS Revision Control System, CVS Concurrent Versions System, RCS CVS –PC : Synergex PVCS,PVCS –Comparison….Comparison
62
5.62/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
63
5.63/68 Build Tools l Compares the date and time stamp on: –Source code, object code, –Object code, executable load image, l Example: –UNIX make,make l Can check dependencies: –Ensures that correct versions/variations are compiled and linked.
64
5.64/68 l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
65
5.65/68 Productivity Gains With CASE Tools … l Survey of 45 companies in 10 industries [Myers, 1992] –Half information systems, –Quarter scientific, –Quarter real-time aerospace, l Results –About 10% annual productivity gains, –$125,000 per seat!
66
5.66/68 Productivity CASE (Cont’d) l Justifications for CASE: –Improved productivity, –Faster development, –Improved SW quality, –Fewer faults, –Better usability, –Easier maintenance, –Improved morale (once the tools are systematically taught!), l CASE environment should not be used at maturity levels 1 or 2, l “A fool with a tool is still a fool”.
67
5.67/68 Summary l Stepwise refinement, l Cost–benefit analysis, l SW metrics, l Case – Taxonomy of CASE, – Scope of CASE, l SW versions, l Configuration control, l Build tools, l Productivity Gains With CASE Tools.
68
5.68/68 The Tools of The Trade The End
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.