Buongiorno! Recentemente ho comprato una scheda Arduino per fare una sorta di "controllo della luce" nella mia stanza. Ecco il codice del firmware che ho scritto:pySerial funziona bene nell'interprete Python, ma non standalone
int control = 0;
int pin = 0;
void setup()
{
Serial.begin(9600);
for(pin = 0; pin <= 13; pin++) pinMode(pin, OUTPUT);
}
void loop()
{
control = Serial.read();
if (control > 0 && control <= 13) digitalWrite(control, HIGH);
if (control < 256 && control >= (256-13)) digitalWrite((256-control), LOW);
}
Dopo di che, ho usato pySerial da interprete Python per controllare i perni, e tutto funzionava bene. Ecco un pezzo di uscita interprete:
Python 2.6.5 (r265:79063, Apr 16 2010, 13:57:41)
[GCC 4.4.3] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import serial
>>> ser = serial.Serial('/dev/ttyUSB0', 9600)
>>> ser.write(chr(12))
>>> # The light turned on here
...
>>> ser.write(chr(256-12))
>>> # The light turned off here
...
poi ho deciso di scrivere un semplice script Python a fare lo stesso:
#!/usr/bin/env python
import serial
import time
ser = serial.Serial('/dev/ttyUSB0', 9600)
ser.write(chr(12))
time.sleep(1)
ser.write(chr(256-12))
Ma non funziona affatto! L'Arduino mostra che qualcosa è stato ricevuto durante il periodo in cui ho lanciato la sceneggiatura, ma non succede nulla. Ecco un pezzo di uscita strace per lo script:
open("/dev/ttyUSB0", O_RDWR|O_NOCTTY|O_NONBLOCK) = 3
ioctl(3, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(3, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(3, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(3, SNDCTL_TMR_START or TCSETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(3, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
open("/dev/ttyUSB0", O_RDWR|O_NOCTTY|O_NONBLOCK) = 4
ioctl(4, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(4, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(4, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(4, SNDCTL_TMR_START or TCSETS, {B9600 -opost -isig -icanon -echo ...}) = 0
ioctl(4, SNDCTL_TMR_TIMEBASE or TCGETS, {B9600 -opost -isig -icanon -echo ...}) = 0
write(4, "\f", 1) = 1
close(4) = 0
rt_sigaction(SIGINT, {SIG_DFL, [], SA_RESTORER, 0x7f45cf4c88f0}, {0x4d9820, [], SA_RESTORER, 0x7f45cf4c88f0}, 8) = 0
exit_group(0) = ?
Sembra che tutto dovrebbe andare bene, in modo da non so quale sia il problema può essere. Gradirei qualsiasi aiuto, molte grazie in anticipo!
PS Quando eseguo il programma in PDB, tutto funziona correttamente. Un Heisenbug.
AGGIORNAMENTO: ho fatto in modo che il controller mi restituisse i dati che stava ricevendo e sembra che non stia ricevendo nulla quando sto eseguendo lo script, ma riceve tutto quando invio i dati dall'interprete. Il codice del firmware appare come segue:
int control = 0;
int pin = 0;
void setup()
{
Serial.begin(9600);
for(pin = 0; pin <= 13; pin++) pinMode(pin, OUTPUT);
}
void loop()
{
if (Serial.available() > 0)
{
control = Serial.read();
if (control <= 13) digitalWrite(control, HIGH);
if (control < 256 && control >= (256-13)) digitalWrite((256-control), LOW);
Serial.println(control);
}
}
Did 'ser.write (chr (12)); time.sleep (1); ser.write (chr (256-12)) 'funziona bene dalla console? – seriyPS
Sì. Luci accese, spente, jpnevulator mostra i dati restituiti dal controller. Quando faccio lo stesso da uno script, jpnevulator non mostra dati restituiti e non succede nulla. –
Ho aggiornato pySerial, ma nessun risultato. –