Software Design Designer clothes?. Outline Announcements: –Homework I on web, due Wed., 5PM by e-mail –Starting Friday, Wed. and Fri. lectures will meet.

Slides:



Advertisements
Similar presentations
Component 4: Introduction to Information and Computer Science Unit 5: Overview of Programming Languages, Including Basic Programming Concepts Lecture 1.
Advertisements

CHAPTER 1 SOFTWARE DEVELOPMENT. 2 Goals of software development Aspects of software quality Development life cycle models Basic concepts of algorithm.
Computers Are Your Future
© Janice Regan, CMPT 102, Sept CMPT 102 Introduction to Scientific Computer Programming The software development method algorithms.
Programming System development life cycle Life cycle of a program
CIS 404: Survey and Use of Software Libraries for Scientific Computing Andrew Pershing 3134 Snee Hall
Computers: Tools for an Information Age
Lecture Notes 1/21/04 Program Design & Intro to Algorithms.
- Chaitanya Krishna Pappala Enterprise Architect- a tool for Business process modelling.
Introduction to Programming G50PRO University of Nottingham Unit 1 : Introduction Paul Tennent
Introduction to High-Level Language Programming
Software Construction. Implementation System Specification Requirements Analysis Architectural Design Detailed Design Coding & Debugging Unit Testing.
CSC 110 A 1 CSC 110 Introduction to Python [Reading: chapter 1]
Introduction 01_intro.ppt
Python Mini-Course University of Oklahoma Department of Psychology Day 1 – Lesson 2 Fundamentals of Programming Languages 4/5/09 Python Mini-Course: Day.
Program development & programming languages Chapter 13.
Programming Languages: Telling the Computers What to Do Chapter 16.
Structured COBOL Programming, Stern & Stern, 9th edition
The NetBeans IDE CSIS 3701: Advanced Object Oriented Programming.
Introduction to M ATLAB EE 100 – EE Dept. - JUST.
Introduction CSE 1310 – Introduction to Computers and Programming Vassilis Athitsos University of Texas at Arlington 1.
Chapter 1 Introduction Dr. Frank Lee. 1.1 Why Study Compiler? To write more efficient code in a high-level language To provide solid foundation in parsing.
Introduction CSE 1310 – Introduction to Computers and Programming Vassilis Athitsos University of Texas at Arlington 1.
Computer Programming A program is a set of instructions a computer follows in order to perform a task. solve a problem Collectively, these instructions.
CMPE13Cyrus Bazeghi 1 Programming Languages Telling computers what to do.
Outline Announcements: –Homework I on web, due Fri., 5PM by –Small error on homework –Wed and Fri in ACCEL, Attendance required –LAST DAY TO ADD/DROP!
CS 403: Development of Scientific Computing Programs Andrew Pershing 3134 Snee Hall
CSE 219 Computer Science III Program Design Principles.
Guide to Programming with Python Chapter One Getting Started: The Game Over Program.
Editing & Compiling: UNIX vs. IDE and an Intro to Architecture.
Lecture 1 Introduction Figures from Lewis, “C# Software Solutions”, Addison Wesley Richard Gesick.
C++ Programming Language Lecture 2 Problem Analysis and Solution Representation By Ghada Al-Mashaqbeh The Hashemite University Computer Engineering Department.
Fundamental Programming: Fundamental Programming K.Chinnasarn, Ph.D.
Problem Solving using the Science of Computing MSE 2400 EaLiCaRA Spring 2015 Dr. Tom Way.
Software Design. Outline Announcements: –Homework I on web Friday –Starting Friday, Wed. and Fri. lectures will meet in ACCEL “Green” Room in Carpenter.
INTRODUCTION TO COMPUTING CHAPTER NO. 04. Programming Languages Program Algorithms and Pseudo Code Properties and Advantages of Algorithms Flowchart (Symbols.
240-Current Research Easily Extensible Systems, Octave, Input Formats, SOA.
The basics of the programming process The development of programming languages to improve software development Programming languages that the average user.
The Software Development Process
EGR 115 Introduction to Computing for Engineers Branching & Program Design – Part 1 Monday 29 Sept 2014 EGR 115 Introduction to Computing for Engineers.
The Hashemite University Computer Engineering Department
Introduction CSE 1310 – Introduction to Computers and Programming Vassilis Athitsos University of Texas at Arlington 1.
1 The Software Development Process ► Systems analysis ► Systems design ► Implementation ► Testing ► Documentation ► Evaluation ► Maintenance.
Outline Announcements: –HW I key online this afternoon –HW II due Friday –Sign up to discuss projects Debugging Testging for correctness.
CMSC 2021 Software Development. CMSC 2022 Software Development Life Cycle Five phases: –Analysis –Design –Implementation –Testing –Maintenance.
Programming. In your own words, explain what an algorithm is, and give an example of how people use algorithms every day.
CIS 401: Applied Scientific Computing with MATLAB Andrew Pershing 3134 Snee Hall
CIS 403: Development of Scientific Computing Programs Andrew Pershing 3134 Snee Hall
Lecture #1: Introduction to Algorithms and Problem Solving Dr. Hmood Al-Dossari King Saud University Department of Computer Science 6 February 2012.
Evolution of C and C++ n C was developed by Dennis Ritchie at Bell Labs (early 1970s) as a systems programming language n C later evolved into a general-purpose.
Program Design. Simple Program Design, Fourth Edition Chapter 1 2 Objectives In this chapter you will be able to: Describe the steps in the program development.
PROGRAMMING FUNDAMENTALS INTRODUCTION TO PROGRAMMING. Computer Programming Concepts. Flowchart. Structured Programming Design. Implementation Documentation.
Ganga/Dirac Data Management meeting October 2003 Gennady Kuznetsov Production Manager Tools and Ganga (New Architecture)
Introduction to Computer Programming Concepts M. Uyguroğlu R. Uyguroğlu.
1 Programming and problem solving in C, Maxima, and Excel.
PROGRAMMING (1) LECTURE # 1 Programming and Languages: Telling the Computer What to Do.
Development Environment
CST 1101 Problem Solving Using Computers
CMIT100 Chapter 14 - Programming.
Topic: Programming Languages and their Evolution + Intro to Scratch
Programming Languages
Lecture 1 Introduction Richard Gesick.
CSCI-235 Micro-Computer Applications
Lecture 2 Introduction to Programming
Introduction CSE 1310 – Introduction to Computers and Programming
Chapter 1 Introduction(1.1)
Language Issues Misunderstimated? Sublimable? Hopefuller?
Chapter 2- Visual Basic Schneider
ICT Gaming Lesson 2.
Chapter 2. Problem Solving and Software Engineering
Presentation transcript:

Software Design Designer clothes?

Outline Announcements: –Homework I on web, due Wed., 5PM by –Starting Friday, Wed. and Fri. lectures will meet in ACCEL “Green” Room in Carpenter Updated Syllabus The Design process Importance of good design Design techniques

Updated Syllabus 1. Intro, Philosophy, Model problem 2. Design of algorithms and responsible coding 4. Editing, compiling: UNIX vs. IDE, intro to architectures 3. Formal & Informal Specification 5. Language issues: C, Fortran, Java, MATLAB 7. Debugging: UNIX db vs. IDE 8. Testing for correctness 6. Building with Make 9. Improving performance--profiling, tuning 11. Platform issues & how to spend your advisor's money 10. Software management, source code control 12. Trends for the future

General Development Development is the process by which things get made (e.g. engineering) The development process is different depending on the product –driven by cost, complexity, and reliability considerations

General Development Building a house –architects/engineers create detailed blueprints –general contractor organizes groups of workers for specific tasks foundation walls, windows & doors electrical plumbing interior finishing –Good design is important because it is costly to rebuild (materials, time) –Good management is important to avoid having workers sitting idle

General Development Making a movie –screenwriter creates script –director plans shoots from the script choose locations, organize personnel, timeline –movie is filmed –movie is edited and released Movies require lots of (expensive) people, so it is critical that time is used efficiently

Development Process I 1. Create a text file containing commands in some language 2. Pass the file to the compiler 3. Run the executable

Development Process II 1.Design: What will the program (or modification) do? How will it work? 2.Specification--formal statements of what code will do 3.Prototyping--a “proof-of-concept” version. Simple version written in an interpreted language (Matlab, Python) 4.Implementation: write the code 5.Build: Get it to compile and run a) Debug I: find and fix syntax errors b) Debug II: find and fix semantic errors (testing) 6.Improve performance through tuning or re-design

