IT勉強宴会


モデリングと開発のスピード感を目撃しよう<第58回IT勉強宴会in新大阪>
2017.9.2(土)に新大阪で開催しました。ブログはこちら
ブログはこちら
--------
2010年から日経コンピュータのレビューを書いています。 過去記事の検索にも便利です。
http://ameblo.jp/hatsanhat

IT勉強宴会は、データモデリングを主体とした上流工程の実践者が集まっている勉強会です。

趣旨

主催者は前職で大きなトラブルに何度か呼ばれて火消しをお手伝いしたことがあります。その後も気になり社内を調べると共通点がありました。それは炎上プロジェクトのすべてがデータモデルを作らず画面や帳表だけでお客様と要件確認をしてたという事です。
今でもそういうプロジェクトは多いと思います。見通しの利く程度の大きさのプロジェクトや、過去に経験した業務ならそれでも何とかなるでしょうが危うい方法です。

【どんな手法でも良いのでモデリングしましょう】

これを伝えることが当IT勉強宴会の目的です。

2004年ごろ東京出張中のホテルで読んだ生産管理・原価管理システムのためのデータモデリングという本にあまりに感激したため生まれて初めて著者紹介欄を見てファンメールを送りました。それがご縁で著者の渡辺幸三さんと、ほぼ毎月1度は飲みに行くようになりました。その時に様々な設計手法の議論や最新技術の話をしていました。主催者の退職をきっかけとしてこの飲み会を発展させるような形で飲み仲間にお手伝いいただきながら続けているのがIT勉強宴会です。

※データモデリングの方法論を詳しく知りたい方は次のブログをご参照ください。
DOAとXead Driverに関する私的な想い

・当勉強会がウェブメディア「カンパネラ」で紹介されました(2014.10)

2017年2月22日水曜日

IT勉強宴会へようそこ

IT勉強宴会タイトル
データモデリングを主体とした上流工程の実践者が集まっている勉強会です。
2017年2月22日 NPO法人IT勉強宴会として登記しました。

◆IT勉強宴会の趣旨

主催者は前職で大きなトラブルに何度か呼ばれて火消しをお手伝いしたことがあります。その後も気になり社内を調べると共通点がありました。それは炎上プロジェクトのすべてがデータモデルを作らず画面や帳表だけでお客様と要件確認をしてたという事です。

今でもそういうプロジェクトは多いと思います。見通しの利く程度の大きさのプロジェクトや、過去に経験した業務ならそれでも何とかなるでしょうが危うい方法です。

【どんな手法でも良いのでモデリングしましょう】
これを伝えることが当IT勉強宴会の目的です。

2004年ごろ東京出張中のホテルで読んだ「生産管理・原価管理システムのためのデータモデリング」という本にあまりに感激したため生まれて初めて著者紹介欄を見てファンメールを送りました。それがご縁で著者の渡辺幸三さんと、ほぼ毎月1度は飲みに行くようになりました。その時に様々な設計手法の議論や最新技術の話をしていました。主催者の退職をきっかけとしてこの飲み会を発展させるような形で飲み仲間にお手伝いいただきながら続けているのがIT勉強宴会です。


※データモデリングの方法論を詳しく知りたい方は次のブログを読んで下さい。
http://blog.benkyoenkai.org/2010/12/doaxeaddriver.html

・当勉強会がネット記事になりました(2014.10)

午前0時過ぎ、居酒屋で本当の勉強会がはじまる

◆過去のIT勉強宴会の情報など

blog.benkyoenkai.org

2015.01.09 第38回> 
 案内
中小企業の社長は何を考えているか
■■■■■■2014■■■■■■
2014.12.12 第37回>  案内<年忘れLT宴会>
2014.11.21 第36回>  案内ITよろず相談会>
2014.10.29 第35回>  案内企業情報システムの再開発手法
2014.09.26 第34回>  案内IT技術者が必要とする連結会計の知識>
2014.07.28 第33回>  案内<「受注生産」のためのシステム開発ライブ>
2014.06.26 第32回>  案内モデルとは何か
2014.05.16 第31回>  案内<システム開発に関わる法令>
2014.03.06 第30回>  案内<【 ソフトを他人に作らせる日本、自分で作る米国 】を語ろう>
2014.02.15 第29回>  案内<ジェネレーティブ・プログラミングの世界>
  IT勉強宴会 開催のご挨拶
  ジェネレーティブ・プログラミングの世界
  帳票・フォームの自動生成
  データマッピングフレームワーク Rmenu
  超高速開発ツール-Wagby-のご紹介
  「仕様書駆動」のための開発基盤 XEAD Driver
