Slide 1

Slide 1 text

Unityと消費電力 Gotanda.unity #3 2017/11/29 @mattak

Slide 2

Slide 2 text

モチベーション 位置ゲームなど… - 屋外 - 充電できない環境で長時間遊ばれる - バッテリーくいすぎると不評 => Unityだとどんな感じか気になったので調査

Slide 3

Slide 3 text

実験 端末: - iPhoneX (iOS 11.1) 比較: - iOS Native - WebView - Unity

Slide 4

Slide 4 text

動作 白表示する Unity - Canvas & Image

Slide 5

Slide 5 text

検証1. Native/WebView/Unity 消費電力が大きいのは?

Slide 6

Slide 6 text

iOS Native

Slide 7

Slide 7 text

iOS Native (energy)

Slide 8

Slide 8 text

iOS Native (energy) ΄΅%JTQMBZ ੨ $16 ࢵ ͸ىಈ࣌ͷΈ

Slide 9

Slide 9 text

iOS Native (cpu)

Slide 10

Slide 10 text

iOS Native (cpu) $16͸ىಈ࣌ͷΈ

Slide 11

Slide 11 text

WebView

Slide 12

Slide 12 text

WebView (energy)

Slide 13

Slide 13 text

WebView (energy) ॳظ$16 ࢵ ͕एׯ ΄΅%JTQMBZ ੨

Slide 14

Slide 14 text

WebView (cpu)

Slide 15

Slide 15 text

LocalでのHTML表示だったので、 通信して表示みる

Slide 16

Slide 16 text

WebView (energy) - 通信表示

Slide 17

Slide 17 text

WebView (energy) - 通信表示 /FUXPSL ᒵ ͱ 0WFSIFBE ੺ Ͱిྗ͘͏

Slide 18

Slide 18 text

IUUQTEFWFMPQFSBQQMFDPNMJCSBSZDPOUFOUEPDVNFOUBUJPO1FSGPSNBODF $PODFQUVBM&OFSHZ(VJEFJ04&OFSHZBOE/FUXPSLJOHIUNM Overhead? Networking Variable Effect on Energy (developer.apple.com) ネットワーク状態に関連してバッテリーが影響を受ける - 例1: 3G/LTEは WiFiよりも電池くう (10h -> 11h) - 例2: network throughputが悪いと待機時間画のびる - 例3: 散発的な通信 は電池食う (通信すると待機状態になる)

Slide 19

Slide 19 text

WebView (energy) - 通信表示 ௨৴଴ػ ੺ ௨৴։࢝ ᒵ

Slide 20

Slide 20 text

Unity

Slide 21

Slide 21 text

Unity (energy)

Slide 22

Slide 22 text

Χϥϑϧ

Slide 23

Slide 23 text

Unity (energy) %JTQMBZ ੨ (16 ྘ ͕൒ʑ $16 ࢵ ͸ৗʹ

Slide 24

Slide 24 text

Unity (energy) ௨৴։࢝ ᒵ ௨৴଴ػ ੺

Slide 25

Slide 25 text

Network? UnityAnalyticsが有効になっていた!

Slide 26

Slide 26 text

外してみたが変わらず…

Slide 27

Slide 27 text

一旦諦めてCPUの状態をみる

Slide 28

Slide 28 text

Unity (cpu)

Slide 29

Slide 29 text

Unity (cpu) ཪͰͣͬͱήʔϜϧʔϓ͕ ճ͍ͬͯΔ

Slide 30

Slide 30 text

検証2. 画面表示を黒にするのは効果あるのか?

Slide 31

Slide 31 text

バッテリーセーバー機能 - 画面が下をむくと自動的に黒

Slide 32

Slide 32 text

動作 黒表示する Unity - Canvas & Image

Slide 33

Slide 33 text

Unity (battery) - 白画面

Slide 34

Slide 34 text

Unity (battery) - 黒画面

Slide 35

Slide 35 text

Unity (battery) - 黒画面 %JTQMBZ ੨ ͕ݮͬͯΔʂ

Slide 36

Slide 36 text

Native iOSでも同様に黒にしてみる

Slide 37

Slide 37 text

Native iOS (battery) - 黒画面

Slide 38

Slide 38 text

Native iOS (battery) - 黒画面 ΄΅ όοςϦʔফඅͳ͠

Slide 39

Slide 39 text

よく観察すると、最近のOSは頻繁に黒画面になる - ロックスクリーンが黒っぽい - 数秒で輝度が下がる - …

Slide 40

Slide 40 text

ちなみに、電源ボタン押して画面ロックしてみると

Slide 41

Slide 41 text

Unity (battery) - バックグラウンド

Slide 42

Slide 42 text

Unity (battery) - バックグラウンド ͦͷؒ͸$16(16ͳͲ ΋Ζ΋Ζࢭ·Δ

Slide 43

Slide 43 text

白画面 >> 黒画面 >> ロックスクリーン

Slide 44

Slide 44 text

検証3. FPSを下げるのは効果あるのか?

Slide 45

Slide 45 text

V Sync Count => Dont Sync Application.targetFrameRate = 1

Slide 46

Slide 46 text

Unity (fps) - fps1 (黒画面)

Slide 47

Slide 47 text

Unity (fps) - fps1 (黒画面) '14͸

Slide 48

Slide 48 text

Unity (battery) - fps1 (黒画面)

Slide 49

Slide 49 text

Unity (battery) - fps1 (黒画面) (16 ྘ ͕ ΄΅ಈ͍ͯͳ͍ /FUXPSL ᒵ ͱ 0WFSIFBE ੺ ͕େ൒ /FUXPSL ᒵ ͑͞ མͪண͚͹ ΄΅$16 ࢵ ͷΈ

Slide 50

Slide 50 text

Unity (cpu) - fps1 (黒画面)

Slide 51

Slide 51 text

Unity (cpu) - fps1 (黒画面) ฏۉ ΄΅΄΅ಈ͍ͯͳ͍

Slide 52

Slide 52 text

高FPS > 低FPS (CPU/GPUへのインパクト)

Slide 53

Slide 53 text

結論 検証1. 消費電力が大きいのは? - Native <= WebView << Unity 検証2. 黒画面効果ある? - YES. ただ画面ロックのほうが更に効果ある 検証3. FPS下げるの効果ある? - YES. GPUとCPU使用率が下がる

Slide 54

Slide 54 text

結論 ネットワーク - 散発リクエストしちゃだめ - Overheadは地味に電力くう - Unityは裏で定期的に通信してる 画面 - 黒っぽくしよう - 画面ロックしよう FPS - 下げよう