lecture 15 - mit

78
Lecture 15 Potpourri: Power, few other things, etc… 10/30/18 1 6.111 Fall 2018 Last Lecture

Upload: others

Post on 16-May-2022

2 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Lecture 15 - MIT

Lecture 15Potpourri: Power, few other things, etc…

10/30/18 16.111 Fall 2018

Last Lecture

Page 2: Lecture 15 - MIT

Announcements I

• Project Proposal Due by today 5pm. Chances are that these proposals won’t be looked at by anyone who matters until Friday…just saying.

• 11/06 2:30-5pm and 11/08 2:30-4pm are Presentation Days:• Tue 2:30-5pm (because of class size), Thu 2:30-4pm• Email Gim if you CANNOT present in 4-5pm window

on Tuesday• Attendance Mandatory

10/30/18 26.111 Fall 2018

Happy Halloween!

Page 3: Lecture 15 - MIT

Announcements II• If you need parts early in project, parts should

be ordered. Email Gim inclusive-or Joe (want to make sure the cost is reasonable). We will batch them to John Sweeney Mon noon and Wednoon..

• Clean out their tool kit and fill out form by 11/9:attached. This avoids the end of term rush.

• Upload Lab 5 Verilog if haven’t done so already

10/30/18 36.111 Fall 2018

Page 4: Lecture 15 - MIT

Announcements III• Thu: tutorials (in lab; optional)• Labkit NTSC camera, Nexys4 camera 2:30p Gim• Labkit flash memory 2:50p Gim• Chroma keying 3:10p Diana• FFT 3:40pm Driss• ADC on Nexys 4:10pm Joe• Git at 9pm with Diana

• Who to ask for help on what (WTAFW):• FFT: Aaron and Driss• Chroma keying: Diana and Mike• Sobel Filters, edge detection: Wings

10/30/18 46.111 Fall 2018

Page 5: Lecture 15 - MIT

Announcements IV• IAP FPGA competition

• Jan 7th-Jan 25th (ish)• Xilinx, Apple, probably other companies sponsoring• Free FPGA dev boards to keep• Prizes most likely• Still figuring stuff out• Work on FPGAs more, use Vivado, and use some newer tools

like High-Level Synthesis• Work on Zynq Platform (SOC with ARM cores and FPGA fabric)

10/30/18 56.111 Fall 2018

Page 6: Lecture 15 - MIT

Bluetooth vs. Bluetooth Low Energy (BLE)• Bluetooth was created in ~1994

• Originally supposed to be a drop-in replacement to RS232,only wireless, and you can still see vestiges of that heritage in documentation and some of its protocols.

• Works on ISM Band (2.4 GHz…shares with Wifi)

10/30/18 66.111 Fall 2018

Page 7: Lecture 15 - MIT

Bluetooth is like USB, many flavors, speeds, etc… Is a Multi-layered stack• Every device has a unique* 48-bit identifier (like a MAC

Address)

• Handshakes and pairing layer

• Public key encryption (92 bit DHKE), followed by 128bit on latter versions

• Actual bits are sent using PSM…either QDPSK or even 8DPSK through a Gaussian filter (don’t hop from phase to phase instantaneously), and frequency hopping!:• Meaning bits are encoded using phase of carrier wave

(improves throughput but requires more complex send/receive circuitry)• (QDPSK: four phases allows two bits at once)• (8DPSK: eight phases allows three bits at once)

10/30/18 7

*Actually unique to the particular device, not type of device like in i2C. Ideally no two devices will share this. They thought ahead 2^48 gives us 280 trillion possibilities, so up to 46,000 bluetooth headsets per person

6.111 Fall 2018

Page 8: Lecture 15 - MIT

Drop-in modules exist• Because of its initial goal of literally being a RS232 serial

replacement, there are modules which literally take in UART (at 115.2 kbps let’s say) and will convert to Bluetooth and send and receive/convert back to UART

• Add a second one that is mated to it on the other end, and you can get a wireless RS232 link.

• Additional feature to maybe add to projects if helpful. Many of you have already written *both sides* of the UART stack so it should be as easy as plugging one of these in to get it working*

10/30/18 8

HC-0X Series

*and then debugging something random for eight hours

6.111 Fall 2018

Page 9: Lecture 15 - MIT

BLE: Bluetooth Low Energy

