소프트웨어 요구 사항

소프트웨어 요구 사항은 대상 시스템의 기능에 대한 설명입니다. 요구 사항은 소프트웨어 제품에서 사용자의 기대치를 전달합니다. 요구 사항은 고객의 관점에서 명확하거나 숨겨져 있거나, 알려 지거나 알려지지 않았거나, 예상되거나 예상치 못한 것일 수 있습니다.

요구 공학

클라이언트로부터 소프트웨어 요구 사항을 수집하고이를 분석하고 문서화하는 프로세스를 요구 사항 엔지니어링이라고합니다.

요구 사항 엔지니어링의 목표는 정교하고 설명적인 '시스템 요구 사항 사양'문서를 개발하고 유지하는 것입니다.

요구 사항 엔지니어링 프로세스

다음을 포함하는 4 단계 프로세스입니다.

  • 타당성 조사
  • 요구 사항 수집
  • 소프트웨어 요구 사항 사양
  • 소프트웨어 요구 사항 검증

프로세스를 간단히 살펴 보겠습니다.

타당성 조사

고객이 원하는 제품을 개발하기 위해 조직에 접근하면 소프트웨어가 수행해야하는 모든 기능과 소프트웨어에서 예상되는 모든 기능에 대한 대략적인 아이디어가 떠 오릅니다.

이 정보를 참조하여 분석가는 원하는 시스템과 기능을 개발할 수 있는지 여부에 대한 자세한 연구를 수행합니다.

이 타당성 조사는 조직의 목표에 초점을 맞추고 있습니다. 이 연구는 소프트웨어 제품이 구현, 조직에 대한 프로젝트의 기여도, 비용 제약 및 조직의 가치와 목표에 따라 실질적으로 구체화 될 수 있는지 분석합니다. 사용성, 유지 보수성, 생산성 및 통합 능력과 같은 프로젝트 및 제품의 기술적 측면을 탐색합니다.

이 단계의 결과물은 프로젝트 수행 여부에 대한 경영진을위한 적절한 의견과 권장 사항을 포함해야하는 타당성 조사 보고서 여야합니다.

요구 사항 수집

타당성 보고서가 프로젝트 수행에 긍정적 인 경우 다음 단계는 사용자의 요구 사항 수집으로 시작됩니다. 분석가와 엔지니어는 클라이언트 및 최종 사용자와 소통하여 소프트웨어가 제공해야하는 내용과 소프트웨어에 포함 할 기능에 대한 아이디어를 파악합니다.

소프트웨어 요구 사항 사양

SRS는 다양한 이해 관계자로부터 요구 사항을 수집 한 후 시스템 분석가가 작성한 문서입니다.

SRS는 의도 한 소프트웨어가 하드웨어, 외부 인터페이스, 작동 속도, 시스템 응답 시간, 다양한 플랫폼 간의 소프트웨어 이식성, 유지 보수 가능성, 충돌 후 복구 속도, 보안, 품질, 제한 등과 상호 작용하는 방법을 정의합니다.

고객으로부터받은 요구 사항은 자연어로 작성되었습니다. 소프트웨어 개발 팀이 이해하고 유용 할 수 있도록 요구 사항을 기술 언어로 문서화하는 것은 시스템 분석가의 책임입니다.

SRS는 다음과 같은 기능을 제공해야합니다.

  • 사용자 요구 사항은 자연어로 표현됩니다.
  • 기술 요구 사항은 조직 내에서 사용되는 구조화 된 언어로 표현됩니다.
  • 설계 설명은 의사 코드로 작성해야합니다.
  • 양식 및 GUI 화면 인쇄의 형식.
  • DFD 등에 대한 조건부 및 수학적 표기법

소프트웨어 요구 사항 검증

요구 사항 사양이 개발 된 후이 문서에 언급 된 요구 사항이 검증됩니다. 사용자가 불법적이고 비실용적 인 솔루션을 요청하거나 전문가가 요구 사항을 잘못 해석 할 수 있습니다. 이로 인해 새싹에 꽂 히지 않으면 비용이 크게 증가합니다. 다음 조건에 대해 요구 사항을 확인할 수 있습니다.

  • 실질적으로 구현할 수있는 경우
  • 유효하고 소프트웨어의 기능 및 도메인에 따라
  • 모호한 부분이있는 경우
  • 완료되면
  • 시연 가능하다면

