Pomiar wartości mocy

Producenci urządzeń muszą podać profil poboru mocy komponentu w pliku /frameworks/base/core/res/res/xml/power_profile.xml.

Aby określić wartości profili zasilania, użyj sprzętu, który mierzy moc wykorzystywaną przez urządzenie, i wykonuj różne operacje, do których potrzebne są informacje. Zmierz zużycie energii podczas tych operacji i oblicz wartości (odpowiednio oblicz różnice w porównaniu z innymi wartościami bazowymi zużycia energii).

Celem profilu zasilania jest odpowiednie oszacowanie zużycia baterii, dlatego wartości profilu zasilania są podawane w amperach. Platforma Android mnoży bieżącą wartość przez czas, przez który podsystem był aktywny, i oblicza wartość w mAh, która jest następnie używana do oszacowania ilości energii zużytej przez aplikację lub podsystem.

Urządzenia z kontrolerami Bluetooth, modemu i Wi-Fi z Androidem 7.0 lub nowszym mogą dostarczać dodatkowe wartości mocy uzyskane na podstawie danych z chipsetu.

Urządzenia z niejednorodnymi procesorami

Profil zasilania dla urządzeń z rdzeniami procesora o różnej architekturze musi zawierać te dodatkowe pola:

  • Łączna liczba procesorów w każdym klastrze (wyrażona w cpu.clusters.cores).
  • Szybkość procesora obsługiwana przez każdy klaster.
  • Aktywny pobór mocy procesora w przypadku każdego klastra.

Aby odróżnić aktywne zużycie energii procesora i obsługiwane prędkości procesora w klastrach, dodaj numer klastra do nazwy tablicy. Numery klastrów są przypisywane według kolejności rdzeni procesora w drzewie urządzenia jądra. Na przykład w przypadku heterogenicznej architektury z 2 klastrami z 4 rdzeniami:

  • cluster0 składa się z cpu0-3
  • cluster1 składa się z cpu4-7

Framework Androida używa tych numerów rdzeni procesora podczas odczytu statystyk z plików sysfs w folderze /sys/devices/system/cpu/cpu<number>/cpufreq/stats.

Przykład procesorów i szybkości klastra:

<array name="cpu.active.cluster0">
<value>200</value>
<value>300</value>
<value>400</value>
</array>
<array name="cpu.speeds.cluster0">
<value>600000</value>
<value>800000</value>
<value>1200000</value>
</array>

<array name="cpu.active.cluster1">
<value>400</value>
<value>500</value>
<value>600</value>
</array>
<array name="cpu.speeds.cluster1">
<value>800000</value>
<value>1200000</value>
<value>1400000</value>
</array>

Wartości mocy

W tabeli poniżej znajdziesz dostępne ustawienia wartości mocy. Aby wyświetlić przykładowy plik w AOSP, zobacz power_profile.xml.

