Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
20220629oolpjp
Search
株式会社レヴィ
June 29, 2022
Education
0
610
20220629oolpjp
株式会社レヴィ
June 29, 2022
Tweet
Share
More Decks by 株式会社レヴィ
See All by 株式会社レヴィ
2024-06-25 ソフトウェア設計における思考と学び方を考える 〜増田さんの思考を構造的に見える化してみる〜
levii
4
950
株式会社レヴィ会社紹介
levii
0
200
Sample-se-one-day-training
levii
0
620
SocSys34-Balus
levii
0
74
20230323TechDLT-vol9
levii
0
350
levii-buzzword-2022
levii
0
350
FIT2022_levii
levii
0
620
20220915modelingLT
levii
4
790
20220910SSDM
levii
0
650
Other Decks in Education
See All in Education
自分にあった読書方法を探索するワークショップ / Reading Catalog Workshop
aki_moon
0
240
LLMs for Social Simulation: Progress, Opportunities and Challenges
wingnus
1
120
Design Guidelines and Models - Lecture 5 - Human-Computer Interaction (1023841ANR)
signer
PRO
0
720
子どものためのプログラミング道場『CoderDojo』〜法人提携例〜 / Partnership with CoderDojo Japan
coderdojojapan
4
14k
Library Prefects 2024-2025
cbtlibrary
0
120
HCI Research Methods - Lecture 7 - Human-Computer Interaction (1023841ANR)
signer
PRO
0
750
Adobe Express
matleenalaakso
1
7.6k
Medicare 101 for 2025
robinlee
PRO
0
320
BrightonSEO, San Diego, CA 2024
mchowning
0
100
The Gender Gap in the Technology Field and Efforts to Address It
codeforeveryone
0
270
勉強したらどうなるの?
mineo_matsuya
10
6.8k
Informasi Program Coding Camp 2025 powered by DBS Foundation
codingcamp2025
0
120
Featured
See All Featured
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
2
290
4 Signs Your Business is Dying
shpigford
181
21k
Build your cross-platform service in a week with App Engine
jlugia
229
18k
Optimising Largest Contentful Paint
csswizardry
33
3k
Typedesign – Prime Four
hannesfritz
40
2.4k
Why Our Code Smells
bkeepers
PRO
335
57k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
5
450
Git: the NoSQL Database
bkeepers
PRO
427
64k
GitHub's CSS Performance
jonrohan
1030
460k
Adopting Sorbet at Scale
ufuk
73
9.1k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
48k
How STYLIGHT went responsive
nonsquared
95
5.2k
Transcript
研究用シミュレーションにおける オブジェクト指向 2022.6.29 オブジェクト指向 LT会 vol.4 miure https://m-miura.jp/
Copyright levii Inc. All rights reserved. 自己紹介 三浦 政司 (みうら
まさし) JAXA宇宙科学研究所 宇宙飛翔工学研究系 准教授 深宇宙探査技術実証機(DESTINY+)プロジェクトチーム 株式会社レヴィ 共同創業者/システムデザイン研究所所長 専門分野 • 制御工学 :分散協調制御、飛翔体誘導制御 • システム工学:システム設計論、システムモデリング • システム科学:エージェントベースシミュレーションなど 好きなこと • 蟻コロニーの飼育 • 自転車 • コミック m-miura.jp 菌類からロケットまで 複雑なものならなんでも 扱う雑食系研究者
発表概要 (自分の)研究用シミュレーションとオブジェクト指向の関わりについて 2つの視点からライトに紹介します。つまり、二本立てです。 ① ABMとOOの考え方が似ているという話 研究で使っているAgent-Based Modeling/Simulationという手法の考え方が オブジェクト指向パラダイムととても良く似ている(or
同じ)ということに 気づいたので紹介します。どちらかと言うと研究紹介です。 ② 研究用シミュレータをOOでつくってみたという話 研究で使うシミュレーションコードがいろいろ不便だったので、 オブジェクト指向で捉え直してオブジェクト指向っぽくつくってみました。
① ABMとOOの考え方が似ているという話
複雑な現象 = 創発的な現象 創発性:相互作用によって個々の要素の性質や振る舞いからは 直接説明することのできない全体的な性質や振る舞いが生じること。 各要素の個々の振る舞いを 理解できても… 要素間に相互作用があると振る舞いの 予測・理解が難しい場合がある(創発性) <創発性は社会現象や自然現象の中にたくさんある>
例:交通渋滞、流行、不況/好況(経済)、蟻の行列、鳥の群れ行動、
エージェントベースアプローチ • 創発性を伴う現象を理解・予測するためのアプローチの一つ • 現象を多数のエージェントの集合とその相互作用で記述する 定められたルールに従って自律的に 行動・意思決定・学習する要素 • エージェント同士の相互作用 •
エージェント-環境間の相互作用
エージェントベースモデルとシミュレーション Agent-Based Model (ABM) :エージェントベースアプローチで構築したモデル Agent-Based Simulation (ABS):ABMをコンピュータ上で動作させて現象を再現
例)サメ-小魚モデル 小魚 近くのサメから逃げる サメ 近くの小魚を追いかける 近くのサメから逃げる
例)サメ-小魚モデル 500 10 500 10 3 97 +視力アップ 創発現象 個々のエージェントモデルからは導き出せな
い全体の特徴的な振る舞い 10 2 小魚 近くのサメから逃げる サメ 近くの小魚を追いかける 近くのサメから逃げる
解説記事も公開しています https://www.jstage.jst.go.jp/article/isciesci/61/5/61_169/_pdf/-char/ja
どこが似ている?/違う? エージェントベースアプローチ オブジェクト指向パラダイム • 「このエージェントはどんな行動をするの?」「何を しっているの?」を考えることが出発点。 • 個々のエージェントが行動ルールとデータを
持っている。 • エージェントは他のエージェントや環境と 相互作用する • 複雑な現象を理解したり予測したりするために現象 をどう捉えるか?のパラダイム • 「このオブジェクトに何を任せる?」「このオブジェクトは何 を知っている?」を考えるのが出発点。 • 個々のオブジェクトが手続きとデータを持っている。 • オブジェクトは、メッセージを通して他の オブジェクトと相互作用する • 複雑さに対処するために、 業務・情報・処理をどう捉えるか?のパラダイム
エージェントベースシミュレーションを用いた研究の例 電力系統の分散型需給制御に関する研究 M.Miura, Y.Tokunaga, K.Sakurama(2016) 小売企業の空間的競争に関する研究 H.Shiroishi, M.Miura (2018) チェーン組織のガバナンスに関する研究
H.Shiroishi, M.Miura (2021)
エージェントベースシミュレーションを用いた研究の例 木材腐朽菌の菌種間競争に関する研究:Y.Fukasawa, M.Miura (2022)
モデル(ver1)の全体像 非公開
環境と環境変数 • 環境は有機物資源が分布する格子状の 2次元空間 • 各セルには初期状態で特定の量の資源が 分布 • 主な環境変数(各セルが値を持つ変数) ◦
資源量 ◦ 阻害物質量 ◦ 生長投資量 ◦ 占有状態(空、菌1、菌2) 例)資源量:10.8 菌1が分泌した阻害物質量:0.8 菌2が分泌した阻害物質量:0 占有状態:菌1 非公開
エージェント • 菌糸エージェントは空間のセル上に 配置され、生成・消滅はするが移動は しない • 主なエージェント変数 (各エージェントが値を持つ変数) ◦ 位置(座標)
◦ 炭素量 ◦ 炭素要求度 ◦ 炭素配分戦略変数 など 例)炭素量:5.32 炭素要求度:0.25 炭素配分戦略変数:0.8 非公開
エージェントの行動ルール:ステップ行動の全体 自身が位置する セルから資源を 獲得 隣接セルの占有 状態と配分戦略 から炭素配分を 決定 隣接セルへの 生長投資
(炭素消費) 自身が位置する セルに阻害物質 を生成 (炭素消費) 呼吸による炭素 を消費 隣接セルの占有 状態と炭素量か ら炭素要求度を 算出 隣接セルの同種 菌と自身の炭素 要求度から受け 渡し量を決定 隣接セルの同種 菌に炭素を受け 渡す(もしくは 受け取る) 非公開
エージェントの行動ルール:生成(生長)と炭素運搬 生成 • あるセル上の生長投資量がしきい値を超えると 菌糸エージェントが生成される • 周囲のセル上の阻害物質(競争相手が分泌したもの)が 多いほどしきい値が大きくなる(=生成しにくくなる) 炭素運搬 •
各菌糸エージェントは「炭素要求度」を計算する • 炭素要求度は次のような場合に大きくなる ◦ 隣接セルに競争相手がいる場合 ◦ 隣接セルが空いている場合 ◦ 自身の保持する炭素量が少ない場合 • 隣接セルの同種菌と自身の要求度の差に応じて 炭素を受け渡す 0.04 0.13 0.81 0.08 0.23 0.21 0.09 0.34 0.74 0.81 青い菌糸の生成には 0.13+0.81+0.23の 阻害物質の影響を受ける 要求度が低いほうから高い方へ と炭素が受け渡される 非公開
アラン・ケイも言っている I thought of objects being like biological cells and/or
individual computers on a network, only able to communicate with messages. さながら生物の細胞、もしくはネットワーク上の銘々のコン ピュータ、それらはただメッセージによってコミュニケーショ ンする存在、僕はオブジェクトをそう考えている
② 研究用シミュレータをOOでつくってみたという話
研究用シミュレータ • 変化が激しい ◦ 研究は仮説検証の繰り返し ◦ 議論するとシミュレーションモデルがすぐに変わる ◦ 見たいデータやカットがすぐに変わる •
いろいろ使うから流用したい ◦ 菌のシミュレーション ◦ 組織のシミュレーション ◦ ロケットのシミュレーション • 便利に業務を行いたい ◦ 研究者から見たら研究 = 業務 ◦ 業務とプログラム構成をつなげることで わかりやすくしたい
研究用シミュレータのオブジェクト指向にチャレンジ:続きはBalusで
宣伝
Copyright levii Inc. All rights reserved. 対話型モデリングツール:Balus® • 素早く簡単にビューやシステムモデルを構築 •
チームメンバやステークホルダが対話しながら システムモデリング • 自動構造化やファシリテート支援などの 高度な機能(実装作業中)
https://levii.co.jp/ Balus モデル
Copyright levii Inc. All rights reserved. システム思考で課題を見える化!レヴィ無料相談会はじめました 詳細&申込:https://levii.co.jp/services/pages/free-consultation/
Copyright levii Inc. All rights reserved. レヴィについて 株式会社レヴィは「複雑さの中に価値と面白さを見つけよう」をミッションに掲げ、 価値あるシステムの創造や複雑な問題の解決にチャレンジする人・チームを支援する サービスを展開しています。
Webサイト : https://levii.co.jp/ お問い合わせ:
[email protected]
@levii_sdl @levii.inc