요구 사항 추출 프로세스

요구 사항 추출 프로세스는 다음 다이어그램을 사용하여 설명 할 수 있습니다.

  • Requirements gathering - 개발자는 클라이언트 및 최종 사용자와 논의하고 소프트웨어에 대한 기대치를 알고 있습니다.
  • Organizing Requirements - 개발자는 중요도, 긴급 성 및 편의성 순으로 요구 사항의 우선 순위를 지정하고 정렬합니다.
  • Negotiation & discussion - 요구 사항이 모호하거나 다양한 이해 관계자의 요구 사항에 약간의 충돌이 있으면 이해 관계자와 협상하고 논의합니다. 그런 다음 요구 사항의 우선 순위가 지정되고 합리적으로 손상 될 수 있습니다.

    요구 사항은 다양한 이해 관계자가 제공합니다. 모호함과 갈등을 제거하기 위해 명확성과 정확성을 위해 논의됩니다. 비현실적인 요구 사항은 합리적으로 손상됩니다.

  • Documentation - 모든 공식 및 비공식, 기능 및 비 기능 요구 사항은 문서화되어 다음 단계 처리에 사용할 수 있습니다.

요구 사항 추출 기법

요구 사항 추출은 클라이언트, 최종 사용자, 시스템 사용자 및 소프트웨어 시스템 개발에 관여하는 다른 사람들과 의사 소통하여 의도 한 소프트웨어 시스템에 대한 요구 사항을 찾는 프로세스입니다.

요구 사항을 발견하는 다양한 방법이 있습니다.

인터뷰

인터뷰는 요구 사항을 수집하는 강력한 매체입니다. 조직은 다음과 같은 여러 유형의 인터뷰를 수행 할 수 있습니다.

  • 수집 할 모든 정보가 미리 결정되는 구조적 (밀폐) 인터뷰는 패턴과 논의 사항을 확고하게 따릅니다.
  • 수집 할 정보가 미리 결정되지 않고 더 유연하고 편향적이지 않은 비 구조화 (개방) 인터뷰.
  • 구두 인터뷰
  • 서면 인터뷰
  • 테이블에서 두 사람이 일대일 인터뷰를합니다.
  • 참가자 그룹간에 진행되는 그룹 인터뷰. 수많은 사람들이 참여함에 따라 누락 된 요구 사항을 발견하는 데 도움이됩니다.

설문 조사

조직은 향후 시스템에 대한 기대 및 요구 사항을 쿼리하여 다양한 이해 관계자들 사이에서 설문 조사를 수행 할 수 있습니다.

설문지

사전 정의 된 일련의 객관적인 질문과 각 옵션이 포함 된 문서가 모든 이해 관계자들에게 전달되어 수집 및 편집됩니다.

이 기술의 단점은 일부 문제에 대한 옵션이 설문지에 언급되지 않은 경우 문제가 방치 될 수 있다는 것입니다.

작업 분석

엔지니어와 개발자 팀은 새로운 시스템이 필요한 작업을 분석 할 수 있습니다. 클라이언트가 특정 작업을 수행 할 소프트웨어가 이미있는 경우이를 연구하고 제안 된 시스템의 요구 사항을 수집합니다.

도메인 분석

모든 소프트웨어는 특정 도메인 범주에 속합니다. 도메인의 전문가는 일반 및 특정 요구 사항을 분석하는 데 큰 도움이 될 수 있습니다.

브레인 스토밍

다양한 이해 관계자들 사이에서 비공식 토론이 열리고 추가 요구 사항 분석을 위해 모든 입력 내용이 기록됩니다.

프로토 타이핑

프로토 타이핑은 사용자가 의도 한 소프트웨어 제품의 기능을 해석 할 수 있도록 세부 기능을 추가하지 않고 사용자 인터페이스를 구축하는 것입니다. 요구 사항에 대한 더 나은 아이디어를 제공하는 데 도움이됩니다. 개발자가 참조 할 수 있도록 클라이언트 측에 설치된 소프트웨어가없고 클라이언트가 자체 요구 사항을 인식하지 못하는 경우 개발자는 처음에 언급 한 요구 사항을 기반으로 프로토 타입을 만듭니다. 프로토 타입이 클라이언트에게 표시되고 피드백이 기록됩니다. 클라이언트 피드백은 요구 사항 수집을위한 입력으로 사용됩니다.