Development Process II (typical) 1. Start writing code, design=rewrite 2. Compile 3. Debug, debug, debug

Importance of Design in Scientific Software Development Despite our lowly status, we are paid for scientific results, not time spent hacking PositionBase SalaryHourly undergrad0-$3500 (summer)$0-7.29/hr grad$15K/year$8.33/hr post. doc.$32K/yr$15.62/hr assist. prof.$60K/yr$31.25/hr Arnold$30million for 24x80 hr weeks $15,625/hr

Importance of Design in Scientific Software Development Even though our wages are low, good design is important for scientific programming –Reduces time spent debugging –Makes code easier to use (more people citing your work) –Makes code easier to extend (better luck next time) –Makes code easier to describe to colleagues

Definition of Design The design process will lead to a description of what your program will do and how it is organized. Some important questions to answer –How will you get data in and out of your program? –What tasks must your program perform? –How will data flow through your program?

Good Design An important characteristic of good design is modularity –Code should be divided into simple pieces (subroutines, method), each solving a specific task –Related pieces should be grouped together in a single file (module, class) Object oriented languages (Java, C++) are inherently modular

Design Techniques Flow charts –Visual representation of your program –This should be at a high-level Universal Modeling Language (UML) –Industry-standard for design and management of object oriented development –Specifies several diagram types--each one takes a different view of a project