• Complete Rethink of what Bluetooth is meant to be used for• Can’t send as much

data reliably, but power usage is significantly reduced

10/30/18 96.111 Fall 2018

Page 10: Lecture 15 - MIT

PowerWhile we’re not really focusing on this in final projects, maybe think about this as another way to characterize your device’s performance

10/30/18 106.111 Fall 2018

Page 11: Lecture 15 - MIT

Problem: Energy Consumption

10/30/18 11

What can One Joule of energy do?

Send a 1 Megabyte file over 802.11b

Operate a mediocre processor

for ~ 7s

The Energy Problem

7.5 cm3

AA battery

Alkaline: ~10,000J

Mow your lawn for

1 ms

• It is getting better, but there’s no Moore’s Law for Batteries

• We need to understand where power goes and manage it

Sleep ESP32 for 1.4 days

Run ESP32 for 2 seconds

https://forum.cosmoquest.org/showthread.php?166243-Energy-Density

6.111 Fall 2018

Page 12: Lecture 15 - MIT

Lower Limit on Computation

10/30/18 6.111 Fall 2018 12

• There is a lower limit takes about !×#$%&# Joules to flip a bit no matter what• Called Landauer Limit

• Experimentally shown in 2012 (Berut et al., Nature 2012)

• Current-(ish) Intel 22nm process takes approximately

• #$×#$%#' Joules (10 fJ)

• Between those two numbers are the inefficiencies and limitations of CMOS

• The end doesn’t have to come in 2050 (if trends continue)….Alternatives include reversible logic which we won’t go into

https://spectrum.ieee.org/computing/hardware/landauer-limit-demonstrated

https://en.wikipedia.org/wiki/Landauer%27s_principle

Page 13: Lecture 15 - MIT

What actually uses the power in our Modern Digital Circuits?

10/30/18 6.111 Fall 2018 13

All modern digital electronics almost invariably use CMOS architectures:Complementary Metal Oxide Semiconductor (Field Effect Transistors)

• Complementary nature means almost no current flowing (no power) at rest

• Power only* expended on theswitch since we need to charge upany MOSFETs that we’re drivingwith our output

*ideally

Page 14: Lecture 15 - MIT

CMOS drives other CMOS

10/30/18 6.111 Fall 2018 14

It is CMOS all the way down

Metal Oxide Semiconductor

Forms capacitor

That Looks Capacitive!!!

Page 15: Lecture 15 - MIT

Takes energy to charge up capacitors (Dynamic Power Consumption)

10/30/18 6.111 Fall 2018 15

http://web.eecs.umich.edu/~twenisch/470_F07/lectures/21.pdf GO BLUE

!" represents the next stage’s input capacitance

Page 16: Lecture 15 - MIT

10/30/18 6.111 Fall 2018 16

During Transition short circuit current also appears(Dynamic Power Consumption)

Page 17: Lecture 15 - MIT

Dynamic Power Consumption

10/30/18 6.111 Fall 2018 17

Capacitive Charging• Caused by need to store

up finite charge • ! ∝ #$%&• C: capacitance of gate• V: Vdd of system• f: frequency of switching

Short Circuit• Caused by need to store up

finite charge • ! ∝ '()$*+,-.• tsc: in crossover• V: Vdd of system• Ipeak: Max current at crossover• Good news this is usually rather

small compared to capacitive

Page 18: Lecture 15 - MIT

Static Power Consumption

10/30/18 6.111 Fall 2018 18

http://web.eecs.umich.edu/~twenisch/470_F07/lectures/21.pdf GO BLUE

Sub-Threshold Leakage:

http://www-inst.eecs.berkeley.edu/~cs150/fa11/agenda/lec/lec22-power.pdf

Doesn’t start right at zero

Gate Leakage:

Where an electron or hole just tunnels through the FET gate

• Burn power even when not switching :/

• As we scale operating voltage and size this becomes more and more of a problem

The fact that no transistor turns off below its threshold voltage

Page 19: Lecture 15 - MIT

Power Consumed

10/30/18 19

Sandy Bridge Power Consumption

6.111 Fall 2018

!"#"$% = !'()$*+, + !."$"+,• In the CMOS era,

historically static power has been small compared to dynamic power

• This has changed in recentyears as things have gotten smaller!

Page 20: Lecture 15 - MIT

