Problemi misura di Temperatura con sonda DS18B20

Ciao a tutti, sto cercando di leggere da una sonda DS18B20 in valore di temperatura, per poi scriverlo su di una pagina web.
Fino alla lettura tutto ok, la vedo sulla seriale, ma quando cerco di aggiungere le componenti ethernet allo scketch (Ethernet.begin(mac, ip):wink: sulla seriale mi compare la scritta "NO MORE ADRESSES"

Mi sapete per cortesia dare una mano non so piu dove sbattere la testa.

Grazie

Sketch, schema e indirizzo dove mandarti un tecnico... :stuck_out_tongue:

Ciao posto solo un parte del codice xk è troppo grande, comunque l'errore risiede nella prima parte

[quote]
#include <[color=#CC6600]OneWire[/color].h>
[color=#CC6600]OneWire[/color]  ds(10);  [color=#7E7E7E]// on pin 10 (a 4.7K resistor is necessary) for temperature sensor DS18B20[/color]
#include <[color=#CC6600]NewPing[/color].h>
#define TRIGGER_PIN  7  [color=#7E7E7E]// Arduino pin tied to trigger pin on the ultrasonic sensor.[/color]
#define ECHO_PIN     6  [color=#7E7E7E]// Arduino pin tied to echo pin on the ultrasonic sensor.[/color]
#define MAX_DISTANCE 350 [color=#7E7E7E]// Maximum distance we want to ping for (in centimeters). Maximum sensor distance is rated at 400-500cm.[/color]
#include <[color=#CC6600]SPI[/color].h>  
#include <[color=#CC6600]Wire[/color].h>  
#include <Time.h>
#include [color=#006699]"RTClib.h"[/color]
#include <[color=#CC6600]Ethernet[/color].h>



[color=#CC6600]const[/color] [color=#CC6600]int[/color] chipSelect = 4;
[color=#CC6600]NewPing[/color] sonar(TRIGGER_PIN, ECHO_PIN, MAX_DISTANCE); [color=#7E7E7E]// NewPing setup of pins and maximum distance.[/color]
[color=#CC6600]RTC_DS1307[/color] rtc;
[color=#CC6600]byte[/color] mac[] = { 0x90, 0xA2, 0xDA, 0x0F, 0x78, 0x31 };
[color=#CC6600]IPAddress[/color] ip(192,168,1,102);

[color=#7E7E7E]// Initialize the Ethernet server library[/color]
[color=#7E7E7E]// with the IP address and port you want to use [/color]
[color=#7E7E7E]// (port 80 is default for HTTP):[/color]
[color=#CC6600]EthernetServer[/color] server(80);


[color=#CC6600]float[/color] T_Aria;
[color=#CC6600]float[/color] T_Max=-10;
[color=#CC6600]float[/color] T_Min=50;
[color=#CC6600]float[/color] T_Max_8;
[color=#CC6600]float[/color] T_Min_8;


[color=#CC6600]void[/color] [color=#CC6600][b]setup[/b][/color]() { 
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]begin[/color](9600);[color=#7E7E7E]// Open serial monitor at 115200 baud to see ping results.[/color]
  rtc.[color=#CC6600]begin[/color]();    
  [color=#CC6600]Wire[/color].[color=#CC6600]begin[/color]();
  [color=#CC6600]Ethernet[/color].[color=#CC6600]begin[/color](mac, ip);
  server.[color=#CC6600]begin[/color]();




}

[color=#CC6600]void[/color] [color=#CC6600][b]loop[/b][/color]() {
  
  [color=#CC6600]byte[/color] i;
  [color=#CC6600]byte[/color] present = 0;
  [color=#CC6600]byte[/color] type_s;
  [color=#CC6600]byte[/color] data[12];
  [color=#CC6600]byte[/color] addr[8];
  [color=#CC6600]float[/color] celsius, fahrenheit;
  
  [color=#CC6600]if[/color] ( !ds.[color=#CC6600]search[/color](addr)) {
    [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]([color=#006699]"No more addresses."[/color]);
    [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]();
    ds.[color=#CC6600]reset_search[/color]();
    [color=#CC6600]delay[/color](250);
    [color=#CC6600]return[/color];
  }
  
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#006699]"ROM ="[/color]);
  [color=#CC6600]for[/color]( i = 0; i < 8; i++) {
    [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]write[/color]([color=#006699]' '[/color]);
    [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color](addr[i], [color=#006699]HEX[/color]);
  }

  [color=#CC6600]if[/color] ([color=#CC6600]OneWire[/color]::[color=#CC6600]crc8[/color](addr, 7) != addr[7]) {
      [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]([color=#006699]"CRC is not valid!"[/color]);
      [color=#CC6600]return[/color];
  }
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]();
 
  [color=#7E7E7E]// the first ROM byte indicates which chip[/color]
  [color=#CC6600]switch[/color] (addr[0]) {
    [color=#CC6600]case[/color] 0x10:
      [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]([color=#006699]"  Chip = DS18S20"[/color]);  [color=#7E7E7E]// or old DS1820[/color]
      type_s = 1;
      [color=#CC6600]break[/color];
    [color=#CC6600]case[/color] 0x28:
      [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]([color=#006699]"  Chip = DS18B20"[/color]);
      type_s = 0;
      [color=#CC6600]break[/color];
    [color=#CC6600]case[/color] 0x22:
      [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]([color=#006699]"  Chip = DS1822"[/color]);
      type_s = 0;
      [color=#CC6600]break[/color];
    [color=#CC6600]default[/color]:
      [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]([color=#006699]"Device is not a DS18x20 family device."[/color]);
      [color=#CC6600]return[/color];
  } 

  ds.[color=#CC6600]reset[/color]();
  ds.[color=#CC6600]select[/color](addr);
  ds.[color=#CC6600]write[/color](0x44, 1);        [color=#7E7E7E]// start conversion, with parasite power on at the end[/color]
  
  [color=#CC6600]delay[/color](1000);     [color=#7E7E7E]// maybe 750ms is enough, maybe not[/color]
  [color=#7E7E7E]// we might do a ds.depower() here, but the reset will take care of it.[/color]
  
  present = ds.[color=#CC6600]reset[/color]();
  ds.[color=#CC6600]select[/color](addr);    
  ds.[color=#CC6600]write[/color](0xBE);         [color=#7E7E7E]// Read Scratchpad[/color]

  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#006699]"  Data = "[/color]);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color](present, [color=#006699]HEX[/color]);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#006699]" "[/color]);
  [color=#CC6600]for[/color] ( i = 0; i < 9; i++) {           [color=#7E7E7E]// we need 9 bytes[/color]
    data[i] = ds.[color=#CC6600]read[/color]();
    [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color](data[i], [color=#006699]HEX[/color]);
    [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#006699]" "[/color]);
  }
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#006699]" CRC="[/color]);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#CC6600]OneWire[/color]::[color=#CC6600]crc8[/color](data, 8), [color=#006699]HEX[/color]);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]();

  [color=#7E7E7E]// Convert the data to actual temperature[/color]
  [color=#7E7E7E]// because the result is a 16 bit signed integer, it should[/color]
  [color=#7E7E7E]// be stored to an "int16_t" type, which is always 16 bits[/color]
  [color=#7E7E7E]// even when compiled on a 32 bit processor.[/color]
  int16_t raw = (data[1] << 8) | data[0];
  [color=#CC6600]if[/color] (type_s) {
    raw = raw << 3; [color=#7E7E7E]// 9 bit resolution default[/color]
    [color=#CC6600]if[/color] (data[7] == 0x10) {
      [color=#7E7E7E]// "count remain" gives full 12 bit resolution[/color]
      raw = (raw & 0xFFF0) + 12 - data[6];
    }
  } [color=#CC6600]else[/color] {
    [color=#CC6600]byte[/color] cfg = (data[4] & 0x60);
    [color=#7E7E7E]// at lower res, the low bits are undefined, so let's zero them[/color]
    [color=#CC6600]if[/color] (cfg == 0x00) raw = raw & ~7;  [color=#7E7E7E]// 9 bit resolution, 93.75 ms[/color]
    [color=#CC6600]else[/color] [color=#CC6600]if[/color] (cfg == 0x20) raw = raw & ~3; [color=#7E7E7E]// 10 bit res, 187.5 ms[/color]
    [color=#CC6600]else[/color] [color=#CC6600]if[/color] (cfg == 0x40) raw = raw & ~1; [color=#7E7E7E]// 11 bit res, 375 ms[/color]
    [color=#7E7E7E]//// default is 12 bit resolution, 750 ms conversion time[/color]
  }
  celsius = ([color=#CC6600]float[/color])raw / 16.0;
  fahrenheit = celsius * 1.8 + 32.0;
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#006699]"  Temperature = "[/color]);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color](celsius);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color]([color=#006699]" Celsius, "[/color]);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]print[/color](fahrenheit);
  [color=#CC6600][b]Serial[/b][/color].[color=#CC6600]println[/color]([color=#006699]" Fahrenheit"[/color]);
  
  [color=#CC6600]float[/color] Temp = ([color=#CC6600]float[/color])raw / 16.0;
    
   [color=#CC6600]DateTime[/color] [color=#CC6600]now[/color] = rtc.[color=#CC6600]now[/color](); 


  T_Aria= (Temp/1024)*500;

[/quote]

Scusate non so cosa sia successo provo a reinserire il codice

#include <OneWire.h>
OneWire ds(10); // on pin 10 (a 4.7K resistor is necessary) for temperature sensor DS18B20
#include <NewPing.h>
#define TRIGGER_PIN 7 // Arduino pin tied to trigger pin on the ultrasonic sensor.
#define ECHO_PIN 6 // Arduino pin tied to echo pin on the ultrasonic sensor.
#define MAX_DISTANCE 350 // Maximum distance we want to ping for (in centimeters). Maximum sensor distance is rated at 400-500cm.
#include <SPI.h>
#include <Wire.h>
#include <Time.h>
#include "RTClib.h"
#include <Ethernet.h>

const int chipSelect = 4;
NewPing sonar(TRIGGER_PIN, ECHO_PIN, MAX_DISTANCE); // NewPing setup of pins and maximum distance.
RTC_DS1307 rtc;
byte mac[] = { 0x90, 0xA2, 0xDA, 0x0F, 0x78, 0x31 };
IPAddress ip(192,168,1,102);

// Initialize the Ethernet server library
// with the IP address and port you want to use
// (port 80 is default for HTTP):
EthernetServer server(80);

float T_Aria;
float T_Max=-10;
float T_Min=50;
float T_Max_8;
float T_Min_8;

void setup() {
Serial.begin(9600);// Open serial monitor at 115200 baud to see ping results.
rtc.begin();
Wire.begin();
Ethernet.begin(mac, ip);
server.begin();

}

void loop() {

byte i;
byte present = 0;
byte type_s;
byte data[12];
byte addr[8];
float celsius, fahrenheit;

if ( !ds.search(addr)) {
Serial.println("No more addresses.");
Serial.println();
ds.reset_search();
delay(250);
return;
}

Serial.print("ROM =");
for( i = 0; i < 8; i++) {
Serial.write(' ');
Serial.print(addr*, HEX);*

  • }*

  • if (OneWire::crc8(addr, 7) != addr[7]) {*
    _ Serial.println("CRC is not valid!");_

  • return;*

  • }*
    _ Serial.println();_

  • // the first ROM byte indicates which chip*

  • switch (addr[0]) {*

  • case 0x10:*
    _ Serial.println(" Chip = DS18S20"); // or old DS1820_

  • type_s = 1;*

  • break;*

  • case 0x28:*
    _ Serial.println(" Chip = DS18B20");_

  • type_s = 0;*

  • break;*

  • case 0x22:*
    _ Serial.println(" Chip = DS1822");_

  • type_s = 0;*

  • break;*

  • default:*
    _ Serial.println("Device is not a DS18x20 family device.");_

  • return;*

  • } *

  • ds.reset();*

  • ds.select(addr);*

  • ds.write(0x44, 1); // start conversion, with parasite power on at the end*

  • delay(1000); // maybe 750ms is enough, maybe not*

  • // we might do a ds.depower() here, but the reset will take care of it.*

  • present = ds.reset();*

  • ds.select(addr); *

  • ds.write(0xBE); // Read Scratchpad*
    _ Serial.print(" Data = ");_
    _ Serial.print(present, HEX);_
    _ Serial.print(" ");_

  • for ( i = 0; i < 9; i++) { // we need 9 bytes*
    _ data* = ds.read();_
    _ Serial.print(data, HEX);
    Serial.print(" ");
    }
    Serial.print(" CRC=");
    Serial.print(OneWire::crc8(data, 8), HEX);
    Serial.println();
    // Convert the data to actual temperature*
    * // because the result is a 16 bit signed integer, it should*
    * // be stored to an "int16_t" type, which is always 16 bits*
    * // even when compiled on a 32 bit processor._
    int16_t raw = (data[1] << 8) | data[0];
    if (type_s) {
    _ raw = raw << 3; // 9 bit resolution default*
    * if (data[7] == 0x10) {
    // "count remain" gives full 12 bit resolution*
    * raw = (raw & 0xFFF0) + 12 - data[6];
    }
    } else {
    byte cfg = (data[4] & 0x60);
    // at lower res, the low bits are undefined, so let's zero them*
    * if (cfg == 0x00) raw = raw & ~7; // 9 bit resolution, 93.75 ms*
    * else if (cfg == 0x20) raw = raw & ~3; // 10 bit res, 187.5 ms*
    * else if (cfg == 0x40) raw = raw & ~1; // 11 bit res, 375 ms*
    * //// default is 12 bit resolution, 750 ms conversion time*
    * }
    celsius = (float)raw / 16.0;*
    fahrenheit = celsius * 1.8 + 32.0;
    Serial.print(" Temperature = ");
    Serial.print(celsius);
    Serial.print(" Celsius, ");
    Serial.print(fahrenheit);
    Serial.println(" Fahrenheit");_

* float Temp = (float)raw / 16.0;*

* DateTime now = rtc.now();*
T_Aria= (Temp/1024)500;
_[/quote]*_

Non si capisce niente.
Se hai la Ethernet non devi usare i pin 10, 11, 12, 13 e possibilmente neanche il 4.
Questo su Arduino UNO. Con altre schede bisogna verificare caso per caso.

Grazie gentilissimo, appena riesco provo a cambiare ingresso.