
/*	**************************************************************	*/

/*
 * PARAM.H
 * This file contains parameters required by the measurement
 * program.
 *
 * Zachary Wolf
 * 12/20/00
 */
 
/* Protection from multiple definitions */
#ifndef __RTPARAM_HEADER
#define __RTPARAM_HEADER

#define TRUE 1
#define FALSE 0
/* Define Current DAC types */  
#define DAC_488 0
#define DAC_488HR 1 
#define DAC_MANUAL 2 
#define DAC_NONE 3 
/* Define Current Readback types */      
#define READBACK_HP3457 0
#define READBACK_HP34970 1 
#define READBACK_NONE 2 
/* Define Current Ramp types */
#define LINEAR 0
#define THREE_LINEAR 1
#define COSINE	2	  
/* Current system defines */
#define Main     0
#define Bucking  1
#define None2    2
#define None3    3 
/* Current system Pattern defines */ 
#define LIST 0
#define CALCULATED 1
 
/* GPIB addresses */
#define GPIB_BOARD_ADDR					0
#define GPIB_HP3457_ADDR				22
#define GPIB_K7011_ADDR					7
#define GPIB_DAC488_ADDR				19
#define GPIB_DAC488HR_ADDR				8
#define GPIB_HP3458_ADDR				24
#define GPIB_HP34970_ADDR				9

/* Email Notification Settings*/
static char MAIL_TO[1000]		=		"sda@slac.stanford.edu";
#define MAIL_SEND_NOTIFICATION			1
#define MAIL_COMPUTER_ID				"Maglab 2 Temp Run"

/* Magnet voltage measurements */
#define VMAG_BOARD_ADDR					GPIB_BOARD_ADDR
#define VMAG_HP3457_ADDR				GPIB_HP3457_ADDR
#define VMAG_K7011_ADDR					GPIB_K7011_ADDR
#define VMAG_HP34970_ADDR				GPIB_HP34970_ADDR
#define VMAG_DEVICE_TYPE				VMAG_HP34970
#define VMAG_K7011_CARD_NUM				1
#define VMAG_MEASUREMENT_NUMBER			2
static int VMAG_PROBE_CHAN_NUM[] 	=		{105, 107};
#define VMAG_SHOW_UI					VMAG_FALSE

/* Magnet current */
#define IMAG_BOARD_ADDR					GPIB_BOARD_ADDR
#define IMAG_SHOW_UI		            TRUE 
#define IMAG_NUM_CURRENT_SYSTEMS		     2
static int IMAG_DAC488_ADDR[]                = {GPIB_DAC488_ADDR, GPIB_DAC488_ADDR, GPIB_DAC488_ADDR};
static int IMAG_DAC488HR_ADDR[]			     = {GPIB_DAC488HR_ADDR, GPIB_DAC488HR_ADDR, GPIB_DAC488HR_ADDR};
static int IMAG_HP3457_ADDR[]				 = {GPIB_HP3457_ADDR, GPIB_HP3457_ADDR, GPIB_HP3457_ADDR}; 
static int IMAG_HP34970_ADDR[]			     = {GPIB_HP34970_ADDR, GPIB_HP34970_ADDR, GPIB_HP34970_ADDR};
static char IMAG_CURRENT_SYSTEM_NAME[][30]	= {"Main", "Bucking", "V Trim"};
static int  IMAG_DAC_CONFIG[]	    =         {DAC_488HR, DAC_488HR, DAC_488HR};
static int  IMAG_READBACK_CONFIG[]		    = {READBACK_HP34970, READBACK_HP34970, READBACK_HP3457}; 
static int IMAG_DAC488_PORT[]         	    = {1, 2, 3};
static int IMAG_DAC488HR_PORT[]		   		= {1, 2, 2};
static int IMAG_HP3457_CHAN[]		   		= {0, 1, 2};
static int IMAG_HP34970_CHAN[]		   		= {101, 102, 103};
static int IMAG_RAMP_STYLE[]		        = {THREE_LINEAR , THREE_LINEAR, THREE_LINEAR}; 
static int IMAG_BIPOLAR[]		            = {FALSE, FALSE, TRUE};
static double IMAG_PS_AMPS_PER_DAC_VOLT[]	= {120.14664,23.9929, 1.22755}; 
static double  IMAG_TRANS_VOLTS_PER_AMP[]	= {.01, 0.08, 0.01}; 
static double IMAG_MAX_CURR_LIMIT[]			= {380, 17., 1.};  /* Maximum current (A) setpoint allowed */
static double IMAG_MIN_CURR_LIMIT[]			= {0.0, 0.0, -1.};  /* Minimum current (A) setpoint allowed */ 
static double IMAG_RAMP_RATE[]				= {20., 2, 0.2};   /* Standard Rate rate (A/s) for ramp functions */
static double IMAG_WAIT_AFTER_RAMP[]		= {20., 20., 10.};    /* Settle time (sec) after ramp is done */ 
static double IMAG_STAND_RAMP_RATE[]		= {10.,  2, 0.2};   /* Standard Rate rate (A/s) for standardize functions */ 
static double IMAG_WAIT_AFTER_STAND_RAMP[]	= {20.,  20., 1.};    /* Settle time (sec) after ramp is done */
static int  IMAG_INIT_ZERO_CURRENT_MEAS[]	= {TRUE, TRUE, TRUE};
static int  IMAG_INIT_TURN_ON[]				= {FALSE, FALSE, FALSE};
static double IMAG_INIT_TURN_ON_CURRENT[]	= {0., 0., 0. };
static int  IMAG_INVERPOWER[]				= {FALSE, FALSE, FALSE};
static int  IMAG_CHECK_CURRENT[]			= {FALSE, FALSE, FALSE};  /*  Flag to check that deisred current = actual current to IMAG_CHECK_CURRENT_TOL level*/
static double IMAG_CHECK_CURRENT_TOL[]		= {0.01, 0.01, 0.01}; /* If (desired_current - actual_current)/desired_current > IMAG_CHECK_CURRENT_TOL imag will give an error */
static double IMAG_CHECK_CURRENT_TOL_LOWER_LIM[]  = {10., 1., 1.}; /* Below this Current (A) the IMAG_CHECK_CURRENT_TOL check will not be performed  */
static double IMAG_CHECK_CURRENT_TOL_BALLPARK_LIM[]   = {5.0, 0.5, 0.5}; /* If Current (A) is below IMAG_CHECK_CURRENT_TOL_LOWER_LIM and above IMAG_CHECK_CURRENT_BALLPARK_LIM the actual current needs to be within IMAG_BALLPARK_TOL (in Imag.h) of desired  */ 