Leakage Has Gotten So bad

10/30/18 20

• How bad is it?• In some contexts, static loss starts

to dominate dynamic loss• This is a really big deal since the

primary loss mechanism is beyond the control of implementation design, etc…

Leakage Current: Moore’s Law Meets Static Powerhttp://www.ruf.rice.edu/~mobile/elec518/readings/DevicesAndCircuits/kim03leakage.pdf

From 2011

6.111 Fall 2018

Page 21: Lecture 15 - MIT

Aside: Shmoo Plot

10/30/18 21

• Sometimes hear plots of various performance specs on semiconductors called “Shmoo” plots• Called that because they plots look like

Shmoos, weird bowling-pin like creatures from Lil Abner, • Anyways sometimes these comparison plots

are called Shmoos

*Wikipedia finally explained this to me…pre-semiconductor, Shmoo plots looked like Shmoos with magnetic devices

6.111 Fall 2018

Page 22: Lecture 15 - MIT

Sandy Bridge vs. Ivy Bridge (32nm vs. 22 nm core i5)• Sandy Bridge was older

model transistor

• Ivy Bridge was 3D transistor which greatly improved static loss (less leakage)

10/30/18 226.111 Fall 2018

Page 23: Lecture 15 - MIT

Trigate MOSFETs

10/30/18 23

• One of the first departures from planar semiconductor fabrication since we started doing it as humans in the early 1950s.• Was in the pipeline since right

around 2000, and finally started coming out in 2014• Cuts static loss (sub-threshold loss

in particular) by 50%

6.111 Fall 2018

Page 24: Lecture 15 - MIT

Sandy Bridge vs. Ivy Bridge (32nm vs. 22 nm core i5)

10/30/18 24

http://blog.stuffedcow.net/2012/10/intel32nm-22nm-core-i5-comparison/

• Intel fell way behind schedule getting their 22nm tech into production, but its trigate devices in IVB, have drastically cut down static power loss

6.111 Fall 2018

Page 25: Lecture 15 - MIT

Digital Power Consumption

10/30/18 25

! = #$→&'()* + (,-./0

Dynamic power consumption

Static power consumption

• 1 : total power consumed

• 23→4 : fraction of gates switching

• 5 : Capacitance of gates, busses, interconnects

• 6 : Operating voltage (677)

• 8 : frequency of operation

• 9:;<=: Leakage Current:

• Sub-threshold leakage

• Gate-Leakage

6.111 Fall 2018

Page 26: Lecture 15 - MIT

10/30/18 6.111 Fall 2018 26

! = #$→&'()* + (,-./0

Cut down on bits flippingSmaller

capacitors, Keep

wires/interconnects

short!

Scale down

system voltage

Drop system voltage

Improve Fabrication

Drop frequency?

Be ON for less time

Page 27: Lecture 15 - MIT

What do we have control over?

10/30/18 27

• Dynamic Power Usage is more closely tied to how we use

the system:

• Design, data structures, etc…

• Clock

• Etc…

• Static Power Usage is more closely tied to actual system

fabrication and capabilities, but our usage of it can also

factor in:

• Temperature (heat sink it)

• Turn on/off completely6.111 Fall 2018

! = #$→&'()* + (,-./0

Dynamic power consumption

Static power consumption

Page 28: Lecture 15 - MIT

Dynamic Power Reduction Strategies

• Reduce Transition Activity or Switching Events• Reduce Capacitance (e.g., keep wires short)• Reduce Power Supply Voltage (not really option in

our designs, but when designing from scratch yes)• Frequency is sometimes fixed by the application,

though this can be adjusted to control power as needed

10/30/18 28

P = a0->1 CL VDD2 f

Optimize at all levels of design hierarchy

6.111 Fall 2018

Page 29: Lecture 15 - MIT

The Transition Activity Factora0->1

10/30/18 29

Current Input

Next Input

Output Transition

00 00 1 -> 100 01 1 -> 100 10 1 -> 100 11 1 -> 001 00 1 -> 101 01 1 -> 101 10 1 -> 101 11 1 -> 010 00 1 -> 110 01 1 -> 110 10 1 -> 110 11 1 -> 011 00 0 -> 111 01 0 -> 111 10 0 -> 111 11 0 -> 0

a0->1 = 3/16