Nazwa Opis Przykładowa wartość Uwagi
ambient.on Dodatkowa ilość energii zużywana, gdy ekran jest w trybie Doze/Ambient/Always-On zamiast w trybie wyłączonym. około 100 mA -
screen.on Dodatkowa ilość energii zużywana, gdy ekran jest włączony z minimalną jasnością. 200 mA Obejmuje kontroler dotykowy i podświetlenie wyświetlacza. przy jasności 0, a nie minimalnej jasności Androida, która zwykle wynosi 10–20%.
screen.full Dodatkowa ilość energii zużywana, gdy ekran jest ustawiony na maksymalną jasność, w porównaniu z ekranem ustawionym na minimalną jasność. 100 mA-300 mA Ułamek tej wartości (na podstawie jasności ekranu) jest dodawany do wartości screen.on w celu obliczenia zużycia energii przez ekran.
wifi.on Dodatkowa energia zużywana, gdy Wi-Fi jest włączone, ale nie odbiera, nie transmituje ani nie skanuje. 2 mA -
wifi.active Dodatkowa moc zużywana podczas przesyłania lub odbierania danych przez Wi-Fi. 31 mA -
wifi.scan Dodatkowa energia zużywana podczas skanowania przez Wi-Fi punktów dostępu. 100 mA -
dźwięk Dodatkowa moc używana podczas dekodowania/kodowania dźwięku za pomocą DSP. około 10 mA Służy do dźwięku z usług DSP.
film Dodatkowa moc używana podczas dekodowania wideo przez DSP. około 50 mA Służy do reklam wideo w DSP.
camera.avg Średnie zużycie energii przez podsystem aparatu w typowej aplikacji do obsługi aparatu. 600 mA Jest to przybliżony szacunek dla aplikacji, która wyświetla podgląd i robi około 10 zdjęć w pełnej rozdzielczości na minutę.
camera.flashlight Średnie zużycie energii przez moduł lampy błyskowej aparatu. 200 mA -
gps.signalqualitybased Dodatkowa moc używana przez GPS w zależności od siły sygnału. Jest to wpis z wieloma wartościami: jedną na każdy poziom sygnału, od najsłabszego do najmocniejszego. 30 mA, 10 mA -
gps.on Dodatkowa energia zużywana podczas ustalania sygnału przez GPS. 50 mA -
radio.active Dodatkowa moc używana podczas nadawania/odbierania przez radio komórkowe. 100 mA-300 mA -
radio.scanning Dodatkowa moc zużywana, gdy radio komórkowe wysyła sygnał do wieży. 1,2 mA -
radio.on Dodatkowa energia zużywana, gdy radio komórkowe jest włączone. Jest to wpis z wieloma wartościami, po jednym na siłę sygnału (brak sygnału, słaby, średni, silny). 1,2 mA Niektóre radioodbiorniki zwiększają moc, gdy szukają wieży komórkowej i nie wykrywają sygnału. Wartości mogą być takie same lub maleć wraz ze wzrostem siły sygnału. Jeśli podasz tylko jedną wartość, ta sama wartość zostanie zastosowana do wszystkich atrybutów. Jeśli podasz 2 wartości, pierwsza będzie używana w przypadku braku sygnału, druga – we wszystkich pozostałych przypadkach i tak dalej.
bluetooth.controller.idle Średnie pobieranie prądu (mA) przez kontroler Bluetooth w stanie spoczynku. - Te wartości nie są szacunkowe, lecz pochodzą z arkusza danych kontrolera. Jeśli występuje kilka stanów odbioru lub nadawania, obliczana jest średnia z tych stanów. System zbiera teraz też dane o skanowaniu Bluetooth Low Energy (LE) i Bluetooth.