관측

전문가 팀이 고객의 조직이나 직장을 방문합니다. 그들은 기존에 설치된 시스템의 실제 작동을 관찰합니다. 그들은 클라이언트 측의 워크 플로우와 실행 문제가 어떻게 처리되는지 관찰합니다. 팀 자체는 소프트웨어에서 예상되는 요구 사항을 형성하는 데 도움이되는 몇 가지 결론을 도출합니다.

소프트웨어 요구 사항 특성

소프트웨어 요구 사항 수집은 전체 소프트웨어 개발 프로젝트의 기초입니다. 따라서 명확하고 정확하며 잘 정의되어야합니다.

전체 소프트웨어 요구 사항 사양은 다음과 같아야합니다.

  • Clear
  • Correct
  • Consistent
  • Coherent
  • Comprehensible
  • Modifiable
  • Verifiable
  • Prioritized
  • Unambiguous
  • Traceable
  • 신뢰할 수있는 출처

소프트웨어 요구 사항

요구 사항 추출 단계에서 어떤 종류의 요구 사항이 발생할 수 있으며 소프트웨어 시스템에서 어떤 종류의 요구 사항이 예상되는지 이해하려고 노력해야합니다.

광범위하게 소프트웨어 요구 사항은 두 가지 범주로 분류되어야합니다.

기능 요구 사항

소프트웨어의 기능적 측면과 관련된 요구 사항이이 범주에 속합니다.

이들은 소프트웨어 시스템 내부 및 소프트웨어 시스템의 기능과 기능을 정의합니다.

예-

  • 다양한 인보이스에서 검색 할 수 있도록 사용자에게 제공되는 검색 옵션입니다.
  • 사용자는 모든 보고서를 관리자에게 메일로 보낼 수 있어야합니다.
  • 사용자는 그룹으로 나눌 수 있으며 그룹은 별도의 권한을 부여받을 수 있습니다.
  • 비즈니스 규칙 및 관리 기능을 준수해야합니다.
  • 소프트웨어는 하위 호환성을 그대로 유지하면서 개발되었습니다.

비 기능적 요구 사항

소프트웨어의 기능적 측면과 관련이없는 요구 사항이이 범주에 속합니다. 사용자가 가정하는 소프트웨어의 암시 적 또는 예상되는 특성입니다.

비 기능적 요구 사항은 다음과 같습니다.

  • Security
  • Logging
  • Storage
  • Configuration
  • Performance
  • Cost
  • Interoperability
  • Flexibility
  • 재해 복구
  • Accessibility

요구 사항은 논리적으로 다음과 같이 분류됩니다.

  • Must Have : 소프트웨어가 없이는 작동한다고 말할 수 없습니다.
  • Should have : 소프트웨어 기능 향상.
  • Could have : 소프트웨어는 이러한 요구 사항에 따라 제대로 작동 할 수 있습니다.
  • Wish list : 이러한 요구 사항은 소프트웨어의 어떤 목표에도 해당되지 않습니다.

소프트웨어를 개발하는 동안 'Must have'는 반드시 구현되어야하며 'Should have'는 이해 관계자와의 논쟁과 부정의 문제이며, 'cand have'와 'wish list'는 소프트웨어 업데이트를 위해 보관 될 수 있습니다.

사용자 인터페이스 요구 사항

UI는 소프트웨어, 하드웨어 또는 하이브리드 시스템의 중요한 부분입니다. 다음과 같은 경우 소프트웨어가 널리 허용됩니다.

  • 작동하기 쉬움
  • 빠른 응답
  • 운영 오류를 효과적으로 처리
  • 간단하면서도 일관된 사용자 인터페이스 제공

