Hi all,
am having problem with displaying deg C using the LM 335 temp sender
i believe i have set the AD settings right for 16F877 RA0 pin
have attached the prog and circuit
thanks
Hi all,
am having problem with displaying deg C using the LM 335 temp sender
i believe i have set the AD settings right for 16F877 RA0 pin
have attached the prog and circuit
thanks
IF ITS STOCK IT WONT ROCK
Hi,
I've never used this sensor but are you sure you have it wired correct?
As in you schematic,viewed from the top with the flat side "up" the left most pin should be GND. The middle pin then goes to the analog in of the PIC with a 12k pullup. At least that's how I read the datasheets example for the basic temp sensor circuit.
/Henrik Olsson.
Hi, Cooter
Your conversion formula is wrong ...
°K = °C +273.15... and your scaling doesn't meet anything known.
now, you MUST Download your sensor datasheet ... and wire it decently.
Can't work at this time !!!
Alain
************************************************** ***********************
Why insist on using 32 Bits when you're not even able to deal with the first 8 ones ??? ehhhhhh ...
************************************************** ***********************
IF there is the word "Problem" in your question ...
certainly the answer is " RTFM " or " RTFDataSheet " !!!
*****************************************
Oh ya, that circuit's is out in the weeds somewhere.
And when you do get it working, the easiest way I've found to calibrate the system is to dip the sensor in ice water and set the reading to match, not change any resistors or rewire anything, just adjust the math on the PIC to match.
And are you sure the A/D is working right? Have you tried putting a pot across the A/D input? Does that respond correctly?
hi all,
am trying to understand how to implament the ADC on the pic 16f877
my code is for a LM335 temp sensor connected to RA0(pin 2)
the VDD and VSS is from a 7805 voltage reg that also supplies the LM335
Cant get ADC to work from my circuit. or is it my code??????????????
why cant i use decimal ie 0.46 in my maths routine?????????????
This has had me up all week trying to get it to work
PLZ someone guide me in the correct direction
'PIC 16f877 with a LM335 temp sender
'
'
define osc 20 ' 20mhz oscillator
' LCD ROUTINES
DEFINE LCD_DREG PORTB
DEFINE LCD_DBIT 4 '4,5,6,7
DEFINE LCD_RSREG PORTB
DEFINE LCD_RSBIT 3
DEFINE LCD_EREG PORTB
DEFINE LCD_EBIT 2
DEFINE LCD_BITS 4
DEFINE LCD_LINES 2
DEFINE LCD_COMMANDUS 2000
DEFINE LCD_DATAUS 50
' Define ADCIN parameters
Define ADC_BITS 10 ' Set number of bits in result
define ADC_CLOCK 3 ' Set clock source
Define ADC_SAMPLEUS 50 ' Set sampling time in uS
AD_RAW var word ' Create adval to store result
AD_RESULT var word
TRISA = %11111111 ' Set PORTA to all input
ADCON1 = %10001110 ' Set PORTA analog and RIGHT justify result
ADCON0 = %10000001 ' Configure and turn on A/D Module
Pause 500 ' Wait .5 second
loop:
ADCIN 0, AD_RAW ' Read channel 0 to ad_raw
AD_RESULT = (ad_raw *0.48828) - 273.15 ' Convert Kelvins to Degrees C
Lcdout $fe, 1 ' Clear LCD
Lcdout "TEMP ", DEC AD_Result ," C" ' Display the decimal value
Pause 100 ' Wait .1 second
Goto loop ' Do it forever
End
IF ITS STOCK IT WONT ROCK
Did you really bought the copy of PBP you have????
Did it came with it a MANUAL ???
Did you read the MANUAL ????
Didn't find any reference as to that PBP is NOT supporting floating maths ???
I am looking forward to you replying to the above so that we can continue support here.
Ioannis
P.S. If you are just connect the sensor to the PIC directly, your useful range will be limited (0C-100C is from 2,7315 to 3,7315 Volts). I suggest to use opamps and extend the range of the sensor from 0C->0Volts to 100C->5 Volts.
************************************************** ***********************
Why insist on using 32 Bits when you're not even able to deal with the first 8 ones ??? ehhhhhh ...
************************************************** ***********************
IF there is the word "Problem" in your question ...
certainly the answer is " RTFM " or " RTFDataSheet " !!!
*****************************************
thanks for the quick responce
got PBP 2.47 from DONTRONICS here in melbourne
Yes. Read the 213 pages and even been looking up web sites with references. downloaded the data sheet read the A2D converter module.. CH 11 pg 127
ok just found 1 error in setting the TRISA had 8 bits set to 1 should have been 6 ie TRISA %111111 not TRISA %11111111
still not workin. even connected a 5k lin pot and got no responce.
and as Ioannis said using an opamp to extend the range i will be now
MY CODE WILL NOT COMPILE WITH THIS LINE
AD_RESULT = (ad_raw *0.48828) - 273.15
Had to do it this way
ad_result = (ad_raw * 48828)/1000
ad_result = ad_result/100
ad_result = (ad_result *27315)/100
WHY????????????????????????????????????????
HMMMMMMM very frustrating
IF ITS STOCK IT WONT ROCK
What do you mean why? Did you read the post earlier? Did you really read it? Let me quote one line from that earlier post:
"Did you read the MANUAL ????
Didn't find any reference as to that PBP is NOT supporting floating maths ???"
How many times do we have to point out to you that PBP does not support floating point math! And if you don't understand the term 'floating point', well, quite frankly 'floating point' means that the decimal is 'floating'...it can move wherever it needs to go according to the math being performed!
PBP DOES NOT SUPPORT FLOATING POINT MATHS! The decimal point is stuck in one place, all the way to the right, no matter what you do, the decimal point will always be to the right...no fractions, no tenths, no hundreths, no nothing. If you divide 10 by 3, you'll get 3, nothing more nothing less. If you use the remainder function, yes, in the case above, you'll get a 1 from it, but it's still not FLOATING POINT...
Somebody get me a drill!!!
Thanks skimask for pointing that out.
ok so i am 1 step closer to getting this to work now.
so the only way to do floating point maths then is with asm right?
and thats why my code will not work correctly with the LM335 and the ADC?
IF ITS STOCK IT WONT ROCK
QUOTE << Hi, Skimask
You can also remember Every number can be close-rounded as the division of two integers ... ( PI = 22/7 i.e. )
That give some brain work to find the couple of the year ... but a small GWBASIC ( LOL !!! ) program can easily sort them.
With the use of the DIV32 function ... that enables more than you ever dreamed !!!
Alain >>
Hi, Scooter
Sometimes, life is really funny ... that comes from 5 threads down on the list ...
************************************************** ***********************
Why insist on using 32 Bits when you're not even able to deal with the first 8 ones ??? ehhhhhh ...
************************************************** ***********************
IF there is the word "Problem" in your question ...
certainly the answer is " RTFM " or " RTFDataSheet " !!!
*****************************************
What savnik (Geia sou!) said was that I made too many questions like in an interrogation, one after another, so I exhausted him to death!
Sorry for that, I couldn't resist...
As for the floating maths, CrazyCooter, you can do real maths with the routines from Microchip (check the melabs site for this), write your own routines, use decimal numbers only with tricks that were many times discussed here or do not use decimal at all.
For example, 2.3 may be represented as 23 and displayed as "2", ".", "3"
Also check the manual and forum for applications of DIV32, */ and // operators. These are what you need to do the job.
Ioannis
Thanks Ioannis,
The man dies, when you KILL the man ...
I just didn't understant who was who ...
Alain
************************************************** ***********************
Why insist on using 32 Bits when you're not even able to deal with the first 8 ones ??? ehhhhhh ...
************************************************** ***********************
IF there is the word "Problem" in your question ...
certainly the answer is " RTFM " or " RTFDataSheet " !!!
*****************************************
I have no understanding of asm so would take me a very long time to understand and implement.
2 decimal places is more than accurate enought for what i want to be doing
and all the adc will be from 0V to 5V in 10 bit
as Ioannis said "check the manual and forum for applications of DIV32, */ and // operators. These are what you need to do the job."
thanks everyone see how i go trying this
IF ITS STOCK IT WONT ROCK
Can anyone please help me with a schematic on how to achieve what Ioannis is suggesting or is the example below not far away from what I'm looking for?
How do I "electronically" rescale 2,7315Volts to an ideal "0V" and/or a 3,7315Volts to an ideal "5V"?
I don't know...
As I'd like to use my sensor to control a freezer, the temperature range I need goes from -30°C to +30°C.
I found quite some info, for example here and I've already ordered some LM358 opamps to build this circuit.
It looks like this circuit will output 0V at 0°C and 1V at 100°C. It is still "loosing" 4 precious volts, isn't it?
How can this circuit be modified to, again ideally, match something like -30°C = 0V and +30°C = 5V?
![]()
Last edited by flotulopex; - 10th April 2015 at 22:19. Reason: typo
Roger
Why not use the LM35?
This sensor is calibrated directly in Celcius, has a linear 10mV/degree C scale factor, is rated for -55 to +150 C range and does not require any external calibration or trimming to provide typical accuracies of =/-0.25C at room temperature and +/-0.75C over the full -55 to +150C range.
Cheers
Barry
VK2XBP
Thanks for the idea Barry.
It's just, I have a LM335 in the drawer....
I can give it a go with the LM35 - need to order one but here, in Switzerland, the LM35 is ten times more expensive than the LM335
Anyway, I would still like to understand how the LM335 could be used with an opamp.
Roger
Attached is one idea. First op-amp works as an adder (or subtracter). It removes the DC offset voltage from the + input. So output is around 0-0,58 volts for -30 to 30 deg.
Then the second op-amp works as an DC amplifier to boost the 0,58 to 5 volts. So you have to make two adjustments, trimmer R9 at 2,4315 volts and R10 to get 5 Volts for 30 deg.
Also very critical is to select op-amps that are able to work at 5Volts and be rail to rail. I thing LMC662 is such a chip.
Ioannis
![]()
Ioannis,
Thank you very much for the schema and your comment.
I need to check what the opamps in my drawer can do and if they don't, I'll order some to test this.
It makes it quite a "large" circuit in comparison of the usage of a single LM35.
What would be the advantage of this circuit vs a LM35 please?
Roger
If it seems too complicated, you can remove R5, R6, R8 making exact adjustment more critical.
The circuit will give you more resolution for the range you asked, -30 to +30 for a 0 to 5 volts output or about 0,083 volt/deg celsious.
Also it gives you an output for negative temperatures.
For the LM35 you will get 10mV/C. This means you will get from 0-0,3 volts for 0-30 C. If you want to measure from -30, then you must raise the ground of the LM35 above say 0,3 or better 0,6 volts. Maybe with a diode. Your output then will not be referenced to ground but from the pins of the LM35 (out and LM35 gnd). Your span for -30 to +30 will be 0,6 volts. If you need to drive an ADC then it would be better to amplify this small signal too.
HTH,
Ioannis
I think you are better off with the LM335 as it's output is 10mv/deg K. The LM35 is 10mv/deg.c. There is going to be a problem with the accuracy below 0 deg C. when using the LM35. If you would like rather than analog you could use a TMP-03/04 from Analog Devices which is a pulse width output. I have used these before and work quite well. Just a thought...
Dave Purola,
N8NTA
EN82fn
Hum...can you explain a little more please?I think you are better off with the LM335 as it's output is 10mv/deg K. The LM35 is 10mv/deg C.
I thought Kelvin were used to express a temperature difference and Celsius/Fahrenheit would represent a value. I must be wrong.
Roger
Deg Kelvin references differently. 0 deg Kelvin is the absolute zero. The point that every thermal motion stops. To convert it to Celsius, just add 273,15. So the 0 Celsius is 273,15 Kelvin and 0 Kelvin -273,15 celsius.
Ioannis
Thanks Ioannis.
This (schema) is where I have come up to now - using the simple simplest, maybe too simple (...) The opamp acts as a voltage doubler (seems enough for what I need).
BTW, I'm using a 16F690 with 10 bits ADC.
At 24°C, the LM35 outputs 1,199V so the opamp's Vout shows 2,396V.
Now, what is the LM35 going to output at 0°C or even less, around -20°C?
Since 1,199V represent 24°C, can I say that at 0°C, I will have 0,959Volts (LM35 Vout)?
Talking "temperature", what is the reference when adjusting temperature sensors at home?
Is it this?
Noooooooooooooo......
NB: You're absolutely right about Kelvins. In the field, talking with cooling systems engineers, to make sure we don't get messed up while setting up machines, we (wrongly) use Kelvins to express a temperature difference or threshold and degrees to set a temperature value![]()
Roger
I don't think it will work for minus temps the way you got it.
Your output as I said earlier, would be directly from the LM35, meaning from the output pin AND the GND pin of the LM35. NOT the circuit Ground.
Now, that leads us to another problem. Your new output will be 0 volts at 0 C, positive at positive temps but negative below zero (LM35 output would seem more negative than the LM35 ground). So the opamp would not be able to handle this negative voltageas you designed it.
You are going to need a differential amplifier, such as the first opamp in my design.
Ioannis
Okay,
I'll give a try to your circuit.
Will a LM358N opamp do the job or does it absolutely need to be LMC662?
Another thing, having in mind the accuracy I need is not that critical (+/- 2°C is okay), what is a "simple" way to measure a freezer's temperature?
Would a thermistor do the trick in an acceptable way too?
Roger
A thermistor is far from linear. I would not use it now, at least without first trying other things.
I came up with a simpler solution to your problem. Drop the op-amp and drive the LM35 output to one ADC of your PIC. Now drive the raised GND of the LM35 to another ADC input of your PIC.
Since the two voltages, referenced to ground, are positive, you can do a calculation in your program. (LM35output-LM35Gnd)*100 and you will have your temp. Be careful here because the subtraction will give you a negative result if the real temp is below zero.
So now you have a circuit absolutely minimal.
I would suggest to use a PIC with 10bits ADC and increase the resolution with oversampling to 12 bits with Darrel Taylor's oversampling routines when you have it working.
Ioannis
Thanks Ioannis,
You're right: less than that is almost impossible
I need to ADC measure the raised GND only once since it will never change - or am I missing something?Now drive the raised GND of the LM35 to another ADC input of your PIC
And "yes", for sure I'll have values to measure that will be below 0°C; in fact, they will have to be always under 0°C or I'll have a problem with the food inside the freezer![]()
Roger
The two diodes connected to the ground of LM35 will change their value due to temperature change.
So this is the reason for why two ADC channels are needed.
Since I'll have to locate the LM35 inside the freezer, shall I put these two diodes as close as possible to the LM35, meaning, the sensor and the diodes will be located inside the freezer? Or is it not necessary?
Roger
You got it right about the temp instability of the diodes.
And since both (diode and LM35) have positive coefficient regarding the temperature, i'd put both in the same thermal spot.
Remeber, NOT to use the LM35D
Ioannis
if you wire a lm335 like this
would not a adc reading of 512 = about -22C and a adc read of 569 = about 0 C
not very much resolution but workable
or am I missing something
Of course it it workable if you accept the 2,59 counts per degree. Noise will be an issue also and especially in this case I would insist on using oversampling to 12 bits to iron out the noise as much as possible.
Ioannis
with a bit of averaging or oversampling 0.5 resolution is achievable, the software solution is at least cheap and easy to try outhaving in mind the accuracy I need is not that critical (+/- 2°C is okay),
Hello,
I have built the circuit and I'm now testing.
I'll send some pictures from the the values I read from the LM35 in a moment - very strange values, not stable at all... :-(
Roger
Bookmarks