システム設計8 プロジェクト管理の仕組み (その40)

更新日

投稿日

 前回のシステム設計7に続いて解説します。
 
 システム要件の一つひとつについて、サブシステム構成における振る舞いを記述し、各々のサブシステムの役割とサブシステム間のやりとりを検証していきます。ここではもう一つだけ、最後に追加したシステム要件「停電時の商品とお金の保証」について検証作業をやってみましょう。再度、FURPS+のブレークダウンを図73に示します。
 
プロジェクト管理
図73. FURPS+のブレークダウン
 
 このシステム要件には「停電を検出し補助電源を起動させる」(システム要件 R1.1)「停電を検出したときに投入されたお金を返却口に返す」(システム要件 R1.2)「停電を検出したときに商品口をロックする」(システム要件 R1.3)の3つの要件が含まれています。それぞれの要件についてサブシステム構成にその振る舞いを記述したものが図76です。
 
プロジェクト管理
図76. サブシステム構成の検証 
 
 今回も、まずサブシステムの役割を検証します。図ではみ出してしまっているように、「補助電源を起動する」という役割を果たすサブシステムがないことがわかります。「状態管理サブシステム」の一部にすればサブシステム構成を変える必要はありませんが、自販機の状態をモニターする役割である「状態管理サブシステム」に補助電源の扱いを任せてしまうのは機構的にも電気的にも複雑なことになりそうです。主電源の管理も含めて補助電源を管理するサブシステムを追加した方が良いのではないかという指摘が出てくるでしょう。
 
 次にシステム間のやりとりを見てみます。図では「?」をつけていますが、システム要件 R1.2 の、「商品管理サブシステム」から「金銭管理サブシステム」に「受け取っていない商品を知らせる」というやりとりに注目してください。このお知らせのためには、「商品管理サブシステム」はユーザが選択した商品で商品口にまだ届いていない商品がないかどうかを把握しておく必要があります。商品口の管理は「操作管理サブシステム」の役割の1つだと考えられるので、商品口に商品があるかどうかを「商品管理サブシステム」が管理するのは問題があるという指摘が出るでしょう。さらに、受け取っていない商品を「金銭管理サブシステム」に知らせるのは、その商品を特定できるデータとなるわけですが、その場合、「金銭管理サブシステム」はその商品の値段を把握していないと投入された金額のうちの商品を受け取っていない分を返却口に返すことができません。つまり、金銭管理サブシステムは商品価格を把握していなくてはいけないことになります。商品価格の設定を金銭管理サブシステムに対して行うのは疑問が残ります。
 
 このようなことから、今考えているサブシステム構成では「停電時の商品とお金の保証」というシステム要件をシンプルな振る舞いで実現できないことがわかります。それではどのようなサブシステム構成にすれば良いのかという試行錯誤が必要になるわけです。例題ではかなり簡素化した内容にはなっていますが、作成した一つひとつのシステム要件を使ってシステム構成の妥当性を検証する必要があること、そして、その検証ができることがよりよいサブシステム構成を考え出すための試行錯誤を可能にしていることがわかっていただけたのではないでしょうか。
 
 このような方法をとっていないように見える場合でも、システム設計をやっている人は同様のことを頭の中でやっています。しかし、システム設計をやっている人の暗黙知のままでは、自分自身システム設計スキルを上げていくことは難しいですし、ましては、他の人と協力してシステム設計をやることも、システム設計ができる人を育てることも困難です。現在、どのようにしてサブシステム構成を設計しているのか確認してみて、それが暗黙知に支えられているものであれば、今回のような仕組み化を検討してください。
 
 さて、前回と今回とで説明しているのはシステムエンジニアリングの部分です。実は、この後の工程であるハードウェアエンジニアリングやソフトウェアエンジニアリングの部分も考え方は同じです。システムエンジニアリングはシステム全体をサブシステムにブレークダウンするというシステム設計作業ですが、サブシステムをブロックに、ブロックをハードウェアモジュールとソフトウェアモジュールにというように徐々に小さな単位にブレークダウンするのも同じ考え方で進めます。どのような単位に分解されるのかというだけの違いです。また、分解されるものの呼び方の違いだけです。そういう意味では、システム設計工程を説明している部分は参考程度に考...
 前回のシステム設計7に続いて解説します。
 
 システム要件の一つひとつについて、サブシステム構成における振る舞いを記述し、各々のサブシステムの役割とサブシステム間のやりとりを検証していきます。ここではもう一つだけ、最後に追加したシステム要件「停電時の商品とお金の保証」について検証作業をやってみましょう。再度、FURPS+のブレークダウンを図73に示します。
 
