Sadp Unit 2 Modified

Download as pdf or txt
Download as pdf or txt
You are on page 1of 3

2.

Architecture Tradeoff Analysis Method (ATAM)

The ATAM is so named because it reveals how well architecture satisfies particular quality
goals, and it provides insight into how quality goals interact? That is, how they trade off. The
ATAM is designed to elicit the business goals for the system as well as for the architecture. It is
also designed to use those goals and stakeholder participation to focus the attention of the
evaluators on the portion of the architecture that is central to the achievement of the goals.

2.1 Participantsinthe ATAM:


The ATAM requires the participation and mutual cooperation of three groups:

The evaluation team: This group is external to the project whose architecture is being
evaluated. It usually consists of three to five people. Each member of the team is assigned
a number of specific roles to play during the evaluation.
Project decision makers: These people are empowered to speak for the development
project or have the authority to mandate changes to it. They usually include the project
manager, and, if there is an identifiable customer who is footing the bill for the
development, he or she will be present (or represented) as well.
Architecture stakeholders: Stakeholders have a vested interest in the architecture
performing as advertised. They are the ones whose ability to do their jobs hinges on the
architecture promoting modifiability, security, high reliability, or the like. Stakeholders
include developers, testers, integrators, maintainers, performance engineers, users,
builders of systems interacting with the one under consideration, and others.

Role Responsibilities Desirable characteristics

Sets up the evaluation; coordinates with Well-organized, with managerial


Team Leader client, making sure client's needs are skills; good at interacting with
met; establishesevaluationcontract; client; ableto meet deadlines
Runs evaluation; facilitates elicitation of Comfortable in front of
Scenarios; Administers scenario audience; excellent facilitation
Evaluation Leader
selection/prioritization process; skills; good understanding of
architectural issues
Writes scenarios on flipchart or Good handwriting; stickler about
Scenario Scribe
whiteboard during scenario elicitation;|not moving on before an idea
IVB. Tech I Semester (R16) 2019-20 2

SOFTWARE ARCHITECTURE AND DESIGN PATTERNS


UNIT-II
captures agreed-on wording of each (scenario) is captured; can
scenario, halting discussion until exact absorb and distill the essence of
wording is captured technical discussions
Captures proceedings in electronic form | Good, fast typist; well organized
Proceedings Scribeon laptop or workstation, raw scenarios, for rapid recall of information;
issue(s) that motivate each scenario good understanding of

architectural issues;
Helps evaluation leaderstay on schedule; Willing to interrupt discussion to
helps control amount of time devoted to call time
Timekeeper each scenario during the evaluation
phase
Keeps notes on how evaluation process Thoughtful observer,
could be improved or deviated from: knowledgeable in the evaluation
Process Observer usually keeps silent but may make| process; should have previous
discreet process-based suggestions to the experience in the architecture
evaluation leader during the evaluation;evaluation method
Helps evaluation leader remember and Fluent in the steps of the method, |
carry out the steps of the evaluation and willing and able to provide
Process Enforcer
method discreet guidance to the
evaluation leader
Raise issues of architectural interest that Good architectural insights; good
stakeholders may not have thought of insights into needs of
stakeholders; experience with
Questioner systems in similar domains;
unafraid to bring up contentious
issues and pursue them; familiar
with attributes of concern
2.3 Phases ofthe ATAM: Activities in an ATAM-based evaluation are spread out over four
phases.

Phase Activity Participants Typical duration

Partnership and preparation: Proceeds informally as


Logistics, planning, Evaluation team leadership and
0 required, perhaps over
stakeholder recruitment, key project decision-makers
a few weeks
team formation
Evaluation team and project 1-2 days followed by a
Evaluation: Steps 1-6 decision-makers hiatus of 2-3 weeks
Evaluation team, project 2 days
2 Evaluation: Steps 7-9
| decisionmakers,stakeholders
Follow-up: Report Evaluation team and evaluation
3 generation and delivery, I week
client
process improvement

2.4 Steps of the Evaluation Phases

1. Present the ATAM (0 hours): Participants already familiar with process.


2. Present business drivers (0.25 hours): The participants are expected to understand the
system and its business goals and their priorities. A brief review ensures that these are fresh in
everyone's mind and that there are no surprises.
3. Present architecture (0.5 hours): All participants are expected to be familiar with the
system. A brief overview of the architecture, using at least module and C&C views, is presented.
1-2 scenarios are traced through these views.
4. Identify architectural approaches (0.25 hours): The architecture approaches for specific
quality attribute concerns are identified by the architect. This may be done as a portion of step 3.
5. Generate QA utility tree (0.5-1.5hours): Scenarios might exist: part of previous evaluations,
part of design, part of requirements elicitation. Put these in a tree. Or, a utility tree may already
exist.

