システム設計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つだと考えられるので、商品口に商品があるかどうかを「商品管理サブシステム」が管理するのは問題があるという指摘が出るでしょう。さらに、受け取っていない商品を「金銭管理サブシステム」に知らせるのは、その商品を特定できるデータとなるわけですが、その場合、「金銭管理サブシステム」はその商品の値段を把握していないと投入された金額のうちの商品を受け取っていない分を返却口に返すことができません。つまり、金銭管理サブシステムは商品価格を把握していなくてはいけないことになります。商品価格の設定を金銭管理サブシステムに対して行うのは疑問が残ります。
 
 このようなことから、今考えているサブシステム構成では「停電時の商品とお金の保証」というシステム要件をシンプルな振る舞いで実現できないことがわかります。それではどのようなサブシステム構成にすれば良いのかという試行錯誤が必要になるわけです。例題ではかなり簡素化した内容にはなっていますが、作成した一つひとつのシステム要件を使ってシステム構成の妥当性を検証する必要があること、そして、その検証ができることがよりよいサブシステム構成を考え出すための試行錯誤を可能にしていることがわかっていただけたのではないでしょうか。
 
 このような方法をとっていないように見える場合でも、システム設計をやっている人は同様のことを頭の中でやっています。しかし、システム設計をやっている人の暗黙知のままでは、自分自身システム設計スキルを上げていくことは難しいですし、ましては、他の人と協力してシステム設計をやることも、システム設計ができる人を育てることも困難です。現在、どのようにしてサブシステム構成を設計しているのか確認してみて、それが暗黙知に支えられているものであれば、今回のような仕組み化を検討してください。
 
 さて、前回と今回とで説明しているのはシステムエンジニアリングの部分です。実は、この後の工程であるハードウェアエンジニアリングやソフトウェアエンジニアリングの部分も考え方は同じです。システムエンジニアリングはシステム全体をサブシステムにブレークダウンするというシステム設計作業ですが、サブシステムをブロックに、ブロックをハードウェアモジュールとソフトウェアモジュールにというように徐々に小さな単位にブレークダウンするのも同じ考え方で進めます。どのような単位に分解されるのかというだけの違いです。また、分解されるものの呼び方の違いだけです。そういう意味では、システム設計工程を説明している部分は参考程度に考えた方が良いかもしれません。システム設計とは、システム全体を電気、機構、ソフトなどの今ある設計チームに分かれて設計を行うことできるまで、エンジニアリング作業を繰り返してブレークダウンする作業とするのが現実的でしょう。
 
 したがって、今説明しているシステムエンジニアリングの進め方を理解できれば、どの段階のエンジニアリングも同じように進めることができるということです。ただ、システムエンジニアリング作業で、ブレークダウンした要件の作成方法についてはまだ解説していません。これは次回にしましょう。
 
 さて、今回は、システム要件の作成の次の作業であるサブシステム構成の検証方法について解説しました。如何だったでしょうか、特定の人が頭の中でやってしまい、その妥当性について議論ができない典型的な作業ですが、今回のような考え方で、いわゆる「見える化」が可能なことがわかっていただければ幸いです。
 
 

   続きを読むには・・・


この記事の著者

石橋 良造

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

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


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

もっと見る
自社の存在価値 普通の組織をイノベーティブにする処方箋 (その119)

  前回は、「整理するフレームワークで整理・構造化した知識の中で焦点を当てる重要部分を切り取る」の議論の中で「顧客だけでなく社会に目を向け...

  前回は、「整理するフレームワークで整理・構造化した知識の中で焦点を当てる重要部分を切り取る」の議論の中で「顧客だけでなく社会に目を向け...


クレーム率シングルppmをゼロに(4) 【快年童子の豆鉄砲】(その59)

  1.「連関図」の結論引き出し関連部分の表示 この事例の場合、熟成が完了した連関図は、データ数が91と多い上、熟成度指数が2.23(筆...

  1.「連関図」の結論引き出し関連部分の表示 この事例の場合、熟成が完了した連関図は、データ数が91と多い上、熟成度指数が2.23(筆...


開発初期の戦略には言語化することが大切 新規事業・新商品を生み出す技術戦略(その5)

         「 新規事業・新商品を開発するにあたって、絶対に『戦略』が必要です 」とお話しす...

         「 新規事業・新商品を開発するにあたって、絶対に『戦略』が必要です 」とお話しす...


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

もっと見る
設計部門と組織政治の影響(その2)

 前回のその1に続いて解説します。   1. 政治的要因のリストアップ    設計部門と組織政治の影響を考察する際に、最初にや...

 前回のその1に続いて解説します。   1. 政治的要因のリストアップ    設計部門と組織政治の影響を考察する際に、最初にや...


設計部門とリスク管理(その3)

【設計部門とリスク管理 連載目次】 1. リスク管理とは目標達成までのシナリオ作成 2. コンティンジェンシープランの注意事項 3. リスク管理...

【設計部門とリスク管理 連載目次】 1. リスク管理とは目標達成までのシナリオ作成 2. コンティンジェンシープランの注意事項 3. リスク管理...


‐現場観察のチェックポイント‐  製品・技術開発力強化策の事例(その8)

 前回の事例その7に続いて解説します。現場観察はどのような場合でも非常に大切です。 価値ある情報をくみ上げる観察力を絶えず自己啓発する必要があります。現場...

 前回の事例その7に続いて解説します。現場観察はどのような場合でも非常に大切です。 価値ある情報をくみ上げる観察力を絶えず自己啓発する必要があります。現場...