Assume inputs (A,B) arrive at f and are uniformly distributed (not guaranteed at all)What is the average power dissipation?

P = a0->1 CL VDD2 f

ZA

B

6.111 Fall 2018

0 to 1 since that’s when capacitors charge

Page 30: Lecture 15 - MIT

Power Consumption Can Be Data Dependent!• We don’t think about this at the programming

level, but at the bit level it can really matter!

• Is your data encoded in a way such that lots of bits flip lots of the time? (lots of charge/discharge cycles!)

• Are common transitions using the fewest bit changes?

10/30/18 306.111 Fall 2018

! = #$→&'()*

Page 31: Lecture 15 - MIT

Number Representation:Two’s Complement vs. Sign Magnitude

10/30/18 31

Two’s complement

0000

0111

0011

1011

1111

1110

1101

1100

1010

1001

1000

0110

0101

0100

0010

0001

+0

+1

+2

+3

+4

+5

+6

+7-0

-1

-2

-3

-4

-5

-6

-7

Sign-Magnitude

Consider a 16 bit bus where inputs toggles

between +1 and –1 (i.e., a small noise input)

Which representation is more energy efficient?

6.111 Fall 2018

Page 32: Lecture 15 - MIT

Bus Coding to Reduce Activity

10/30/18 32

MajorityFunction

invert

D Q

Input

Data Bus

NOutput

[Stan94]

Extra bit to indicated if thebus is inverted

• Minimize bit transitions on high capacitance busses

• Input toggles from 0 to -1 with two’s compliment

• That’s 8’h00 to 8’hFF (really bad)• Instead:

• encode 0 as 8’h00 with INV=0

• Encode -1 as 8’h00 with INV=1

6.111 Fall 2018

Back to two’s complement then

Page 33: Lecture 15 - MIT

Hamming Distance

10/30/18 33

• Reduce Hamming Distance between sequences…don’t count up with states using regular binary…use a Gray code perhaps• Counting to 8 in regular 3bit binary

involves 14 total bit changes• Counting to 8 in 3bit Gray involves 8

total bit changes(big savings)

000001010011100101110111

31213121

Count Transitions

14

6.111 Fall 2018

Page 34: Lecture 15 - MIT

Time Sharing is a Bad Idea (From a power perspective)

10/30/18 34

Time Sharing Increases Switching Activity

2

6.111 Fall 2018

If you have data sets that are expected to be very different in value, consider giving each their own bus

Minimize the 0->1 transitions that will happen on any given one bus.

Page 35: Lecture 15 - MIT

Glitching Transitions

10/30/18 356.111 Fall 2018

Glitches are no longer an annoyance, but vile leeches sucking our vital life fluids (power) from our bodies (electrical devices)

10 femtoJoules, please!

@22nm process: 10 fJ x 100 MHz = 1 microWatt

Page 36: Lecture 15 - MIT

Glitching Transitions

• Balancing paths reduces glitching transitions

• Structures such as multipliers have lot of glitching transitions

• Keeping logic depths short (e.g., pipelining) reduces glitching

10/30/18 36

++

+

A B C D

(A+B) + (C+D)

+

+

+

A B

C

D

(((A+B) + C)+D)

Chain TopologyTree Topology

6.111 Fall 2018

Glitches are no longer an annoyance, but vile leeches sucking our vital life fluids (power) from our bodies (electrical devices)

Page 37: Lecture 15 - MIT

Not just a Hardware Issue: “Cool” Software

10/30/18 37

CPU

0111111100000000011111110000000101111111000000100111111100000011

1000000000000000100000000000000110000000000000101000000000000011

float a [256], b[256];float pi= 3.14;

for (i = 0; i < 255; i++) {a[i] = sin(pi * i /256);}for (i = 0; i < 255; i++) {b[i] = cos(pi * i /256);}

float a [256], b[256];float pi= 3.14;

for (i = 0; i < 255; i++) {a[i] = sin(pi * i /256);b[i] = cos(pi * i /256);

}

a[0]a[1]a[2]a[3]

b[0]b[1]b[2]b[3]

address

MEMORY address

16

Address bus will undergo:512(8)+2+4+8+16+32+64+128+256= 4607 bit transitions

Address bus will undergo:2(8)+2(2+4+8+16+32+64+128+256)= 1030 transitions

6.111 Fall 2018

Here’s some C