Stealing from UML Industrial UML-systems are overkill for most scientific problems, but we can borrow some useful views of our programs –Class Diagram--describe an object’s fields (data) and methods (functions) –State Diagram--describe how an object’s state (data) changes

Stealing from UML Class Diagrams –Box with three regions: name, fields (data), methods (subroutines)

Stealing from UML State Diagrams –Start state (), named states (ovals), end state (  ) –Connect with arrows –Diagrams can branch when conditions are satisfied (if-then-else) Soaking Normal Rinsing Spinning Delicate Check Settings Set to delicate Normal

Iterative Refinement Iterative refinement is an important design technique –Takes a top-down view –Enforces modularity Iterative refinement is a 3 step process 1. Describe--what will your program/subroutine do? 2. Divide--what are the essential tasks? 3. Repeat--subdivide tasks if possible.

Iterative Refinement I.Do Laundry A.Wash B.Dry C.Fold

A.Wash 1.Get clothes 2.Place in washer 3.Configure washer 4.Start B.Dry 1.Move from washer to dryer 2.Configure dryer 3.Start C.Fold 1.Remove from dryer 2.If (shirt) then a. Fold shirt else b. Fold pants Do Laundry

Main Point of Design –Think before you code!

Numerical Solution We start with an initial distribution of C over the interval [0 1] Divide [0 1] into discrete points separated by dx C(x,t+dt) will depend on C(x), C(x-dx), & C(x+dx) I’ve placed a full derivation of the model problem on the web site which I will go through now x C(x,t) C(x,t+dt)

Designing RAD1 1.Get C0, u, k, dt,t, T, m, L (dx=L/(m-1)) from user 2.Build matrix A using k, dt, dx 3.Build RHS vector b using u, k, and reaction data 4.Solve A*C=b for C 5.t=t+dt 6.If(t<T) a)Copy C=C0 b)Change u and k if needed c)Repeat 2-6 Else d) Output C and quit