사용자 동의는 주로 사용자가 소프트웨어를 사용할 수있는 방법에 따라 다릅니다. UI는 사용자가 시스템을 인식 할 수있는 유일한 방법입니다. 성능이 좋은 소프트웨어 시스템은 매력적이고 명확하며 일관되고 반응이 빠른 사용자 인터페이스를 갖추어야합니다. 그렇지 않으면 소프트웨어 시스템의 기능을 편리하게 사용할 수 없습니다. 시스템을 효율적으로 사용할 수있는 수단을 제공하면 좋은 시스템이라고합니다. 사용자 인터페이스 요구 사항은 아래에 간략하게 설명되어 있습니다.

  • 콘텐츠 프레젠테이션
  • 쉬운 탐색
  • 간단한 인터페이스
  • Responsive
  • 일관된 UI 요소
  • 피드백 메커니즘
  • 기본 설정
  • 목적에 맞는 레이아웃
  • 색상과 질감의 전략적 사용.
  • 도움말 정보 제공
  • 사용자 중심 접근 방식
  • 그룹 기반보기 설정.

소프트웨어 시스템 분석가

IT 조직의 시스템 분석가는 제안 된 시스템의 요구 사항을 분석하고 요구 사항이 적절하고 정확하게 구상되고 문서화되었는지 확인하는 사람입니다. 분석가의 역할은 SDLC의 소프트웨어 분석 단계에서 시작됩니다. 개발 된 소프트웨어가 클라이언트의 요구 사항을 충족하는지 확인하는 것은 분석가의 책임입니다.

시스템 분석가는 다음과 같은 책임이 있습니다.

  • 의도 한 소프트웨어의 요구 사항 분석 및 이해
  • 프로젝트가 조직 목표에 어떻게 기여할 것인지 이해
  • 요구 사항의 출처 파악
  • 요구 사항 검증
  • 요구 사항 관리 계획 개발 및 구현
  • 비즈니스, 기술, 프로세스 및 제품 요구 사항 문서화
  • 요구 사항의 우선 순위를 지정하고 모호성을 제거하기 위해 클라이언트와 협력
  • 클라이언트 및 기타 이해 관계자와 함께 수락 기준 마무리

소프트웨어 지표 및 측정

소프트웨어 측정은 소프트웨어의 다양한 속성과 측면을 정량화하고 상징화하는 프로세스로 이해할 수 있습니다.

소프트웨어 메트릭은 소프트웨어 프로세스 및 소프트웨어 제품의 다양한 측면에 대한 측정 값을 제공합니다.

소프트웨어 측정은 소프트웨어 엔지니어링의 기본 요구 사항입니다. 소프트웨어 개발 프로세스를 제어하는 ​​데 도움이 될뿐만 아니라 궁극적 인 제품의 품질을 우수하게 유지하는 데 도움이됩니다.

소프트웨어 엔지니어 인 Tom DeMarco에 따르면 "측정 할 수없는 것은 제어 할 수 없습니다." 그의 말에 따르면 소프트웨어 측정이 얼마나 중요한지 분명합니다.

몇 가지 소프트웨어 메트릭을 살펴 보겠습니다.

  • Size Metrics - LOC (Lines of Code)는 대부분 제공되는 수천 개의 소스 코드 행으로 계산되며 KLOC로 표시됩니다.

    Function Point Count는 소프트웨어에서 제공하는 기능의 척도입니다. 기능 점수는 소프트웨어의 기능적 측면의 크기를 정의합니다.

  • Complexity Metrics - McCabe의 Cyclomatic 복잡성은 프로그램 또는 해당 모듈의 복잡성으로 인식되는 프로그램에서 독립 경로 수의 상한을 정량화합니다. 제어 흐름 그래프를 사용하여 그래프 이론 개념으로 표현됩니다.
  • Quality Metrics - 결함, 유형 및 원인, 결과, 심각도의 강도 및 그 의미는 제품의 품질을 정의합니다.

    개발 과정에서 발견 된 결함의 수와 제품이 클라이언트 측에 설치되거나 납품 된 후 고객이보고 한 결함의 수는 제품의 품질을 정의합니다.

  • Process Metrics - SDLC의 다양한 단계에서 사용되는 방법 및 도구, 회사 표준 및 개발 성능은 소프트웨어 프로세스 메트릭입니다.
  • Resource Metrics - 사용 된 노력, 시간 및 다양한 리소스는 리소스 측정을위한 메트릭을 나타냅니다.