Page 38: Lecture 15 - MIT

Clock Gating is another Potentially Good Idea!

(For energy conservation only… don’t get any messed up ideas. You have to be carefulwith this powerful tool)

10/30/18 38

+

X

Global Clock Adder Clock

Multiplier Clock

Adder Off

Enable_Adder

Enable_Multiplier

Multiplier On

100’s of different clocks in a microprocessor

Clock gating reduces activityand is the most common low-power

technique used today

6.111 Fall 2018

Careful to keep combinatorial paths short…avoid clock skew!!!

Maybe there’s some

counters and other

things just running in an

FSM even when “idle”

Page 39: Lecture 15 - MIT

Clock Generation Uses Power!• In very complex modern systems, clock management (amplifiers,

phase locked loops, etc) add significant overhead to a system’s power needs. In some recent systems, the clock distribution system can account for 30% of all power.

• In general with everything, if you don’t need it, don’t use it. • Human eye can’t tell difference between these two dimmers

10/30/18 39

Running Blue LED at 50% duty cycle at 100HzBased off of 12 MHz clock

Consuming 0.35 W

Running Blue LED at 50% duty cycle at 4000HzBased off of 480 MHz clock

Consuming 0.5W

6.111 Fall 2018

Page 40: Lecture 15 - MIT

Temperature

10/30/18 40

• While some input power gets used for

information/computation, most is

ultimately lost as heat

• As temperature rises, carrier (the

electrons and holes) mobility will drop off

quickly

• As mobility drops off, current delivered

drops off, systems can’t charge/discharge

as quickly, we run into trouble

• Static losses also get really bad at high temperatures

• So you want to keep temperature down!

http://www.ioffe.ru/SVA/NSM/Semicond/Ge/electric.html

6.111 Fall 2018

Page 41: Lecture 15 - MIT

Anatomy of a Heat Sink

10/30/18 6.111 Fall 2018 41

Copper heat pipes

Aluminum heat fins

Attach to chip with silver paste Often add a fan too

https://reefll.com/index.php?route=product/product&product_id=69

Page 42: Lecture 15 - MIT

Intel Pentium 4 Thermal Guidelines

10/30/18 42

n Pentium 4 @ 3.06 GHz dissipates 81.8W!(i7 Haswell 3.2GHz 65W)

n Maximum TC = 69 °C

n RCA < 0.23 °C/W for 50 C ambient

n Typical chips dissipate 0.5-1W (cheap packages without forced air cooling)

Execution core

120oC

Cache70°C

Integer & FP ALUs

Temp(oC)

Courtesy of Intel (Ram Krishnamurthy)

6.111 Fall 2018

Page 43: Lecture 15 - MIT

Junction (Silicon) Temperature

10/30/18 43

Simple Scenario

Tj-Ta= RqJA PD

Silicon

RqJA is the thermal resistance between silicon and Ambient

RqJAPD

Tj= Ta + RqJA PD

Make this as low as possible

Realistic Scenario

RqJCPD

RqCA = RqCS + RqSA

SinkCase

Silicon

TJ

TA

TJ

TC

TS

TATJ

TC

TS

TA

RqCS

RqSA

is minimized by facilitating heat transfer (bolt case to extended metal surface – heat sink)

These are thermal model

circuits

Not electrical circuits

6.111 Fall 2018

Page 44: Lecture 15 - MIT

Does your GHz Processor run at a GHz?

10/30/18 44

Processor

Thermal

Sensor

Chip

Activity

Control

Use of Thermal Feedback

• Note that there is a difference between average and peak power

• On-chip thermal sensor (diode based), measures the silicon temperature

• If the silicon junction gets too hot (say 125 �C), then the activity is reduced (e.g., reduce clock rate or use clock

gating)

6.111 Fall 2018

Page 45: Lecture 15 - MIT

Thermal Shutdown

10/30/18 6.111 Fall 2018 45

Page 46: Lecture 15 - MIT

Other Things we Can Sort of Do

• The next few things we can discuss can mostly be implemented after fabrication, but require additional capabilities in the design

10/30/18 6.111 Fall 2018 46

Page 47: Lecture 15 - MIT

Reduce Supply Voltage: But is it Free?

10/30/18 47

IN OUT

VDD

+

-CL

t =0+