■■■■■■2013■■■■■■
2013.12.13 第28回>  案内ドメイン駆動開発を知ろう
2013.10.31 第27mini 案内XEAD初心者の会:XEAD Driverインストール>
2013.10.04 第26回>  案内<仕様書で駆動される生産管理システムの開発事例>
2013.08.30 第25回>  案内<クラウドビジネスの実態とエコシステムとしてのセールスフォース概要>
2013.07.01 第24回>  案内ITエンジニアの ゼロから始める英語勉強法(ペラペラ実践編)
2013.05.24 第23回>  案内知的書評合戦ビブリオバトル!
  求む!上流工程技術者
  『仕様書で動く生産管理システム』の開発事例報告
  3D-CADデータの一気通貫とIT活用でものづくり力向上を!  
  製造業のプロジェクトにおけるボトルネック ~BOM/部品表の問題~
2013.02.22 第21回>業界標準プロセスと、なんちゃってDOA/要求開発と三要素分析法で要件定義
■■■■■■2012■■■■■■
2012.12.21 第20回>BPMとデータモデリング
2012.09.28 第19回>新刊「チケット駆動開発」の紹介/サロゲートキーとデータモデル
<2012.08.24 第18回>rubyでお手軽に帳票・バッチのある業務システムを作ろう
<2012.06.29 第17回>渡辺幸三が語る「データ中心設計の基本とクラウド開発」
2012.05.25 第16回DOA技術者のためのセールスフォース入門
2012.03.19 第15回>DAMA日本支部およびDMBOKについて
2012-01-13 第14回DBセキュリティツールGuardiumのご紹介/Rubyフレームワーク
■■■■■■2011■■■■■■
2011-12-16 第13回>コッド論文を読もう
2011-10-28 第12回>言い訳ドリブン開発/データベース設計はプログラミングの後に行う
2011-09-26 第11回>DOA+オーバービューマスタ統合/全社システムのアーキテクチャー
2011-07-08 第10回>DOAの基本をおさらいしようの会
<2011-06-03 第9回>SEのための帳簿知識入門
2011-04-22 第8回>「渡辺さんに目の前でシステムをつくってもらっちゃおう!」
2011-03-18 第7回>プロジェクト内コミュニケーションの新しい形/IFRSの導入で会計と業務の関係が変わる!
2011-02-25 第6回>チケット駆動開発~タスクマネジメントからAgile開発へ/「ビジネスソフト」の選び方、作り方
2011-01-14 第5回>Google Apps Script概説/テスト駆動開発(TDD)の実際
■■■■■■2010■■■■■■
2010-12-14 第4回>オープンソース Openbravo POS/基幹業務としてのクラウド
2010-11-06 第3回>刮目せよ!モデリング技術がもたらすオープンソース業務システム-前座-
2010-09-15 第2回>運用を考慮した設計(略すな危険)/小型コンピュータの最新動向
  GitHubの使い方
  システム設計注意点-運用を考慮する

  これからの会計システム開発とFusionPlace


◆メーリングリスト
 次のアドレスに空メールを送ってご参加下さい。退会も簡単です。
 ※+は1バイトのプラスの文字です
 過去の情報はここからご覧いただけます。

◆個人ブログ

雑誌「日経コンピュータ」の主要記事を主体としたIT関連情報を発信しています

2015年9月6日日曜日

メンバー紹介①渡辺幸三さん◆レファレンスモデルの役割

渡辺さんは、業務システムの設計手法「三要素分析法」の提唱者で、三要素分析法に基づいた設計ツール「X-TEA Modeler」および、設計情報にもとづいてアプリケーションを実行するための基盤「X-TEA Driver」を開発・公開されています。また、さまざまな設計データを「レファレンスモデル」として公開されています。自宅近くの居酒屋さんで話を伺いました。

◆設計スキルを底上げするための教材として

―「レファレンスモデル」を公開することの意義についてお聞かせください。業務システムの設計情報を公開するというのはあまり聞かない話ですが、なぜこのような取り組みをされているのでしょうか。