プロジェクト管理
図73. FURPS+のブレークダウン
 
 このシステム要件には「停電を検出し補助電源を起動させる」(システム要件 R1.1)「停電を検出したときに投入されたお金を返却口に返す」(システム要件 R1.2)「停電を検出したときに商品口をロックする」(システム要件 R1.3)の3つの要件が含まれています。それぞれの要件についてサブシステム構成にその振る舞いを記述したものが図76です。
 
プロジェクト管理
図76. サブシステム構成の検証 
 
 今回も、まずサブシステムの役割を検証します。図ではみ出してしまっているように、「補助電源を起動する」という役割を果たすサブシステムがないことがわかります。「状態管理サブシステム」の一部にすればサブシステム構成を変える必要はありませんが、自販機の状態をモニターする役割である「状態管理サブシステム」に補助電源の扱いを任せてしまうのは機構的にも電気的にも複雑なことになりそうです。主電源の管理も含めて補助電源を管理するサブシステムを追加した方が良いのではないかという指摘が出てくるでしょう。
 
 次にシステム間のやりとりを見てみます。図では「?」をつけていますが、システム要件 R1.2 の、「商品管理サブシステム」から「金銭管理サブシステム」に「受け取っていない商品を知らせる」というやりとりに注目してください。このお知らせのためには、「商品管理サブシステム」はユーザが選択した商品で商品口にまだ届いていない商品がないかどうかを把握しておく必要があります。商品口の管理は「操作管理サブシステム」の役割の1つだと考えられるので、商品口に商品があるかどうかを「商品管理サブシステム」が管理するのは問題があるという指摘が出るでしょう。さらに、受け取っていない商品を「金銭管理サブシステム」に知らせるのは、その商品を特定できるデータとなるわけですが、その場合、「金銭管理サブシステム」はその商品の値段を把握していないと投入された金額のうちの商品を受け取っていない分を返却口に返すことができません。つまり、金銭管理サブシステムは商品価格を把握していなくてはいけないことになります。商品価格の設定を金銭管理サブシステムに対して行うのは疑問が残ります。
 
 このようなことから、今考えているサブシステム構成では「停電時の商品とお金の保証」というシステム要件をシンプルな振る舞いで実現できないことがわかります。それではどのようなサブシステム構成にすれば良いのかという試行錯誤が必要になるわけです。例題ではかなり簡素化した内容にはなっていますが、作成した一つひとつのシステム要件を使ってシステム構成の妥当性を検証する必要があること、そして、その検証ができることがよりよいサブシステム構成を考え出すための試行錯誤を可能にしていることがわかっていただけたのではないでしょうか。
 
 このような方法をとっていないように見える場合でも、システム設計をやっている人は同様のことを頭の中でやっています。しかし、システム設計をやっている人の暗黙知のままでは、自分自身システム設計スキルを上げていくことは難しいですし、ましては、他の人と協力してシステム設計をやることも、システム設計ができる人を育てることも困難です。現在、どのようにしてサブシステム構成を設計しているのか確認してみて、それが暗黙知に支えられているものであれば、今回のような仕組み化を検討してください。
 
 さて、前回と今回とで説明しているのはシステムエンジニアリングの部分です。実は、この後の工程であるハードウェアエンジニアリングやソフトウェアエンジニアリングの部分も考え方は同じです。システムエンジニアリングはシステム全体をサブシステムにブレークダウンするというシステム設計作業ですが、サブシステムをブロックに、ブロックをハードウェアモジュールとソフトウェアモジュールにというように徐々に小さな単位にブレークダウンするのも同じ考え方で進めます。どのような単位に分解されるのかというだけの違いです。また、分解されるものの呼び方の違いだけです。そういう意味では、システム設計工程を説明している部分は参考程度に考えた方が良いかもしれません。システム設計とは、システム全体を電気、機構、ソフトなどの今ある設計チームに分かれて設計を行うことできるまで、エンジニアリング作業を繰り返してブレークダウンする作業とするのが現実的でしょう。
 
 したがって、今説明しているシステムエンジニアリングの進め方を理解できれば、どの段階のエンジニアリングも同じように進めることができるということです。ただ、システムエンジニアリング作業で、ブレークダウンした要件の作成方法についてはまだ解説していません。これは次回にしましょう。
 
 さて、今回は、システム要件の作成の次の作業であるサブシステム構成の検証方法について解説しました。如何だったでしょうか、特定の人が頭の中でやってしまい、その妥当性について議論ができない典型的な作業ですが、今回のような考え方で、いわゆる「見える化」が可能なことがわかっていただければ幸いです。
 
 

   続きを読むには・・・


