beautypg.com

Campbell Scientific CNR1 Net Radiometer User Manual

Page 36

background image

Appendix C. CR3000/CR5000 Program that Controls the Heater

BeginProg
Scan

(1,Sec,0,0)

'Control the net radiometer heater.

PWM

(duty_cycle,4,250,mSec)


'Datalogger

panel

temperature.

PanelTemp

(panel_temp,250)


'Measure

battery

voltage.

Battery

(batt_volt)


'Measure the HMP45C temperature and relative humidity.

VoltDiff

(t_hmp,1,mV1000C,5,TRUE,200,250,0.1,-40)

VoltDiff

(rh_hmp,1,mV1000C,6,TRUE,200,250,0.1,0)


'Measure NR 01 Net Radiometer.

Resistance

(t_nr01,1,mV200,10,Ix1,1,1675,TRUE,TRUE,200,250,1,0)

VoltDiff

(Rs_downwell,1,mV20C,11,TRUE,200,250,NR01_SHORT_DW_CAL,0)

VoltDiff

(Rs_upwell,1,mV20C,12,TRUE,200,250,NR01_SHORT_UW_CAL,0)

VoltDiff

(Rl_down_meas,1,mV20C,13,TRUE,200,250,NR01_LONG_DW_CAL,0)

VoltDiff

(Rl_up_meas,1,mV20C,14,TRUE,200,250,NR01_LONG_UW_CAL,0)


'Find the HMP45C vapor pressure and saturation vapor pressure (kPa).

VaporPressure

(e_hmp,t_hmp,rh_hmp)

SatVP

(e_sat_hmp,t_hmp)


'Compute net radiation, albedo, downwelling and upwelling longwave radiation.

t_nr01

=

t_nr01/100

PRT

(t_nr01,1,t_nr01,1,273.15)


Rn

=

Rs_downwell-Rs_upwell+Rl_down_meas-Rl_up_meas

albedo

=

Rs_upwell/Rs_downwell

Rl_downwell

=

Rl_down_meas+(5.67e-8*t_nr01*t_nr01*t_nr01*t_nr01)

Rl_upwell

=

Rl_up_meas+(5.67e-8*t_nr01*t_nr01*t_nr01*t_nr01)


CallTable

(scratch)

If

(

scratch.Output(1,1)

)

Then

GetRecord

(scratch_out(1),scratch,1)

rh_hmp_mean

=

100*e_hmp_mean/e_sat_hmp_mean

DewPoint

(t_dew_hmp_mean,t_hmp_mean,rh_hmp_mean)


'Control the NR 01 heater using 4 Hz pulse width modulation. Below the dew

' point temperature applies 100% power. Above the dew point, power is reduced

' linearly to 20% until the dew point plus DELTA_SET_POINT_1. After the dew

' point plus DELTA_SET_POINT_1 and until the dew point plus

'

DELTA_SET_POINT_2

plus

DELTA_SET_POINT_2, the power is reduced linearly to 0%.

If ( (t_nr01 <> NaN) AND (t_dew_hmp_mean <> NaN) AND (no_heat_flag <> TRUE) ) Then

set_point_temperature

=

t_dew_hmp_mean+273.15

Select Case t_nr01

Case

Is

<

(

set_point_temperature

)

duty_cycle

=

1

Case Is < ( set_point_temperature+DELTA_SET_POINT_1 )

duty_cycle

=

MAX_DUTY_CYCLE_1+(t_nr01-(t_dew_hmp_mean+273.15))*SLOPE_1

Case

Is

<

(

set_point_temperature+DELTA_SET_POINT_1+DELTA_SET_POINT_2

)

duty_cycle

=

MAX_DUTY_CYCLE_2+(t_nr01-

(t_dew_hmp_mean+273.15+DELTA_SET_POINT_1))*SLOPE_2

C-4