Android 7.0 i nowsze nie używają już wartości mocy Bluetooth dla bluetooth.active (używanego podczas odtwarzania dźwięku przez Bluetooth A2DP) i bluetooth.on (używanego, gdy Bluetooth jest włączony, ale nieaktywny).
bluetooth.controller.rx Średnie pobieranie prądu (mA) przez kontroler Bluetooth podczas odbierania. -
bluetooth.controller.tx Średnie pobieranie prądu (mA) przez kontroler Bluetooth podczas transmisji. -
bluetooth.controller.voltage Średnie napięcie robocze (mV) kontrolera Bluetooth. -
modem.controller.sleep Średnie pobieranie prądu (mA) przez kontroler modemu w stanie uśpienia. 0 mA Te wartości nie są szacunkowe, lecz pochodzą z arkusza danych kontrolera. Jeśli występuje kilka stanów odbioru, obliczana jest ich średnia. Jeśli istnieje kilka stanów transmisji, od Androida 9 można określić wartość dla każdego z nich.
modem.controller.idle Średnie pobieranie prądu (mA) przez kontroler modemu w stanie bezczynności. -
modem.controller.rx Średnie pobieranie prądu (mA) przez kontroler modemu podczas odbierania. -
modem.controller.tx Średnie pobieranie prądu (mA) przez kontroler modemu podczas transmisji przy różnych poziomach mocy RF. Jest to wpis z wieloma wartościami, z jedną wartością na poziom mocy nadawania. 100 mA, 200 mA, 300 mA, 400 mA, 500 mA
modem.controller.voltage Średnie napięcie robocze (mV) kontrolera modemu. -
wifi.controller.idle Średnie pobieranie prądu (mA) przez kontroler Wi-Fi w stanie bezczynności. - Te wartości nie są szacunkowe, lecz pochodzą z arkusza danych kontrolera. Jeśli występuje kilka stanów odbioru lub nadawania, obliczana jest średnia z tych stanów.
wifi.controller.rx Średnie pobieranie prądu (mA) przez kontroler Wi-Fi podczas odbierania. -
wifi.controller.tx Średnie pobieranie prądu (mA) przez kontroler Wi-Fi podczas przesyłania danych. -
wifi.controller.voltage Średnie napięcie robocze (mV) kontrolera Wi-Fi. -
cpu.speeds Jest to wpis wielowartościowy, który zawiera listę wszystkich możliwych szybkości procesora w kHz. 125 000 kHz, 250 000 kHz, 500 000 kHz, 10 000 000 kHz, 150 000 kHz Liczba i kolejność wpisów muszą odpowiadać wpisom mA w pliku cpu.active.
cpu.idle Łączna moc pobierana przez system, gdy procesory (i system SoC) są w stanie uśpienia. 3 mA -
cpu.awake Dodatkowa moc używana, gdy procesory są w stanie bezczynności (pętla bezczynności jądra); system nie jest w stanie zawieszenia. 50 mA Platforma może mieć więcej niż 1 stan bezczynności z różnymi poziomami poboru mocy. Wybierz reprezentatywny stan bezczynności na dłuższe okresy bezczynności harmonogramu (kilka milisekund). Przejrzyj wykres mocy na swoim sprzęcie pomiarowym i wybierz próbki, w których procesor ma najniższe zużycie energii. Odrzuć wyższe próbki, w których procesor nie był w stanie bezczynności.
cpu.active Dodatkowa moc używana przez procesory podczas działania z różnymi prędkościami. 100 mA, 120 mA, 140 mA, 160 mA, 200 mA Wartość reprezentuje moc wykorzystywaną przez szyny procesora podczas pracy z różnymi prędkościami. Ustaw maksymalną prędkość w rdzeniu dla każdej z dozwolonych prędkości i ustaw procesor na tę prędkość. Liczba i kolejność wpisów odpowiadają liczbie i kolejności wpisów w cpu.speeds.
cpu.clusters.cores Liczba rdzeni w każdym klastrze procesora. 4, 2 Wymagany tylko w przypadku urządzeń z niejednorodnymi architekturami procesorów. Liczba wpisów i ich kolejność powinny odpowiadać liczbie wpisów klastra dla cpu.active i cpu.speeds. Pierwszy wpis reprezentuje liczbę rdzeni procesora w klastrze 0, drugi – liczbę rdzeni procesora w klastrze 1 itd.
battery.capacity Łączna pojemność baterii w mAh. 3000 mAh -

Skanowanie w trybie Low Energy (LE) i Bluetooth

W przypadku urządzeń z Androidem 7.0 system zbiera dane o skanowaniu w technologii Low Energy (LE) i ruchu sieci Bluetooth (np. RFCOMM i L2CAP) oraz łączy te działania z aplikacją inicjującą. Skanowania Bluetooth są powiązane z aplikacją, która zainicjowała skanowanie, ale nie są powiązane z skanowaniem zbiorczym (zamiast tego są powiązane z aplikacją Bluetooth). W przypadku aplikacji skanującej przez N milisekund koszt skanowania to N milisekund czasu odbioru i N milisekund czasu nadawania. Pozostały czas pracy kontrolera jest przypisany do ruchu sieciowego lub aplikacji Bluetooth.