PDA

Archiv verlassen und diese Seite im Standarddesign anzeigen : [ERLEDIGT] Atmega328P - Sleep-Modi - Stromaufnahme



Moppi
19.11.2018, 06:59
Guten Morgen,

ich möchte mal etwas Input zu folgendem Szenario, wegen des Sleep-Modus beim Atmega328P. Ein Problem ist, dass ich keine Angabe im Datenblatt zur Stromaufnahme finde, wenn ich den Atmega mit 5V bei 16MHz betreibe - es ist immer nur die Rede von 3V bei 8MHz o.ä. Bin mir auch nicht so ganz sicher, wie genau meine Messanordnung ist, ich denke mir aber: nicht so sehr ungenau. Auch das Ablesen müsste vernünftige Werte ergeben, dass man sich daran orientieren kann. Also wenn jemand Lust hat, das mal zu interpretieren und seine Gedanken dazu nieder zu schreiben? Ich denke, die von mir ermittelten Werte können so sein und sind realistisch, auch wenn ich nun im Power Down Sleep Mode nicht auf µA komme.

Schaltung:

Spannungsregler LM2936-Z5.0
Atmega328P betrieben mit 5V
Leistungsaufnahmereduktion des Atmega durch: SLEEP_MODE_PWR_DOWN
Spannungsteiler - zwischen Vcc+12V und GND - 22k und 10kOhm (gesamt also 32kOhm), benutze ich zum Messen der 12V-Batteriespannung an einem ADC-Eingang
1 digitaler Ausgang ist beschaltet mit 100Ohm auf Basis von 2xBC547B (Transistoren als Open Collector - beide Emitter gegen GND, Zwecks Motoransteuerung)


Messgerät/-anordnung:

Drehspulmessgerät bis 100µA
gemessener Innenwiederstand: ca. 960Ohm
Messbereichserweiterung: 3 Ohm (3 x 1 in Reihe, +/-5%)
gemessen wird immer die Gesamtstromaufnahme direkt an der Batterie


Ich habe folgende Stromaufnahme gemessen:

Ohne Atmega328P, nur Spannungregler und Spannungsteiler: 0.6mA
Mit Atmega328P und Spannungregler und Spannungsteiler: 1.2mA im Power Down Mode
Mit Atmega328P und Spannungregler und Spannungsteiler: 17.5mA im Wachzustand (Transistoren nicht angesteuert ohne angeschlossene Last, also Kollektor unbeschaltet)

Ich habe auch den Power Save Mode überprüft:

Mit Atmega328P und Spannungregler und Spannungsteiler: 2.4mA im Power Save Mode
Mit Atmega328P und Spannungregler und Spannungsteiler: 14.5mA im Wachzustand (Transistoren nicht angesteuert ohne angeschlossene Last, also Kollektor unbeschaltet)

Wobei der Unterschied 17.5mA zu 14.5mA tatsächlich so ist, ich habe das mehrmals gemessen / überprüft.

MfG
Moppi

