Differenze tra le versioni di "Misurare la corrente con un anello amperometrico"
Riga 8: | Riga 8: | ||
Il sensore amperometrico si apre come una pinza, occorre richiuderlo in modo che ''abbracci'' il uno dei due fili che portano la corrente ad un utilizzatore (a 230V alternata). | Il sensore amperometrico si apre come una pinza, occorre richiuderlo in modo che ''abbracci'' il uno dei due fili che portano la corrente ad un utilizzatore (a 230V alternata). | ||
− | [[File:cursensor.png| | + | [[File:cursensor.png|300px]] |
Questo e' il programma Python che calcola l'intensita' di corrente istantanea in transito: | Questo e' il programma Python che calcola l'intensita' di corrente istantanea in transito: |
Versione delle 18:40, 3 mar 2013
Questo esperimento usa la scheda Input Analogico collegata come descritto in "Collegare dispositivi I2C" e questo sensore amperometrico
Il sensore amperometrico viene fornito con un jack di collegamento. Attaccate i due contatti del Jack a un entrata della scheda di input analogico (il programma presentato di default ipotizza che sia collegato sulla porta 0). Non importa la polarita', infatti questo sensore amperomentrico non e' altro che un trasformatore a una spira di primario con una resistenza di carico, generera' in output una tensione proporzionale alla corrente in transito raggiungendo 1V al passaggio di 30A.
Il sensore amperometrico si apre come una pinza, occorre richiuderlo in modo che abbracci il uno dei due fili che portano la corrente ad un utilizzatore (a 230V alternata).
Questo e' il programma Python che calcola l'intensita' di corrente istantanea in transito:
#!/usr/bin/env python3 import sys,fcntl,os,time,struct,math analog_addr = 0x68 I2C_SLAVE = 0x0703 SAMPLES = 50 devname = "/dev/i2c-0" if len(sys.argv) < 2: line = 0 else: line = int(sys.argv[1]) dev=os.open("/dev/i2c-0", os.O_RDWR) fcntl.ioctl(dev, I2C_SLAVE, analog_addr) cmd=bytearray([0x80 | 0x10 | (line<<5)]) os.write(dev, cmd) sqsum=0 for j in range(SAMPLES): time.sleep(0.004167) ret=os.read(dev, 2) value=struct.unpack('>h',ret)[0] sqsum += (value * value) current = math.sqrt(sqsum/SAMPLES)*30/1000 print("{:7.4f}A {:6.3f}W".format(current,current * 230))
Come si vede viene rilevato un certo numero di campioni e poi ne viene calcolato lo scarto quadratico medio dalla tensione nulla. Il fattore di conversione 30/1000 si deve al fatto che la misura e' in millivolt e 1 volt corrisponde a 30 Ampere.