ソフトウェア要件システムの要件は、システムが提供するサービスを実行する必要があることの説明と、システムの操作に対する制約です。ソフトウェアエンジニアリング用語のIEEE標準用語集では、要件を次のように定義している[1]。
ソフトウェア要件の処理に関連するアクティビティは、大まかに引き出し、分析、仕様、および管理に分類できる[2]。 聞き出し→詳細は「要件聞き出し」を参照
聞き出しとは、利害関係者やその他の情報源からの要件の収集と発見のことである。共同アプリケーション設計(JAD)セッション、インタビュー、ドキュメント分析、フォーカスグループなど、さまざまな手法を使用する。聞き出しは、要件開発の最初の段階である。 分析→詳細は「要件分析」を参照
分析では、聞き出した内容を論理的に掘り下げる。分析を通して、各要件のより深く正確な理解を行い、複数の補完的な方法で一連の要件を表す。 要件トリアージまたは要件の優先順位付けは、多くの場合分析に続く別の活動である[3]。 これは、プランニングポーカーなどによる計画段階でのアジャイルソフトウェア開発に関連するが、プロジェクトの文脈と性質、要件、またはビルドされる製品/サービスによって内容が異なることがある。 仕様→詳細は「ソフトエア要求仕様」を参照
仕様には、効果的なコミュニケーションと変更管理を容易にする、永続的でよく整理された方法で収集された要件知識を表現および保存することが含まれる。ユースケース、ユーザーストーリー、機能要件、および視覚的分析モデルは、要件仕様の一般的な選択肢である。 検証検証には、プロジェクトのビジネス目標を満たすソリューションを構築するための正しい要件のセットが指定されていることを確認するための手法が含まれる。 管理→詳細は「要求管理」を参照
要件はプロジェクト中に変更され、多くの場合それらがあります。この変更の管理は、利害関係者のために正しいソフトウェアが構築されていることを確認するために最も重要になる。 要件エンジニアリングのツールサポート要件の引き出し、分析、および検証のためのツールこれらの活動には、観察レポート(ユーザー観察)、アンケート(インタビュー、調査、投票)、ユースケース、ユーザーストーリーなどのアーティファクトが含まれる可能性がある。要件ワークショップ(シャレット)、ブレーンストーミング、マインドマッピング、ロールプレイングなどの活動、さらに、プロトタイピング [4]といった活動を支援するソフトウェア製品が使用できる。 FreeMindなどのマインドマッピングツールやConcordionなどのSpecification by Exampleツールを使用することもできる[5]。 さらに、これらの活動から得られたアイデアやステートメントは、ウィキやTrelloなどの他のコラボレーションツールを使用して収集、整理できる。実際に実装されている機能と標準への準拠は、製品ごとに異なる。 要件仕様のツールソフトウェア要件仕様書(SRS)は、ワープロやスプレッドシートなどの一般的なソフトウェアツールを使用して作成されるが、この活動を実行するための専用ツールもいくつかある。 これらのツールは、SRSドキュメントをインポート、編集、エクスポート、および公開できる。IEEE 2918-2011などの標準やReqIFなどに対応しているものもある。 要件文書検証のためのツールこの種のツールは、予想される構造または標準に従って、要件ドキュメントにエラーがあるかどうかを確認する。 要件比較のためのツールこの種のツールは、予想されるドキュメント構造と標準に従って2つの要件セットを比較する。 要件のマージと更新のためのツールこの種のツールを使用すると、要件ドキュメントをマージおよび更新できる。 要件のトレーサビリティのためのツールこの種のツールを使用すると、モデルやソースコードなどの他のアーティファクト(順方向のトレーサビリティ)、またはビジネスルールや制約などの以前のアーティファクト(逆方向のトレーサビリティ)まで要件をトレースできる。 モデルベースのソフトウェアまたはシステム要件エンジニアリングのためのツールモデルベースシステムエンジニアリング(MBSE)は、システム要件、設計、分析、測定[6]、 検証および妥当性確認アクティビティをサポートするためのモデリングの正式なアプリケーションであり、概念設計フェーズから始まり、開発フェーズとその後のライフサイクルフェーズまで続く。要件エンジニアリングのいくつかの段階でモデルベースのアプローチを採用することも、他の段階ではより伝統的なアプローチを採用することも可能である。 形式性と複雑さのレベルは、関連する基礎となる方法論によって異なる(たとえば、 i*はSysMLよりもはるかに形式的であり、 UMLよりもさらに形式的である)。 一般的な要件エンジニアリングのためのツールこのカテゴリのツールは、前述の機能と、要件構成管理やコラボレーションなどの他の機能を組み合わせて提供する場合がある。実際に実装されている機能と標準への準拠は、製品ごとに異なる。 他の段階や活動をサポートする、さらに有能で一般的なツールがあります。それらはALMツールとして分類される。 関連項目
脚注
参考文献
|