oberallgeier
19.11.2018, 09:18
Hallo Moppi.
.. seine Gedanken dazu nieder zu schreiben? ..Hei was für ein interessantes Problem. Ich selbst habe extrem wenig Erfahrung mit Power Down; nur mein Pacer, ein Taktgeber (https://dl.dropbox.com/s/4ocqv9atfna7irn/PCR80_2145.jpg?dl=0) für Lauf- und Fitnesstraining mit LP2950 und tiny85@1 MHz, wird nach ner geringen Wartezeit mit SM2/SM1/SM0 auf 010 in den Power-down geschickt. Dort verbraucht er mit nem billigen 9V-Block so wenig, dass er nach geringem Einsatz und gefühlten drei Monaten Liegezeit noch immer aufzuwecken war (Testaufbau mit Interrupt-Ein (https://dl.dropbox.com/s/rp15safwbamnbwe/aaA_1827.jpg?dl=0)schalten), Schaltplan (https://dl.dropbox.com/s/jt56kj6gziqywrm/PCR_80-aaA.jpg?dl=0) dafür, Handnotiz (https://dl.dropbox.com/s/63knu5wn9p6kjjx/pacer_70_80-.jpg?dl=0), Realisierun (https://dl.dropbox.com/s/4ocqv9atfna7irn/PCR80_2145.jpg?dl=0)g).

Egal:
Deine Frage war nach Auskünften im Datenblatt des 328P zu 5V@16 MHz. Da gibts wenig. Aber beispielsweise "32.2.1. ATmega328 DC Characteristics – Current Consumption" nennt zu Power Supply Current bei Idle/4Mhz @3V typ. 0,3 mA, bei Idle/8Mhz @5V typ. 1,2 mA. Ist auch nicht wirklich aufschlussreich - bei zwei verschiedenen Taktraten. Es könnte VERMUTET werden, dass die GEschichte nichtlinear ist.

Die Tabelle 33.1.1. Active Supply Current gibt wenigstens einen groben Anhalt, dass unter diesen Bedingungen bei 5V etwa doppelt so viel Strom verbraucht wird wie bei etwa 3 V (Graphen nur für 3,3 und 2,7V).

Schließlich habe ich im Datenblatt (Atmel-42735B-ATmega328/P_Datasheet_Complete-11/2016) noch das Diagramm gefunden
Figure 33-11. ATmega328: Power-Down Supply Current vs. VCC
das bei power down zwischen 5V und 3V einen Mehrverbrauch von etwa 50% (gegen 3V) vermuten lässt. Ne ähnliche Größenordnung bringt auch Figure 33-12. ATmega328: Power-Down Supply Current vs. VCC.

Na ja, wie erwähnt, es sind Gedanken, vielleicht Anhaltspunkte.

Moppi
19.11.2018, 10:02
Ja, genau, Danke Dir! Das meinte ich: Gedanken. Die mache ich mir auch und habe da auch Vermutungen. Letzten Endes ist auch so, wie es ist: wenn man es messen kann, weiß man es dann - selbst, wenn es nicht genau im Datenblatt aufgeführt ist. Meine Vermutung ist auch eher dahingehend, da man sich so auf die 3V fixiert, dass dieser 3V-Betrieb vielleicht auch eher als Standardbetrieb für batteriebetriebene Anwendungen anzusehen ist. Vielleicht bringt mich aber auch jemand auf die Idee, dass ich mit dem Messen was falsch mache und einfach .. Mist messe ... kann ja auch sein. Obwohl ich das jetzt schon überprüft habe, indem ich nur einen 1 Ohm-R genommen habe, für die Messbereichserweiterung, um so statt 100µA am Endausschlag 100mA ablesen zu können. Wenn ich darüber ablese, komme ich aber zu denselben Größenordnungen bei den Messergebnissen. Die 3x 1 Ohm in Reihe habe ich genommen, um Endausschlag 30mA zu haben.

MfG

seite5
19.11.2018, 22:51
Im Power-Down ist jeder interne Takt abgeschaltet - Clock/Frequenz also völlig egal (DS, S.39)
Der Stromverbrauch sollte lt. DS im Power-Down, Seite 1 (ohne alle andere Beschaltung) bei 0.1µA liegen, 600µA ist viel.
Verstehe ich das richtig - je nach eingestelltem Sleep-Modus fließen mal 14.5mA und mal 17.5mA im "Wachzustand"? Da ist schlichtweg
was faul im Staate Dänemark!
mfg
Achim

oberallgeier
19.11.2018, 23:30
.. Atmega (328P) mit 5V bei 16MHz betreibe .. SLEEP_MODE_PWR_DOWN ..

.. Der Stromverbrauch sollte lt. DS im Power-Down, Seite 1 (ohne alle andere Beschaltung) bei 0.1µA liegen, 600µA ist viel ..Welche Datenblatt-Version? Die von mir oben zitierte Fassung von November 2016 hat diese Angabe auf Seite 2 - dort ist angegeben "Power-down Mode: 0.1μA" - mit 1.8V bei 1MHz.


.. Ich habe folgende Stromaufnahme gemessen: .. Ohne Atmega328P, nur Spannungregler und Spannungsteiler: 0.6mA ..

.. Der Stromverbrauch sollte lt. DS im Power-Down, Seite 1 (ohne alle andere Beschaltung) bei 0.1µA liegen, 600µA ist viel ..


.. Da ist schlichtweg was faul im Staate Dänemark!
mfg
AchimDas stimmt, nur wolln wa ja nich Äpfel mit Birnen vergleichen.

wkrug
20.11.2018, 06:39
Wenn Ich mich da noch recht erinnere gab's da auch noch was mit der Konfiguration der unbeschaltenen Ports.
Die müssen auf einen bestimmten Zustand gebracht werden um Strom zu sparen.
Welcher das jetzt genau war weiss Ich jetzt leider nicht mehr genau - Sollte aber im Datenblatt stehen.
Ausserdem kann man ja alle nicht genutzte Peripherie abschalten. Jedes aktivierte Feature ( A/D Wandler, USART, ... ) zieht Strom.
In einer ELEKTOR gab's auch mal einen Artikel zur Stromminimierung bei AVR Controllern.

Moppi
20.11.2018, 07:00
Ich habe nochmals gemessen und mit verschiedenen Messbereichserweiterungen für das Drehspulmesswerk. Ich habe im Power Down Mode den Messbereich auf 1mA festgelegt und gesehen, dass der Atmega328, bei 5V Betrieb, sogar etwas mehr als 600µA nimmt. Es sind etwa um die 700µA. In anderen Foren stellen User teils dasselbe fest. Beim Arduino Mini soll es wieder anders sein. Das ist aber auch ein ATmega328. Der Brown-Out Detector soll auch im Sleep-Mode Strom verbrauchen:


14.11.3. Brown-Out Detector
If the Brown-Out Detector (BOD) is not needed by the application, this module should be turned off. If the
BOD is enabled by the BODLEVEL Fuses, it will be enabled in all sleep modes, and hence, always
consume power. In the deeper sleep modes, this will contribute significantly to the total current
consumption.

Das nächste wäre:


14.11.4. Internal Voltage Reference
The Internal Voltage Reference will be enabled when needed by the Brown-Out Detection, the Analog
Comparator or the Analog-to-Digital Converter. If these modules are disabled as described in the sections
above, the internal voltage reference will be disabled and it will not be consuming power. When turned on
again, the user must allow the reference to start up before the output is used. If the reference is kept on in
sleep mode, the output can be used immediately.

Der Watchdog-Timer:


14.11.5. Watchdog Timer
If the Watchdog Timer is not needed in the application, the module should be turned off. If the Watchdog
Timer is enabled, it will be enabled in all sleep modes and hence always consume power. In the deeper
sleep modes, this will contribute significantly to the total current consumption.

Den Watchdog und den Timer 1 benötige ich zum Aufwachen, die kann ich nicht abschalten, das wäre dann vermutlich nur mit einer externen RTC möglich.

Für diese Anwendung einer Lüftersteuerung spielt das jetzt keine so große Rolle, die Verbrauchswerte unter 4mA gehen im Verbrauch des Lüfters - 30 bis 80mA - praktisch unter. Dennoch ist es für mich die Gelegenheit, das dann jetzt auch mal auszuprobieren und zu messen. Ich habe auch nur am Kontroller selbst die Stromaufnahme gemessen, da kommt dieselbe Größenordnung raus, wie auf den andern Wegen bestimmt. Es sind 600 bis 750µA.

MfG
Moppi

- - - Aktualisiert - - -


Wenn Ich mich da noch recht erinnere gab's da auch noch was mit der Konfiguration der unbeschaltenen Ports.
Die müssen auf einen bestimmten Zustand gebracht werden um Strom zu sparen.


Beim Einschalten des ATmega sind alle IOs im hochohmigen Zustand, bis dass sie mittels pinMode konfiguriert werden. Auch die internen Pull-Up-Widerstände müssen erst aktiviert werden. Sollten die aktiviert sein, um Strom zu sparen?


- - - Aktualisiert - - -
Und es kam noch etwas zutage, aus einem andern Forum:


Are you using a '328 instead of a '328p? (a '328-PU is not a '328p, it's a '328 in DIP package; the corresponding p-spec part is '328p-pu.

Ich habe 328P-PU. Aber da müsste das Datenblatt "ATmega328/P" von 2016 doch das richtige sein.

MfG

oberallgeier
20.11.2018, 09:04
.. der Atmega328, bei 5V Betrieb, sogar etwas mehr als 600µA .. Arduino Mini soll es wieder anders sein. Das ist aber auch ein ATmega328 ..Mal ein bisschen Gebrabbel von mir - achso, das Letzte zuerst:
.. Und es kam noch etwas zutage, aus einem andern Forum: Ich habe 328P-PU. Aber da müsste das Datenblatt "ATmega328/P" von 2016 doch das richtige sein ..Ein anders Forum? HIER sind die Spezialisten ;-) - - na gut, ich bin keiner.

Zu 328P-PU bzw. ATmega328/P :
Es gibt laut den typspezifischen Datenblättern zur 328er Familie mehrere Gehäuseformen:
28-pin 28P3, ein PDIP = Plastic Dual In line Package,
28-pin 28M1, ein VQFN = Very Thin Quad Flat (No Lead Package),
32-pin 32M1-A, ein MLF = Micro Lead Frame Package,
32-pin 32A, TQFP = Thin profile plastic Quad Flat Package
wobei z.B. der 28Pinner keinen Anschluss für ADC6 und ~7 hat, der TQFP-32 hat die natürlich. Den TQFP bekomme ich mit (m)einer kleinen 08er WEllerspitze noch bestens gelötet, der MLF geht wohl nur mit Heißluft/Reflow. Ansonsten - innendrinn sind die Teile immer gleich - Ausnahmen wie eben: ADC6/~7 ja oder nein bestehen.

Zu den Typen ATmega328/~328P gibts noch den ATmega328PB in gleichen Gehäuseformen; letzterer mit zusätzlichen Funktionen wie zweite UART und so.

Zu 328 und 328P:
In einer "Parametric Product Table" von Atmel aus 2007 habe ich nen Link gefunden auf "picoPower Technology" der aber heute in die www-Präsentationen von Microchip zielt. Dort, bei Microchip ist noch die AN2515 zu finden,
http://ww1.microchip.com/downloads/en/AppNotes/AN2515-AVR-Low-Power-Techniques-00002515C.pdf
die auf Low-Power Techniken eingeht. @Moppi: sehr lesenswert. Und klar: WDT frisst einiges an Power, meist ohne dass die Anwendung benötigt wird *gg*.

Soviel ich weiß, wurde der Zusatzbuchstabe "P" von Atmel vor über zehn Jahren eingeführt um auf die hier zur Diskussion stehenden Low-Power-Möglichkeiten hinzuweisen.

Ansonsten ist der Unterschied der beiden Typen: 328 für -40°C to 85°C und 328P für TA = -40°C to 105°C. Unabhängig von der Gehäuseform des jeweiligen Teilchens. Deswegen nehme ich lieber die 328P-Version - mit Rücksicht auf meine Lötorgien zum Beispiel.

TLDR

Moppi
20.11.2018, 09:21
Danke für die Infos. Ich nehme auch lieber die 328P-Version. :)
Dokument habe ich gespeichert, lese ich mir mal in Ruhe durch.
Jetzt habe ich es mal auf 1MHz-Takt abgesehen (und zwar hier (https://www.roboternetz.de/community/threads/72697-boards-txt-Frage?p=647978&viewfull=1#post647978)). Damit sollte der Verbrauch auch runter gehen - hatte vor langer Zeit mal so was gelesen. Allerdings vermutlich nicht, wenn der ext. Takt im Sleep Mode sowieso abgeschaltet ist.
Falls das noch nicht ausreicht, nehme ich mal noch einen Spannungsteiler, um aus den 5V vom Regler 3.3V zu machen.

MfG

wkrug
20.11.2018, 15:33
Beim Einschalten des ATmega sind alle IOs im hochohmigen Zustand, bis dass sie mittels pinMode konfiguriert werden. Auch die internen Pull-Up-Widerstände müssen erst aktiviert werden. Sollten die aktiviert sein, um Strom zu sparen?
Üblicherweise startet ja der Controller und durchläuft die Initialisierung.

Kannst ja hier mal drüber gucken...
https://www.roboternetz.de/community/threads/51190-Konfiguration-Port-Pins-bei-Powerdown-%28Stromsparen%29

Moppi
20.11.2018, 15:53
Gute zu wissen, dass es das Problem 2010 schon mal gab! Aber da ist man auch nicht weiter gekommen.

Wo genau Du hinaus willst, weiß ich nicht ganz, aber z.B.:
DIDR0 = DIDR0 | B00111111; // Digitale Eingangspuffer ausschalten, analoge Eingangs Pins 0-5 auf 1
Habe ich in meinem Code drinne, bringt nichts, keinen Unterschied. Die Analog-Digital-Konverter werden abgeschaltet. Der Analog-Comperator ist deshalb sowieso gleich dann auch mit aus. Extra ausschalten bringt nichts, habs so im Code drin:
ACSR = B10000000; // Analogen Comparator abschalten, ACD bit7 zu 1

Ansonsten sind die IO-Ports nicht undefiniert, sie sind wenn, als hochohmige Eingänge geschaltet, solange das nicht aktiv im Sketch geändert wird.

oberallgeier
20.11.2018, 16:17
.. Jetzt habe ich es mal auf 1MHz-Takt abgesehen .. Damit sollte der Verbrauch auch runter gehen - hatte vor langer Zeit mal so was gelesen ..Lesen bildet, stimmt ja, aber ich mach solche Dinge lieber selber. Und da hast Du heute Glück, dass ich mit nem Riesenschnupfen bei bestem Wetter (hmm, na ja, Sonne pur aber Minusgrade) daheim hängen muss .. siehe unten.


.. Falls das noch nicht ausreicht, nehme ich mal noch einen Spannungsteiler, um aus den 5V vom Regler 3.3V zu machen ..Na ich weiß nicht, da kräuselts mir die Nackenhaare und ein Männlein flüstert mir: wer im Controller sparen will, kann den Strom im Spannungsteiler verheizen. Oder ? Liege ich da soo daneben?

Mal zu meiner Nachmittagsbeschäftigung:
Aufbau: alte Experimentierplatine für mega8/168/328, alle vermeidbaren Teile abgebaut,

......https://dl.dropbox.com/s/wthyr7eyv4rtoc3/DSC04135-Ausschni-15%25.jpg?dl=0 (https://dl.dropbox.com/s/6zu9zoj0l0baej3/DSC04135-Ausschnitt.JPG?dl=0)
......© oberallgeier; größeres Bild im Bild verlinkt

Aktiv/mit den Controllerpinns verbunden sind die Stromversorgung - ohne Spannungswandler, direkt von der Schraubklemme - und die beiden Kondensatoren für den fallweise steckbaren Quarz. Alle sonstigen Leitungen hängen "im Freien", die Kondensatoren für den MAX232 sind ja nur für den Chip - wenn der drauf steckt, die Leitungen zum seriellen Stecker sind ebenfalls unbeschaltet.
Controller: ATmega328 PDIP28. ATMega328P habe ich nicht in PDIP (na ja, die beiden hier sind defekt), aber die Daten vom 328 sind sicher ausreichend vertrauenswürdig.
Programm: Ein lausiges Zeit-Schindeprogramm. Nach der Initialisierung eine while(1)-Schleife, die für wenige Controllertakte einen Pin hoch- und danach wieder runterzieht. Die Pausen dazwischen dauern etwa eine Mikrosekunde bei 20 MHz, Code siehe unten.
Labornetzteil zur Spannungsversorgung KORAD KA3005D, DMM MetraHit 12S, Spannungsangaben nur laut Labornetzteil, Strommessung mit DMM.
Geschätzte Messgenauigkeit beim Aufbau sicher deutlich besser als 10 %

Messwerte:

ATmega328
@3V 20 MHz Quarz 6,14 mA
8 MHz intOsz. 2,94 mA
1 MHz intO(DIV8) 0,58 mA
128 kHz intOsz. 0,11 mA
128 kHz intOsz-DIV8 0,06 mA

@5V 20 MHz Quarz 13,09 mA
8 MHz intOsz. 6,46 mA
1 MHz intO(DIV8) 1,85 mA
128 kHz intOsz. 0,95 mA
128 kHz intOsz-DIV8 0,85 mA

// ================================================== =========================== =
//### Programm 1 µs MIKROsekunde pausieren lassen !! Pausenwert EXerimentell !
void wmus (uint16_t us) // Wait in Mikrosekunden
{
for(; us>0; us--)
{
uint16_t __c = 4;
__asm__ volatile (
"1: sbiw %0,1" "\n\t"
"brne 1b"
: "=w" (__c)
: "0" (__c)
);
}
}
// ================================================== =========================== =

Ich konnte es ja nicht lassen. Hatte noch nen nanoClone genommen (meine sind grad ALLE auf 20 MHz umgequarzt) und den direkt mit 7,5V bestromt. Der frisst (mit der ganzen Peripherie, Spannunswandler, on-board-LED-Spannungskontrolle, on-board-user-LED etc etc: bei 20 MHz ext. Quarz 21 mA und bei 1 MHz (int.Osz-8MHz und DIV.8.) noch 9 mA. 3V hatte ich hier nicht getestet, den Strom von "hinten" in die Platine und den Spannungswandler . . . da war ich mir zu unsicher.

Fazit: Bei 3V ist der Stromhunger, grob, nur halb so groß, die Frequenz schlägt deutlich zu. Wussten wir schon aus dem Datenblatt - nur nicht so.

NACHTRAG : Zum Messen war der ISP-Stecker stets abgezogen wegen Resetleitung mit LED. Auch wenn deren Einfluss nicht wirklich merkbar war.

Moppi
20.11.2018, 16:32
Schön, dass Du dir die Mühe gemacht hast! :) Tol! Toll! Toll!

Allerdings werde ich aus einem nicht ganz schlau @oberallgeier: 128 kHz intOsz-DIV8 0,06 mA
Was und wie soll man das verstehen? Mag sein, dass Du das blickst - ich noch nicht ganz.

Aber ich konnte es ja auch nicht lassen. Na ja, habe noch mal gesucht und bin doch noch auf einen Arduino gestoßen, der offenbar auf wenige µA runtergefahren wird.

Und zwar, um es euch zu ermöglichen, das nachzuvollziehen, hier (https://www.youtube.com/watch?v=urLSDi7SD8M)

Ich habe mir das angeschaut und weil ich es mir nicht vorstellen konnte ausprobiert, denn ich habe einen riesen Code ausm Netz, der das nicht schafft. Mein Programm funktioniert auf dem Atmega328P nach wie vor, mit 5V @16MHz. Und dank diesem Video habe ich gute 600µA eingespart. Das heißt, da meine übrige Beschaltung mit Spannungsteiler (ca. 0,000375 A und Spannungsregler nochmal was dazu) auch schon ca. 450µA zieht und ich jetzt nur noch ca. 600µA messe (und das ist mehr eine Schätzung, da am direkt Anfang der Messskala, am Nullpunkt) - bei Power Down - ist diese Anleitung wohl tatsächlich etwas, was mal funktioniert.

Prima, toll, klasse und Danke - für eure Unterstützung!



MfG
Moppi

PS: den Spannungsteiler für 3.3V hätte ich nur genommen, um den Verbrauch am Atmega328 runter zu bekommen, ich dachte, das versteht sich - nicht, um den Gesamtverbrauch zu reduzieren. ;)