PIR sensor and thermostat switch

I have a temperature controlled switch and a PIR sensor hooked up to my arduino. The idea is to have the sensor to read motion and for the temperature switch read above a certain temperature, both of these conditions have to be met before the led on the arduino should light up. Yet the problem is that the light comes on even if the temperature switch has not reached its set point that it would write the pin as high.

/////////////////////////////
//VARS
//the time we give the sensor to calibrate (10-60 secs according to the datasheet)
int calibrationTime = 15;        

//the time when the sensor outputs a low impulse
long unsigned int lowIn;         

//the amount of milliseconds the sensor has to be low 
//before we assume all motion has stopped
long unsigned int pause = 1000;  

boolean lockLow = true;
boolean takeLowTime; 

int pirPin = 3;    //the digital pin connected to the PIR sensor's output
int ledPin = 13;
int thermPin = 7;

/////////////////////////////
//SETUP
void setup(){
  Serial.begin(9600);
  pinMode(pirPin, INPUT);
  pinMode(ledPin, OUTPUT);
  digitalWrite(pirPin, LOW);
pinMode(thermPin, INPUT);
digitalWrite(thermPin, LOW);
  //give the sensor some time to calibrate
  Serial.print("calibrating sensor ");
    for(int i = 0; i < calibrationTime; i++){
      Serial.print(".");
      delay(1000);
      }
    Serial.println(" done");
    Serial.println("SENSOR ACTIVE");
    delay(50);
  }

////////////////////////////
//LOOP
void loop(){
 if(digitalRead(thermPin) == HIGH && digitalRead(pirPin) == HIGH){
       digitalWrite(ledPin, HIGH);   //the led visualizes the sensors output pin state
       if(lockLow){  
         //makes sure we wait for a transition to LOW before any further output is made:
         lockLow = false;            
         Serial.println("---");
         Serial.print("motion detected at ");
         Serial.print(millis()/1000);
         Serial.println(" sec"); 
         
         }         
         takeLowTime = true;
 }
         else{
          digitalWrite(ledPin, LOW);
         }
       


        if(takeLowTime){
        lowIn = millis();          //save the time of the transition from high to LOW
        takeLowTime = false;
      }
       //if the sensor is low for more than the given pause, 
       //we assume that no more motion is going to happen
       if(!lockLow && millis() - lowIn > pause){  
           //makes sure this block of code is only executed again after 
           //a new motion sequence has been detected
           lockLow = true;                        
           Serial.print("motion ended at ");      //output
           Serial.print((millis() - pause)/1000);
           Serial.println(" sec");
           
           }
       }

We need to see what type of thermal sensor and how it is connected.

Weedpharma

  pinMode(pirPin, INPUT);
  pinMode(ledPin, OUTPUT);
  digitalWrite(pirPin, LOW);

What do you think the third line is doing? Why do you think you need to do that?

pinMode(thermPin, INPUT);
digitalWrite(thermPin, LOW);

What do you think the second line is doing? Why do you think you need to do that?

 Serial.print("calibrating sensor ");
    for(int i = 0; i < calibrationTime; i++){
      Serial.print(".");
      delay(1000);
      }
    Serial.println(" done");

There is NOTHING in that code that is calibrating any sensor. That Serial.print() statement is complete nonsense.

if(digitalRead(thermPin) == HIGH && digitalRead(pirPin) == HIGH){

Isitreallynecessarytojamthecurlybraceupagainstthestatement? It belongs on a line BY ITSELF.

        takeLowTime = true;

Time is true, huh? Nonsense.

even if the temperature switch has not reached its set point

I suspect, then, that your switch is wired incorrectly.

This code is abysmal. Dump it, and start over.

I just got the PIR code from the Arduino site. I am using a 12 v temperature controlled switch through a optocoupler.

I just got the PIR code from the Arduino site.

Well, it's crap.

I am using a 12 v temperature controlled switch through a optocoupler.

That doesn't tell us ANYTHING about how you have wired it.

You need to write a sketch that does nothing but read the state of the pin that the optocoupler is connected to, and print that state to the Serial Monitor. When you see that the values printed match what you expect, then change to the state change detection example model, and print only when the state changes.

When you KNOW that the optocoupler is wired, and is being read, correctly, you can put the PIR code back in.