2)(2 T

VDD

VK

-

VDD

VSG

S

D

DDV

DDTDD

DD

VVVV

TV

DDV

k

DDV

LC

Di

VL

CDelay

1)( 2

2)(2

2 »-

µ

-

×

=

=

VDD from 2V to 1V, energy ¯ by x4, delay ­ x2

6.111 Fall 2018

! = #$→&'()* + (,-./0

Page 48: Lecture 15 - MIT

Transistors Are Basically Free… (What do you do with a Billion Transistors?)

10/30/18 48

OUT

IN

X

Pserial = Cmult 22 f Pparallel = (2Cmult 12 f /2) = Pserial/4

f =1GHzVDD=2V

X X

INf = 500MhzVDD=1V

f = 500MhzVDD=1V

IN

SELECT

Trade Area for Low Power, Possibly higher latency

OUT

6.111 Fall 2018

! ∝ #$%&

Page 49: Lecture 15 - MIT

Digitally adjustable DC-DC converter powers SA-1110 StrongArm core

µOS selects appropriate clock frequency based on workload and latency constraints

SA-1110

Control

µOS

VoutController

3.6V

5

Dynamic Voltage Scaling on a Processor

10/30/18 496.111 Fall 2018

• Some systems take to extreme and dynamically scale their voltage!

Page 50: Lecture 15 - MIT

Subthreshold Operation: slow,minimum energy operation

Strong Inversion Operation: fast, power-hungry

Exploit Sub-threshold Operation (VDD < VT)for Sensor Circuits

Data Memory

TwiddleROMs

ButterflyDatapath

Control logic

VDD = 0.18V

10/30/18 506.111 Fall 2018

Energy savings in subthreshold• Running your circuits below the threshold voltage of

transistors (when they turn “on”) also yields energy gains! (cost of speed)

Page 51: Lecture 15 - MIT

The Threat of Static Power Loss

10/30/18 51

• If you’re a major loss mechanism becomes static phenomena, then there will become a point where a cranking the clock could be beneficial!

• Run as fast as possible with the best hardware as possible (32 bit MCU if appropriate vs. 8 bit or something)

• Then sleep/power down! (the static loss monster won’t get you if you’re in sleep)

• Not necessarily the right solution, particularly as new transistor models come in and keep static loss at bay, but you never know.

6.111 Fall 2018

Page 52: Lecture 15 - MIT

Hardware vs. Software

10/30/18 52

Embedded Processor

Direct MappedHardware

FPGA

DSP

Flex

ibili

ty

Energy/Operation

0.1-1pJ/Op

1nJ/Op

Courtesy of R. Brodersen, J. Rabaey, TI, ARM/StrongARM

0.25nJ/Op

6.111 Fall 2018

Page 53: Lecture 15 - MIT

Alternative Energy Sources• Energy Harvesting – movement

• Energy Harvesting – thermoelectric generator

• Ambient RF

• Grapes

• Gastric fluids

10/30/18 536.111 Fall 2018

Page 54: Lecture 15 - MIT

Energy Scavenging

• Solar is by far the most mature technology• Been in commercial products as

far back as 1960s

10/30/18 6.111 Fall 2018 54

https://en.wikipedia.org/wiki/Solar_cell

Page 55: Lecture 15 - MIT

Energy Scavenging: Mechanical

10/30/18 55

Jose Mur Miranda/ Jeff Lang

Vibration-to-Electric Conversion

~ 10mW

MEMS Generator Power Harvesting Shoes

Joe Paradiso(Media Lab)

After 3-6 steps, it provides 3 mA for 0.5 sec~10mW

6.111 Fall 2018

Page 56: Lecture 15 - MIT

Energy Scavenging: Mechanical

10/30/18 6.111 Fall 2018 56

LTC3588

Optimized for :collecting 60 Hz vibrations at low sub-g accelerations!

Page 57: Lecture 15 - MIT

Low-Profile Wearable Body-Powered Thermoelectric Generator

• Low profile, lightweight, conformal.• Utilization of small temperature difference• Utilization of natural convection for cooling

Credit: Krishna Settaluri MIT ‘2010

10/30/18 576.111 Fall 2018

Page 58: Lecture 15 - MIT

Energy harvesting• Thermo-electric

generator• Thermoelectric

material converts temperature difference into voltage

10/30/18 58

http://electronicdesign.com/content/content/73937/73937-fig2.gifhttps://www.adafruit.com/products/700

40 K temp difference1.8 V @ 368 mA

6.111 Fall 2018

Page 59: Lecture 15 - MIT

Experimental Results

10/30/18 59

15mV

Optimal Electrical Load Resistance 33Ω(20Ω theoretical)

Optimized Power 11µW

16 TEG Islands (2 TEG modules)Credit: Krishna Settaluri MIT ‘2010

6.111 Fall 2018

Page 60: Lecture 15 - MIT

Apparently Powered by Body Heat

10/30/18 6.111 Fall 2018 60

https://www.powerwatch.com/

Page 61: Lecture 15 - MIT

Ambient RF

10/30/18 61

Prudential Center FM Stations:WZLX 100.7, WBMX 104.1, WMJX 106.7, and WXKS-FM 107.9, WBOS 92.9, WBQT 96.9, and WROR-FM 105.7.

Power output:22,000 watts

Recovered:~ 0.2 milliwatt

6.111 Fall 2018

Page 62: Lecture 15 - MIT

Ambient RF

10/30/18 626.111 Fall 2018

Ambient RF Energy Harvesting in Urban and Semi-Urban Environments, Manuel Piñuela,

Student Member, IEEE, Paul D. Mitcheson, Senior Member, IEEE, and Stepan Lucyszyn,

Senior Member, IEEE 2013

Energy to be had in the signals that are

all around us

Previously not practical since even

simple circuits used lots of power, but

as transistors have scaled…gotten

reasonable….couple with ASICs and you

could be in business

Page 63: Lecture 15 - MIT

Grape Power

10/30/18 636.111 Fall 2018

I guess

Page 64: Lecture 15 - MIT

Grape Juice Voltage

10/30/18 64

Copper pennyZinc screw

Newman’s OwnGrape Juice

Infinite Power!

6.111 Fall 2018

If we ignore huge amount of energy required to grow grapes, process grapes, ship grape juice, extract petroleum from the earth to synthesize the plastics that form the container, etc…

Page 65: Lecture 15 - MIT

But does mean…

10/30/18 6.111 Fall 2018 65

Nadeau et al…2017 Nature Biomedical Engineering

Page 66: Lecture 15 - MIT

FFTs

10/30/18 6.111 Fall 2018 66

Page 67: Lecture 15 - MIT

Audio Feature Extraction• Most features are best recognized in the frequency domain

• Use Discrete Fourier Transform (DFT)

• Algorithm used: Fast Fourier Transform (FFT)

• Input: N data values acquired at sample frequency ωS

• Nyquist rate is ωS/2

• Output: N complex values representing DFT coefficients in the frequency range −ωS/2 to

+ωS/2.

• Each value covers a frequency range of ωS/N

• Indices (0,(N/2)-1) are for frequencies i*(ωS/N)

• Indices (N/2,N-1) are for frequencies −ωS/2 + (i – N/2)*(ωS/N)

• If N is even, output is symmetric, so we can calculate magnitude using only positive

frequencies. Magnitude ≈ * constant factors.

• Example

• Audio data from AC97 sampled at 8kHz

• 2048 data points => 2048-point FFT

• 2048 complex results, each result covers 8k/2048 = 4Hz range

10/30/18 6.111 Fall 2018 67

r2 + i2

Page 68: Lecture 15 - MIT

Fast Fourier Transforms• FFTs are really central to a lot of DSP

• Software FFTs are *relatively* easy to do

• Implementing one in an FPGA from the ground up

is a bit less intuitive, but it can be done, and since it

can do much of its operations in parallel it has a

niche in a lot of real-time applications

• Great review article below (sort of step-by-step

build) which should be accessible if you’ve

seen/done/thought about implementing FFTs

before in something like C for example…will post on

Course site

10/30/18 6.111 Fall 2018 68

Slade, George. (2013). The Fast Fourier Transform in Hardware: A Tutorial Based on an FPGA Implementation. .

Page 69: Lecture 15 - MIT

Full FFT block Diagram

10/30/18 6.111 Fall 2018 69

Page 70: Lecture 15 - MIT

Data Memory Blocks

10/30/18 6.111 Fall 2018 70

Page 71: Lecture 15 - MIT

FFT example - Labkit• IP wizard will build a N-point FFT module

• WARNING: they’re big!

• In theory, there are two operating modes (select at build time)• “pipelined” where you get a complex value out for every sample you

send the module – runs continuously• “burst” where you load up N samples, wait a while and get your answer

while loading the set of samples.

• To use FFT, use sampleVerilog

• Demo: audio spectrum analyzer• Uses “pipelined” mode

• 44 page datasheet

10/30/18 6.111 Fall 2018 71

clk_27mhzready

1reset

1

0from _ac97_data[7:0] xk_re[22:0]

xk_im[22:0]

xk_index[13:0]

Might not be accessible anymore in current ISE!!

Page 72: Lecture 15 - MIT

FFT – Nexys4 DDR • IP core uses AXI4 protocol • 97 page datasheet

10/30/18 6.111 Fall 2018 72

Page 73: Lecture 15 - MIT

AXI Protocol

• Separate data and address connections for reads and writes: simultaneous, bidirectional data transfer.

• Useful for memory mapped applications

10/30/18 6.111 Fall 2018 73

Page 74: Lecture 15 - MIT

FFT of AC97 dataTo process AC97 samples:• use Pipelined mode (input one sample in each cycle, get one

sample out each cycle).• FFT expects one sample each cycle, so hook READY to CE so that FFT

only cycles once per AC97 frame

• use Unscaled mode, do scaling yourself• Number of output bits = (input width) + NFFT + 1

- NFFT is log2(size of FFT)• let number of FFT points = P, assume 48kHz sample rate

• there are P frequency bins• positive freqs in bins 0 to (P/2 – 1)• negative freqs in bins (P/2) to (P-1)• each bin covers (48k/P)Hz• Use XK_INDEX to tell which bin’s data you’re getting out• Typically you want magnitude = sqrt(xk_re^2 + xk_im^2)

10/30/18 6.111 Fall 2018 74

Page 75: Lecture 15 - MIT

Tools• Labkit hardware with sample Verilog

• NTSC Camera – display BW images • ZBT Memory – high speed memory two 512Kx36 banks • Alphanumeric data with hex display• Compact Flash – 128Mbits non-volatile memory

• Nexys4 hardware with sample Verilog• VGA Camera• SD card read/write

• Application support• Sound -Matlab script: convert wav files to AC97 8bit COE file Images -

Matlab script: convert BMP COE field • USB PC-Labkit data transfer

• git – Shared project team repository with version control• hg – Shared project team repository with version control for

people who want to be different

10/30/18 756.111 Fall 2018

Page 76: Lecture 15 - MIT

Iterative SQRT module

10/30/18 76

// takes integer square root iterativelymodule sqrt #(parameter NBITS = 8, // max 32

MBITS = (NBITS+1)/2)(input wire clk,start,input wire [NBITS-1:0] data,output reg [MBITS-1:0] answer,output wire done);

