/*	**************************************************************	*/

/*
 * PARAM.H
 * This file contains parameters required by the measurement
 * program.
 *
 * Scott Anderson
 * 1/14/2015
 */
 
/* Protection from multiple definitions */
#ifndef __PARAM_HEADER
#define __PARAM_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
#define PSCII  3
/* Current system defines */
#define MAIN     0
#define VTRIM    1
#define HTRIM    2
/* TMAG Probe Type defines (see TMAG.h)*/
#define THERM_5K  0
#define THERM_10K 1
#define RTD_2W    2
#define RTD_4W    3
#define THERMOCPL 4

/* GPIB addresses */
#define GPIB_BOARD_ADDR					0
#define GPIB_PDI5025_ADDR				13
#define GPIB_HP3458_ADDR				24
#define GPIB_HP3457_ADDR				22
#define GPIB_HP34970_ADDR				9
#define GPIB_DAC488_ADDR				19
#define GPIB_DAC488HR_ADDR				8
#define GPIB_VRZ404a_ADDR				29
#define GPIB_VRZ404b_ADDR				30
#define GPIB_TELETRAC_ADDR				3
#define GPIB_K7011_ADDR					7 
#define GPIB_PM500_ADDR                 3
#define GPIB_HP5508_ADDR				3   

/* RS232 addresses */

#define RS232_COM_PORT  				3
#define RS232_ND720_ADDR				1
#define RS232_EV16P_ADDR				11    


/* Email Notification Settings*/
static char MAIL_TO[1000]		=		"sda@slac.stanford.edu";
#define MAIL_SEND_NOTIFICATION			0
#define MAIL_COMPUTER_ID				"MMF Field Integral"