まず、業界全体の設計品質を底上げする必要があると考えるからです。ユーザ企業にとって、業務システムの開発は未だに高価でリスクの高いものです。さまざまな要因があるでしょうが、まずは設計技術を向上させることで状況は改善されると考えています。

新しいシステムを新規で開発するとき、多くの現場ではゼロから設計しています。しかし、業務システムの設計において、プロジェクトに固有な条件はあるものの、共通する設計課題も少なくない。こうした課題は、先人の知恵をそのまま借りたほうが効率的に解決できます。
―確かに、簡単な例で言えば、ユーザや組織の管理といったモジュールはどのシステムでも必須ですから、そういった箇所はすでに実績のあるモデルを使ったほうが効率的なのでしょうね。

そうです。建築の分野では多くの設計情報が公開されていますが、システム開発の分野では入門レベル程度のものしか見あたりません。レファレンスモデルはそういう状況を改善してくれます。

◆方法論の有効性を示すための素材として

レファレンスモデルを公開する2つめの理由は、設計手法を評価するための素材になると考えるからです。

―渡辺さんご自身も「三要素分析法」という設計手法を提唱されています。

業務システム開発向けの設計手法はいろいろあります。選択肢があったほうが良いのでしょうが、ユーザ企業が実験台になるべきではありません。その前に手法の有効性を検討できたほうがいい。その枠組みに沿って記述された設計事例や実システムが公開されていれば、第三者でも方法論の有効性を事前に検証できます。

―開発視点で考えると「どのようなプロセスか」という点に興味がかたよりがちですが、当然ながら一番大事なのは「どういうものが作れるか」ですよね。

「どういう事例を支えられるか」ですね。たとえば音楽を記述するための枠組みがあるとします。その有効性は、いかに多彩な楽曲を記述できるかで検証できます。じっさいにそのように検証されて、現在の楽典の体系がメジャーになりました。しかし、システム開発の枠組みに関しては、そういう視点が欠けている。「こういうやり方(書き方)がいい」という主張には、そのやり方(書き方)でまとめられた事例の数々がレファレンスとして添えられるべきです。

◆モデル駆動の枠組みを探る

3つめの理由は、「モデル駆動の枠組み」を探るための素材になるというものです。ソフトウエア開発には、飛行機や建築物と違って資材が要りません。だから、設計情報そのものが動作可能であるという面白い特性があります。レファレンスモデルそのものをソフトウエアとして動作させられるか。そういうことを考える素材になってくれます。

―渡辺さんはじっさいにそのような枠組みをX-TEA Driverとして公開されていますね。

音楽の楽典の例といっしょなんです。音楽の記述体系として適切ならば、その体系にもとづいて機械に演奏させることができる。五線譜で書けばそのまま演奏してくれる音楽ソフトはいろいろありますよね。ソフトウエアもいっしょで、「こういうやり方(書き方)がいい」という枠組みがあれば、その体系で記述された内容にしたがってコンピュータが動作する基盤が遅かれ早かれ出現するはずです。

―開発方法論を提唱するということは、第三者がその有効性を検証できるようないろいろな素材を添える責任をともなっているということですか。

そういう責任がないなら、誰だって明日から方法論者になれますよね。そういう素材をいろいろと提示できるという点で、私はプログラマであって良かったと思っています。まあプログラマとしては、同じ勉強宴会のメンバーである久保さんに比べたら恥ずかしいようなレベルなんですが。

―今日はどうもありがとうございました。


渡辺さんのサイト
http://homepage2.nifty.com/dbc/index.html

2015年2月15日日曜日

花束問題のしおり

花束問題をしおりとして製本できるように編集してみました。

MS WORDをお持ちの方はDOCの方をダウンロードしてご自分のメモなどを追加して下さい。データモデルに興味にある方は正規化の資料などをいれても良いでしょう。UMLの表記法を入れても参考になるでしょう。

https://drive.google.com/file/d/0BykMR9FfFyLOSF85MjdyVUluV0E/view?usp=sharing

段組みが特殊なので、WORD互換のエミュレータではくずれるかも知れません。そのためにPDF版を用意しました。

https://drive.google.com/open?id=0BykMR9FfFyLORVlLU2czY1dJUkk&authuser=0


<しおりの作り方>
1.全部のページ(4ページ)を印刷する
2.全部を印刷面を表にして2つ折りする
3.1ページめが表表紙/裏表紙になるように全体をおおう

わかるとは思いますが、図を書きました。

このフォーマットは旅のしおりをつくるのに重宝しています。