/* Temperature measurements */
#define TMAG_BOARD_ADDR					GPIB_BOARD_ADDR
#define TMAG_HP3457_ADDR				GPIB_HP3457_ADDR
#define TMAG_HP34970_ADDR				GPIB_HP34970_ADDR
#define TMAG_K7011_ADDR					GPIB_K7011_ADDR
#define TMAG_DEVICE_TYPE				TMAG_HP34970
#define TMAG_K7011_CARD_NUM				1
#define TMAG_K7011_HP3457_CHAN			1
#define TMAG_SHOW_UI					TMAG_FALSE
#define TMAG_NUM_TMAG_PROBES			3
static int TMAG_PROBE_CHAN_NUM[] 	=		{109, 110, 111};
static char TMAG_PROBE_NAME[][30] = {"Return Water", "Return Water", "Supply Water"}; 
#define TMAG_LOW_CURRENT_MEAS           TMAG_FALSE
#define TMAG_COILS_MEAS_NUM				1
static int TMAG_PROBE_OVERTEMP_FLAG[] = {1,    1,   1};
static double TMAG_PROBE_OVERTEMP[] = {50.0,   50.0,  45.0};

/* Cart Measuerments */
#define WATER_BOARD_ADDR				GPIB_BOARD_ADDR
#define WATER_HP3457_ADDR				GPIB_HP3457_ADDR
#define WATER_HP3458_ADDR				GPIB_HP3458_ADDR
#define WATER_HP34970_ADDR				GPIB_HP34970_ADDR
#define WATER_K7011_ADDR				GPIB_K7011_ADDR
#define WATER_MEAS_SYSTEM				WATER_NONE
#define WATER_K7011_CARD_NUM			1
#define WATER_K7011_HP3457_CHAN		1
#define WATER_SHOW_UI					WATER_TRUE
#define WATER_DIFFERENCE				WATER_FALSE
#define WATER_NUM_SENSORS				0
//double WATER_FREQUENCY_DIVIDER =			36.3241667;		 /*for cart 1*/
//double WATER_FREQUENCY_DIVIDER =			36.7666667;		 /*for cart 2*/
static double WATER_FREQUENCY_DIVIDER	=		35.9808333;	     /*for cart 3*/
static char WATER_SENSOR_MULTIPLIER =		75.0;
static char WATER_SENSOR_TYPE[][30] = {"WATER_HPASHCROFT_P", "WATER_HPASHCROFT_P", "WATER_HPLEIGHTON_T", "WATER_HPLEIGHTON_T", "WATER_HOFFER_F"};
static int WATER_SENSOR_CHAN_NUM[] = {116, 117, 118, 119, 120};
static char WATER_SENSOR_NAME[][30] = {"Supply Pressure (psi)", "Supply Pressure (psi)", "Water Tempurature (C)", "Water Tempurature (C)", "Flow Rate (gpm)"};
#define WATER_OVERTEMP_TEMP				60

/* Measurement parameters */
#define RT_NUM_COILS					1
#define RT_LOW_CURRENT                  0
#define RT_TIME_BTWN_MEAS_SEC			60
#define RT_TIME_TO_MEASURE_SEC			7200
#define RT_R_DELTAR_OVER_DELTAT		    .00393


 /* Measurement parameters */
#define RT_TRANSFER_CURRENT_SYSTEM   Main
#define RT_CURRENT_SYSTEM_PATTERN  LIST    // LIST (list) or CALCULATED (Calculated in program) 
#define RT_WARMUP_TIME	           0 
#define RT_NUM_ITERATIONS  		   0
#define RT_TRIP_TEST	 0
static int RT_NUM_STAND_CYCLES[]	=  {0, 0, 0, 0};
static double RT_STAND_MAX[]	=	  {6.0, 0.0, 0.0, 0}; 
static double RT_STAND_MIN[]	=	  {-6.0, 0.0, 0.0, 0.0};
static double RT_WARMUP_CURRENT[]	 = {6.0, 6.0, 6.0, 6.0};


#define RT_NUM_LIST_CURRENT_COLUMNS 1
static int RT_NUM_TEST_CURRENTS[]  = {RT_NUM_LIST_CURRENT_COLUMNS,RT_NUM_LIST_CURRENT_COLUMNS,RT_NUM_LIST_CURRENT_COLUMNS, RT_NUM_LIST_CURRENT_COLUMNS};   

static double  RT_TEST_CURRENTS[IMAG_NUM_CURRENT_SYSTEMS][RT_NUM_LIST_CURRENT_COLUMNS] =  {{375.0}, 
																						   {16.3}};


/* Of interest */
// (1/R)(dR/dT) = .00393 for copper (1/C), from Dave
// (1/R)(dR/dT) = .00409 for aluminum (1/C), CRC EC grade Aluminum, from Cherrill
 
/* End protection */
#endif