/* Voltage integration system */
#define VTGAP_BOARD_ADDR				GPIB_BOARD_ADDR
#define VTGAP_PDI5025_ADDR				GPIB_PDI5025_ADDR
#define VTGAP_HP3458_ADDR				GPIB_HP3458_ADDR
#define VTGAP_HP34970_ADDR				GPIB_HP34970_ADDR 
#define VTGAP_PDI5025_CHANNEL			'A'
#define VTGAP_PDI5025_GAIN				1
#define VTGAP_HP3458_RANGE				1.
#define VTGAP_CONFIG					VTGAP_HP3458
#define VTGAP_T_SAMP_BEFORE			    2.0
#define VTGAP_T_SAMP_AFTER				1.0
#define VTGAP_DO_OFFSET_CORRECTION		VTGAP_TRUE
#define VTGAP_SHOW_UI					VTGAP_TRUE
#define VTGAP_NUM_SWITCH_CHAN 	         1; /* # of switch channels being used.  Only used if  VTGAP_HP3458_HP34970 set*/  
static int VTGAP_SWITCH_CHAN[] 	=	     {222}; /* Switch channel numbers  */
static char VTGAP_CHAN_NAME[][30] =      {"Calib"};   /* Chan name which is either Calibration or the name of undulator i.e. HXU_4

/* Magnet current */
#define IMAG_BOARD_ADDR					GPIB_BOARD_ADDR
#define IMAG_SHOW_UI		            FALSE 
#define IMAG_NUM_CURRENT_SYSTEMS		     1
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 (A) ", "HTrim (A) ", "VTrim"};
static int  IMAG_DAC_CONFIG[]	    =         {DAC_NONE, DAC_488, DAC_488};
static int  IMAG_READBACK_CONFIG[]		    = {READBACK_NONE, READBACK_HP34970, READBACK_HP34970}; 
static int IMAG_DAC488_PORT[]         	    = {2, 2, 3};
static int IMAG_DAC488HR_PORT[]		   		= {1, 2, 3};
static int IMAG_HP3457_CHAN[]		   		= {0, 1, 2};
static int IMAG_HP34970_CHAN[]		   		= {102, 102, 103};
static int IMAG_RAMP_STYLE[]		        = {COSINE, THREE_LINEAR, THREE_LINEAR};
static int IMAG_STAND_RAMP_STYLE[]		    = {LINEAR, LINEAR, LINEAR}; 
static int IMAG_BIPOLAR[]		            = {FALSE, TRUE, TRUE};
static double IMAG_PS_AMPS_PER_DAC_VOLT[]	= {1.20, 1.20, 1.20};  /* PS5, MCOR */
static double  IMAG_TRANS_VOLTS_PER_AMP[]	= {.08333333, .08333333, .08333333}; 
static double IMAG_MAX_CURR_LIMIT[]			= {12.1, 6.1, 1.};  /* Maximum current (A) setpoint allowed */
static double IMAG_MIN_CURR_LIMIT[]			= {-12.1,-6.1, -1.};  /* Minimum current (A) setpoint allowed */ 
static double IMAG_RAMP_RATE[]				= {1.0, 1.0, 0.2};   /* Standard Rate rate (A/s) for ramp functions */
static double IMAG_WAIT_AFTER_RAMP[]		= {10., 2., 2.};    /* Settle time (sec) after ramp is done */ 
static double IMAG_STAND_RAMP_RATE[]		= {1.0, 1.0, 0.2};   /* Standard Rate rate (A/s) for standardize functions */ 
static double IMAG_WAIT_AFTER_STAND_RAMP[]	= {10., 20., 1.};    /* Settle time (sec) after ramp is done */
static int  IMAG_INIT_ZERO_CURRENT_MEAS[]	= {FALSE, FALSE, FALSE};
static int  IMAG_INIT_TURN_ON[]				= {FALSE, FALSE, FALSE};
static double IMAG_INIT_TURN_ON_CURRENT[]	= {20., 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[]  = {3., 1., 1.}; /* Below this Current (A) the IMAG_CHECK_CURRENT_TOL check will not be performed  */
static double IMAG_CHECK_CURRENT_TOL_BALLPARK_LIM[]   = {1.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  */ 
static int  IMAG_SET_ZERO_OFFSET_CURRENT_FLAG[]	= {TRUE, TRUE, TRUE};
static double IMAG_SET_ZERO_OFFSET_CURRENT[]    = {0.000252705, 0.00033, 0.01};


/* 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_NONE
#define VMAG_K7011_CARD_NUM				1
#define VMAG_NUMBER_MEASUREMENTS		1
static int VMAG_PROBE_CHAN_NUM[] 	  =	{105};
static char VMAG_PROBE_NAME[][30]	  = {"Trim (V)"}; 
#define VMAG_SHOW_UI					VMAG_FALSE


/* 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_NONE
#define TMAG_K7011_CARD_NUM				1
#define TMAG_K7011_HP3457_CHAN			1
#define TMAG_SHOW_UI					TMAG_TRUE
#define TMAG_NUM_TMAG_PROBES			4
static int TMAG_PROBE_CHAN_NUM[] 	=	{102, 101, 103, 105, 104};
static int TMAG_PROBE_TYPE[] 	=		{THERM_10K, THERM_10K, THERM_10K, THERM_10K, THERM_5K};
static char TMAG_PROBE_NAME[][30] =     {"Lower_Module", "Lower_Jaw", "Ambient", "3458_Meas_Junction", "Walker_Meas_Junction"}; 
#define TMAG_LOW_CURRENT_MEAS           TMAG_FALSE
#define TMAG_COILS_MEAS_NUM				1
static int TMAG_PROBE_OVERTEMP_FLAG[] = {0,   0, 0, 0, 0};
static double TMAG_PROBE_OVERTEMP[] =   {30.0, 30.0, 30.0, 30.0, 30.0};



/* Xmag measurements */
#define XMAG_BOARD_ADDR					GPIB_BOARD_ADDR
#define XMAG_VRZ404a_ADDR				GPIB_VRZ404a_ADDR
#define XMAG_VRZ404b_ADDR				GPIB_VRZ404b_ADDR
#define XMAG_TELETRAC_ADDR				GPIB_TELETRAC_ADDR
#define XMAG_TELETRAC_AXIS				'X'
#define XMAG_DEVICE_TYPE				XMAG_NONE
#define XMAG_NUM_DEV					1
static char XMAG_DEV_NAME[][40] = {"Heidenhain +x position (um)"};


/* Position measurements */
#define POSITION_BOARD_ADDR					GPIB_BOARD_ADDR
#define POSITION_RS232_COM_PORT   			RS232_COM_PORT
#define POSITION_TELETRAC_ADDR				GPIB_TELETRAC_ADDR 
#define POSITION_HP5508_ADDR				GPIB_HP5508_ADDR 
#define POSITION_ND720_ADDR				    RS232_ND720_ADDR  
#define POSITION_EV16P_ADDR				    RS232_EV16P_ADDR 
#define POSITION_AXIS_1			            'X'
#define POSITION_AXIS_2		            	'Y' 
#define POSITION_DEVICE_TYPE				POSITION_NONE
#define POSITION_NUM_AXIS                    2
static int POSITION_AXIS_NUM[] =            {1,2};
static char POSITION_AXIS_NAME[][40] =      {"Downstream", "Upstream"};   

/* Ambient measurements */
#define AMBIENT_BOARD_ADDR				GPIB_BOARD_ADDR
#define AMBIENT_HP3457_ADDR				GPIB_HP3457_ADDR
#define AMBIENT_HP34970_ADDR			GPIB_HP34970_ADDR
#define AMBIENT_K7011_ADDR				GPIB_K7011_ADDR
#define AMBIENT_MEAS_SYSTEM				AMBIENT_NONE
#define AMBIENT_K7011_CARD_NUM			1
#define AMBIENT_K7011_HP3457_CHAN		1
#define AMBIENT_SHOW_UI					AMBIENT_FALSE
#define AMBIENT_NUM_SENSORS				4
static char AMBIENT_SENSOR_TYPE[][40] = {"AMBIENT_THERM_R37", "AMBIENT_THERM_R37", "AMBIENT_THERM_R37", "AMBIENT_THERM_R37"};
static int AMBIENT_SENSOR_CHAN_NUM[] = {102, 109, 111, 104};
static char AMBIENT_SENSOR_NAME[][50] = {"Magnet 22 Lower Jaw (C)", "Magnet 22 Upper Jaw (C)", "Beam Pipe Top Magnet 17", "Beam Pipe Bottom Magnet 17"};


/*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				5
//static double WATER_FREQUENCY_DIVIDER =			36.3241667;		 /*for TS 1*/
static double WATER_FREQUENCY_DIVIDER =			36.7666667;		 /*for TS 3*/
//static double WATER_FREQUENCY_DIVIDER	=		35.9808333;	     /*for TS 5*/
static double WATER_FLOW_DIVIDER =			5.8881;		 /*Nominal is 5.8881*/  
static char WATER_SENSOR_MULTIPLIER =		75.0;
static char WATER_SENSOR_TYPE[][30] = { "WATER_HPLEIGHTON_T", "WATER_HPLEIGHTON_T","WATER_HPASHCROFT_P", "WATER_HPASHCROFT_P", "WATER_HOFFER_FV"};
static int WATER_SENSOR_CHAN_NUM[] = {116, 117, 118, 119, 120};
static char WATER_SENSOR_NAME[][30] = { "Supply Temp(C)", "Return Temp(C)","Supply Pres(psi)", "Return Pres(psi)", "Flow Rate(gpm)"};
#define WATER_OVERTEMP_TEMP				55.0


/* Measurement parameters */
#define UND_GAP_DESIRED_MEAS  READ_ONLY_MEAS		 // enumeration with FULL_MEAS, READ_ONLY_MEAS, CALIB_MEAS
#define UND_GAP_INT_START_POS	            0.008  /*  Gap start point in meters */  
#define UND_GAP_INT_DIST_MOVE_UND_GAP		0.004  /*  Gap move in meters */  
#define UND_GAP_INT_NUM_MEASUREMENTS        10 					   
#define UND_GAP_INT_DELAY_BETWEEN_MEASUREMENTS    1   /* delay in seconds between measurements */
#define UND_GAP_INT_ITERATIONS               1    //  Number of measurement sets
#define UND_GAP_INT_DELAY_BETWEEN_SETS     2  /* delay in seconds between measurements */ 





/* End protection */
#endif