2015年1月26日月曜日

花束問題V1.2

=========================================================================
当問題は、IT勉強宴会(http://www.benkyoenkai.org)の例題として作成しました。
著作権は著者に帰属しますが、この注意書きを含め全体であれば無料で自由に再配布する事を許可します。部分変更したい場合は全体の配布とは別に変更部分を配布して下さい。
 配布方法は著作物、メール、WEBを問わず自由です。
                           2015.01.22 佐野初夫
-------------------------------------------------------------------------
【花束配送問題(V1.2)】
ロットと在庫推移(日別の在庫数)の管理が必要な、比較的複雑な業務要件にもとづくモデリング手法比較用の標準問題。

■事業と問題の概要
フラワーショップ「フレール・メモワール」は店舗売りとは切り離してWEBショップ事業を立ち上げた。WEBで注文を受け付けて、指定された日付に指定場所に花束を届けるという形態。
当初は受注も少なく手作業で管理出来ていたが、受注が増えるにつれシステム化の必要性が出てきた。「新鮮な花を大切な記念日に」を売り文句にしていることもあって、廃棄される在庫が多く、受注の増加にともなって利益が伸びていないため。

■回答方法
このビジネスのために、効率的な仕入・販売を支援する業務システムのモデル(回答者が通じている手法においてまとめられる各種図面)を作図する。当然ながら、実際のヒアリングでは、あらかじめ謳われている要件以外の要望やアイデアがいくらでも出てくるものなので、大きく逸脱しない限り、適宜ユーザ要件を補ったり修正してもかまわない。ただし、その際にはどのような補足や修正がなされたかをその意図とともに明示すること。

■文書化されているユーザ要件
///商品と在庫///
①花束の組み合わせは事前に「商品」として決めうちされている。1個の商品あたり、どの「単品(後述)」がどれだけ必要かも決められている。シングルレベルしかない部品表のようなもの。単品の在庫も含めて、保管場所は1箇所で、これが増える予定もない。

②花束の材料となるそれぞれの花は「単品」として管理される。「単品」はそれぞれ特定の仕入先から購入され、単品毎に品質維持可能日数が決められている。購入後にその日数を超えると結束には利用できずに廃棄されなければならない。なお、受注・出荷されるものは「商品」のみであって、単品がそのまま出荷されることはない。

///得意先と受注・出荷///
③リピータを期待するので、得意先(個人のみ)情報を管理したい。届け先は毎回違う可能性があるが、前回の受注情報から届け先を簡単にコピーできるような機能は欲しい。

④1回の受注で、1箇所の届け先に対する1種類の商品1個を、「届け日」と「お届けメッセージ」、「お届け先電話番号」とともに受け付ける。出荷日は届け先に関係なく届け日の前日とする。

⑤いったん受注を受けてから、届け日の変更が要望されることがある。その際には可能な限り変更に対応できるようにしたいが、指定日に出荷変更できないようならばその旨を顧客に直ちに伝えられるようでなければならない。

⑥単品を結束して商品(花束)にするための工程は十分に効率化されていて、材料さえあれば一瞬で結束可能とみなしてよい。したがって、出荷日当日に結束指示すれば出荷可能である。

///発注と入荷///
⑦単品を発注する際、単品毎に発注リードタイム(入荷されるまでにかかる日数)が異なる。発注リードタイムさえ越えていれば、どんな将来の入荷向けの単品も発注可能だし、入荷日の変更要望も受け付けてもらえる。

⑧「単品」毎に購入単位数が決まっている。たとえば、50本必要だとしても、購入単位が100本ならば100本買わなければならない。なお、仕入先の供給能力は十分かつ、納期も正確とみなしてよい。

⑨発注の判断は、在庫推移(日別の在庫予定数)をみながら人間が行う。したがって、自動発注処理を考える必要はない。

///代金の扱い///
⑩IDの登録の際にクレジットカード情報を入れるため請求や入金に関しては考慮する必要はない。

⑪入荷の実績情報があれば処理できるので、仕入先への支払に関しても考慮する必要はない。

///現状の画面・帳票///
⑫添付資料(花束問題伝票V1.0.ppt)のとおりであるが、現状のままでは使いにくいと感じているため、ユーザとしては全面的に刷新してもかまわないと考えている。

以上


sample001

sample002

sample003

sample004

sample005

sample006

sample007

-----------------------------------------------------------------