Khái quát về phần mềm
Tầm quan trọng của việc xác định cầu
Kỹ thuật yêu cầu
Yêu cầu theo quan điểm khách hàng
Nhà phân tích yêu cầu
Khái Quát Về Phần Mềm
Software = Program
Software product = Program + Document
+ Support
Loại sản phẩm phần mềm
Generic Product: là sản phẩm đóng gói
và bán rộng rãi trên thị trường.
Bespoke Product: là sản phẩm được
phát triển theo yêu cầu đặc thù của từng
khách hàng
99 trang |
Chia sẻ: candy98 | Lượt xem: 604 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Bài giảng Thu nhận yêu cầu - Chương 1: Tổng quan về kỹ thuật yêu cầu - Trần Thị Kim Chi, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
1
TỔNG QUAN VỀ KỸ
THUẬT YÊU CẦU
REQUIREMENT ENGINEERING
Giảng viên: Trần Thị Kim Chi
2
Nội dung
Khái quát về phần mềm
Tầm quan trọng của việc xác định cầu
Kỹ thuật yêu cầu
Yêu cầu theo quan điểm khách hàng
Nhà phân tích yêu cầu
3
Khái Quát Về Phần Mềm
Software = Program
Software product = Program + Document
+ Support
Loại sản phẩm phần mềm
Generic Product: là sản phẩm đóng gói
và bán rộng rãi trên thị trường.
Bespoke Product: là sản phẩm được
phát triển theo yêu cầu đặc thù của từng
khách hàng.
4
Khái Quát Về Phần Mềm
Các đặc tính quan trọng của sản phẩm
phần mềm
Maintainability: phần mềm có thể thay đổi thuận tiện
theo yêu cầu của người dùng
Dependability: tính ổn định, bảo mật và an toàn của
phần mềm. Không gây tổn hại về vật chất hay kinh tế
cho hệ thống.
Efficiency: Sử dụng hiệu quả tài nguyên của hệ thống
cho công việc
Usability: giao diện và phương thức phải phù hợp với
người dùng đồng thời đáp ứng đúng yêu cầu của người
dùng
5
Phần Mềm – Đủ hay Thiếu
Phần mềm được viết ngay từ khi có những máy tính
programable đầu tiên. Được quan tâm và phát triền từ
rất sớm
Có rất nhiều phần mềm đã được viết Không thiếu phần
mềm
Thực tế việc sản xuất phần mềm không đáp ứng kịp yêu
cầu của người sử dụng:
Không đủ về số lượng
Thiếu về chất lượng
Không kịp về thời gian
Phần mềm không đáp ứng đủ cho người dùng
6
Nguyên nhân khách quan
Số lượng phần mềm phải được hiểu là số đầu/loại phần
mềm được sử dụng cho từng mục tiêu ứng dụng.
Nhu cầu sử dụng phần mềm là rất lớn
Nhiều ngành nghề cần dùng phần mềm máy tính
Mỗi ngành nghề cần nhiều loại phần mềm khác nhau
Mội loại phần mềm cần nhiều cấp độ khác nhau theo trình
độ người dùng
7
Nguyên nhân khách quan
Chất lượng phần mềm cũng chưa đáp ứng tốt hoàn toàn
người sử dụng:
Tính customize rất cao của sản phẩm phần mềm.
Trình độ sử dụng khác nhau và điều kiện hạ tầng ứng
dụng khác nhau
Nhu cầu phần mềm thường rất cấp bách
Tầm nhìn và chiến lược chưa đầy đủ của người sử dụng
Không có kế hoạch lâu dài
Phải thay đổi theo từng đối tượng người dùng
8
Nguyên nhân chủ quan
Tính chuyên nghiệp trong sản xuất phần mềm chưa cao.
Các dữ liệu quan sát được
Cứ 6 đề án triển khai thì có 2 bị huỷ bỏ
Trung bình thời gian thực hiện thực tế bị kéo dài 50 % (cá biệt
200-300%)
Các đề án lớn dễ thất bại
3/4 các hệ thống lớn có lỗi khi thực thi
Quá trình phân tích yêu cầu (5 % công sức): để lại 55 % lỗi, có
18 % phát hiện được
Quá trình thiết kế (25 % công sức): để lại 30 % lỗi, có 10 %
phát hiện được
Quá trình mã hoá, kiểm tra và bảo trì: để lại 15 % lỗi, có 72 %
phát hiện được
9
Nguyên nhân chủ quan
Nhiều vấn đề về phần mềm xuất hiện do thiếu sót trong
lúc thu thập, thỏa thuận và chỉnh sửa yêu cầu.
Lỗi xảy ra trong giai đoạn thu thập yêu cầu chiếm từ 40-
60% tổng lỗi trong một dự án phần mềm.
Có sự khác biệt giữa cái mà người phát triển phần mềm
(developer) nghĩ và xây dựng với cái mà khách hàng
thật sự cần.
"Hello, Phil?” This is Maria in Human Resources.
“We're having a problem with the employee system
you programmed for us. An employee just changed
her name to Sparkle Starlight, and we can't get the
system to accept the name change. Can you
help?"
"She married some guy named Starlight?"
"No, she didn't get married, just changed her
name," Maria replied. "That's the problem. It looks
like we can change a name only if someone's
marital status changes."
Tại sao xác định yêu cầu là quan trọng
A story
10
"Well, yeah, I never thought someone might just
change her name. I don't remember you telling
me about this possibility when we talked about
the system. That's why you can get to the
Change Name dialog box only from the Change
Marital Status dialog box," Phil said.
A story
11
"I assumed you knew that people could legally change
their name anytime they like," responded Maria. "We
have to straighten this out by Friday or Sparkle won't be
able to cash her paycheck. Can you fix the bug by
then?"
"It's not a bug!" Phil retorted. "I never knew you needed
this capability. I'm busy on the new performance
evaluation system. I think I have some other change
requests for the employee system here, too." [sound of
rustling paper]
A story
12
"Yeah, here's another one. I can probably fix it by the
end of the month, but not within a week. Sorry about
that. Next time, tell me these things earlier and please
write them down.“
"What am I supposed to tell Sparkle?" demanded Maria.
"She's really going to be ticked if she can't cash her
check."
A story
13
"Hey, Maria, it's not my fault," Phil protested (phản
kháng). "If you'd told me in the first place that you had to
be able to change someone's name at any time, this
wouldn't have happened. You can't blame me for not
reading your mind."
Angry and resigned, Maria snapped, "Yeah, well, this is
the kind of thing that makes me hate computer systems.
Call me as soon as you get it fixed, will you?"
A story
14
15
Tầm quan trọng trong XĐ yêu cầu?
Công nghệ và xã hội không ngừng thay đổi một cách
nhanh chóng, và ảnh hưởng to lớn của hệ thống thông
tin trong một môi trường vô cùng phức tạp
Kỹ thuật yêu cầu (requirements engineering - RE) đóng
một vai trò vô cùng quan trọng
Cần có sự tham gia của các chuyên gia trong việc thu
nhận và quản lý yêu cầu
Hệ thống nghiệp vụ - Hệ thống thông tin – Phần mềm
Vậy tầm quan trọng của thu nhận yêu cầu là gì?
16
Tầm quan trọng trong XĐ yêu cầu?
Lý do 1:
Sản phẩm phát triển với tốc độ chóng mặt. Ngày nay
khách hàng thường đòi hỏi phiên bản mới của sản phẩm
trong khoảng thời gian dưới 1 năm
Ví dụ: theo Siemens thì 20 năm trước, 55% hàng bán là
từ sản phẩm tuổi <5. Ngày nay, 75% hàng bán được là
từ sản phẩmcó tuổi <5.
17
Tầm quan trọng trong XĐ yêu cầu?
18
Tầm quan trọng trong XĐ yêu cầu?
19
Tầm quan trọng trong XĐ yêu cầu?
Lý do 2:
Thay đổi không ngừng của công nghệ và chuyển giao
đã ảnh hưởng nhiều đến mức độ thành thạo của chuyên
gia. Vài năm trước, các kỹ sư có thể sống cả đời với
nghề nghiệp của mình trong một công ty nào đó, nhưng
ngày nay việc thay đổi công việc rất thường xuyên.
20
Tầm quan trọng trong XĐ yêu cầu?
Lý do 3:
Gia công phần mềm đã làm thay đổi nhanh chóng chu
kỳ phát triển phần mềm
Đặc tả sản phẩm để thực thi hay sản xuất bởi nhiều bộ
phận khác nhau nên bị nhiều hạn chế và không có
chuyên môn nghiệp vụ.
Tương tự như phải tạo đặc tả cho máy giặt mà người
thiết kế có thể chưa từng nhìn thấy máy giặt lần nào. Để
thành công, đặc tả cần phải chính xác.
21
Tầm quan trọng trong XĐ yêu cầu?
Lý do 4:
Việc phát triển phần mềm thường liên kết chặt chẽ với
nghiệp vụ. Ví dụ: phần mềm cellphone và phần mềm về
hàng không thường được thiết kế xây dựng chặt chẽ
phù hợp với nghiệp vụ.
Công nghiệp bắt đầu dùng phần mềm để tạo các phiên
bản mới cho sản phẩm. Các sáng kiến có thể thực hiện
hiện dễ dàng bằng phần mềm hơn là phần cứng vì ít
đầu tư kỹ thuật hơn và chi phí sửa đổi rẻ hơn
22
Tầm quan trọng trong XĐ yêu cầu?
Nguyên nhân thất bại của dự án (RE-62%)
Những yêu cầu không đầy đủ - Incomplete
requirements (13.1%)
Lack of user involvement – không cuốn hút người
dùng(12.4%)
Lack of resources – thiếu nguồn tài nguyên(10.6%)
Unrealistic expectations – thiếu thực tế(9.9%)
Lack of executive support (9.3%)
Changing requirements and specifications (8.7%)
Lack of planning (8.1%)
System no longer needed (7.5%)
23
Tầm quan trọng trong XĐ yêu cầu?
24
25
Một yêu cầu là một đặc trưng của hệ thống, hay là sự
mô tả những việc, mà hệ thống có khả năng thực hiện
để hoàn thành mục tiêu của hệ thống
Yêu
cũng có là các ràng buộc trong quá trình
phát triển hệ thống.
Requirements described the “what” of a system, not the
“how”
Yêu cầu có thể được ràng buộc bởi hợp đồng hay văn
bản
Có những yêu cầu ngầm định (implicit)
Một yêu cầu có thể được nhận biết (known, spoken)/
không nhận biết (forgotten, unspoken)
Yêu cầu (requirement)
26
“Tôi không có thời gian
để viết yêu cầu!
Bạn không thấy tôi
đang bận gỡ lỗi?”
Yêu cầu (requirement)
Theo IEEE 1990, yêu
u n m :
1. A condition or capability needed by a user to solve
a problem or achieve an objective.
2. A condition or capability that must be met or
possessed by a system or system component to
satisfy a contract, standard, specification, or other
formally imposed document.
3. A documented representation of a condition or
capability as in 1 or 2.
Software Requirements (SR)?
27
Yêu cầu quan trọng vì nó cung cấp các cơ sở cho tất cả
công việc phát triển hệ thống sau đó.
Ngay khi yêu cầu được xác định, nhà phát triển khởi
đầu các công việc kỹ thuật khác như: thiết kế hệ thống,
phát triển, kiểm thử, thực thi và vận hành.
Vai trò của yêu cầu
28
Yêu cầu được phát biểu (stated requirement)
Yêu cầu thực (real requirement)
Phân loại yêu cầu
29
Là các yêu cầu được cung cấp bởi khách hàng khi bắt
đầu phát triển hệ thống.
Các dạng yêu cầu:
Yêu cầu về thông tin
Dự toán
Bảng báo giá
Phát biểu công việc (statement of work – SOW)
Stated Requirements
30
Là các yêu cầu phản ánh nhu cầu xác thực của người
dùng.
Thường khác nhau rất lớn giữa yêu cầu phát biểu và
yêu cầu thực.
Việc phân tích các yêu cầu khách hàng (stated
requirements) được dùng để xác định và tinh chỉnh các
nhu cầu thực sự của khách hàng.
Real Requirements
31
Là hệ thống các phương thức có liên quan với nhau chỉ
định cái mà khách hàng muốn hệ thống làm gì.
There are two majors tasks in the requirements
engineering:
Analysis
Modeling
Requirements Engineering
32
Analysis is the process of determining what the
customer wishes the system to do and formally creating
a list of requirements that the customer can understand
and agree to do.
Modeling is a process of interpreting the customer
requirements into something that software engineers
can understand.
Requirements Engineering
33
Phân
i yêu u
34
Gồm hai loại chính:
• Yêu cầu chức năng (Function requirements)
• Yêu cầu phi chức năng (Non Functional Requirements)
Yêu cầu chức năng (Functional
requirements)
35
Yêu cầu chức năng (Functional requirements):
chức năng dịch vụ hệ thống cung cấp.
Xác định chức năng của phần mềm mà các nhà phát
triển phải xây dựng để giúp người dùng hoàn thành
nhiệm vụ của họ, thỏa mãn được yêu cầu nghiệp vụ.
Đôi khi còn được gọi là behavioral requirements.
Ví dụ: “The system shall e-mail a reservation
confrimation the user”
Yêu cầu chức năng (Functional
requirements)
36
Yêu cầu chức năng (Functional requirements): Yêu
cầu chức năng chỉ ra những gì hệ thống làm, chúng
thường quan hệ các use-case hay những qui tắc
nghiệp vụ (business rule)
• Một số yêu cầu chức năng
• Chức năng tính toán
• Chức năng lưu trữ
• Chức năng tìm kiếm
• Chức năng kết xuất
• Chức năng backup, restore
• Chức năng đa người dùng
• Chức năng đa phương tiện
Yêu cầu chức năng (Functional
requirements)
37
Thí dụ: Trong hệ thống quản lý thư viện
• Người dùng có thể tìm kiếm, download, in những bài
báo
• Người dùng được cấp một vùng lưu trữ riêng để có
thể copy để lưu trữ tài liệu lâu dài
Yêu cầu phi chức năng (Non-functional
requirements
38
Yêu cầu phi chức năng (Non-functional
requirements): Không tập trung vào các chức năng của
hệ thống mà chỉ tập trung vào các ràng buộc của hệ
thống. Những ràng buộc về tiêu chuẩn, thời gian, qui
trình phát triển, chủ yếu là những yêu cầu về chất
lượng.
Sáu loại chính của yêu cầu phi chức năng: security,
privacy, usability, reliability, availability, and performance.
Ràng buộc: phản ảnh những đặc trưng của miền ứng
dụng. Chúng có thể là những yêu cầu chức năng hay
yêu cầu phi chức năng.
Yêu cầu phi chức năng (Non-functional
requirements
39
Một số yêu cầu phi chức năng
• Độ tin cậy, thời gian đáp ứng, các yêu cầu về lưu
trữ
• Các chuẩn được sử dụng, các công cụ CASE, ngôn
ngữ lập trình
• Yêu cầu của người sử dụng: dễ sử dụng, thân thiện
• Ràng buộc về ngân sách
• Phù hợp với các chính sách của tổ chức sử dụng hệ
thống
• Yêu cầu tương thích giữa phần cứng và phần mềm
• Các yêu cầu từ các tác nhân ngoài khác
Yêu cầu phi chức năng (Non-functional
requirements
40
Yêu cầu phi chức năng (Non-functional
requirements
41
Ví dụ
Trong hệ thống quản lý thư viện
• Yêu cầu sản phẩm: giao diện người dùng không chứa
frame và applet java
• Yêu cầu tổ chức: qui trình phát triển hệ thống và tài
liệu phân phối phải phù hợp theo tiêu chuẩn “STAN-
07” (sử dụng ngôn ngữ, phương pháp thiết kế)
• Yêu cầu ngoài: hệ thống không được lộ thông tin của
khách hàng (tên, số tham chiếu)
Phân
i yêu u
42
Khả thi - Feasible
Có giá trị - Valid
Không nhập nhằng - Unambiguous
Dễ kiểm chứng - Verifiable
Dễ biến đổi - Modifiable
Toàn vẹn - Consistent
Đầy đủ - Complete
Lần vết được - Traceable
Đặc trưng của yêu cầu
43
Software Requirement bao
m 3 c phân t:
Yêu cầu nghiệp vụ (Business requirements)
Yêu cầu người dùng (User requirements)
Yêu cầu chức năng (Functional requirements)
c c yêu u
44
Biễu diễn các mục tiêu của tổ chức hay khách hàng yêu
cầu hệ thống phải có
Yêu cầu nghiệp vụ thường do người tài trợ cho dự án,
khách mua phần mềm, người quản lý các người dùng,
bộ phận tiếp thị (maketing)cung cấp
Thường được ghi nhận trong phần đặc tả (vision) và
phạm vi (scope) của tài liệu, đôi khi còn được gọi là
tuyên bố dự án (project charter) hay tài liệu yêu cầu thị
trường (market requirements document)
Yêu cầu nghiệp vụ (Business
requirements)
45
Mô tả mục tiêu (goal) hay tác vụ (task) của người dùng
đối với hệ thống.
Các cách để biểu diễn yêu cầu người dùng:
Use cases, scenario
Bảng event-response.
Yêu cầu người dùng mô tả cái (what) mà người dùng có
thể làm đối với hệ thống.
Ví dụ: use case "Make a Reservation" dùng trong các
website của hàng không, thuê xe, hay khách sạn.
Yêu cầu người dùng (User
requirements)
46
Xác định chức năng của phần mềm mà các nhà phát
triển phải xây dựng để giúp người dùng hoàn thành
nhiệm vụ của họ, thỏa mãn được yêu cầu nghiệp vụ.
Đôi khi còn được gọi là yêu cầu về hành vi (behavioral
requirements)
Ví dụ: Hệ thống sẽ gởi một xác nhận giữ chỗ cho khách
hàng
Yêu cầu chức năng (Functional
requirements)
47
Mô
yêu u c cao i n m, a c
ng con (subsystem) o.
t ng thể n n m hay bao m
c ng con a n m ng như n ng.
Con
i ng n ng, y c c
năng
ng ng nh vai a con
i.
System requirements
48
i liên hê a c c yêu u
srse 49
i liên hê a c c yêu u
srse 50
Phân
i i u yêu u
51
Môi trường vật lý
Giao tiếp
Người dùng và nhân tố con người
Chức năng
Lập tài liệu
Dữ liệu
Tài nguyên
An ninh
Bảo đảm chất lượng
Các loại yêu cầu
52
i c giao m t n m n ng
ng m, ng sung thêm ng
nh c c a t o y c n y tinh
(beaker)
Yêu cầu của phần mềm là gì?
Case study
53
Nhấn mạnh tới tính cộng tác và lặp lại
Tạo tài liệu cho những kết quả quan sát
Kiểm tra
Nó còn nhấn mạnh tới vai trò của kinh nghiệm
và tính xã hội
t thu p yêu u
Requirements Engineering
54
t thu p yêu u liên quan n t
c t ng chu :
c nh yêu u a i ng,
Phân
ch yêu u suy n thêm c yêu u
c
c yêu u
m tra xem yêu u a c p i nhu
u i ng không
t thu p yêu u
Requirements Engineering
55
Các bước trong Qui trình phát triển yêu cầu
56
Các bước trong Qui trình phát triển yêu cầu
57
Các bước trong Qui trình phát triển yêu cầu
58
Các bước trong Qui trình phát triển yêu cầu
59
Xác định yêu cầu:
• Là hoạt động chuyển thông tin phát sinh trong suốt
tiến trình phân tích thành tài liệu định nghĩa tập
hợp các yêu cầu
• Phản ánh chính xác điều mà người dùng muốn
• Tài liệu phải được viết để hệ thống sẽ được hiểu
bởi
• Người dùng cuối
• Những khách hàng của hệ thống.
Các bước trong Qui trình phát triển yêu cầu
60
Đặc tả yêu cầu:
• Bản mô tả các yêu cầu hệ thống được thiết lập như cơ
sở của hợp đồng giữa khách hàng và nhà phát triển
phần mềm
• Mô tả thật chi tiết về yêu cầu người dùng và yêu cầu hệ
thống
• hữu ích cho thiết kế
• Mô tả chính xác để nắm bắt đúng vấn đề
• Việc lập tài liệu này được thực hiện song song cùng với
một số các thiết kế cấp cao khác.
• Lỗi trong định nghĩa yêu cầu cần được xem xét kỹ
lưỡng.
• Nó phải được sửa chữa theo đúng vấn đề này.
Các bước trong Qui trình phát triển yêu cầu
61
Quản lý yêu cầu:
• Quản lý yêu cầu là tiến trình quản lý sự thay đổi của
yêu cầu trong suốt quy trình công nghệ yêu cầu và phát
triển hệ thống
• Yêu cầu thì chắc hẳn là sẽ không hoàn thiện và không
nhất quán
• Các yêu cầu mới thì liên tục phát sinh trong suốt tiến
trình khi nhu cầu công việc thay đổi và có sự hiểu rõ
hơn về hệ thống đang phát triển
• Các quan điểm khác nhau có các yêu cầu khác nhau và
điều này thường làm phát sinh mâu thuẫn
c nh n a
requirement engineering
62
Ranh
i a t n
n yêu u
63
Kỹ thuật yêu
u
64
65
Lợi ích khi thu thập yêu cầu hiệu quả
Lợi ích của việc tạo yêu cầu có chất lượng
thường không dễ thấy nên nhiều người thường
nhầm lẫn là tiêu tốn thời gian khi bàn luận về
yêu cầu sẽ dẫn đến làm chậm trễ việc hoàn
thành sản phẩm
Giảm việc phải làm lại
Thu thập yêu cầu cho phép đội phát triển hiểu
rõ về người dùng và thị trường, một nhân tố
quan trọng cho sự thành công của bất kỳ dự án
nào
66
Lợi ích khi thu thập yêu cầu hiệu quả
Khi người dùng cùng tham gia trong giai đoạn
thu thập yêu cầu sẽ xây dựng được niềm tin và
lòng trung thành của khách hàng
Đội ngũ phát triển có thể tránh viết những đoạn
mã thừa khi nắm vững nhiệm vụ của người
dùng
Sự quan tâm của khách hàng giảm được khoảng
cách giữa cái người dùng cần và cái người phát
triển tạo ra.
67
Những lợi ích không định lượng
1. Lỗi liên quan đến yêu cầu ít hơn
2. Giảm được việc phải làm lại trong bước phát triển
3. Ít hơn trong việc tạo tính năng không cần thiết
4. Giảm chi phí mở rộng
5. Quá trình phát triển hệ thống sẽ nhanh hơn
6. Giảm bớt các giao tiếp sai lầm với khách hàng
7. Hạn chế phạm vi hệ thống bị phình rộng
8. Hạn chế được những hỗn độn dự án
9. Các ước lượng về hệ thống chính xác hơn
10.Mức độ thỏa mãn khách hàng và thành viên của đội sẽ
cao hơn
u do c nh yêu u không ng i rework
(
m i ) —doing over something that you thought was
already done.
Rework
t – % ng chi t n
n i do yêu u m i – % chi m i.
u khi c nh yêu u sai
68
So
nh chi a sai i a yêu
u i i i m c nhau
n t???
69
SDLC
70
Imagine how different your life would be if you could cut
the rework effort in half! You could build products faster,
build more and better products in the same amount of
time, and perhaps even go home occasionally.
Khi không
i rework
71
Insufficient User Involvement – thiếu sự tham gia
người dùng
Creeping User Requirements – Yêu cầu người dùng
phình ra
Ambiguous Requirements – yêu cầu mơ hồ, không rõ
ràng
Gold Plating - Yêu cầu mạ vàng (Gold Plating): khi
người phát triển cộng thêm chức năng không có trong
đặc tả
Minimal Specification – Yêu cầu tối thiểu
Overlooked User Classes – Bỏ qua lớp người dùng
Inaccurate Planning – Hoạch định không chính xác
assignment a m: m m 10
(srse)
Nguyên nhân
n n c nh yêu
u không nh công
72