reg busy;reg [4:0] bit;// compute answer bit-by-bit, starting at MSBwire [MBITS-1:0] trial = answer | (1 << bit);

always @(posedge clk) beginif (busy) beginif (bit == 0) busy <= 0;else bit <= bit - 1;if (trial*trial <= data) answer <= trial;

endelse if (start) beginbusy <= 1;answer <= 0;bit <= MBITS - 1;

endend

assign done = ~busy;endmodule

6.111 Fall 2018

Cool way/inspiration about how to implement an iterative algorithm in hardware

Computers square root by guessing and checking

Page 77: Lecture 15 - MIT

How to Make Your Projects Work• What are the power requirements?

• Labkit: 3.3V, 5V, +12, -12• Nexys4: 3.3V

• Characterize external components before designing your system• Understand input/output voltage specs• Understand behavior of unused input/control lines• Understand tri-state control lines

• Synchronize external signals to system clock.

• Exercise with care: grounds – in particular high current devices

• Look at waveforms on a scope for external signals >1Mhz

• Do NOT assume plug/play except for speakers, microphones, NTSC camera

• Verilog modules except for Labs 3-5 are provided “As-is”. No warranty expressed or implied.

10/30/18 776.111 Fall 2018

Page 78: Lecture 15 - MIT

See you in lab!

10/30/18 78

Final project represents 72 good hours of credit, so you should average 2-3 hours/day of work on your project assuming you give yourself the occasional day off…

Do not try to do 72 hours in three days.

6.111 Fall 2018