この記事の著者

石橋 良造

組織のしくみと個人の意識を同時に改革・改善することで、パフォーマンス・エクセレンスを追求し、実現する開発組織に変えます!

組織のしくみと個人の意識を同時に改革・改善することで、パフォーマンス・エクセレンスを追求し、実現する開発組織に変えます!


「技術マネジメント総合」の他のキーワード解説記事

もっと見る
イノベーション 普通の組織をイノベーティブにする処方箋 (その142)

  イノベーションの活動を行うことを妨げる「失敗のコストのマネジメント」の解説をしていますが、今回もこの解説を続けたいと思います。 &n...

  イノベーションの活動を行うことを妨げる「失敗のコストのマネジメント」の解説をしていますが、今回もこの解説を続けたいと思います。 &n...


製品設計におけるトレードオフのコントロール(その1)

 製品設計におけるトレードオフのコントロールを、今回と次回の2回に分けて解説します。   1.トレードオフを意識しながら製品設計するとは  製品...

 製品設計におけるトレードオフのコントロールを、今回と次回の2回に分けて解説します。   1.トレードオフを意識しながら製品設計するとは  製品...


自社の強みとは 『価値づくり』の研究開発マネジメント (その23)

   前回は、オープンイノベーションを成功させるためのビジネスモデルの必要性を解説しました。今回は、自社の強みの設定について議論したいと思...

   前回は、オープンイノベーションを成功させるためのビジネスモデルの必要性を解説しました。今回は、自社の強みの設定について議論したいと思...


「技術マネジメント総合」の活用事例

もっと見る
スーパーマンではなくプロフェッショナルな技術者に(その3)

【プロフェッショナルな技術者 連載目次】 1. 製品開発現場が抱えている問題 2. プロフェッショナルによる製品開発 3. 設計組織がねらい通り...

【プロフェッショナルな技術者 連載目次】 1. 製品開発現場が抱えている問題 2. プロフェッショナルによる製品開発 3. 設計組織がねらい通り...


羽のない扇風機が創られた時の目標設定、横並び競争と何が違うのか?

【目次】 1. 福原流QFDは技術者の創造性を引き出す技法 私も含めて我々技術者の思考は知らず知らずにうちに技術手段のHOWを考え...

【目次】 1. 福原流QFDは技術者の創造性を引き出す技法 私も含めて我々技術者の思考は知らず知らずにうちに技術手段のHOWを考え...


CMMIの要件管理 プロジェクト管理の仕組み (その2)

 前回のその1に続いて、今回は、CMMIの要件管理です。CMMI では次のこと(特定プラクティスといいます)ができている必要があります。   ...

 前回のその1に続いて、今回は、CMMIの要件管理です。CMMI では次のこと(特定プラクティスといいます)ができている必要があります。   ...