Presentation is loading. Please wait.

Presentation is loading. Please wait.

Informatics 223 Applied Software Design Techniques

Similar presentations


Presentation on theme: "Informatics 223 Applied Software Design Techniques"— Presentation transcript:

1 Informatics 223 Applied Software Design Techniques
Lecture 1 Duplication of course material for any commercial purpose without the explicit written permission of the professor is prohibited.

2 Today Logistics Course goals Defining design Onward

3 Logistics http://www.ics.uci.edu/~andre/informatics223s2017.html
Professor: André van der Hoek No required book

4 Logistics Office hours by appointment Open door policy DBH 5038

5 Course goals To know the theory of software design
To become fluid in using a representative set of software design techniques To understand how to examine existing software designs To learn the practices of expert software designers

6 Structure of the course
Lecture (some) Discussion (lots) Case study (one, ongoing) Design practice (several) No midterm or final

7 Questions

8 Defining design Decision making, in the face of uncertainty, with high penalties for error To choose the things we use shall look as they do A creative activity—it involves bringing into being something new and useful that has not existed previously Relating product with situation to give satisfaction The imaginative jump from present facts to future possibilities To form a plan or scheme of, to arrange or conceive in the mind, … for later execution

9 Defining design To initiate change in man-made things
To plan or intend for a purpose To work out a solution in one’s mind The transition from possible solutions to a specific one

10 Three themes Design focuses on identifying a novel envisioned future
Design involves deliberate decision making and planning; it is not simply acting out of impulse Design decisions are consequential: there are stakeholders who must be satisfied with the result

11 Our definition To decide upon a plan for a novel change in the world that, when realized, satisfies stakeholders But as we did so opportunistically, we quickly figured out we needed something to frame the discussion, what are they doing when they are doing this? So we arrived at design behaviors – things they do, things that recur, and things that have a definite purpose in the design meeting with respect to advancing the design at hand.

12 Design designer plan maker change in the world other stakeholders
audience experiences

13 Design a luxury airplane
designer plan maker change in the world other stakeholders audience experiences

14 Design a library designer plan maker change in the world
other stakeholders audience experiences

15 Design an award designer plan maker change in the world
other stakeholders audience experiences

16 Design fields Architecture design Graphic design Fashion design
Game design Chip design Car design Urban design Product design Interior design

17 Design fields Architecture design Graphic design Fashion design
Game design Chip design Car design Urban design Product design Interior design Writing Painting Sculpting Music composition

18 Design fields Architecture design Graphic design Fashion design
Game design Chip design Car design Urban design Product design Interior design Writing Painting Sculpting Music composition Software design

19 Design designer plan maker change in the world other stakeholders
audience experiences

20 Software design software designer source code compiler*
runnable program other stakeholders users experiences [* or, at times, the person who installs and configures the software instead of the compiler]

21 Feasibility and desirability
designer plan maker change in the world other stakeholders audience experiences

22 Feasibility and desirability
designer plan maker change in the world other stakeholders audience experiences desirability

23 Four types of design desirability feasibility
what is it to accomplish? how does one interact with it? desirability feasibility what is its conceptual core? what are its implementation details?

24 Four types of design what is it to accomplish? satisfactory experience
how does one interact with it? satisfactory experience plan for realization change in the world what is its conceptual core? what are its implementation details?

25 Four types of software design
what is it to accomplish? how does one interact with it? application design satisfactory experience plan for realization interaction design change in the world what is its conceptual core? what are its implementation details? architecture design implementation design

26 Design an instant message system
what is it to accomplish? how does one interact with it? application design satisfactory experience plan for realization interaction design change in the world what is its conceptual core? what are its implementation details? architecture design implementation design

27 Design a word processor
what is it to accomplish? how does one interact with it? application design satisfactory experience plan for realization interaction design change in the world what is its conceptual core? what are its implementation details? architecture design implementation design

28 Design cycle synthesize analyze evaluate

29 Design cycle goals constraints assumptions decisions ideas synthesize
analyze evaluate

30 Goals A goal represents an explicit acknowledgment of a desired result that the eventual design solution must achieve Goals may be suggested by any of the stakeholders client other stakeholders audience designer Goals change over time, and may or may not be (partially) addressed by the current state of the design solution

31 Example goals The luxury airplane must be 10% more fuel-efficient than its predecessor The library must be able to hold 250,000 books The award must be representative of the professional society that is commissioning it

32 Constraints A constraint represents an explicit acknowledgment of a condition that restricts the design project Constraints may be suggested by any of the stakeholders client other stakeholders audience designer Constraints change over time, and may or may not be (partially) met by the current state of the design project

33 Example constraints The luxury airplane must weigh less than 50,000 pounds The library must not violate federal disability laws The award must cost less than $1000 to produce

34 Assumptions An assumption represents a fact that is taken for granted, may or may not be true, and influences the design project Assumptions may be made by any of the stakeholders client other stakeholders audience designer Assumptions change over time, and may or may not be (partially) fulfilled by the current state of the design project

35 Example assumptions The average person weighs 85 kilograms
The library needs to serve the community with an area stocked with personal computers The professional society’s logo is red and white, which therefore must be its preferred colors for the award

36 Decisions A decision represents a specific choice of how to further the design solution, typically after some amount of consideration Decisions are the sole responsibility of the designer, though they can be (heavily) influenced by other stakeholders Decisions change over time, and new decisions may or may not (partially) align with the current state of the design project

37 Example decisions The fuselage and wings of the luxury airplane shall be made out of carbon composites The library shall have bookshelves that are not movable The award shall be made out of colored glass

38 Idea An idea represents a thought or opinion, ranging from highly unformed to fully formed, that potentially shapes the design solution Ideas typically are the sole responsibility of the designer, though they may be inspired by many different sources Ideas change over time, and new ideas may or may not (partially) align with the current state of the design project

39 Example ideas What if the luxury airplane had a shower on board?
Perhaps the library membership cards should have RFID tags, so a visitor can simply grab the books they want, walk by an automated scanner, and have their books be on loan I am thinking that the award should be a variant of last year’s award

40 Design an instant message system
synthesize goals constraints assumptions decisions ideas analyze evaluate

41 Design a word processor
synthesize goals constraints assumptions decisions ideas analyze evaluate

42 Design the software to fly a drone
synthesize goals constraints assumptions decisions ideas analyze evaluate

43 Routine, adaptive, and original design projects
high original complexity adaptive routine low high low familiarity

44 Design an instant message system
high original complexity adaptive routine low high low familiarity

45 Design a word processor
high original complexity adaptive routine low high low familiarity

46 Design the software to fly a drone
high original complexity adaptive routine low high low familiarity

47 Design is difficult!

48 In this class… …we introduce the practices of expert software designers that help ameliorate these difficulties …we study core ways in which software designers structure their solutions …we practice!

49 Our focus application design interaction design architecture design
what is it to accomplish? how does one interact with it? application design satisfactory experience plan for realization interaction design change in the world what is its conceptual core? what are its implementation details? architecture design implementation design

50 Onward Choose, and have approved by me via by Friday April 7, noon, a software system that is 100,000 lines of code or greater. This will be the subject of your case study, throughout the quarter. Read all of the papers listed on the web site for April 6. Prepare four questions, observations, or assertions about the papers and their overall content (printed, with name and student id).


Download ppt "Informatics 223 Applied Software Design Techniques"

Similar presentations


Ads by Google