6. Analyze architectural approaches (2-3 hours): This step-mapping the highly ranked
scenarios onto the architecture-consumes the bulk of the time and can be expanded or
contracted as needed.
7. Brainstorm scenarios (0 hours): This step can be omitted as the assembled (internal)
stakeholders are expected to contribute scenarios expressing their concerns in step 5.

IVB. Tech I Semester (R16) 2019-20

SOFTWARE ARCHITECTURE AND DESIGN PATTERNS


UNIT-II
8. Analyze architectural approaches (0 hours): This step is also omitted, since all analysis is
done in step 6.
9. Present results (0.5 hours): At the end of an evaluation, the team reviews the existing and
newly discovered risks, non-risks, sensitivities, and tradeoffs and discusses whether any new risk
themes have arisen.
3. Cost Benefit Analysis Method (CBAM)
The software architect or decision maker wishes to maximize the difference between the benefit
derived from the system and the cost of implementing the design. The CBAM begins where the
ATAM concludes and, in fact, depends upon the artifacts that the ATAM produces as output.
Figure 1 depicts the context for the CBAM.

Performance

Businesss Architecture
Security
Goals Strategies Benefit
Modifiability
Usability
Cost

Figure 1: Depicts the context for the CBAM

Implementingthe CBAM
A process flow diagram for the CBAM is given in Figure 12.3. The first four steps are annotated
with the relative number of scenarios they consider. That number steadily decreases, ensuring
that the method concentrates the stakeholders' time on the scenarios believed to be of the greatest
potential in terms of ROI.
Step 1: Collate scenarios: Collate the scenarios elicited during the ATAM exercise, and give
the stakeholders the chance to contribute new ones. Prioritize these scenarios based on satisfying
the business goals of the system and choose the top one-third for further study.
Step 2: Refine scenarios: Refine the scenarios output from step 1, focusing on their stimulus-
response measures. Elicit the worst-case, current, desired, and best-case quality attribute
response level for each scenario.
Step 3: Prioritize scenarios: Allocate 100 votes to each stakeholder and have them distribute
the votes among the scenarios, where their voting is based on the desired response value for each
scenario. Total the votes and choose the top 50% of the scenarios for further analysis. Assign a
weight of 1.0 to the highest-rated scenario; assign the other scenarios a weight relative to the
highest rated. This becomes the weighting used in the calculation of a strategy's overall benefit.
Make a list of the quality attributes that concern the stakeholders.
Step 4: Assign utility: Determine the utility for each quality attribute response level (worst-case,
current, desired, and best-case) for the scenarios from step3.

IVB. Tech I Semester (R16) 2019-20 5

sOFTWARE ARCHITECTURE AND DESIGN PATTERNS


UNIT-II
Step 5: Develop architectural strategies for scenarios and determine their expected quality
attribute response levels: Develop (or capture already developed) architectural strategies that
address the chosen scenarios and determine the "expected" quality attribute response levels that
will result from them. Given that an architectural strategy may have effects on multiple
scenarios, we must perform this calculation for each scenario affected.
Step 6: Determine the utility of the "expected" quality attribute response levels by
interpolation: Using the elicited utility values (that form a utility curve), determine the utility of
the expected quality attribute response level for the architectural strategy. Do this for each
relevant quality attribute enumerated in step 3.
Step 7: Calculate the total benefit obtained from an architectural strategy: Subtract the
utility value of the "current" level from the expected level and normalize it using the votes
elicited in step 3. Sum the benefit due to a particular architectural strategy across all scenarios
and across all relevant quality attributes.
Step 8: Choose architectural strategies based on ROI subject to cost and schedule
constraints: Determine the cost and schedule implications of each architectural strategy.
Calculate the ROI value for each as a ratio of benefit to cost. Rank-order the architectural
strategies according to the ROI value and choose the top ones until the budget or schedule is
exhausted.
Step 9: Confirm results with intuition: For he chosen architectural strategies, consider
whether these seem to align with the organization's business goals. If not, consider issues that
may have been overlooked while doing this analysis. If there are significant issues, perform
another iteration of these steps.

You might also like