Owen's Notes: Difference between revisions

From EOVSA Wiki
Jump to navigation Jump to search
 
(87 intermediate revisions by 2 users not shown)
Line 18: Line 18:
Check that the data files are being updated. Goto the user@dpp terminal and type:
Check that the data files are being updated. Goto the user@dpp terminal and type:


:<p style="font-family:courier">ls /data1/IDB |tail</p>
<pre style="font-family:courier">ls /data1/IDB |tail</pre>
 
Check that the adc_plot.py program is running.


Regularly check to see if a flare is in progress (http://ovsa.njit.edu/status.php). If there is a flare in progress you may need to pause the schedule (http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Pausing_and_Adjusting_the_Schedule).
Regularly check to see if a flare is in progress (http://ovsa.njit.edu/status.php). If there is a flare in progress you may need to pause the schedule (http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Pausing_and_Adjusting_the_Schedule).


Perform a Phase Calibration
Perform a Phase Calibration


Check that the network monitoring function (fix_packets()) is working on the DPP. It can also be seen as dropouts on the spectrogram ([http://ovsa.njit.edu/status.php http://ovsa.njit.edu/status.php]).
Check that the network monitoring function (fix_packets()) is working on the DPP. It can also be seen as dropouts on the spectrogram ([http://ovsa.njit.edu/status.php http://ovsa.njit.edu/status.php]).
Line 52: Line 55:
To VNC into Helios, open a terminal and type the following command:
To VNC into Helios, open a terminal and type the following command:


:<p style="font-family:courier">ssh -L 5902:helios.solar.pvt:20000 oweng@ovsa.njit.edu</p>
<pre style="font-family:courier">ssh -L 5902:helios.solar.pvt:20000 oweng@ovsa.njit.edu</pre>


Note replace oweng with your gateway login name)
Note replace oweng with your gateway login name)
Line 58: Line 61:
Then open Remmina Remote Desktop Client. Make sure VNC is selected at the top left. Type in:
Then open Remmina Remote Desktop Client. Make sure VNC is selected at the top left. Type in:


:<p style="font-family:courier">localhost:2</p>
<pre style="font-family:courier">localhost:2</pre>


and enter the password when prompted.
and enter the password when prompted.
Line 68: Line 71:
From a new terminal window type:
From a new terminal window type:


:<p style="font-family:courier">ssh -L 8887:helios.solar.pvt:22 oweng@ovsa.njit.edu</p>
<pre style="font-family:courier">ssh -L 8887:helios.solar.pvt:22 oweng@ovsa.njit.edu</pre>


From another terminal issue the command:
From another terminal issue the command:


:<p style="font-family:courier">ssh -p 8887 sched@localhost</p>
<pre style="font-family:courier">ssh -p 8887 sched@localhost</pre>


Now type in:
Now type in:


:<p style="font-family:courier">x11go</p>
<pre style="font-family:courier">x11go</pre>


Now restart the VNC client.
Now restart the VNC client.
Line 85: Line 88:
To log in to pipeline, from a terminal enter the command:
To log in to pipeline, from a terminal enter the command:


:<p style="font-family:courier">ssh -L 8888:pipeline.solar.pvt:22 oweng@ovsa.njit.edu</p>
<pre style="font-family:courier">ssh -L 8888:pipeline.solar.pvt:22 oweng@ovsa.njit.edu</pre>


Then from a new terminal enter:
Then from a new terminal enter:


:<p style="font-family:courier">ssh -p 8888 user@localhost</p>
<pre style="font-family:courier">ssh -p 8888 user@localhost</pre>


==== Win1 ====
==== Win1 ====
To log in to the win1 machine, from a terminal enter the command:
To log in to the win1 machine, from a terminal enter the command:


:<p style="font-family:courier">ssh -L 8889:win1.solar.pvt:5900 oweng@ovsa.njit.edu</p>
<pre style="font-family:courier">ssh -L 8889:win1.solar.pvt:5900 oweng@ovsa.njit.edu</pre>


Then from a new VPN client enter the hostname:
Then from a new VPN client enter the hostname:


:<p style="font-family:courier">localhost:8889</p>
<pre style="font-family:courier">localhost:8889</pre>


==== DPP ====
==== DPP ====
To login to the DPP machine, from a terminal enter the command:
To login to the DPP machine, from a terminal enter the command:


:<p style="font-family:courier">ssh -L 8890:dpp.solar.pvt:5900 oweng@ovsa.njit.edu</p>
<pre style="font-family:courier">ssh -L 8890:dpp.solar.pvt:5900 oweng@ovsa.njit.edu</pre>


Then from a new terminal enter:
Then from a new terminal enter:


:<p style="font-family:courier">ssh -p 8900 user@localhost</p>
<pre style="font-family:courier">ssh -p 8900 user@localhost</pre>


=== Remote File Copy ===
=== Remote File Copy ===
To copy files using scp (SSH-COPY) through the above tunnels, use the command (this example for port 8888):
To copy files using scp (SSH-COPY) through the above tunnels, use the command (this example for port 8888):


:<p style="font-family:courier">scp -P 8888 user@localhost:<path and file to copy> <file destination></p>
<pre style="font-family:courier">scp -P 8888 user@localhost:<path and file to copy> <file destination></pre>


=== Local Login ===
=== Local Login ===
Line 121: Line 124:
Open the Remmina Remote Desktop Client. Make sure VNC is selected at the top left. Type in:
Open the Remmina Remote Desktop Client. Make sure VNC is selected at the top left. Type in:


:<p style="font-family:courier">helios:20000</p>
<pre style="font-family:courier">helios:20000</pre>


and enter the password when prompted.
and enter the password when prompted.
Line 129: Line 132:
To access a helios terminal, from a new terminal window type:
To access a helios terminal, from a new terminal window type:


:<p style="font-family:courier">ssh sched@helios</p>
<pre style="font-family:courier">ssh sched@helios</pre>


==== Pipeline ====
==== Pipeline ====
To log in to pipeline, from a terminal enter the command:
To log in to pipeline, from a terminal enter the command:


:<p style="font-family:courier">ssh user@pipeline</p>
<pre style="font-family:courier">ssh user@pipeline</pre>


==== Win1 ====
==== Win1 ====
To log in to the win1 machine, from a new VPN client enter the hostname:
To log in to the win1 machine, from a new VPN client enter the hostname:


:<p style="font-family:courier">win1</p>
<pre style="font-family:courier">win1</pre>


==== DPP ====
==== DPP ====
To login to the DPP machine, from a terminal enter the command:
To login to the DPP machine, from a terminal enter the command:


:<p style="font-family:courier">ssh user@dpp</p>
<pre style="font-family:courier">ssh user@dpp</pre>


<!--
<!--
Line 154: Line 157:


From a terminal issue the command:
From a terminal issue the command:
:<p style="font-family:courier">sudo useradd -m -d /opt/''username'' ''username''</p>
<pre style="font-family:courier">sudo useradd -m -d /opt/''username'' ''username''</pre>
where ''username'' is the name of the new account.
where ''username'' is the name of the new account.


You will be prompted to enter a password. If creating the account for someone else, ensure they change it after their first login. They can issue the command
You will be prompted to enter a password. If creating the account for someone else, ensure they change it after their first login. They can issue the command
:<p style="font-family:courier">passwd</p>
<pre style="font-family:courier">passwd</pre>


If creating the account on pipeline, they will probably need access to the python files located in :<span style="font-family:courier">/common/python/current/</span>
If creating the account on pipeline, they will probably need access to the python files located in :<span style="font-family:courier">/common/python/current/</span>


To set this up, edit the :<span style="font-family:courier">~/.bash_profile</span> using nano:
To set this up, edit the :<span style="font-family:courier">~/.bash_profile</span> using nano:
:<p style="font-family:courier">nano ~/.bash_profile</p>
<pre style="font-family:courier">nano ~/.bash_profile</pre>


Add the following line:
Add the following line:
:<p style="font-family:courier">export PYTHONPATH="/common/python/current":"/common/python/mapping"</p>
<pre style="font-family:courier">export PYTHONPATH="/common/python/current":"/common/python/mapping"</pre>


Press <CRTL> X to exit and when prompted press Y to save the file.
Press <CRTL> X to exit and when prompted press Y to save the file.


To immediately make the changes to effect issue the command:
To immediately make the changes to effect issue the command:
:<p style="font-family:courier">source ~/.bash_profile</p>
<pre style="font-family:courier">source ~/.bash_profile</pre>


If a user requires superuser privileges, from an account with superuser access enter the following:
If a user requires superuser privileges, from an account with superuser access enter the following:
:<p style="font-family:courier">sudo usermod -aG sudo ''user''</p>
<pre style="font-family:courier">sudo usermod -aG sudo ''user''</pre>


where ''user'' is the name of the account you are granting the privileges. -->
where ''user'' is the name of the account you are granting the privileges. -->
Line 181: Line 184:
=== Administrators ===
=== Administrators ===
Log in to the gate way machine and start a superuser prompt:
Log in to the gate way machine and start a superuser prompt:
:<p style="font-family:courier">su</p>
<pre style="font-family:courier">su</pre>


or  
or  
:<p style="font-family:courier">sudo su</p>
<pre style="font-family:courier">sudo su</pre>


Then issue the following commands:
Then issue the following commands:


:<p style="font-family:courier">useradd -m -s /bin/bash ''username''</p>
<pre style="font-family:courier">
:<p style="font-family:courier">usermod -a -G ''username'' ''username''</p>
useradd -m -s /bin/bash ''username''
:<p style="font-family:courier">cd /home/''username''</p>
usermod -a -G ''username'' ''username''
:<p style="font-family:courier">mkdir .ssh</p>
cd /home/''username''
:<p style="font-family:courier">chown ''username'' .ssh</p>
mkdir .ssh
:<p style="font-family:courier">chmod 700 .ssh</p>
chown ''username'' .ssh
chmod 700 .ssh
</pre>
   
   
Once the above commands have been entered, ask the user to send you the public ssh key. Once you have this issue the following commands:
Once the above commands have been entered, ask the user to send you the public ssh key. Once you have this issue the following commands:


:<p style="font-family:courier">echo "''public key''" > .ssh/authorized_keys</p>
<pre style="font-family:courier">
:<p style="font-family:courier">chmod 600 .ssh/authorized keys</p>
echo "''public key''" > .ssh/authorized_keys
chmod 600 .ssh/authorized keys
</pre>


Note that the public key will be be very long. There can be no new line in the key, and the key should start with 'ssh rsa'.
Note that the public key will be be very long. There can be no new line in the key, and the key should start with 'ssh rsa'.
Line 206: Line 213:
You must generate a pair of ssh keys to be able to access the gateway machine. From a command prompt issue the following command:
You must generate a pair of ssh keys to be able to access the gateway machine. From a command prompt issue the following command:


:<p style="font-family:courier">ssh-keygen</p>
<pre style="font-family:courier">ssh-keygen</pre>


This will generate a pair of keys in the .ssh folder. The id_rsa file is the private key. '''DO NOT SHARE YOUR PRIVATE KEY WITH ANYBODY!'''
This will generate a pair of keys in the .ssh folder. The id_rsa file is the private key. '''DO NOT SHARE YOUR PRIVATE KEY WITH ANYBODY!'''
Line 233: Line 240:


If this does not work then from a helios terminal type in the command:
If this does not work then from a helios terminal type in the command:
:<p style="font-family:courier">ps -elf | grep "schedule"</p>
<pre style="font-family:courier">ps -elf | grep "schedule"</pre>


An output similar to that below will be displayed:
An output similar to that below will be displayed:
Line 242: Line 249:


To terminate the program type:
To terminate the program type:
:<p style="font-family:courier">kill -9 PID#</p>
<pre style="font-family:courier">kill -9 PID#</pre>


where PID# is the number obtained from the ps command.
where PID# is the number obtained from the ps command.
Line 250: Line 257:


From a helios terminal issue the the command:
From a helios terminal issue the the command:
:<p style="font-family:courier">screen -ls</p>
<pre style="font-family:courier">screen -ls</pre>


This will list all of the available screens as shown below.
This will list all of the available screens as shown below.
Line 262: Line 269:
then issue the command:
then issue the command:


:<p style="font-family:courier">screen -r schedule</p>
<pre style="font-family:courier">screen -r schedule</pre>


to restore the current screen. Take a screen capture of the terminal window if there are any errors listed and send a copy to Owen or Dale.  
to restore the current screen. Take a screen capture of the terminal window if there are any errors listed and send a copy to Owen or Dale.  
Line 268: Line 275:
If it is not listed then issue the command:
If it is not listed then issue the command:


:<p style="font-family:courier">screen -S schedule</p>
<pre style="font-family:courier">screen -S schedule</pre>


to start a new screen.
to start a new screen.
Line 274: Line 281:
In either case once the screen is open change to the ~/Dropbox/PythonCode/Current directory:
In either case once the screen is open change to the ~/Dropbox/PythonCode/Current directory:


:<p style="font-family:courier">cd ~/Dropbox/PythonCode/Current</p>
<pre style="font-family:courier">cd ~/Dropbox/PythonCode/Current</pre>


Restart the schedule:
Restart the schedule:


:<p style="font-family:courier">python /common/python/current/schedule.py &</p>
<pre style="font-family:courier">python /common/python/current/schedule.py &</pre>


Press <CRTL>AD to exit from screen.
Press <CRTL>AD to exit from screen.
Line 303: Line 310:


From a helios terminal issue the the command:
From a helios terminal issue the the command:
:<p style="font-family:courier">screen -ls</p>
<pre style="font-family:courier">screen -ls</pre>


This will list all of the available screens as shown below.
This will list all of the available screens as shown below.
Line 315: Line 322:
then issue the command:
then issue the command:


:<p style="font-family:courier">screen -r stateframe</p>
<pre style="font-family:courier">screen -r stateframe</pre>


to restore the current screen. Take a screen capture of the terminal window if there are any errors listed and send a copy to Owen or Dale.  
to restore the current screen. Take a screen capture of the terminal window if there are any errors listed and send a copy to Owen or Dale.  
Line 321: Line 328:
In either case once the screen is open change to the ~/Dropbox/PythonCode/Current directory:
In either case once the screen is open change to the ~/Dropbox/PythonCode/Current directory:


:<p style="font-family:courier">cd ~/Dropbox/PythonCode/Current</p>
<pre style="font-family:courier">cd ~/Dropbox/PythonCode/Current</pre>


Restart the stateframe display:
Restart the stateframe display:


:<p style="font-family:courier">python /common/python/current/sf_display.py &</p>
<pre style="font-family:courier">python /common/python/current/sf_display.py &</pre>


Press <CRTL>AD to exit from screen.  
Press <CRTL>AD to exit from screen.  
Line 336: Line 343:
=== Helios ===
=== Helios ===
To restart Helios, at a terminal enter the command
To restart Helios, at a terminal enter the command
:<p style="font-family:courier">sudo reboot now</p>
<pre style="font-family:courier">sudo reboot now</pre>
and wait about 5 minutes for it to restart.
and wait about 5 minutes for it to restart.


Open a terminal and start the dropbox server:
Open a terminal and start the dropbox server:
:<p style="font-family:courier">python /home/sched/Downloads/dropbox.py start</p>
<pre style="font-family:courier">python /home/sched/Downloads/dropbox.py start</pre>


'''Important:''' Check to see if the time service is running. Enter the command:
'''Important:''' Check to see if the time service is running. Enter the command:
:<p style="font-family:courier">chronyc sourcestats</p>
<pre style="font-family:courier">chronyc sourcestats</pre>


If nothing is displayed, then the time service will need to be started by typing:
If nothing is displayed, then the time service will need to be started by typing:
:<p style="font-family:courier">sudo systemctl restart chrony.service</p>
<pre style="font-family:courier">sudo systemctl restart chrony.service</pre>


Start the x11vnc server by typing:
Start the x11vnc server by typing:
:<p style="font-family:courier">x11go</p>
<pre style="font-family:courier">x11go</pre>
 
Copy the acc0time.txt file to /tmp as follows:
 
<pre style="font-family:courier">cp /home/sched/Dropbox/PythonCode/Current/acc0time.txt /tmp/</pre>


Start the schedule as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Starting_the_schedule_window
Start the schedule as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Starting_the_schedule_window
Line 356: Line 367:


Open up a new terminal tab and log into the DPP by typing:
Open up a new terminal tab and log into the DPP by typing:
:<p style="font-family:courier">ssh user@dpp</p>
<pre style="font-family:courier">ssh user@dpp</pre>


Now issue the command:
Now issue the command:
:<p style="font-family:courier">ls /data1/IDB | tail 10</p>
<pre style="font-family:courier">ls /data1/IDB | tail 10</pre>


Open up a new terminal tab and log into the DPP as above.
Open up a new terminal tab and log into the DPP as above.
View the SMP_AFFINITY.sh by typing the command:
View the SMP_AFFINITY.sh by typing the command:
:<p style="font-family:courier">cat /home/user/test_svn/shell_scripts/SMP_AFFINITY.sh</p>
<pre style="font-family:courier">cat /home/user/test_svn/shell_scripts/SMP_AFFINITY.sh</pre>


Note down the two CPU's that are in use. Issue the following commands:
Note down the two CPU's that are in use. Issue the following commands:
:<p style="font-family:courier">ipython --pylab</p>
<pre style="font-family:courier">
:<p style="font-family:courier">import dpp_plot_packets as dpp</p>
ipython --pylab
:<p style="font-family:courier">dpp.fix_packets(cpu = [cpu1, cpu2])</p>
import dpp_plot_packets as dpp
dpp.fix_packets(cpu = [cpu1, cpu2])
</pre>


where cpu1 and cpu2 are the CPUs that were noted down earlier.
where cpu1 and cpu2 are the CPUs that were noted down earlier.
Line 377: Line 390:
First, check that the 10 Gb ethernet interfaces are present, by typing the command:
First, check that the 10 Gb ethernet interfaces are present, by typing the command:


:<p style="font-family:courier">ifconfig</p>
<pre style="font-family:courier">ifconfig</pre>


which should show a list of interfaces including enp5s0 and enp7s0. If these are NOT present, type:
which should show a list of interfaces including enp5s0 and enp7s0. If these are NOT present, type:


:<p style="font-family:courier">sudo modprobe myri10ge</p>
<pre style="font-family:courier">sudo modprobe myri10ge</pre>


to start the device driver. Then check again that these interfaces are present.
to start the device driver. Then check again that these interfaces are present.
Line 388: Line 401:
The adc_plot program will need to be restarted. To do this enter the command:
The adc_plot program will need to be restarted. To do this enter the command:


:<p style="font-family:courier">/bin/bash /home/user/test_svn/shell_scripts/adc_plot.sh > /dev/null &</p>
<pre style="font-family:courier">/bin/bash /home/user/test_svn/shell_scripts/adc_plot.sh > /dev/null &</pre>


==== Resetting the Interrupt Priority ====
==== Resetting the Interrupt Priority ====
The interrupt priority is now automatically reconfigured at startup. There is a 1 minute delay to allow drives to mount and other programs to load prior to the <span style="font-family:courier">dpp_fix_packets.py</span> program running. Output from the program can be viewed by accessing a DPP terminal and entering the command:
The interrupt priority is now automatically reconfigured at startup. There is a 1 minute delay to allow drives to mount and other programs to load prior to the <span style="font-family:courier">dpp_fix_packets.py</span> program running. Output from the program can be viewed by accessing a DPP terminal and entering the command:


:<p style="font-family:courier">screen -r fixpackets</p>
<pre style="font-family:courier">screen -r fixpackets</pre>


Significant information is also displayed on the stateframe display on Helios.
Significant information is also displayed on the stateframe display on Helios.
Line 399: Line 412:
==== Start Data Recording ====
==== Start Data Recording ====
To start data recording enter:
To start data recording enter:
:<p style="font-family:courier">rmlock</p>
<pre style="font-family:courier">rmlock</pre>


==== Mounting the dppdata1 disk ====
==== Mounting the dppdata1 disk ====
Note also that if the DPP reboots it is likely necessary to mount its disk on Pipeline, otherwise the pipeline task will fail. To check, log in to Pipeline and type df. The dppdata1 disk should be present. If it isn't, issue the command from pipeline:
Note also that if the DPP reboots it is likely necessary to mount its disk on Pipeline, otherwise the pipeline task will fail. To check, log in to Pipeline and type df. The dppdata1 disk should be present. If it isn't, issue the command from pipeline:


:<p style="font-family:courier">sudo mount -a</p>
<pre style="font-family:courier">sudo mount -a</pre>


=== ACC ===
=== ACC ===
Line 483: Line 496:
:<p>Using a text editor open the file <span style="font-family:courier">/home/sched/Dropbox/PythonCode/Current/solar.scd</span>. You should see the same list as in the schedule. An example is shown below.</p>
:<p>Using a text editor open the file <span style="font-family:courier">/home/sched/Dropbox/PythonCode/Current/solar.scd</span>. You should see the same list as in the schedule. An example is shown below.</p>


::<span style="font-family:courier">2021-03-29 10:06:58 ACQUIRE 1229+020</span>
<pre "font-family:courier">
::<span style="font-family:courier">2021-03-29 10:07:58 LOSELECT</span>
2021-03-29 10:06:58 ACQUIRE 1229+020
::<span style="font-family:courier">2021-03-29 10:10:58 PHASECAL_LO 1229+020 pcal_lo.fsq</span>
2021-03-29 10:07:58 LOSELECT
::<span style="font-family:courier">2021-03-29 10:30:58 HISELECT</span>
2021-03-29 10:10:58 PHASECAL_LO 1229+020 pcal_lo.fsq
::<span style="font-family:courier">2021-03-29 10:31:58 PHASECAL 1229+020 pcal_hi-all.fsq</span>
2021-03-29 10:30:58 HISELECT
::<span style="font-family:courier">2021-03-29 11:31:58 STOW</span>
2021-03-29 10:31:58 PHASECAL 1229+020 pcal_hi-all.fsq
::<span style="font-family:courier">2021-03-29 14:37:00 SUN</span>
2021-03-29 11:31:58 STOW
::<span style="font-family:courier">2021-03-29 15:10:00 ACQUIRE 2253+161</span>
2021-03-29 14:37:00 SUN
::<span style="font-family:courier">2021-03-29 15:14:00 PHASECAL 2253+161 pcal_hi-all.fsq</span>
2021-03-29 15:10:00 ACQUIRE 2253+161
::<span style="font-family:courier">2021-03-29 15:40:00 PHASECAL 2253+161 solar.fsq</span>
2021-03-29 15:14:00 PHASECAL 2253+161 pcal_hi-all.fsq
::<span style="font-family:courier">2021-03-29 15:41:00 SKYCALTEST 2253+161</span>
2021-03-29 15:40:00 PHASECAL 2253+161 solar.fsq
::<span style="font-family:courier">2021-03-29 15:45:00 SUN</span>
2021-03-29 15:41:00 SKYCALTEST 2253+161
::<span style="font-family:courier">2021-03-29 17:00:00 GAINCALTEST</span>
2021-03-29 15:45:00 SUN
::<span style="font-family:courier">2021-03-29 17:03:00 SUN</span>
2021-03-29 17:00:00 GAINCALTEST
::<span style="font-family:courier">2021-03-29 18:30:00 SOLPNTCAL solar.fsq solpnt.trj</span>
2021-03-29 17:03:00 SUN
::<span style="font-family:courier">2021-03-29 18:35:00 SUN</span>
2021-03-29 18:30:00 SOLPNTCAL solar.fsq solpnt.trj
::<span style="font-family:courier">2021-03-29 19:50:00 ACQUIRE 2253+161</span>
2021-03-29 18:35:00 SUN
::<span style="font-family:courier">2021-03-29 19:54:00 PHASECAL 2253+161 pcal_hi-all.fsq</span>
2021-03-29 19:50:00 ACQUIRE 2253+161
::<span style="font-family:courier">2021-03-29 20:25:00 SUN</span>
2021-03-29 19:54:00 PHASECAL 2253+161 pcal_hi-all.fsq
::<span style="font-family:courier">2021-03-29 21:30:00 SOLPNTCAL solar.fsq solpnt.trj</span>
2021-03-29 20:25:00 SUN
::<span style="font-family:courier">2021-03-29 21:35:00 SUN</span>
2021-03-29 21:30:00 SOLPNTCAL solar.fsq solpnt.trj
::<span style="font-family:courier">2021-03-30 00:10:00 ACQUIRE 0319+415</span>
2021-03-29 21:35:00 SUN
::<span style="font-family:courier">2021-03-30 00:14:00 PHASECAL 0319+415 pcal_hi-all.fsq</span>
2021-03-30 00:10:00 ACQUIRE 0319+415
::<span style="font-family:courier">2021-03-30 00:45:00 SUN</span>
2021-03-30 00:14:00 PHASECAL 0319+415 pcal_hi-all.fsq
::<span style="font-family:courier">2021-03-30 01:18:00 STOW</span>
2021-03-30 00:45:00 SUN
::<span style="font-family:courier">2021-03-30 04:12:55 ACQUIRE 1229+020</span>
2021-03-30 01:18:00 STOW
::<span style="font-family:courier">2021-03-30 04:13:55 LOSELECT</span>
2021-03-30 04:12:55 ACQUIRE 1229+020
::<span style="font-family:courier">2021-03-30 04:16:55 PHASECAL_LO 1229+020 pcal_lo.fsq</span>
2021-03-30 04:13:55 LOSELECT
::<span style="font-family:courier">2021-03-30 04:36:55 HISELECT</span>
2021-03-30 04:16:55 PHASECAL_LO 1229+020 pcal_lo.fsq
::<span style="font-family:courier">2021-03-30 04:37:55 PHASECAL 1229+020 pcal_hi-all.fsq</span>
2021-03-30 04:36:55 HISELECT
::<span style="font-family:courier">2021-03-30 05:37:55 STOW</span>
2021-03-30 04:37:55 PHASECAL 1229+020 pcal_hi-all.fsq
2021-03-30 05:37:55 STOW
</pre>


:<p>Remove any lines that you need to and then save the file, overwriting the existing <span style="font-family:courier">solar.scd</span> file.</p>
:<p>Remove any lines that you need to and then save the file, overwriting the existing <span style="font-family:courier">solar.scd</span> file.</p>
Line 527: Line 542:
:Ensure you are logged into a helios terminal and in the <span style="font-family:courier">Dropbox/PythonCode/Current</span> directory.
:Ensure you are logged into a helios terminal and in the <span style="font-family:courier">Dropbox/PythonCode/Current</span> directory.


:Access ipython: <span style="font-family:courier">ipython --pylab</span>
:Access ipython:
:<pre style="font-family:courier">ipython --pylab</pre>


:Enter the following commands:
:Enter the following commands:
::<pre style="font-family:courier">
import whenup
from util import Time</span>
whenup.make_sched(t=Time('yyyy-mm-dd'))
</pre>


::<span style="font-family:courier">import whenup</span>
:where <span style="font-family:courier">yyyy</span> is the year, <span style="font-family:courier">mm</span> is the month and <span style="font-family:courier">dd</span> is the day. For example to view the schedule for 2021-08-26 you would enter:


::<span style="font-family:courier">from util import Time</span>
::<pre style="font-family:courier">whenup.make_sched(t=Time('2021-08-26'))</pre>


::<span style="font-family:courier">whenup.make_sched(t=Time('yyyy-mm-dd'))</span>
:The output of this command is given below:


:where <span style="font-family:courier">yyyy</span> is the year, <span style="font-family:courier">mm</span> is the month and <span style="font-family:courier">dd</span> is the day. For example to view the schedule for 2021-08-26 you would enter:
<pre style="font-family:courier">
['2021-08-26 11:14:02 ACQUIRE 0319+415',
'2021-08-26 11:15:02 LOSELECT',
'2021-08-26 11:18:02 PHASECAL_LO 0319+415 pcal_lo.fsq',
'2021-08-26 11:38:02 HISELECT',
'2021-08-26 11:39:02 PHASECAL 0319+415 pcal_hi-all.fsq',
'2021-08-26 12:39:02 STOW',
'2021-08-26 14:14:00 SUN',
'2021-08-26 15:10:00 ACQUIRE 0319+415',
'2021-08-26 15:14:00 PHASECAL 0319+415 pcal_hi-all.fsq',
'2021-08-26 15:40:00 PHASECAL 0319+415 solar.fsq',
'2021-08-26 15:41:00 SKYCALTEST 0319+415',
'2021-08-26 15:45:00 SUN',
'2021-08-26 17:00:00 GAINCALTEST',
'2021-08-26 17:03:00 SUN',
'2021-08-26 18:30:00 SOLPNTCAL solar.fsq solpnt.trj',
'2021-08-26 18:35:00 SUN',
'2021-08-26 19:50:00 ACQUIRE 1229+020',
'2021-08-26 19:54:00 PHASECAL 1229+020 pcal_hi-all.fsq',
'2021-08-26 20:25:00 SUN',
'2021-08-26 21:30:00 SOLPNTCAL solar.fsq solpnt.trj',
'2021-08-26 21:35:00 SUN',
'2021-08-27 00:10:00 ACQUIRE 1229+020',
'2021-08-27 00:14:00 PHASECAL 1229+020 pcal_hi-all.fsq',
'2021-08-27 00:45:00 SUN',
'2021-08-27 01:36:00 STOW',
'2021-08-27 04:50:02 ACQUIRE 2253+161',
'2021-08-27 04:51:02 LOSELECT',
'2021-08-27 04:54:02 PHASECAL_LO 2253+161 pcal_lo.fsq',
'2021-08-27 05:14:02 HISELECT',
'2021-08-27 05:15:02 PHASECAL 2253+161 pcal_hi-all.fsq',
'2021-08-27 06:15:02 STOW']
</pre>
 
If needed, this can be copied and pasted into the <span style="font-family:courier">solar.scd</span> file. This is especially useful if the schedule needs to be restarted towards the end of the day. In this case (depending on time of year), the schedule program may load the schedule for the following day. If this occurs and you want to resume the schedule, use <span style="font-family:courier">whenup</span> with the previous days date and copy the output into the <span style="font-family:courier">solar.scd</span> file. Make sure you remove all leading spaces, brackets, commas and quotes. Save the file and load the <span style="font-family:courier">solar.scd</span> from the schedule and click <span style="font-family:courier">GO</span>.
 
== Checking the adc_plot.py Program ==
The <span style="font-family:courier">adc_plot.py</span> program controls the backend gains. This must remain running. To check if it running follow the following procedure:
 
:From the DPP, issue the command:
 
:<pre style="font-family:courier">ls /tmp/*.npy | tail</pre>
 
:The list of files will be of the form <span style="font-family:courier">ADCplotYYYYMMDD_HHMM.npy</span>. The most recent date should be the current day's date.
 
:If the file is not current then issue the command:
 
:<pre style="font-family:courier">ps -elf | grep adc</pre>
 
:The output of this command should look similar to:
 
<pre style="font-family:courier">
0 S user    18108 23862  0  80  0 -  2900 wait  20:56 pts/2    00:00:00 /bin/bash /home/user/test_svn/shell_scripts/adc_plot.sh
0 S user    18109 18108 35  80  0 - 708344 poll_s 20:56 pts/2  00:21:57 /common/anaconda2/bin/python /common/python/current/adc_plot.py
1 S user    26081    1  0  80  0 -  7607 poll_s Mar30 ?        00:00:00 SCREEN -S adc_plot
0 S user    27917 18481  0  80  0 -  3285 pipe_w 21:57 pts/6    00:00:00 grep --color=auto adc
</pre>
 
:If <span style="font-family:courier">/common/anaconda2/bin/python /common/python/current/adc_plot.py</span> is at the end of the line and the <span style="font-family:courier">.npy</span> file for the current day is NOT present then issue the command:
 
:<pre style="font-family:courier">kill -9 #####</span>
 
:where ##### is the PID, column 4 of the output above.
 
:Then issue the command:


::<span style="font-family:courier">whenup.make_sched(t=Time('2021-08-26'))</span>
:<pre style="font-family:courier">/bin/bash /home/user/test_svn/shell_scripts/adc_plot.sh</pre>


:The output of this command is given below:
:Wait about a minute and then run


::<span style="font-family:courier">['2021-08-26 11:14:02 ACQUIRE 0319+415',</span>
:<span style="font-family:courier">ls /tmp/*.npy | tail</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 11:15:02 LOSELECT',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 11:18:02 PHASECAL_LO 0319+415 pcal_lo.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 11:38:02 HISELECT',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 11:39:02 PHASECAL 0319+415 pcal_hi-all.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 12:39:02 STOW',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 14:14:00 SUN',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 15:10:00 ACQUIRE 0319+415',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 15:14:00 PHASECAL 0319+415 pcal_hi-all.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 15:40:00 PHASECAL 0319+415 solar.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 15:41:00 SKYCALTEST 0319+415',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 15:45:00 SUN',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 17:00:00 GAINCALTEST',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 17:03:00 SUN',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 18:30:00 SOLPNTCAL solar.fsq solpnt.trj',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 18:35:00 SUN',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 19:50:00 ACQUIRE 1229+020',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 19:54:00 PHASECAL 1229+020 pcal_hi-all.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 20:25:00 SUN',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 21:30:00 SOLPNTCAL solar.fsq solpnt.trj',</span>
::<span style="font-family:courier">&nbsp;'2021-08-26 21:35:00 SUN',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 00:10:00 ACQUIRE 1229+020',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 00:14:00 PHASECAL 1229+020 pcal_hi-all.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 00:45:00 SUN',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 01:36:00 STOW',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 04:50:02 ACQUIRE 2253+161',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 04:51:02 LOSELECT',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 04:54:02 PHASECAL_LO 2253+161 pcal_lo.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 05:14:02 HISELECT',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 05:15:02 PHASECAL 2253+161 pcal_hi-all.fsq',</span>
::<span style="font-family:courier">&nbsp;'2021-08-27 06:15:02 STOW']</span>


If needed, this can be copied and pasted into the <span style="font-family:courier">solar.scd</span> file. This is especially useful if the schedule needs to be restarted towards the end of the day. In this case (depending on time of year), the schedule program may load the schedule for the following day. If this occurs and you want to resume the schedule, use <span style="font-family:courier">whenup</span> with the previous days date and copy the output into the <span style="font-family:courier">solar.scd</span> file. Make sure you remove all leading spaces, brackets, commas and quotes. Save the file and load the <span style="font-family:courier">solar.scd</span> from the schedule and click <span style="font-family:courier">GO</span>.
:and ensure there is a <span style="font-family:courier">.npy</span> file for the current day.


== Calibrations ==
== Calibrations ==
Line 585: Line 640:
At the prompt type the following command:
At the prompt type the following command:


:<p style="font-family:courier">python /common/python/current/calwidget.py</p>
<pre style="font-family:courier">python /common/python/current/calwidget.py</pre>


The following window will open up:
The following window will open up:
Line 650: Line 705:
Log in to pipeline and issue the command:
Log in to pipeline and issue the command:


<p style="font-family:courier">cat /data1/processing/LOG/udb_process_log.txt_''yyyymmdd'' | tail</p>
<pre style="font-family:courier">cat /data1/processing/LOG/udb_process_log.txt_''yyyymmdd'' | tail</pre>


where <span style="font-family:courier">''yyyymmdd''</span> is the year month and day of the calibration data.
where <span style="font-family:courier">''yyyymmdd''</span> is the year month and day of the calibration data.
Line 656: Line 711:
If more than 5 lines similar to the output shown below are present, then the lock file will need to be removed.
If more than 5 lines similar to the output shown below are present, then the lock file will need to be removed.


:<p style="font-family:courier">Fri Jan 22 15:35:01 2021 /data1/processing/udb_process.lock  Exists, returning</p>
<pre style="font-family:courier">
:<p style="font-family:courier">Fri Jan 22 15:40:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 15:35:01 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 15:45:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 15:40:02 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 15:50:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 15:45:02 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 15:55:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 15:50:02 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 16:00:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 15:55:02 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 16:05:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 16:00:02 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 16:10:01 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 16:05:02 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 16:15:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 16:10:01 2021 /data1/processing/udb_process.lock  Exists, returning
:<p style="font-family:courier">Fri Jan 22 16:20:02 2021 /data1/processing/udb_process.lock  Exists, returning</p>
Fri Jan 22 16:15:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 16:20:02 2021 /data1/processing/udb_process.lock  Exists, returning
</pre>


To remove the lock file simply type:
To remove the lock file simply type:
:<p style="font-family:courier">rmlock</p>
<pre style="font-family:courier">rmlock</pre>


Processing should then resume.
Processing should then resume.
Line 696: Line 753:


From the Schedule window issue the following commands:
From the Schedule window issue the following commands:
:<p style="font-family:courier">$scan-stop</p>
<pre style="font-family:courier">
:<p style="font-family:courier">stow</p>
$scan-stop
:<p style="font-family:courier">femauto-off</p>
stow
:<p style="font-family:courier">femattn 0</p>
femauto-off
:<p style="font-family:courier">$fem-init</p>
femattn 0
$fem-init
</pre>


Wait approximately 1 minute for the new settings to update. The frontend power levels should be between 1-4 dBm. If they aren't then reissue the <span style="font-family:courier">$fem-init</span> command
Wait approximately 1 minute for the new settings to update. The frontend power levels should be between 1-4 dBm. If they aren't then reissue the <span style="font-family:courier">$fem-init</span> command


Then proceed with:
Then proceed with:
:<p style="font-family:courier">$subarray1 ant1-14</p>
<pre style="font-family:courier">$subarray1 ant1-14
:<p style="font-family:courier">dcmauto-off ant1-14</p>
dcmauto-off ant1-14
:<p style="font-family:courier">fseq-file solar.fsq</p>
fseq-file solar.fsq
:<p style="font-family:courier">fseq-on</p>
fseq-on
:<p style="font-family:courier">$capture-1s dcm</p>
$capture-1s dcm
</pre>


Click on the Clear button and then the Go button.
Click on the Clear button and then the Go button.
Line 715: Line 775:
From a pipeline terminal issue the following commands
From a pipeline terminal issue the following commands


:<p style="font-family:courier">ipython --pylab</p>
<pre style="font-family:courier">ipython --pylab
:<p style="font-family:courier">import roachcal</p>
import roachcal
:<p style="font-family:courier">tbl=roachcal.DCM_calnew('/dppdata1/PRT/PRTyyyymmddhhmmssdcm.dat',dcmattn=10,missing='ant15')</p>
tbl=roachcal.DCM_calnew('/dppdata1/PRT/PRTyyyymmddhhmmssdcm.dat',dcmattn=10,missing='ant15')
 
</pre>
In the above command yyyymmddhhmmss is the year, month, day, hour minute and second of the dcm file. Pressing tab will complete the filename. for the missing field, antenna 15 must be included. Add any other antennas that are not to be included on the gain calibration separated by spaces.
In the above command yyyymmddhhmmss is the year, month, day, hour minute and second of the dcm file. Pressing tab will complete the filename. for the missing field, antenna 15 must be included. Add any other antennas that are not to be included on the gain calibration separated by spaces.


Enter
Enter
:<p style="font-family:courier">tbl</p>
<pre style="font-family:courier">tbl</pre>


to view the contents of the tbl variable that was just created.
to view the contents of the tbl variable that was just created.


Band 1 has recently had bad attenuations. To use older good values for this band issue the command:
Band 1 has recently had bad attenuations. To use older good values for this band issue the command:
:<p style="font-family:courier">tbl = roachcal.override(tbl, bandlist=[1])</p>
<pre style="font-family:courier">tbl = roachcal.override(tbl, bandlist=[1])</pre>


Other bands can be excluded by adding the bands to the bandlist (space separated).
Other bands can be excluded by adding the bands to the bandlist (space separated).
Line 733: Line 793:
It is useful to compare the new table with an existing table to check for errors/glitches. To do this issue the command:
It is useful to compare the new table with an existing table to check for errors/glitches. To do this issue the command:


:<p style="font-family:courier">roachcal.compare_tbl(tbl, t=Time('2020-05-08'))</p>
<pre style="font-family:courier">roachcal.compare_tbl(tbl, t=Time('2020-05-08'))</pre>


Replace the time with the previous days gain calibration. All of the differences should be close to zero.
Replace the time with the previous days gain calibration. All of the differences should be close to zero.


Finally:
Finally:
:<p style="font-family:courier">import cal_header</p>
<pre style="font-family:courier">
:<p style="font-family:courier">cal_header.dcm_master_tablesql(tbl)</p>
import cal_header
cal_header.dcm_master_tablesql(tbl)
</pre>


From the Schedule window click the Stop button and then the Go button.
From the Schedule window click the Stop button and then the Go button.


In the schedule command box enter the command
In the schedule command box enter the command
:<p style="font-family:courier">$scan-start</p>
<pre style="font-family:courier">$scan-start</pre>


=== Total Power Calibration ===
=== Frontend Benchtest ===
The Power calibration is performed whenever components are replaced in the receiver. For a description of how to service the receiver see [[http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Receiver_Trouble_Shooting_and_Repair]].
The Benchtest is performed whenever components are replaced in the receiver. For a description of how to service the receiver see [[http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Receiver_Trouble_Shooting_and_Repair]].


==== Setup ====
==== Setup ====
Line 777: Line 839:
Edit the first line so that the correct antenna is present. For example, if antenna 5 is to be calibrated then the first line should read similar to:
Edit the first line so that the correct antenna is present. For example, if antenna 5 is to be calibrated then the first line should read similar to:


<p style="font-family:courier">1 2019-11-08 12:07:00 FEMBENCHTEST ant5</p>
<pre style="font-family:courier">1 2019-11-08 12:07:00 FEMBENCHTEST ant5</pre>


Once edited, save and close the file.
Once edited, save and close the file.
Line 815: Line 877:
From ipython, enter the following commands:
From ipython, enter the following commands:


<p style="font-family:courier">import fem_cal as fc</p>
<pre style="font-family:courier">
 
import fem_cal as fc
<p style="font-family:courier">import crio</p>
import crio
 
fc.fem_cal(ant
<p style="font-family:courier">fc.fem_cal(ant)</p>
</pre>


where ant is the antenna number for the particular calibration.
where ant is the antenna number for the particular calibration.
Line 827: Line 889:
To retrieve the crio.ini file for a given antenna issue the following command in ipython:
To retrieve the crio.ini file for a given antenna issue the following command in ipython:


<p style="font-family:courier">crio.save_crio_ini(ant_str='ant#')</p>
<pre style="font-family:courier">crio.save_crio_ini(ant_str='ant#')</pre>


where # is the antenna number. Press CRTL Z to exit ipython temporarily.
where # is the antenna number. Press CRTL Z to exit ipython temporarily.
Line 835: Line 897:
Finally enter the command
Finally enter the command


<p style="font-family:courier">crio.reload_crio_ini(ant_str='ant#')</p>
<pre style="font-family:courier">crio.reload_crio_ini(ant_str='ant#')</pre>


=== Update Antenna Pointing ===
=== Update Antenna Pointing ===
Line 843: Line 905:
From the terminal, start ipython:
From the terminal, start ipython:


:<p style="font-family:courier">ipython --pylab</p>
<pre style="font-family:courier">ipython --pylab</pre>


Import the calibration and Time libraries:
Import the solpnt_x and Time libraries:
<pre style="font-family:courier">
import solpnt_x as sx
from util import Time
</pre>


:<p style="font-family:courier">import calibration as cal</p>
Load up the solar pointing scans for a given date and time.
:<p style="font-family:courier">from util import Time</p>


Load up the solar pointing scans for a given date and time.
<pre style="font-family:courier">
tsolpnt = Time('yyyy-mm-dd HH:MM:SS')
solout = sx.solpnt_xanal(tsolpnt)
</pre>


:<p style="font-family:courier">x,y,qual=cal.solpntanal(Time('2020-03-17 18:30'))</p>
To view the beam widths as a function of frequency for each antenna and polarisation:


The above command will load the scans from the 17 March 2020 18:30 UT.
<pre style="font-family:courier">sx.solpnt_bsize(solout)</pre>


To view the beam widths as a function of frequency for each antenna and polarisation:
[[File:Ant4 Bsize.png]]


:<p style="font-family:courier">cal.sp_bsize(x,y)</p>
[[File:Example-X-BW.png|200px|thumb|right|An example of the X-beam widths for each antenna]]
[[File:Example-X-BW.png|200px|thumb|right|An example of the Y-beam widths for each antenna]]
To obtain the pointing offsets:
To obtain the pointing offsets:


:<p style="font-family:courier">xoff,yoff,dx,dy=cal.sp_offsets(x,y)</p>
<pre style="font-family:courier">offsets = sx.solpnt_offsets(solout)</pre>


This will display the offsets for each antenna and feed. Ideally the offsets should be at zero. If particular antennas significantly deviate from zero then a correction can be made.
This will display the current pointing positions of each antenna. Ideally each antenna should be pointing at the center of the disk. If particular antennas significantly deviate from the center then a correction can be made.
 
[[File: Pointing_offsets.png]]
 
[[File: Pointing_offsets2.png]]


For example, the following command will adjust the pointing offsets for antennas 6 to 8, 10 and 13:
For example, the following command will adjust the pointing offsets for antennas 6 to 8, 10 and 13:


:<p style="font-family:courier">cal.offsets2ants(Time('2020-03-17 18:30'),xoff,yoff,ant_str='ant6 ant7 ant8 ant10 ant13')</p>
<pre style="font-family:courier">sx.offsets2ants(offsets, ant_str='ant6 ant7 ant8 ant10 ant13')</pre>


The newer antennas with the alt-az drives that have had tracking updated will need to be rebooted. From the Schedule Window issue the commands:
The newer antennas with the alt-az drives that have had tracking updated will need to be rebooted. From the Schedule Window issue the commands:


:<p style="font-family:courier">reboot 1 ant6-8</p>
<pre style="font-family:courier">
 
reboot 1 ant6-8</pre>
:<p style="font-family:courier">tracktable sun_tab.radec 1 ant6-8</p>
tracktable sun_tab.radec 1 ant6-8
 
track ant6-8
:<p style="font-family:courier">track ant6-8</p>
</pre>


The antenna pointing adjustment is typically performed once per month.
The antenna pointing adjustment is typically performed once per month.
Line 886: Line 955:
From a helios terminal enter the following commands:
From a helios terminal enter the following commands:


:<p style="font-family:courier">ipython --pylab</p>
<pre style="font-family:courier">
ipython --pylab
from util import Time
import dbutil as db
trange = Time([datestr1,datestr2]).lv.astype(int)
query = 'select Timestamp,Ante_Cont_PointingCoefficient1,Ante_Cont_PointingCoefficient7 from fV66_vD15 where I15 = # and (cast(Timestamp as bigint) % 86400) = 100 and Timestamp between ' + str(trange[0]) + ' and ' + str(trange[1]) + ' order by Timestamp'
data, msg = db.do_query(cursor,query)
n = len(data['Timestamp'])
for i in range(n):
    print Time(data['Timestamp'][i],format='lv').iso,data['Ante_Cont_PointingCoefficient1'][i],data['Ante_Cont_PointingCoefficient7'][i]
</pre>


:<p style="font-family:courier">from util import Time</p>
Here <span style="font-family:courier">datestr1</span> and <span style="font-family:courier">datestr</span> is the range of times that are to be searched in the form <span style="font-family:courier">yyyy-mm-dd HH:MM</span> and <span style="font-family:courier">#</span> is the antenna number-1


:<p style="font-family:courier">import dbutil as db</p>
The above code will display a list of pointing coefficients. Select a suitable pair and then from the schedule issue the commands:


:<p style="font-family:courier">trange = Time([datestr1,datestr2]).lv.astype(int)</p>
<pre style="font-family:courier">
pointingcoefficient1 xxx ant#
pointingcoefficient7 xxx ant#
</pre>


:<p style="font-family:courier">query = 'select Timestamp,Ante_Cont_PointingCoefficient1,Ante_Cont_PointingCoefficient7 from fV66_vD15 where I15 = # and (cast(Timestamp as bigint) % 86400) = 100 and Timestamp between ' + str(trange[0]) + ' and ' + str(trange[1]) + ' order by Timestamp'</p>
where <span style="font-family:courier">xxx</span> are the new pointing coefficients and :<span style="font-family:courier">#</span> is the antenna number.
 
:<p style="font-family:courier">data, msg = db.do_query(cursor,query)</p>
 
:<p style="font-family:courier">n = len(data['Timestamp'])</p>
 
:<p style="font-family:courier">for i in range(n):</p>                           
::<p style="font-family:courier">    print Time(data['Timestamp'][i],format='lv').iso,data['Ante_Cont_PointingCoefficient1'][i],data['Ante_Cont_PointingCoefficient7'][i]</p>
 
Here <span style="font-family:courier">datestr1</span> and <span style="font-family:courier">datestr</span> is the range of times that are to be searched in the form <span style="font-family:courier">yyyy-mm-dd HH:MM</span> and <span style="font-family:courier">#</span> is the antenna number-1
 
The above code will display a list of pointing coefficients. Select a suitable pair and then from the schedule issue the commands:
 
:<p style="font-family:courier">pointingcoefficient1 xxx ant#</p>
:<p style="font-family:courier">pointingcoefficient7 xxx ant#</p>
 
where <span style="font-family:courier">xxx</span> are the new pointing coefficients and :<span style="font-family:courier">#</span> is the antenna number.


==== Star Pointing for the 2m Antennas ====
==== Star Pointing for the 2m Antennas ====
Line 926: Line 992:


Enter the following commands:
Enter the following commands:
:<p style="font-family:courier">ipython --pylab</p>
<pre style="font-family:courier">
:<p style="font-family:courier">import readbsc as rb</p>
ipython --pylab
:<p style="font-family:courier">rb.do_stars(Y,M,D,h,m,npts=n)</p>
import readbsc as rb
rb.do_stars(Y,M,D,h,m,npts=n)
</pre>


where Y,M,D,h,m are the year, month, day, hour, minute and second of the start of the observations, and npts is the number of points to observe (you will probably need about 50).
where Y,M,D,h,m are the year, month, day, hour, minute and second of the start of the observations, and npts is the number of points to observe (you will probably need about 50).
Line 938: Line 1,006:
Enter <span style="font-family:courier">nano STARS.ctl</span> to edit this file. You should see text similar to:
Enter <span style="font-family:courier">nano STARS.ctl</span> to edit this file. You should see text similar to:


:<p style="font-family:courier">$SCAN-STOP</p>
<pre style="font-family:courier">
:<p style="font-family:courier">SUBARRAY1 ant7</p>
$SCAN-STOP
:<p style="font-family:courier">TRACKTABLE startracktable.radec</p>
SUBARRAY1 ant7
:<p style="font-family:courier">TRACK</p>
TRACKTABLE startracktable.radec
TRACK
</pre>


Change the antenna number to the antenna that the telescope is attached to. Press [CRTL X] to exit and press [Y] to save the file.
Change the antenna number to the antenna that the telescope is attached to. Press [CRTL X] to exit and press [Y] to save the file.
Line 947: Line 1,017:
Enter <span style="font-family:courier">nano starpointing.scd</span> to edit the starpointing.scd file (example below).
Enter <span style="font-family:courier">nano starpointing.scd</span> to edit the starpointing.scd file (example below).


:<p style="font-family:courier">2021-05-30 03:30:00 STARS</p>
<pre style="font-family:courier">
:<p style="font-family:courier">2021-05-30 09:30:00 REWIND</p>
2021-05-30 03:30:00 STARS
2021-05-30 09:30:00 REWIND
</pre>


Change the date to the date at which you want to start observations. Press [CRTL X] to exit and press [Y] to save the file.
Change the date to the date at which you want to start observations. Press [CRTL X] to exit and press [Y] to save the file.
Line 1,056: Line 1,128:


From a helios terminal, view the <span style="font-family:courier">calpnt48.scd</span> file by issuing the command:
From a helios terminal, view the <span style="font-family:courier">calpnt48.scd</span> file by issuing the command:
:<p style="font-family:courier">cat /home/sched/Dropbox/PythonCode/Current/calpnt48.scd</p>
<pre style="font-family:courier">cat /home/sched/Dropbox/PythonCode/Current/calpnt48.scd</pre>


Below are the first few lines of this file:
Below are the first few lines of this file:
<p style="font-family:courier">
<pre style="font-family:courier">
2019-06-22 10:26:00 ACQUIRE 2136+006<br>
2019-06-22 10:26:00 ACQUIRE 2136+006
2019-06-22 10:30:00 CALPNTCAL 2136+006 band21.fsq calpnt.trj<br>
2019-06-22 10:30:00 CALPNTCAL 2136+006 band21.fsq calpnt.trj
2019-06-22 10:55:00 ACQUIRE 2253+161<br>
2019-06-22 10:55:00 ACQUIRE 2253+161
2019-06-22 10:59:00 CALPNTCAL 2253+161 band21.fsq calpnt.trj<br>
2019-06-22 10:59:00 CALPNTCAL 2253+161 band21.fsq calpnt.trj
2019-06-22 11:24:00 ACQUIRE 2136+006<br>
2019-06-22 11:24:00 ACQUIRE 2136+006
2019-06-22 11:28:00 CALPNTCAL 2136+006 band21.fsq calpnt.trj<br>
2019-06-22 11:28:00 CALPNTCAL 2136+006 band21.fsq calpnt.trj
2019-06-22 11:53:00 ACQUIRE 2253+161<br>
2019-06-22 11:53:00 ACQUIRE 2253+161
2019-06-22 11:57:00 CALPNTCAL 2253+161 band21.fsq calpnt.trj<br>
2019-06-22 11:57:00 CALPNTCAL 2253+161 band21.fsq calpnt.trj
</p>
</pre>


The dates and times need to be edited. Use the following equation to compute the new times:
The dates and times need to be edited. Use the following equation to compute the new times:
:<p style="font-family:courier">OFFSET = NST - OST</p>
<pre style="font-family:courier">
:<p style="font-family:courier">NT = OT + OFFSET</p>
OFFSET = NST - OST
NT = OT + OFFSET
</pre>


where NST is the sidereal time when you wish to start the calibration, OST is the sidereal time for the first entry in the <span style="font-family:courier">calpnt48.scd</span> file, NT is a new UT time in the schedule, and OT is the old UT time in the schedule.  
where NST is the sidereal time when you wish to start the calibration, OST is the sidereal time for the first entry in the <span style="font-family:courier">calpnt48.scd</span> file, NT is a new UT time in the schedule, and OT is the old UT time in the schedule.  
Line 1,078: Line 1,152:
The <span style="font-family:courier">/home/sched/Dropbox/PythonCode/Current/update_calpnt48.py</span> file contains a function that will automatically create a new <span style="font-family:courier">calpnt48.scd</span> file. To use it issue the following commands from a Helios terminal:
The <span style="font-family:courier">/home/sched/Dropbox/PythonCode/Current/update_calpnt48.py</span> file contains a function that will automatically create a new <span style="font-family:courier">calpnt48.scd</span> file. To use it issue the following commands from a Helios terminal:


:<p style="font-family:courier">cd /home/sched/Dropbox/PythonCode/Current/</p>
<pre style="font-family:courier">
 
cd /home/sched/Dropbox/PythonCode/Current/
:<p style="font-family:courier">ipython --pylab</p>
ipython --pylab</p>
 
from util import Time</p>
:<p style="font-family:courier">from util import Time</p>
import update_calpnt48 as ucp
 
ucp.update_calpnt48(t2 = Time("yyyy-mm-dd hh:mm"))
:<p style="font-family:courier">import update_calpnt48 as ucp</p>
</pre>
 
:<p style="font-family:courier">ucp.update_calpnt48(t2 = Time("yyyy-mm-dd hh:mm"))</p>


where yyyy-mm-dd hh:mm is the approximate UT start date and time for the calibration. If the time is omitted then the current time will be used.
where yyyy-mm-dd hh:mm is the approximate UT start date and time for the calibration. If the time is omitted then the current time will be used.
Line 1,104: Line 1,176:
If you just want to see the screen output without overwriting the existing <span style="font-family:courier">calpnt48.scd</span> file issue the command from ipython:
If you just want to see the screen output without overwriting the existing <span style="font-family:courier">calpnt48.scd</span> file issue the command from ipython:


:<p style="font-family:courier">ucp.update_calpnt48(t2 = Time("yyyy-mm-dd hh:mm", overwrite=False))
<pre style="font-family:courier">ucp.update_calpnt48(t2 = Time("yyyy-mm-dd hh:mm", overwrite=False))</pre>


Once run, type <span style="font-family:courier">exit</span> to exit ipython.
Once run, type <span style="font-family:courier">exit</span> to exit ipython.
Line 1,115: Line 1,187:
==== Using the Delay Widget ====
==== Using the Delay Widget ====
From pipeline, start the delay widget as follows:
From pipeline, start the delay widget as follows:
:<p style="font-family:courier">python /common/python/current/delay_widget.py</p>
<pre style="font-family:courier">python /common/python/current/delay_widget.py</pre>


A window similar to the one shown below should appear:
A window similar to the one shown below should appear:
Line 1,153: Line 1,225:


From pipeline access ipython:
From pipeline access ipython:
:<p style="font-family:courier">ipython --pylab</p>
<pre style="font-family:courier">ipython --pylab</pre>


Load the cal_header and and Time modules:
Load the cal_header and and Time modules:
:<p style="font-family:courier">import cal_header as ch</p>
<pre style="font-family:courier">
:<p style="font-family:courier">from util import Time</p>
import cal_header as ch
from util import Time
</pre>


We want to use the dla_censql2table function to create a table of the delays. This is done by:
We want to use the dla_censql2table function to create a table of the delays. This is done by:
:<p style="font-family:courier">ch.dla_cen2sqltable(t=Time('yyyy-mm-dd hh:mm'),acc=False)</p>
<pre style="font-family:courier">ch.dla_cen2sqltable(t=Time('yyyy-mm-dd hh:mm'),acc=False)</pre>


where <span style="font-family:courier">yyyy-mm-d hh:mm</span> is the date and time for the last delays (it will look for the first time prior to that specified) and <span style="font-family:courier">acc=False</span> tells the function not to send values to the ACC.
where <span style="font-family:courier">yyyy-mm-d hh:mm</span> is the date and time for the last delays (it will look for the first time prior to that specified) and <span style="font-family:courier">acc=False</span> tells the function not to send values to the ACC.


For example to view delays from the 3rd of November 2020 (or the first date prior to this) you would issue the command:
For example to view delays from the 3rd of November 2020 (or the first date prior to this) you would issue the command:
:<p style="font-family:courier">ch.dla_cen2sqltable(Time('2020-11-01 01:00'),acc=False)</p>
<pre style="font-family:courier">ch.dla_cen2sqltable(Time('2020-11-01 01:00'),acc=False)</pre>


Note that this writes the data to a text file: <span style="font-family:courier">/tmp/delay_centers.txt</span>
Note that this writes the data to a text file: <span style="font-family:courier">/tmp/delay_centers.txt</span>


To view this file issue the command:
To view this file issue the command:
:<p style="font-family:courier">!cat /tmp/delay_centers.txt</span>
<pre style="font-family:courier">!cat /tmp/delay_centers.txt</pre>


To view an older file, use the <span style="font-family:courier">ch.dla_cen2sqltable</span> with an earlier time and reissue the cat command. The delays that were changed should be different for the given antennas. Note that if antenna 1 delays were changed, this change will be shown in antenna 14.
To view an older file, use the <span style="font-family:courier">ch.dla_cen2sqltable</span> with an earlier time and reissue the cat command. The delays that were changed should be different for the given antennas. Note that if antenna 1 delays were changed, this change will be shown in antenna 14.
Line 1,183: Line 1,257:
alias loadctl='source /home/user/.setenv_ctl'
alias loadctl='source /home/user/.setenv_ctl'
</pre>
</pre>


To create new entries for the cloud data base, from your pipeline account run the following commands:
To create new entries for the cloud data base, from your pipeline account run the following commands:


 
<pre style="font-family:courier">
<code>
bash
bash
loadctl  
loadctl  
ipython
ipython
import eovsactl.sql2mysql as s2m
import eovsactl.sql2mysql as s2m
s2m.sync2mysql()
s2m.sync2mysql()
s2m.sqltable2mysql('abin',host='amazonaws.com')
s2m.sqltable2mysql('abin',host='amazonaws.com')
s2m.sqltable2mysql('abin',host='localhost')
s2m.sqltable2mysql('abin',host='localhost')
<code>
</pre>


== Trouble Shooting ==
The commands above will create a .sql file at /data1/
=== General Problems ===
==== Temperature Controller ====
Occassionally a front end temperature will show an error. This is usually because the temperature controller that reports the temperature has locked up. To fix this type the following command in the Schedule window:
:<p style="font-family:courier">tec$bc ant#</p>


where # is the antenna number that needs the temperature controller rebooted.
To send it to the cloud type:


To clear the temperature error history (that updates every minute) issue the command:
<pre style="font-family:courier">
:<p style="font-family:courier">tec$sc ant#</p>
!mysql -h eovsa-db0.cgb0fabhwkos.us-west-2.rds.amazonaws.com -u admin -p eOVSA < /data1/yyyy-mm-dd.sql
</pre>


If the above steps do not work, the following command can be issued:
The password is the last one in the .netrc file
:<p style="font-family:courier">$pcycle fem ant#</p>


This will recycle power to the front end controller. If this does not work you can check the log file from a helios terminal by typing
To check if the file was sent to the cloud, use the python command:
:<p style="font-family:courier">tail -20 /tmp/schedule.log</p>


A display similar to that below will be shown:
<pre style="font-family:courier">
:<p style="font-family:courier">2020-08-17 13:56:03.002 Ant4 attempt #1 to login.<br />2020-08-17 13:56:03.002 Ant4 Login failed with status code: 401<br />2020-08-17 13:56:04.002 Ant4 attempt #2 to login.<br />2020-08-17 13:56:04.002 Ant4 Login successful.<br />2020-08-17 13:56:04.002 Ant4 Fronttend now off<br />2020-08-17 13:56:19.002 Ant4 attempt #1 to login.<br />2020-08-17 13:56:19.002 Ant4 Login successful.<br />2020-08-17 13:56:20.002 Ant4 Frontend now on</p>
s2m.get_latest_timestamp()
</pre>


Note that the second line says that the login failed. It will attempt a login in three times.
== Reprocessing Pipeline Data ==
If this fails you can attempt a recycle to issue the command again. If this does not work the front end needs to be reset at the auxiliary box at the antenna. This is done by switching off the two breakers, waiting 10 seconds and then switching them back on. The breakers are shown below.
Occassionally, pipeline data will need to be reprocessed if it failed or there were bad calibrations.


[[File:auxboxbreakers.jpg]]
=== Creating  full disk images ===
Log in to a pipeline terminal and create a new screen:


==== Packet Loss on DPP ====
<pre style="font-family:courier">
screen -S fulldisk
</pre>


The packet loss monitoring has now largely been automated. However it is still a good idea to check to make sure everything is running smoothly.
Next run the following command:


Details on the new programs and procedures can be found here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#DPP_Fix_Packets_Details
<pre style="font-family:courier">
/bin/bash /common/python/eovsapy/shellScript/pipeline.sh -c 1 yyyy mm dd > /tmp/test_pipeline.log
</pre>


==== Data Recording on the DPP has Stopped ====
where <span style="font-family:courier">yyyy</span> is the year, <span style="font-family:courier">mm</span> is the month and <span style="font-family:courier">dd</span> is the day of the data to be processed.
To Check if the DPP is recording data, from a DPP terminal issue the command:
<p style="font-family:courier">ls /data1/IDB |tail</p>


This will display the last 10 IDB files that were created. They should have a time stamp about 10 minutes apart and the last file should only be 10 minutes or so old.
This will take several hours to run.
When completed run the command:


If current IDB files are not displayed then firstly check to see if The STATE is On in the phase tracking section of the stateframe is displayed as shown below.
<pre style="font-family:courier">
/bin/bash /common/python/eovsapy/shellScript/pipeline_plt.sh -c 1 -e 1 yyyy mm dd > /tmp/test_pipeline_plt.log
</pre>


[[File:Sf display state.png]]
This should only take a few seconds to run.


If the state is off then simply click Stop on the schedule window and then click on Go. The state should return to On. Check to see if the DPP is creating files after about a minute.
Finally run the following command:


If the DPP is still not recording data or the State was already on then follow the instruction below.
<pre style="font-family:courier">
/bin/bash /common/python/eovsapy/shellScript/pipeline_compress.sh -n 1 -O 1 yyyy mm dd > /tmp/test_pipeline_compress.log
</pre>


:Log in to the DPP computer (user@dpp).
Note you can reprocess multiply days by running each day in a separate screen. Remember to assign a different name to each screen and assign a different name to each log file.
:Enter <span style="font-family:courier">top</span> . A display similar to that below should be shown.


[[File:Dpp_top.png]]
=== Total Power Calibration ===
To check if a total power calibration has been done on a particular day follow the steps below from a pipeline terminal


:Look for <span style="font-family:courier">dppxmp</span> under “command” column (shown here in the red box). If this is present not the PID# (shown here in the green box. Note that this number will change if dppxmp is restarted).
<pre style="font-family:courier">
ipython --pylab
import cal_header as ch
from util import Time
from stateframe import extract
xml, buf = ch.read_cal(10, Time('yyyy-mm-dd 20:00'))
outtm = Time(extract(buf, xml['SQL_timestamp']), format='lv').iso
Time(extract(buf, xml['SQL_timestamp']), format='lv').iso
outtm
</pre>


:Press 'q' to exit the <span style="font-family:courier">top</span> program
where <span style="font-family:courier">yyyy</span> is the year, <span style="font-family:courier">mm</span> is the month, <span style="font-family:courier">dd</span> is the day.


:If <span style="font-family:courier">dppxmp</span> is present issue the command:
The return time should be 20:00 on the date specified. If not then copy the record to the correct time as follows:


::<span style="font-family:courier">kill pid#</span>
<pre style="font-family:courier">
ch.copy_cal(10,Time(outtm),Time('yyyy-mm-dd 20:00'))
</pre>


:where PID# is the number noted down previously. This will stop the <span style="font-family:courier">dppxmp</span> program.
To rerun the Total Power calibration, exit ipython and enter the command:


:Enter the command <span style="font-family:courier">rmlock<span style="font-family:courier">
<pre style="font-family:courier">
/bin/tcsh /home/user/test_svn/shell_scripts/pipeline_allday_fits.csh --clearcache 2023 10 16 > /tmp/test_pipeline_fits.log
</pre>


:Check again to see if data recording has recovered
== Trouble Shooting ==
=== General Problems ===
==== Temperature Controller ====
Occassionally a front end temperature will show an error. This is usually because the temperature controller that reports the temperature has locked up. To fix this type the following command in the Schedule window:
<pre style="font-family:courier">tec$bc ant#</pre>


:Type “rmlock" on DPP terminal. Check if the data recording has recovered by sending  <span style="font-family:courier">ls /data1/IDB |tail</span>
where # is the antenna number that needs the temperature controller rebooted.


==== Restarting the Schedule ====
To clear the temperature error history (that updates every minute) issue the command:
If the schedule needs to be restarted then follow the steps below:
<pre style="font-family:courier">tec$sc ant#</pre>


:Click Stop and then Clear.
If the above steps do not work, the following command can be issued:
<pre style="font-family:courier">$pcycle fem ant#</pre>


:Click Today and then Go.
This will recycle power to the front end controller. If this does not work you can check the log file from a helios terminal by typing
<pre style="font-family:courier">tail -20 /tmp/schedule.log</pre>


==== Pipeline Problems ====
A display similar to that below will be shown:
If there is no data showing at [http://www.ovsa.njit.edu/browser/ http://www.ovsa.njit.edu/browser/] then something has gone wrong with the pipeline processing. Below is a image of what the webpage looks like when an error has occurred.
<pre style="font-family:courier">
2020-08-17 13:56:03.002 Ant4 attempt #1 to login.
2020-08-17 13:56:03.002 Ant4 Login failed with status code: 401
2020-08-17 13:56:04.002 Ant4 attempt #2 to login.
2020-08-17 13:56:04.002 Ant4 Login successful.
2020-08-17 13:56:04.002 Ant4 Fronttend now off
2020-08-17 13:56:19.002 Ant4 attempt #1 to login.
2020-08-17 13:56:19.002 Ant4 Login successful.
2020-08-17 13:56:20.002 Ant4 Frontend now on
</pre>


[[File:eovsa_browser_nodata.png|none|The 'No Data' errors on the EOVA browser page.]]
Note that the second line says that the login failed. It will attempt a login in three times.
If this fails you can attempt a recycle to issue the command again. If this does not work the front end needs to be reset at the auxiliary box at the antenna. This is done by switching off the two breakers, waiting 10 seconds and then switching them back on. The breakers are shown below.


Clicking on the Newest button will refresh the page and upload the latest data. If this does not correct the problem take a note of the date in the web address of the page. Then click on 'Today's Data'. A list of fits files should appear as below:
[[File:auxboxbreakers.jpg]]


[[File:eovsa_browser_files.png|none|Example list of files if pipeline processing was successful.]]
==== Packet Loss on DPP ====


To check to see why the images are not visible, the log files can be inspected. Log on to pipeline and type the command:
The packet loss monitoring has now largely been automated. However it is still a good idea to check to make sure everything is running smoothly.


:<p style="font-family:courier">crontab -l</p>
Details on the new programs and procedures can be found here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#DPP_Fix_Packets_Details


The image below show a part of the output. The portion in the red box is the script that generates the full disk image.
==== Data Recording on the DPP has Stopped ====
To Check if the DPP is recording data, from a DPP terminal issue the command:
<pre style="font-family:courier">ls /data1/IDB |tail</pre>


[[File:Pipeline_crontab_fdimg.png]]
This will display the last 10 IDB files that were created. They should have a time stamp about 10 minutes apart and the last file should only be 10 minutes or so old.


To view the programs run by this script issue the command:
If current IDB files are not displayed then firstly check to see if The STATE is On in the phase tracking section of the stateframe is displayed as shown below.


:<p style="font-family:courier">cat /common/python/suncasa/shellScript/pipeline_fdimg.bash</p>
[[File:Sf display state.png]]


and an output similar to that below should be produced:
If the state is off then simply click Stop on the schedule window and then click on Go. The state should return to On. Check to see if the DPP is creating files after about a minute.


[[File:Pipeline_fdimg_script.png]]
If the DPP is still not recording data or the State was already on then follow the instruction below.


Note that the are three log files produced: <span style="font-family:courier">/tmp/pipeline.log</span>, <span style="font-family:courier">/tmp/pipeline_plt.log</span> and <span style="font-family:courier">/tmp/pipeline_compress.log</span>.
:Log in to the DPP computer (user@dpp).
:Enter <span style="font-family:courier">top</span> . A display similar to that below should be shown.


By inspecting these files you should be able to determine at what point an error occurred. To view these files type:
[[File:Dpp_top.png]]


:<p style="font-family:courier">cat [logfile]</p>
:Look for <span style="font-family:courier">dppxmp</span> under “command” column (shown here in the red box). If this is present not the PID# (shown here in the green box. Note that this number will change if dppxmp is restarted).


where [logfile] is the name of the logfile you wish to view.
:Press 'q' to exit the <span style="font-family:courier">top</span> program


==== Bad Front End Attenuation Values ====
:If <span style="font-family:courier">dppxmp</span> is present issue the command:
The front end power values on both the horizontal and vertical channels should be between about +1 dBm and +4 dBm. These can be found on the stateframe display as shown below.


[[File:Sf display attn.png]]
<pre style="font-family:courier">kill pid#</pre>


If the power deviates significantly from the 1 to 3 dBm range (unless there is a burst in progress or a gaincal test being performed) then the attenuations can be adjusted by issuing the following commands from the Schedule window:
:where PID# is the number noted down previously. This will stop the <span style="font-family:courier">dppxmp</span> program.


:<p style="font-family:courier">hattn first second ant#</p>
:Enter the command <span style="font-family:courier">rmlock<span style="font-family:courier">


where first and second are the attenuations of the first and second attenuators for the horizontal polarization and ant# is the antenna number. Note that first should always be zero.
:Check again to see if data recording has recovered


Similarly to adjust the vertical attenuators:
:Type “rmlock" on DPP terminal. Check if the data recording has recovered by sending  <span style="font-family:courier">ls /data1/IDB |tail</span>


:<p style="font-family:courier">vattn first second ant#</p>
==== Restarting the Schedule ====
If the schedule needs to be restarted then follow the steps below:


'''Note that no warning will be shown if the power deviates significantly from the acceptable range.'''
:Click Stop and then Clear.


==== Warning on Power and Attenuation ====
:Click Today and then Go.


On the state frame display in the Power and Attenuation section, occasionally an antenna will turn yellow (warning). This will usually be because the 1st attenuator value is not zero. This will occur during a gaincaltest or a burst. The value should be even. If the value is 9, then the CRIO file will most likely need to be be reloaded.
==== Pipeline Problems ====
If there is no data showing at [http://www.ovsa.njit.edu/browser/ http://www.ovsa.njit.edu/browser/] then something has gone wrong with the pipeline processing. Below is a image of what the webpage looks like when an error has occurred.


Follow the instructions here http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Reloading_the_crio.ini_File to relaod the crio.ini file
[[File:eovsa_browser_nodata.png|none|The 'No Data' errors on the EOVA browser page.]]


==== Error on Power and Attenuation ====
Clicking on the Newest button will refresh the page and upload the latest data. If this does not correct the problem take a note of the date in the web address of the page. Then click on 'Today's Data'. A list of fits files should appear as below:
On the state frame display in the Power and Attenuation section, occasionally an antenna will turn red (error). This may happen during a gaincal. However If it occurs outside a gancal and the Power values are reading <span style="font-family:courier">nan</span> (Not a Number), then it is possible that communications have been lost at the front end. You can try and cycle power to the front end by issuing the command from schedule:
:<p style="font-family:courier">$pcycle fem ant#</p>


If the $pcycle command does not work you can try testing the network connection. From a helios terminal, issue the command:
[[File:eovsa_browser_files.png|none|Example list of files if pipeline processing was successful.]]
:<p style="font-family:courier">ping ant#.solar.pvt</p>


where # is the number of the antenna. If you get a message similar to:
To check to see why the images are not visible, the log files can be inspected. Log on to pipeline and type the command:
:<p style="font-family:courier">From helios.solar.pvt (192.168.24.103) icmp_seq=1 Destination Host Unreachable</p>


then it means that the communications are down. Contact Owen to reset the power at the antenna.
<pre style="font-family:courier">crontab -l</pre>


==== Resetting Attenuation Values ====
The image below show a part of the output. The portion in the red box is the script that generates the full disk image.
Occasionally, the front end attenuation values may get stuck, typically after a calibration. To reset the attenuations, use the following commands on the schedule:
:<p style="font-family:courier">femauto-off ant#</p>
:<p style="font-family:courier">femattn 0 0 ant#</p>


==== Schedule Commands not Working ====
[[File:Pipeline_crontab_fdimg.png]]


If schedule commands are not working then the ACC may need to be restarted.
To view the programs run by this script issue the command:


To determine if the ACC needs restarting issue a command from Schedule. At the top right of the Stateframe the 'Task' should be updated. if it is not then follow the following procedure:
<pre style="font-family:courier">cat /common/python/suncasa/shellScript/pipeline_fdimg.bash</pre>
 
and an output similar to that below should be produced:


:Go to the Windows computer and from the Quicklaunch menu select 'EOVSA E&C'.
[[File:Pipeline_fdimg_script.png]]


:Once running click on 'Reset ACC' and wait about 10 seconds.
Note that the are three log files produced: <span style="font-family:courier">/tmp/pipeline.log</span>, <span style="font-family:courier">/tmp/pipeline_plt.log</span> and <span style="font-family:courier">/tmp/pipeline_compress.log</span>.


==== Queue Overflow Error ====
By inspecting these files you should be able to determine at what point an error occurred. To view these files type:
On the Stateframe display, a 'Queue Overflow' Error may occur under the Frequency Tuning bar. To correct this issue type the following command into the Raw Command box on the schedule:
:<p style="font-family:courier">lo1a-reboot</p>


Stop and then restart the schedule.
<pre style="font-family:courier">cat [logfile]</pre>


==== Bright Scram ====
where [logfile] is the name of the logfile you wish to view.
A bright scram occurs when the dish becomes more reflective, usually due to ice or water. This will cause more heat to be focused which can result in damage to the feed (burnt feed). A bright scram moves the dish 10 degrees off the Sun. It will the periodically move back to the Sun and remain tracking once the temperature at the feed drops sufficiently.


'''<span style="color:#FF0000">ONLY PERFORM THE PROCEDURE BELOW IF YOU ARE ABSOLUTELY SURE THAT A BRIGHT SCRAM IS FALSE AND REALLY NEEDS TO BE CLEARED. YOU RISK BURNING THE FEED!'''
==== Bad Front End Attenuation Values ====
The front end power values on both the horizontal and vertical channels should be between about +1 dBm and +4 dBm. These can be found on the stateframe display as shown below.


A bright scram can be cleared by issuing the following command from the schedule:
[[File:Sf display attn.png]]
:<p style="font-family:courier">bscram-clear ant#</p>


If an antenna is performing brightscrams erroneously (for example during a phasecal), then an individual antenna can have the brightscram disabled by issuing the following command from the schedule:
If the power deviates significantly from the 1 to 3 dBm range (unless there is a burst in progress or a gaincal test being performed) then the attenuations can be adjusted by issuing the following commands from the Schedule window:
:<p style="font-family:courier">bscram-off ant#</p>


To re-enable brightscram on a particular antenna issue the command:
<pre style="font-family:courier">hattn first second ant#</pre>
:<p style="font-family:courier">bscram-on ant#</p>


==== Older Antennas Not Tracking ====
where first and second are the attenuations of the first and second attenuators for the horizontal polarization and ant# is the antenna number. Note that first should always be zero.
The older antennas (9-11 and 13) will occasionally seem to stop tracking. This is usually because it has lost where it is pointing. It will move incredibly slowly until it reaches its limit before returning to regular tracking. This process cant take up to about 20 minutes. If it has not resolved it tracking problems in this time, proceed with normal trouble shooting.


==== Antenna Trouble Shooting ====
Similarly to adjust the vertical attenuators:


If an antenna in the State-frame Antenna Tracking section is highlighted red, go through the following list.
<pre style="font-family:courier">vattn first second ant#</pre>


===== Reloading the track table =====
'''Note that no warning will be shown if the power deviates significantly from the acceptable range.'''


Reload the track table as by issuing the following commands from the schedule
==== Warning on Power and Attenuation ====
:<p style="font-family:courier">tracktable sun_tab.radec ant#</p>
:<p style="font-family:courier">track ant#</p>


Note that omitting the ant# will resend the commands to all antennas. You can specify more that on antenna.
On the state frame display in the Power and Attenuation section, occasionally an antenna will turn yellow (warning). This will usually be because the 1st attenuator value is not zero. This will occur during a gaincaltest or a burst. The value should be even. If the value is 9, then the CRIO file will most likely need to be be reloaded.


===== Stowing the antennas =====
Follow the instructions here http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Reloading_the_crio.ini_File to relaod the crio.ini file
Attempt to stow the antenna by issuing:
:<p style="font-family:courier">stow ant#</p>
If there are still errors, from the state-frame display, click on the antenna display and then click on the tab for the appropriate antenna.


===== Antenna at its limits (New Antennas) =====
==== Error on Power and Attenuation ====
If a limit is highlighted you will need to move the antenna from its limit. Firstly issue the command:
On the state frame display in the Power and Attenuation section, occasionally an antenna will turn red (error). This may happen during a gaincal. However If it occurs outside a gancal and the Power values are reading <span style="font-family:courier">nan</span> (Not a Number), then it is possible that communications have been lost at the front end. You can try and cycle power to the front end by issuing the command from schedule:
:<p style="font-family:courier">runmode 2 ant#</p>
<pre style="font-family:courier">$pcycle fem ant#</pre>


Issue the appropriate command according to the following table:
If the $pcycle command does not work you can try testing the network connection. From a helios terminal, issue the command:
<pre style="font-family:courier">ping ant#.solar.pvt</pre>


{| class="wikitable"
where # is the number of the antenna. If you get a message similar to:
!  Co-ord    || Limit || Command
<pre style="font-family:courier">From helios.solar.pvt (192.168.24.103) icmp_seq=1 Destination Host Unreachable</pre>
|-
|  Azimuth  || High  || <span style="font-family:courier">azimuthvelocity -5000 ant6</span>
|-
|            || Low  || <span style="font-family:courier">azimuthvelocity 5000 ant6</span>
|-
|  Elevation || High  || <span style="font-family:courier">elevationvelocity -5000 ant3</span>
|-
|            || Low  || <span style="font-family:courier">elevationvelocity 5000 ant6</span>
|}


Once the limit indicator goes green issue the command:
then it means that the communications are down. Contact Owen to reset the power at the antenna.


:<span style="font-family:courier">azimuthvelocity 0 ant#</span> or <span style="font-family:courier">elevationvelocity 0 ant#</span>
==== Resetting Attenuation Values ====
Occasionally, the front end attenuation values may get stuck, typically after a calibration. To reset the attenuations, use the following commands on the schedule:
<pre style="font-family:courier">femauto-off ant#
femattn 0 0 ant#
</pre>


Return the antenna to tracking:
==== Schedule Commands not Working ====
:<p style="font-family:courier">track ant#</p>


===== Antenna at its limits (Old Antennas) =====
If schedule commands are not working then the ACC may need to be restarted.


Initially try to stow the antenna:
To determine if the ACC needs restarting issue a command from Schedule. At the top right of the Stateframe the 'Task' should be updated. if it is not then follow the following procedure:
:<p style="font-family:courier">stow ant#</p>


It may take a while for the antenna to stow.
:Go to the Windows computer and from the Quicklaunch menu select 'EOVSA E&C'.


If the antenna fails to stow, it will need to be manually driven off its limit as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_Old_Antennas_Manually and then try to stow the antenna.
:Once running click on 'Reset ACC' and wait about 10 seconds.


Once stowed, return the antenna to tracking:
==== Queue Overflow Error ====
:<p style="font-family:courier">track ant#</p>
On the Stateframe display, a 'Queue Overflow' Error may occur under the Frequency Tuning bar. To correct this issue type the following command into the Raw Command box on the schedule:
<pre style="font-family:courier">lo1a-reboot</pre>


===== Bad values for antenna position =====
Stop and then restart the schedule.
If any of the following is true:


:on antennas 1 to 8 or 12 the azimuth is outside the range of 0 to 360 degrees,
==== Bright Scram ====
A bright scram occurs when the dish becomes more reflective, usually due to ice or water. This will cause more heat to be focused which can result in damage to the feed (burnt feed). A bright scram moves the dish 10 degrees off the Sun. It will the periodically move back to the Sun and remain tracking once the temperature at the feed drops sufficiently.


:on antennas 1 to 8 or 12 the elevation is outside the range of 0 to 90 degrees,
'''<span style="color:#FF0000">ONLY PERFORM THE PROCEDURE BELOW IF YOU ARE ABSOLUTELY SURE THAT A BRIGHT SCRAM IS FALSE AND REALLY NEEDS TO BE CLEARED. YOU RISK BURNING THE FEED!'''


:on antennas 9 to 11 or 13 the hour angle is outside the range of -180 to 180 degrees,
A bright scram can be cleared by issuing the following command from the schedule:
<pre style="font-family:courier">bscram-clear ant#</pre>


:on antennas 9 to 11 or 13 the declination is outside the range of -90 to 90 degrees,
If an antenna is performing brightscrams erroneously (for example during a phasecal), then an individual antenna can have the brightscram disabled by issuing the following command from the schedule:
<pre style="font-family:courier">bscram-off ant#</pre>


you can try to issue the following commands:
To re-enable brightscram on a particular antenna issue the command:
:<p style="font-family:courier">stop ant#</p>
<pre style="font-family:courier">bscram-on ant#</pre>
:<p style="font-family:courier">sync-motion ant#</p>


The antenna should then go to its stow position. Once it is stowed send the commands:
==== Older Antennas Not Tracking ====
:<p style="font-family:courier">tracktable sun_tab.radec ant#</p>
The older antennas (9-11 and 13) will occasionally seem to stop tracking. This is usually because it has lost where it is pointing. It will move incredibly slowly until it reaches its limit before returning to regular tracking. This process cant take up to about 20 minutes. If it has not resolved it tracking problems in this time, proceed with normal trouble shooting.
:<p style="font-family:courier">track ant#</p>


The antenna should resume tracking.
==== Antenna Trouble Shooting ====


===== Rebooting the antenna =====
If an antenna in the State-frame Antenna Tracking section is highlighted red, go through the following list.
On the newer antennas (antennas 1 to 8 and 12), access the window computer, click on then Quick launch icon at bottom right and then click on the antenna that is problematic.


[[File:Ant_Selector.png]]
===== Reloading the track table =====


A screen window to that below will come up. Ensure that the Enable box at the lower right is checked.
Reload the track table as by issuing the following commands from the schedule
<pre style="font-family:courier">tracktable sun_tab.radec ant#
track ant#
</pre>


[[File:Win_Ant_Controller.png]]
Note that omitting the ant# will resend the commands to all antennas. You can specify more that on antenna.


One or both of the Permit boxes may be red.
===== Stowing the antennas =====
Attempt to stow the antenna by issuing:
<pre style="font-family:courier">stow ant#</pre>


Click on the Reboot Drives button. and wait about 10 seconds. The click on the Drives On Button. It should turn Green. Click on the Operate Button. If this does not turn green you may need to reboot the edge13b server.
If there are still errors, from the state-frame display, click on the antenna display and then click on the tab for the appropriate antenna.


Click Exit.
===== Antenna at its limits (New Antennas) =====
If a limit is highlighted you will need to move the antenna from its limit. Firstly issue the command:
<pre style="font-family:courier">runmode 2 ant#</pre>


===== Rebooting the antenna interface on the edge13b server =====
Issue the appropriate command according to the following table:


Whenever an antenna link seems to be down (indicated by the lack of a blinking link light on the edge13b router), note the port that is down (The antenna is labelled on each fibre pair).
{| class="wikitable"
!  Co-ord    || Limit || Command
|-
|  Azimuth  || High  || <span style="font-family:courier">azimuthvelocity -5000 ant6</span>
|-
|            || Low  || <span style="font-family:courier">azimuthvelocity 5000 ant6</span>
|-
|  Elevation || High  || <span style="font-family:courier">elevationvelocity -5000 ant3</span>
|-
|            || Low  || <span style="font-family:courier">elevationvelocity 5000 ant6</span>
|}


[[File:Edge13b_router.jpg]]
Once the limit indicator goes green issue the command:


Refer to it as
<pre style="font-family:courier">azimuthvelocity 0 ant#</pre>
:<p style="font-family:courier">fa0/#</p>
or
<pre style="font-family:courier">elevationvelocity 0 ant#</pre>


where # is the number of the port. E.g., if port 1 is down, it will be referred to as fa0/1.
Return the antenna to tracking:
<pre style="font-family:courier">track ant#</pre>


From Helios, telnet to the switch:
===== Antenna at its limits (Old Antennas) =====
:<p style="font-family:courier">telnet edge13b.admin.pvt</p>


Enter the the password when prompted.
Initially try to stow the antenna:
<pre style="font-family:courier">stow ant#</pre>


Enter the command:
It may take a while for the antenna to stow.
:<p style="font-family:courier">show inter fa0/1</p>


[[File:Edge13b_status.png]]
If the antenna fails to stow, it will need to be manually driven off its limit as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_Old_Antennas_Manually and then try to stow the antenna.


The first line will show the status. If it is listed as Connected then nothing needs to be done. Enter:
Once stowed, return the antenna to tracking:
:<p style="font-family:courier">quit</p>  
<pre style="font-family:courier">track ant#</pre>


to exit from telnet
===== Bad values for antenna position =====
If any of the following is true:


If the connection is listed as err-disabled then proceed with the following steps. At the telnet terminal issue the commands:
:on antennas 1 to 8 or 12 the azimuth is outside the range of 0 to 360 degrees,
:<p style="font-family:courier">enable</p>


and enter the password.
:on antennas 1 to 8 or 12 the elevation is outside the range of 0 to 90 degrees,
:<p style="font-family:courier">configure ter</p>
:<p style="font-family:courier">interface fa0/#</p>


where # is the port number.
:on antennas 9 to 11 or 13 the hour angle is outside the range of -180 to 180 degrees,


:<p style="font-family:courier">shutdown</p>
:on antennas 9 to 11 or 13 the declination is outside the range of -90 to 90 degrees,
:<p style="font-family:courier">no shutdown</p>
:<p style="font-family:courier">end</p>


You can then reissue the show inter command to see if the interface is running. The port light should also be blinking on the server.
you can try to issue the following commands:
<pre style="font-family:courier">
stop ant#
sync-motion ant#
</pre>


Issue then command
The antenna should then go to its stow position. Once it is stowed send the commands:
:<p style="font-family:courier">quit</p>
<pre style="font-family:courier">tracktable sun_tab.radec ant#
<pre style="font-family:courier">track ant#
</pre>


to exit telnet.
The antenna should resume tracking.


===== Resetting antenna parameters =====
===== Rebooting the antenna =====
On the newer antennas (antennas 1 to 8 and 12), access the window computer, click on then Quick launch icon at bottom right and then click on the antenna that is problematic.


If the antenna still will not start goto the following webpage:
[[File:Ant_Selector.png]]
:<p style="font-family:courier">http://ant#.solar.pvt</p>


Click Login and then enter the username and password.
A screen window to that below will come up. Ensure that the Enable box at the lower right is checked.


Click Parameters and the change Option 10.00 to 1070 and Option 10.38 to 100. Click on change.
[[File:Win_Ant_Controller.png]]


Then click on logout.
One or both of the Permit boxes may be red.  


After the above procedures are completed you will need to reload the track table. This is done from the State Frame display using the following commands (again ensure that ant5 is replaced with the appropriate antenna):
Click on the Reboot Drives button. and wait about 10 seconds. The click on the Drives On Button. It should turn Green. Click on the Operate Button. If this does not turn green you may need to reboot the edge13b server.


:<p style="font-family:courier">tracktable pcal_tab.radec ant5</p>
Click Exit.
:<p style="font-family:courier">track ant5</p>


===== Antenna Communications Failure =====
===== Rebooting the antenna interface on the edge13b server =====


If an antenna is highlighted in the Communications section of the State-Frame display then the following procedure can be used to correct it.
Whenever an antenna link seems to be down (indicated by the lack of a blinking link light on the edge13b router), note the port that is down (The antenna is labelled on each fibre pair).


From the Schedule on Helios enter the command
[[File:Edge13b_router.jpg]]
:<p style="font-family:courier">$pcycle crio ant2</p>


and wait about 2 minutes.
Refer to it as
<pre style="font-family:courier">fa0/#</pre>


From the Schedule on Helios issue the command
where # is the number of the port. E.g., if port 1 is down, it will be referred to as fa0/1.


:<p style="font-family:courier">sync ant#</p>
From Helios, telnet to the switch:
<pre style="font-family:courier">telnet edge13b.admin.pvt</pre>


for the newer antennas or
Enter the the password when prompted.


:<p style="font-family:courier">sync-motion ant#</p>
Enter the command:
<pre style="font-family:courier">show inter fa0/1</pre>


for the older antennas where # is the antenna number.
[[File:Edge13b_status.png]]


If this does not resolve the communications problem, then proceed with the procedure below.
The first line will show the status. If it is listed as Connected then nothing needs to be done. Enter:
<pre style="font-family:courier">quit</pre>
Access the win1 computer.


Click on Start then select NI Max.
to exit from telnet


[[File:Start-NIMAX.png]]
If the connection is listed as err-disabled then proceed with the following steps. At the telnet terminal issue the commands:
<pre style="font-family:courier">enable</pre>


Goto Remote Systems and then select the CRIO that is not communicating.
and enter the password.
<pre style="font-family:courier">
configure ter
interface fa0/#
</pre>


[[File:NIMAX.png]]
where # is the port number.


Click the System Settings tab at the bottom of the window. Status should be listed as <span style="font-family:courier">Connected - Running</span>
<pre style="font-family:courier">shutdown
no shutdown
end
</pre>


[[File:NIMAX-settings.png]]
You can then reissue the show inter command to see if the interface is running. The port light should also be blinking on the server.


Click on Refresh to reconnect.
Issue then command
<pre style="font-family:courier">quit</pre>


The CRIO will have an IP address in the range of 192.168.24.41 to 192.168.24.53. If it is not working this IP address will be strange. Click Restart.
to exit telnet.


From the Schedule on Helios issue the command
===== Resetting antenna parameters =====


:<p style="font-family:courier">sync ant#</p>
If the antenna still will not start goto the following webpage:
<pre style="font-family:courier">http://ant#.solar.pvt</pre>


where # is the antenna number.
Click Login and then enter the username and password.


If the communications are still not restored, you will need open Labview.
Click Parameters and the change Option 10.00 to 1070 and Option 10.38 to 100. Click on change.


If it is not already open, Click Start then NI Labview 2015.
Then click on logout.


[[File:Start-NI-Labview.png]]
After the above procedures are completed you will need to reload the track table. This is done from the State Frame display using the following commands (again ensure that ant5 is replaced with the appropriate antenna):


The LabView start screen will appear after a few seconds.
<pre style="font-family:courier">
tracktable pcal_tab.radec ant5
font-family:courier">track ant5
</pre>


[[File:NI-Labviewstrtscrn.png]]
===== Antenna Communications Failure =====


Click on the Operate menu option and then select Debug Application or Shared Library.
If an antenna is highlighted in the Communications section of the State-Frame display then the following procedure can be used to correct it.


[[File:LV-Op-debug.png]]
From the Schedule on Helios enter the command
<pre style="font-family:courier">$pcycle crio ant2</pre>


Once the new window opens type in the name of the CRIO in the Machine Name or IP Address box. Then click Refresh. The file startup.rtexe should appear. Click on Connect.
and wait about 2 minutes.  


'''<span style="color:red">Note that if a message similar to 'No debuggable application found' is displayed you may need to click on refresh several times. When it first reboots it will say it cannot find any debuggable applications, and then at some point it comes back with startup.exe. But if you wait too long it ends up in software safe mode (it will display "Safe Mode" next to Running) and you will need to click on "Restart" in the NI-Max program and click refresh on the Labview program until you see startup.exe, wait for a few seconds and then hit the button to load the debug software.</span>'''
From the Schedule on Helios issue the command


[[File:LV-debugstart.png]]
<pre style="font-family:courier">sync ant#</pre>


In the new window that opens check that the time is updating and that the time is correct an updating and that the Run index is updating. The Exec States should all be set to Run.
for the newer antennas or


[[File:Crio-debug.png]]
<pre style="font-family:courier">sync-motion ant#</pre>


At the top of the screen click on the Stop Icon and then the Go icon (the arrow).
for the older antennas where # is the antenna number.


From the Schedule on Helios issue the command
If this does not resolve the communications problem, then proceed with the procedure below.
:<p style="font-family:courier">sync ant#</p>
Access the win1 computer.


or
Click on Start then select NI Max.  
:<p style="font-family:courier">sync-motion ant#</p>
where # is the antenna number, depending on whether it is a new or old antenna.


To exit from the Debug session, right click on an empty part of the form which will bring up Remote Debugging. Click on this and then select Quit Debug Session.
[[File:Start-NIMAX.png]]


[[File:LV-debug-close.png]]
Goto Remote Systems and then select the CRIO that is not communicating.


If the above procedure has not worked, then from the debug session, right click on an empty part of the window and then click on Remote Debugging and then Show Block Diagram.
[[File:NIMAX.png]]


[[File:LV_show_block_diagram.png]]
Click the System Settings tab at the bottom of the window. Status should be listed as <span style="font-family:courier">Connected - Running</span>


This will bring up the block diagram. Double click on the left bottom icon.
[[File:NIMAX-settings.png]]


[[File:LV_comm_icon.png]]
Click on Refresh to reconnect.


This brings up the cRIO antenna VI.
The CRIO will have an IP address in the range of 192.168.24.41 to 192.168.24.53. If it is not working this IP address will be strange. Click Restart.


[[File:Crio_ant_vi.png]]
From the Schedule on Helios issue the command


Click on the stop button. It should restart in a few seconds automatically. Close the opened windows except for the Debug session (click on an empty part of the form then Remote Debuggingthen Quit Debug Session).
<pre style="font-family:courier">sync ant#</pre>


If all else fails, restart the CRIO from the Viking unit.
where # is the antenna number.


===== Restarting the Viking Unit =====
If the communications are still not restored, you will need open Labview.
The Viking units control power to the various systems (Antenna, Front End and CRIO). To recycle power to a particular system, goto the webpage


:<p style="font-family:courier">http://vik#.solar.pvt</p>
If it is not already open, Click Start then NI Labview 2015.


where # is the antenna number. Enter the username and password. The following screen should appear:
[[File:Start-NI-Labview.png]]


[[File:Viking.png]]
The LabView start screen will appear after a few seconds.


Note that when the relays are off, power is being supplied to the indicated system. In the image above, all relays are off so each system is powered.
[[File:NI-Labviewstrtscrn.png]]


To recycle power to a particular system, click on the circle next to the system. If the circle was red initially, it will go green, and vice-versa. If you are turning the relay on then wait ten seconds before turning the relay off again. Ensure that the relay is Off (red) before logging out.
Click on the Operate menu option and then select Debug Application or Shared Library.


===== Ant 12 Cable Wrap =====
[[File:LV-Op-debug.png]]
From time to time, Ant 12 may get past its limits and get into the wrong "turn."  If this happens, the cables can be unwrapped using the hand controller, but doing that does not reset the "turn" indicator (parameter 20.17).  After manually unwrapping in this way, go to the antenna web page (or the Ant12_ACI interface on the win1 machine) and check the value of parameter 20.17.  If it says 2, it means it is on the wrong turn (should be 1).  In that case, attempting to STOW or TRACK the antenna will only make it try to unwrap and end up stuck at the north limit.  If this happens, manually move the antenna back to the south point with the hand controller, and then check the value of parameter 20.17.  If it is not now 1, you may have moved the antenna in the wrong direction.  Once it is back to 1, check the parameter 20.15, which is the encoder zero.  Add or subtract 360 degrees to that value and set the 20.15 parameter to the new value.  For example, on 8/17/2021, the encoder zero was -29, so we set it to 331.  Next time it happens, we would probably set the value back to -29.  In any case, after changing the parameter, the dish should STOW properly.


=== Receiver Trouble Shooting and Repair ===
Once the new window opens type in the name of the CRIO in the Machine Name or IP Address box. Then click Refresh. The file startup.rtexe should appear. Click on Connect.


==== Positioning the Antenna ====
'''<span style="color:red">Note that if a message similar to 'No debuggable application found' is displayed you may need to click on refresh several times. When it first reboots it will say it cannot find any debuggable applications, and then at some point it comes back with startup.exe. But if you wait too long it ends up in software safe mode (it will display "Safe Mode" next to Running) and you will need to click on "Restart" in the NI-Max program and click refresh on the Labview program until you see startup.exe, wait for a few seconds and then hit the button to load the debug software.</span>'''
If working on a newer antenna follow the instructions here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_New_Antennas_Manually


If working on an older antenna follow the instructions here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_Old_Antennas_Manually
[[File:LV-debugstart.png]]


==== Removing the Receiver ====
In the new window that opens check that the time is updating and that the time is correct an updating and that the Run index is updating. The Exec States should all be set to Run.
Switch off the power to the receiver at the auxiliary box by pulling down the two breakers.


[[File:auxboxbreakers.jpg]]
[[File:Crio-debug.png]]


Below is an image of the tools required for removing the receiver.
At the top of the screen click on the Stop Icon and then the Go icon (the arrow).


[[File:rectools.png]]
From the Schedule on Helios issue the command
<pre style="font-family:courier">sync ant#</pre>


'''Whenever touching the receiver ensure that the Anti-static strap is worn and grounded!'''
or
<pre style="font-family:courier">sync-motion ant#</pre>


Loosen the nuts on bolts that attach the receiver to the feed almost the entire way but leave them on the bolts. The feed can be pressed forward to give enough room to detach the SMA cables.
where # is the antenna number, depending on whether it is a new or old antenna.


[[File:recbolts.png]]
To exit from the Debug session, right click on an empty part of the form which will bring up Remote Debugging. Click on this and then select Quit Debug Session.


Carefully disconnect the SMA cables from the feed. Note the position of the horizontal and vertical polarisation cables.  
[[File:LV-debug-close.png]]


[[File:smacablesfeed.png]]
If the above procedure has not worked, then from the debug session, right click on an empty part of the window and then click on Remote Debugging and then Show Block Diagram.


Place caps on the end of the SMA cables.
[[File:LV_show_block_diagram.png]]


[[File:smacablescapped.png]]
This will bring up the block diagram. Double click on the left bottom icon.


Carefully remove all of the cables from the back of the receiver.
[[File:LV_comm_icon.png]]


[[File:Reccables.png]]
This brings up the cRIO antenna VI.


Place a cap on the fibre optic port and the fibre optic cable.
[[File:Crio_ant_vi.png]]


[[File:Fibrecablecapped.png]]    [[File:Fibreportcapped.png]]
Click on the stop button. It should restart in a few seconds automatically. Close the opened windows except for the Debug session (click on an empty part of the form then Remote Debuggingthen Quit Debug Session).


Remove the nuts entirely.
If all else fails, restart the CRIO from the Viking unit.
Remove the 3 allen bolts.


[[File:recallenbolts.png]]
===== Restarting the Viking Unit =====
The Viking units control power to the various systems (Antenna, Front End and CRIO). To recycle power to a particular system, goto the webpage


The receiver can now be taken into the lab for testing or repair.
<pre style="font-family:courier">http://vik#.solar.pvt</pre>


==== Opening the Receiver ====
where # is the antenna number. Enter the username and password. The following screen should appear:
'''Ensure you are grounded with the anti-static strap!'''


Remove removing the bolts from the stoppers, but keep the stoppers in place. Once removed the triangular front mounting bracket will slide off.
[[File:Viking.png]]


[[File:recstoppers.png]]
Note that when the relays are off, power is being supplied to the indicated system. In the image above, all relays are off so each system is powered.


Recessed into the case are 6 screws that need to be undone. the location of 4 of these are shown in the image below. Loosen the screws using a Phillips head screwdriver. The will no come all the way out.
To recycle power to a particular system, click on the circle next to the system. If the circle was red initially, it will go green, and vice-versa. If you are turning the relay on then wait ten seconds before turning the relay off again. Ensure that the relay is Off (red) before logging out.


[[File:reccasescrews.png]]
===== Ant 12 Cable Wrap =====
From time to time, Ant 12 may get past its limits and get into the wrong "turn."  If this happens, the cables can be unwrapped using the hand controller, but doing that does not reset the "turn" indicator (parameter 20.17).  After manually unwrapping in this way, go to the antenna web page (or the Ant12_ACI interface on the win1 machine) and check the value of parameter 20.17.  If it says 2, it means it is on the wrong turn (should be 1).  In that case, attempting to STOW or TRACK the antenna will only make it try to unwrap and end up stuck at the north limit.  If this happens, manually move the antenna back to the south point with the hand controller, and then check the value of parameter 20.17.  If it is not now 1, you may have moved the antenna in the wrong direction.  Once it is back to 1, check the parameter 20.15, which is the encoder zero.  Add or subtract 360 degrees to that value and set the 20.15 parameter to the new value.  For example, on 8/17/2021, the encoder zero was -29, so we set it to 331.  Next time it happens, we would probably set the value back to -29.  In any case, after changing the parameter, the dish should STOW properly.


Place the receiver on it side and cautiously partially open the case. The SMA cable connecting the two halves together needs to be disconnected before the case can be fully opened. Carefully loosen the SMA cable on the Horizontal polarisation side and disconnect the cable.
=== Receiver Trouble Shooting and Repair ===
==== Removing the Front End Module (FEM)====
===== Positioning the Antenna =====
If working on a newer antenna follow the instructions here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_New_Antennas_Manually


[[File:Recinternalsmacable.png]]
If working on an older antenna follow the instructions here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_Old_Antennas_Manually


Cautiously fully open the case.
===== Removing the FEM =====
There is a full replica of the Auxiliary box under the bench. If testing is to be performed then this will need to be connected. Note that the CRIO out at the antenna will also need to be powered on. Ensuring that the power is off, connect the cables to the receiver.
Switch off the power to the receiver at the auxiliary box by pulling down the two breakers.


'''Whenever disconnecting or connecting components to the receiver, ensure that the power is off!'''
[[File:auxboxbreakers.jpg]]


[[File:Auxrep.png]] [[File:Cablesconnected.png]]
Below is an image of the tools required for removing the receiver.


Reconnect the SMA cable between the two halves of the receivers.
[[File:rectools.png]]


==== Connecting the Power Meter ====
'''Whenever touching the receiver ensure that the Anti-static strap is worn and grounded!'''


If required for testing, the power meter will need to be connected to the either the horizontal or vertical polarisation. The power meter is normally kept in the correlator room.
Loosen the nuts on bolts that attach the receiver to the feed almost the entire way but leave them on the bolts. The feed can be pressed forward to give enough room to detach the SMA cables.


[[File:Powermeter.jpg]]
[[File:recbolts.png]]


Connect the power meter to the appropriate polarisation as shown below.
Carefully disconnect the SMA cables from the feed. Note the position of the horizontal and vertical polarisation cables.  


[[File:Powermeterconnected.jpg]]
[[File:smacablesfeed.png]]


==== Replacing the LNA ====
Place caps on the end of the SMA cables.


Ensure that power is off to the receiver.
[[File:smacablescapped.png]]
The LNA locations is shown below. It is in the same place on the other half of the receiver for the other polarisation.


[[File:LNAinrec.jpg]]
Carefully remove all of the cables from the back of the receiver.


Carefully unsolder the black and red wires connected to the LNA.
[[File:Reccables.png]]


Undo the nuts on either side of the LNA. To undo they will move towards the LNA.
Place a cap on the fibre optic port and the fibre optic cable.


Remove the allen bolts fixing the LNA to the case.
[[File:Fibrecablecapped.png]]    [[File:Fibreportcapped.png]]


Carefully remove the LNA.
Remove the nuts entirely.
Remove the 3 allen bolts.


Add some silicone heat sink compound to the base of the new LNA.
[[File:recallenbolts.png]]


Repeat the process in reverse to install the new LNA.
The receiver can now be taken into the lab for testing or repair.


=== Brightscram Adjustment ===
===== Opening the FEM Case =====
Occasionally, the brightscram sensors will need to be tested or adjusted. A clear day with full sun is required for this adjustment. Antennas 1 to 8 have a bright scram sensor.
'''Ensure you are grounded with the anti-static strap!'''


There are two major components to the brightscram sensor: The buffer board and the sensor. The sensor is located on the antenna feed as shown in the image below.
Remove removing the bolts from the stoppers, but keep the stoppers in place. Once removed the triangular front mounting bracket will slide off.


[[File: Brightscram sensor.jpg]]
[[File:recstoppers.png]]


The sensor needs to be aligned with the point of the feed.
Recessed into the case are 6 screws that need to be undone. the location of 4 of these are shown in the image below. Loosen the screws using a Phillips head screwdriver. The will no come all the way out.


The buffer board is located in the auxiliary box as shown below.
[[File:reccasescrews.png]]


[[File: BufferBoard.jpg]]
Place the receiver on its side and cautiously partially open the case. The SMA cable connecting the two halves together needs to be disconnected before the case can be fully opened. Carefully loosen the SMA cable on the Horizontal polarisation side and disconnect the cable.


Refer to the annotated image below and follow the procedure below to adjust the brightscram settings.
[[File:Recinternalsmacable.png]]


[[File: Buf board bscram.jpg]]
Cautiously fully open the case.
There is a full replica of the Auxiliary box under the bench. If testing is to be performed then this will need to be connected. Note that the CRIO out at the antenna will also need to be powered on. Ensuring that the power is off, connect the cables to the FEM.


:With the antenna pointing at the Sun, measure the voltage between V<sub>sense</sub> and Ground.
'''Whenever disconnecting or connecting components to the receiver, ensure that the power is off!'''


:Measure the voltage between V<sub>trig</sub> (Pin 2 on the U8 chip) and ground.
[[File:Auxrep.png]] [[File:Cablesconnected.png]]


:Adjust this voltage by turning the screw on Trig Adj (labelled VR3 on the board). The Voltage here should be about 0.05 V '''BELOW''' that of V<sub>Sense</sub>.
Reconnect the SMA cable between the two halves of the receivers.


:Once done, using the spray container, wet the dish. The dish should move off the sun and return 10 minutes later. If it does not, you will need to adjust V<sub>trig</sub> until it does.
===== Power Meter Benchtest =====
The purpose of this test is to find the relationship between voltage (V) and power (dBm) of the front end. The coefficients for the curve fit need to be placed into the crio.ini file for the appropriate antenna.  


=== UPS Battery Replacement ===
The power meter will need to be connected to the either the horizontal or vertical polarization. The power meter is normally kept in the correlator room.
Periodically, the batteries on the Uninterruptable Power Supplies (UPS) will need replacing. There are 4 in total: one in each of the four central racks and one in the network rack. The LCD  at the front of the UPS will display a message when the batteries need to be replaced as shown below.


[[File:UPS_Batt_Warning.jpg]]
Always have the anti-static cable conected when working on an FEM.


Below is an annotated image of the UPS front panel showing the important components.
[[File:Power Meter 1.jpg]]


[[File:UPS_Front_Panel.jpg]]
:1. Plug in the power meter to a power point.


To remove the battery pack, follow the instructions below.
:2. Retrieve the 25 foot serial cable and connect one end to the back of the Power Meter.


:Undo the three screws on the front chasis.
:[[File:Power_Meter_Back.jpg]]


:Disconnect the blue battery connector.
:3. Retrieve the USB to serial cable. Connect the serial end to the serial cable and the USB end to a USB2 port on helios.


:Lift the battery back and pull out. '''Be careful! It is heavy!.'''
:[[File:Power_Meter_Helios.jpg]]


:See the image below of the removed battery pack.
:4. Press the power button on the power meter and wait for it to display the power (in dBm).


[[File:BattPack_removed.jpg]]
:5. Press the Cal/Zero button and the the zero softkey (right of the display).


:Remove the top cover by undoing the screws at either end of the tray. The image below shows the batteries within the tray.
:6. Remove the end of the power sensor head.


[[File:UPS-Batteries.jpg]]
:[[File:Power_Meter_Sensor.jpg]] [[File:Power_Meter_End_Removed.jpg]]


=== Resetting the ManLight ===
:7. Connect the sensor to the calibration port of the power meter and press the Cal softkey. Wait for the calibration to complete
Detach the serial cable from the ACC and connect to a serial to USB adapter. Connect this to the laptop.


Check the serial ports in Device manager  to obtain the com port number.
:[[File:Power_Meter_Calibration.jpg]]


Click on Start -> PRD Serial -> main.exe.
:8. Disconnect the sensor from the calibration port and reconnect the end.


Select Setup and change COM1 to the appropriate port.
:9. Disconnect the cable from the RF input of the optical link for the polarization that is to be tested.


In the Enables tab disable IP, IT and ITF monitor ports.
:[[File:FEM_RF.jpg]] [[File:Powermeterconnected.jpg]]


Start the program running by clicking on the arrow in the upper left.
:10. Turn on the FEM.


In the Control tabs set the following:
:11. From a Helios terminal enter the following commands:


:'ACC mode pump current 1' to 250 and press the LOAD button.
<pre style="font-family:courier">
cd Dropbox/PythonCode/owen/
conda activate /common/anaconda2/envs/py3.10
PYTHONPATH=/common/python/
ipython --pylab
import benchtest
</pre>


:'AM - EDFA Mode' to ACC - constant current and press the load button.
:12. To start the benchtest enter the following command:
<pre style="font-family:courier">benchtest.benchtest(ant, pol, verbose=True)</pre>


:'LO - loss Output Power Alarm threshold' to 20 and press the load button.
:where ant is the antenna number, pol is the polarization. For example to perform a benchtest on ant10 H-Pol you would issue the command:
<pre style="font-family:courier">benchtest.benchtest(10, 'H', verbose=True)</pre>


If any load button does not underpress, the GUI is hung up and rebooting the computer may be necessary. In that case you can start where you left off.
:13. The benchtest should take about two minutes to complete.


== Antenna A Power Outage and Reset ==
:14. If you see the error:
=== Recycling Power to Antenna A ===
<pre style="font-family:courier">Cannot read from port 6341</pre>


To recycle power to Antenna A goto http://pduanta.solar.pvt and enter the username and password.
:just restart the benchtest (step 12)


There will be eight devices that can be chosen from. Click <span style="font-family:courier">Cycle</span> to recycle the power to the appropriate option.
:15. Once complete, turn off the FEM.


You may need to follow the procedure below to bring Antenna A back to operation.
:16. If required connect the power meter to the other polarization and repeat the benchtest. Ensure you reconnect the RF cable to the optical link.


=== Recovering Antenna A from a Power Outage ===
:17. The data file are currently stored in <span style="font-family:courier">/home/helios/Dropbox/PythonCode/owen</pre>. Find the most recent file for each polarization that was just tested.</span>


On the Stateframe display click on the CryoRX tab. This will bring up the display shown below.
:18. To get the coefficient, in ipython enter the following command:
<pre style="font-family:courier">benchtest.benchtest_anal(filename)</pre>
:For example:
<pre style="font-family:courier">benchtest.benchtest_anal('20240607T165026_10_H_benchtest.csv')</pre>


[[File:CryoRXdisp.png]]
:A plot will be displayed and the coefficients shown in the terminal for the given polarization.


==== Recycling Power to the FEM ====
[[File:Example_PM_Benchtest.png]]
Login to the feanta machine as follows:
:<p style="font-family:courier">ssh antctl@feanta</p>


If the FEM Outlets on the CryoRX window are marked as Off then from a Helios terminal:
<pre style="font-family:courier">
HPol.c0 =  6.0492718
HPol.c1 =  6.6828002
HPol.c2 =  0.0150576
HPol.c3 =  0.3935591
HPol.c4 =  0.0990589
</pre>


Then type in the command:
:19. Repeat for the other polarization if needed.
:<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl start</p>


Otherwise recycle the power to the FEM as follows:
:20. To upload the coefficents to the crio, first exit ipython and the python3 environment.
:<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl stop</p>
<pre style="font-family:courier">
exit
source deactivate
source deactivate
</pre>


Wait about 10 seconds and the issue the start command:
:21. Change to the <spanstyle="font-family:courier">Current</span> folder, change the python path and Restart ipython.
:<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl start</p>
<pre style="font-family:courier">
cd /home/sched/Dropbox/PythonCode/Current
PYTHONPATH=/common/python/current/
ipython --pylab
</pre>


Once done type in:
:22. Retrieve the current <span style="font-family:courier">crio.ini</span> file for the benchtest antenna.
:<p style="font-family:courier">exit</p>
<pre style="font-family:courier">
import crio
crio.save_crio_ini(ant_str)
</pre>


==== Recycling Power to the Brick ====
:For example, to get the file for antenna 10:
If faults are showing on the Motor section (4th green line down) the Brick power will need to be recycled. To do this issue the following commands from the Schedule Window:
<pre style="font-family:courier">
:<p style="font-family:courier">outlet 3 off ant14</p>
import crio
:<p style="font-family:courier">outlet 3 on ant14</p>
crio.save_crio_ini('ant10')
</pre>


==== Restarting the LNAs ====
:23. In a file manager navigate to the <span style="font-family:courier">/home/sched/Dropbox/PythonCode/Current/crio_inis</span> and double click on the most recent file for the benchtest antenna.
From a Helios terminal:
:<p style="font-family:courier">ssh root@lna14.solar.pvt</p>


If you get an error "No route to host" you will need to restart the computer at the 27m antenna by issuing the commands below from the Schedule Window:
:24. Find the block labelled <span style="font-family:courier">[FEM Power Scale]</span> and replace the HPOL and VPOL values with those from the benchtest. Save the file and exit.
:<p style="font-family:courier">outlet 6 off ant14</p>
:<p style="font-family:courier">outlet 6 on ant14</p>


Then issue the command from the terminal:
:25. From ipyhton, reload the ini file to the crio.
:<p style="font-family:courier">./killAll python</p>
<pre style="font-family:courier">
crio.reload_crio_ini(ant_str)
</pre>


Then press the up arrow until the most recent python command is found and press enter. Text will scroll up continuously
:For example, to reload the file for antenna 10:
Just type <span style="font-family:courier">exit</span> even with the text scrolling to exit the ssh session.
<pre style="font-family:courier">
crio.reload_crio_ini('ant10')
</pre>


From Schedule issue the command:
:<p style="font-family:courier">$lna-init ant14</p>


The Drain Voltage for Hi H will be incorrect (~.61 when it should be 1.2). To correct this, from Schedule issue:
:<p style="font-family:courier">lna drain hh 2.4 ant14</p>


==== Aligning the Receivers ====
'''<span style="color:#FF0000">Only do this once Mark Hodges has confirmed that he does NOT have the external vacuum pump connected!</span>'''


The receivers must be properly aligned. From Schedule send the command:
:<p style="font-family:courier">frm-home ant14</p>


If the receivers do not home properly, you will need to cycle power on the brick: http://ovsa.njit.edu//wiki/index.php/Owen%27s_Notes#Recycling_Power_to_the_Brick
</pre>


It will take a few minutes for the FRM to find its home position. Once it has send the command:
==== Replacing the LNA ====
:<p style="font-family:courier">frm-set-pa 0 ant14</p>


to zero the positions.
Ensure that power is off to the receiver.
The LNA locations is shown below. It is in the same place on the other half of the receiver for the other polarisation.


Set the Hi Receiver:
[[File:LNAinrec.jpg]]
:<p style="font-family:courier">rx-select hi ant14</p>


==== Ant A Maths Error ====
Carefully unsolder the black and red wires connected to the LNA.
Goto the webpage <span style="font-family:courier">https://ant14.solar.pvt</span>. You should get to the screen as shown below:


[[File:AntA-Web-Home.png]]
Undo the nuts on either side of the LNA. To undo they will move towards the LNA.


Ensure that on the left under the SP image that there is a green 'Ready' message.
Remove the allen bolts fixing the LNA to the case.


If there is a Maths Error then follow the following procedure.  
Carefully remove the LNA.


Click on the Login tab and enter the username and password.
Add some silicone heat sink compound to the base of the new LNA.


Click on the Parameter tab to see the following screen:
Repeat the process in reverse to install the new LNA.


[[File:AntA-Web-Param-Opt10-marked.png]]
=== Brightscram Adjustment ===
Occasionally, the brightscram sensors will need to be tested or adjusted. A clear day with full sun is required for this adjustment. Antennas 1 to 8 have a bright scram sensor.


Click on view next to #10.
There are two major components to the brightscram sensor: The buffer board and the sensor. The sensor is located on the antenna feed as shown in the image below.


At the next screen click on view next to Item #10.00:
[[File: Brightscram sensor.jpg]]


[[File:AntA-Web_Opt10.00-marked.png]]
The sensor needs to be aligned with the point of the feed.


In the Update Value box enter 1070 and click on Change
The buffer board is located in the auxiliary box as shown below.


Click on the arrow near the top of the page to return to menu 10.
[[File: BufferBoard.jpg]]


Click on View next to Item #10.38
Refer to the annotated image below and follow the procedure below to adjust the brightscram settings.


In the Update Value box enter 100 and click on Change.
[[File: Buf board bscram.jpg]]


=== Preventing the Receiver from Moving During Maintenance ===
:With the antenna pointing at the Sun, measure the voltage between V<sub>sense</sub> and Ground.
During some types of maintenance, the receiver should not be moved. To prevent this from happening, log into feanta:


:<p style="font-family:courier">ssh antctl@feanta</p>
:Measure the voltage between V<sub>trig</sub> (Pin 2 on the U8 chip) and ground.


and then issue the command:
:Adjust this voltage by turning the screw on Trig Adj (labelled VR3 on the board). The Voltage here should be about 0.05 V '''BELOW''' that of V<sub>Sense</sub>.


:<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl stop</p>
:Once done, using the spray container, wet the dish. The dish should move off the sun and return 10 minutes later. If it does not, you will need to adjust V<sub>trig</sub> until it does.


Type <span style="font-family:courier">exit<span> to end the feanta session.  
=== UPS Battery Replacement ===
Periodically, the batteries on the Uninterruptable Power Supplies (UPS) will need replacing. There are 4 in total: one in each of the four central racks and one in the network rack. The LCD  at the front of the UPS will display a message when the batteries need to be replaced as shown below.


To reactivate, log back into feanta and send the command:
[[File:UPS_Batt_Warning.jpg]]
:<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl start</p>


Note that this resets every evening. If a shutdown is required for longer than that then feanta may need to be shutdown.
Below is an annotated image of the UPS front panel showing the important components.


== Site Wide Power Outage ==
[[File:UPS_Front_Panel.jpg]]
Most of the procedures to recover from a site wide power outage are covered above. Below are the the steps required in order.


=== 27m Antenna (Antenna A) ===
To remove the battery pack, follow the instructions below.


Refer to the procedure here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Recovering_Antenna_A_from_a_Power_Outage
:Undo the three screws on the front chasis.


=== 2m Antennas (Antennas 1-13) ===
:Disconnect the blue battery connector.


For any antennas that have a communications failure (highlighted in red in the communications section of the Stateframe Display) follow the procedures here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Antenna_Communications_Failure
:Lift the battery back and pull out. '''Be careful! It is heavy!.'''


It may take some time for the CRIOs to restart. If after 20 minutes a CRIO has not restarted, redo the procedure.
:See the image below of the removed battery pack.


Stop the schedule by clicking on the stop button.
[[File:BattPack_removed.jpg]]


Stow the antennas by issuing the command
:Remove the top cover by undoing the screws at either end of the tray. The image below shows the batteries within the tray.
:<p style="font-family:courier">stow</p>


If some of the antennas did not stow the refer to Antenna trouble shooting: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Antenna_Trouble_Shooting
[[File:UPS-Batteries.jpg]]


If an antenna is highlighted in the Power and Attenuation section on the stateframe display then you may need to reload the .ini file to the CRIO as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Warning_on_Power_and_Attenuation
=== Resetting the ManLight ===
Detach the serial cable from the ACC and connect to a serial to USB adapter. Connect this to the laptop.


== Data Backup ==
Check the serial ports in Device manager  to obtain the com port number.
=== Local IDB File Backup ===
Periodically IDB files will need to be moved from pipeline. Currently these are being stored on NAS4. Typically a year of data will be copied. Follow the procedure below (replace nas4 with the appropriate drive):


:Login to pipeline. an then issue the command:
Click on Start -> PRD Serial -> main.exe.
::<p style="font-family:courier">screen -S filecopy</p>
:Enter the command;
::<p style="font-family:courier">cp -r -v /data1/eovsa/fits/IDB/yyyy* /nas4/IDB/</p>
:where yyyy is the year of the files to copy.
:Press <CRTL>AD to exit the screen


=== Caltech IDB File Backup ===
Select Setup and change COM1 to the appropriate port.
IDB files are copied onto two USB drives and mailed to Caltech. The drives hold approximately three months of IDB data. Use the following procedure to copy the files.


:Connect the USB drives to your local computer. Make a note of the last file on the disk. Delete all of the IDB, FDB and IFDB files from the drives.
In the Enables tab disable IP, IT and ITF monitor ports.
:Connect the drive to the USB port at the back of the pipeline machine.
:Login to the user account on pipeline.
:List the available drives by typing the command:
::<p style="font-family:courier">sudo fdisk -l</p>
:A list of drives will appear. Find the line similar to the one below:
::<p style="font-family:courier">/dev/sdc1  2048 7813969919 7813967872  3.7T Microsoft basic data</p>
:Note that the device might be different to /dev/sdc1, but it will be the 3.7T drive. In the rest of these instructions assumes that the device is /dev/sdc1. Replace this with whatever is the appropriate device.
:Mount the USB drive:
::<p style="font-family:courier">sudo mount /dev/sdc1 /media/IDB-backup1</p>
:Open the IDB backup script using nano:
::<p style="font-family:courier">nano owen/archiveIDB.sh</p>
:Find the two lines similar to:
::<p style="font-family:courier">start=$(date -d "2020-09-13" +%Y%m%d)</p>
::<p style="font-family:courier">end=$(date -d "2020-12-31" +%Y%m%d)</p>
:Change the start date to the day after the last date of the previous data copy and the end date to 3 months further on.
:Press [CTRL][X] and the Y to exit and save the file.
:If a screen named filecopy does not exist then issue the following command:
::<p style="font-family:courier">screen -S filecopy</p>
:If the screen does exist then
::<p style="font-family:courier">screen -r filecopy</p>
:To start the filecopy issue the following commands:
::<p style="font-family:courier">cd ~/owen</p>
::<p style="font-family:courier">./archiveIDB.sh</p>
:You can then press [CTRL][a][d] to exit the screen.
Once the copy has been completed, unmount the drive:
:<p style="font-family:courier">sudo umount /media/IDB-backup1</p>
Repeat the process for the second drive.


=== Common Files ===
Start the program running by clicking on the arrow in the upper left.
The common folder on Helios is backed up automatically on Sundays at midnight. This backup is stored on the nas2 drive. To manually back up the folder, issue the following commands from a helios terminal:


::<p style="font-family:courier">screen -S commoncopy</p>
In the Control tabs set the following:
:Enter the command:
::<p style="font-family:courier">rsync -av --delete --progress --log-file=/home/sched/rsynclogs/rsync_common.log -e ssh /common/ user@pipeline:/nas2/common/</p>
:Press <CRTL>AD to exit the screen


Output from rsync is logged in <span style="font-family:courier">/home/sched/rsynclogs/rsync_common.log<span>
:'ACC mode pump current 1' to 250 and press the LOAD button.


=== Crontab Backups ===
:'AM - EDFA Mode' to ACC - constant current and press the load button.
The crontab files are backed up on nas2 in the crontabs folder.


The helios crontab is stored in <span style="font-family:courier">helios_cron</span>
:'LO - loss Output Power Alarm threshold' to 20 and press the load button.


The pipeline crontab is stored in <span style="font-family:courier">pipeline_cron</span>
If any load button does not underpress, the GUI is hung up and rebooting the computer may be necessary. In that case you can start where you left off.
 
=== Spectrogram on Webpage not updating ===
If the EOVSA spectrogram on the [http://ovsa.njit.edu/status.php observing status] page is not updating and IDB files are being created then it is likely a corrupted FDB file. To fix this follow the instructions below.
 
:From a dpp terminal change to the /data1/FDB directory
 
<pre style="font-family:courier">
cd /data1/FDB
</pre>
 
:Use nano to edit the current FDB file
<pre style="font-family:courier">
nano FDByyyymmdd.txt
</pre>
:where yyyy is the year, mm is the month and dd is the day for the current date.


The dpp crontab is stored in <span style="font-family:courier">dpp_cron</span>
:Good lines in this file will look similar to:
<pre style="font-family:courier">
IDB20240630020518  240629233014 Sun^@^@^@^@^@^@^@^@^@ NormalObserving^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@
  895868450  895896900  1719713118      0  1719713687      0  3802557918.  3802558487.
IDB20240630021517  240629233014 Sun^@^@^@^@^@^@^@^@^@ NormalObserving^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@
  895898450  895903600  1719713718      0  1719713821      0  3802558518.  3802558621.
IDB20240630022119  240630022111 1229+020^@^@^@^@ PHASECAL^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@
  895916550  895942000  1719714080      0  1719714589      0  3802558880.  3802559389.
</pre>


== Location of IDB and Associated Files ==
:Bad lines will often have all fields populated with zeros and *'s in them.


{|class="wikitable" style="text-align: center;"
:Simply delete the bad lines.
|+ style="caption-side:top;"|''IDB File Locations''
!Date Range||Location
|-
|2014 to 2015||nas3/IDB2014-15
|-
|2016-01-01 to 2016-07-31||nas1
|-
|2016-08-01 to 2016-11-30||nas2
|-
|2016-12-01 to 2021-02-28||nas3/IDB
|-
|2021-03-01 to 2021-12-31||nas4/IDB
|-
|}


{|class="wikitable" style="text-align: center;"
:Press <CRTL><x> to exit and <y> when prompted to save.
|+ style="caption-side:top;"|''FDB File Locations''
!Date Range||Location
|-
|2013-12-19 to 2015012031||nas3/FDB2014-15
|-
|2016-01-01 to 2016-07-31||nas1/FDB
|-
|2016-08-01 to 2016-11-30||nas2/FDB
|-
|2016-12-01 to 2021-02-28||nas3/FDB
|-
|2021-03-01 to 2021-12-31||nas4/FDB
|-
|}


{|class="wikitable" style="text-align: center;"
:Within 10 minutes the webpage should have updated.
|+ style="caption-side:top;"|''IFDB File Locations''
!Date Range||Location
|-
|2014-01-24 to 2015012031||nas3/IFDB2014-15
|-
|2016-01-01 to 2016-07-31||nas1/IFDB
|-
|2016-08-01 to 2016-11-30||nas2/IFDB
|-
|2016-12-01 to 2021-02-28||nas3/IFDB
|-
|2021-03-01 to 2021-12-31||nas4/IFDB
|-
|}


== Schedule Command Description ==
== Antenna A Power Outage and Reset ==
=== Recycling Power to Antenna A ===


NOTE: All Schedule commands accept as optional arguments a list of antennas to which the command should selectively sent. Accepted syntaxes are:
To recycle power to Antenna A goto http://pduanta.solar.pvt and enter the username and password.


Command ant1 ant2 ant3
There will be eight devices that can be chosen from. Click <span style="font-family:courier">Cycle</span> to recycle the power to the appropriate option.


Command ant1-3
You may need to follow the procedure below to bring Antenna A back to operation.


Command subarray1
=== Recovering Antenna A from a Power Outage ===


Command subarray2
On the Stateframe display click on the CryoRX tab. This will bring up the display shown below.


If no antenna list is indicated, the command is sent to all antennas currently in subarray1.
[[File:CryoRXdisp.png]]


These commands can be found in the <span style="font-family:courier">~/Dropbox/EOVSA\ M\&C/EOVSA\ Schedule\ Commands.docx</span> and <span style="font-family:courier">~/Dropbox/OVSA\ Expansion/Design/Antennas/Ant_A\&B_Commands.pdf</span> files.
==== Recycling Power to the FEM ====
Login to the feanta machine as follows:
<pre style="font-family:courier">ssh antctl@feanta</pre>


=== Commands handled directly by ACC ===
If the FEM Outlets on the CryoRX window are marked as Off then from a Helios terminal:


<p style="color:#0000FF">'''ABORT'''</p>
Then type in the command:
:Aborts all commands sent to ACC but not yet executed
<pre style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl start</pre>


<p style="color:#0000FF">'''CLEAROFF [antenna list]'''</p>
Otherwise recycle the power to the FEM as follows:
:Sets all AzEl or RaDec offsets to zero
<pre style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl stop</pre>


<p style="color:#0000FF">'''DCMATTN HPOLattn VPOLattn [antenna list]'''</p>
Wait about 10 seconds and the issue the start command:
:Indicates the VPOL and HPOL attenuations for the DCM modules indicated in the list. The attenuations are applied on the next second start.
<pre style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl start</pre>
:<p style="color:#FF0000">'''Warning: The command is executed only if the DCM modules are in manual mode (see the DCMAUTO-ON and DCMAUTO-OFF command below)'''</p>


<p style="color:#0000FF">'''DCMAUTO-OFF [antenna list]'''</p>
Once done type in:
:Sets the DCM modules in the manual attenuation mode. This mode allows the attenuations requested by the DCMATTN to be applied.
<pre style="font-family:courier">exit</pre>


<p style="color:#0000FF">'''DCMAUTO-ON [antenna list]'''</p>
==== Recycling Power to the Brick ====
:Sets the DCM modules in the automatic attenuation mode. This mode ignores the manual DCMATTN commands and applies the attenuation set through the DCMOFFSET mechanism.
If faults are showing on the Motor section (4th green line down) the Brick power will need to be recycled. To do this issue the following commands from the Schedule Window:
<pre style="font-family:courier">
outlet 3 off ant14
outlet 3 on ant14
</pre>


<p style="color:#0000FF">'''DCMOFFSET  inc1 inc2…..inc50'''</p>
==== Restarting the LNAs ====
:Sets the 50 DCM attenuation offset increments to be added to the current list of DCM offset attenuations to be cycled during each second, starting with the next second boundary. The command expects up to 50 arguments. If fewer arguments are provided, the existing set is repeated in the same sequence until all 50 slots are filled. This command is only intended for testing. During normal operations, the DCM offsets states are requested by the DPP computer when needed.
From a Helios terminal:
<pre style="font-family:courier">ssh root@lna14.solar.pvt</pre>
:<p style="color:#FF0000">'''Warning: The command is executed only if the DCM modules are in auto mode (see the DCMAUTO-ON and DCMAUTO-OFF command below).'''</p>
:'''NOTE: The DCM offsets are changed on the edge of the next second after a TCP/IP message is received by ACC at the TCP.dpp.port (default port: 6344-set in ACC.ini file ). The message is expected to be a fixed length binary string having the following format: 50 32bit integers (I32)'''


<p style="color:#0000FF">'''DCMOFFSET-CLEAR'''</p>
If you get an error "No route to host" you will need to restart the computer at the 27m antenna by issuing the commands below from the Schedule Window:  
:Clears the current list of 50 DCM offset attenuations that are applied when DCMAUTO-ON is set.
<pre style="font-family:courier">
:<p style="color:#FF0000">'''Warning: This command clears the offset attenuations for all DCM modules.'''</p>
outlet 6 off ant14
outlet 6 on ant14
<p style="color:#0000FF">'''DCMTABLE  [antennalist] filename'''</p>
</pre>
:Request the antenna list portion of a specific DCM base attenuation table to be uploaded on the respective DCM modules. The DCM table must have 30 columns and 50 rows, each pair of adjacent columns listing the HPOL-VPOL pairs for each of the 50 slots of a tuning sequence. The DCM table text file must be located in the ACC “c:\parm” directory and its default name is “DCM.txt”.
 
Then issue the command from the terminal:
:The DCM/table_timeout key in the ACC.ini files have to be manually edited in order to modify the default timeout (ms) of the DCM modules when a table is broadcasted.
<pre style="font-family:courier">./killAll python</pre>


:The actual DCM attenuations for a given tuning slot are calculated based on the following formula
Then press the up arrow until the most recent python command is found and press enter. Text will scroll up continuously
::<p style="color:#00FF00">DCM_atten[pol,tuning_index]=DCM_base_atten[pol,tuning_index]+DCM_offset[broadcasted]</p>
Just type <span style="font-family:courier">exit</span> even with the text scrolling to exit the ssh session.


<p style="color:#0000FF">'''DPPOFFSET-OFF'''</p>
From Schedule issue the command:
:Ignores DCM offset attenuation recommendations sent by DPP but still allows setting the offsets via the DCMOFFSET schedule command.
<pre style="font-family:courier">$lna-init ant14</pre>


<p style="color:#0000FF">'''DPPOFFSET-ON'''</p>
The Drain Voltage for Hi H will be incorrect (~.61 when it should be 1.2). To correct this, from Schedule issue:
:Applies DCM offset attenuation recommendations sent by DPP but still allows setting the offsets via the DCMOFFSET schedule command.
<pre style="font-family:courier">lna drain hh 2.4 ant14</pre>


:'''NOTE: This is the default behavior of the system after each hardware ACC reboot or after a REBOOT or RESET command is sent via TCP/IP to the emergency 6543 acc.solar.ini port'''
==== Aligning the Receivers ====
'''<span style="color:#FF0000">Only do this once Mark Hodges has confirmed that he does NOT have the external vacuum pump connected!</span>'''


<p style="color:#0000FF">'''FEM-INIT</p>
The receivers must be properly aligned. From Schedule send the command:
:Initialize all front-end module base attenuations with the values read from the ACC initialization file: “c:\ni-rt\startup\acc.ini”.
<pre style="font-family:courier">frm-home ant14</pre>


<p style="color:#0000FF">'''FEMATTN level [antennalist]'''</p>
If the receivers do not home properly, you will need to cycle power on the brick: http://ovsa.njit.edu//wiki/index.php/Owen%27s_Notes#Recycling_Power_to_the_Brick
:Manually selects the front-end attenuation levels for the antennas indicated in the list to be applied on the next second boundary. The attenuation level selects the corresponding entry in the “c:\parms\FEMATTN.txt” attenuation FEM table located on each the cRIOs.
:The attenuation level set by this command is saved in the [FEM AGC] section of the “c:\ni-rt\startup\crio.ini” and it is automatically applied when the module is restarted.
:<p style="color:#FF0000">'''Warning:  The attenuation level setting may be overwritten by the AGC loop, if active.'''</p>


:The format of the table is as shown below (column heads are added here for clarity)
It will take a few minutes for the FRM to find its home position. Once it has send the command:
{| class="wikitable" style="text-align: center; margin: auto;"
<pre style="font-family:courier">frm-set-pa 0 ant14</pre>
|-
 
! FEMATTN level !! First attenuation !! Second attenuation !! Total attenuation
to zero the positions.
|-
 
| 0 || 0 || 0 || 0
Set the Hi Receiver:
|-
<pre style="font-family:courier">rx-select hi ant14</pre>
| 1 || 0 || 3 || 3
 
|-
==== Ant A Maths Error ====
| 2 || 0 || 6 || 6
Goto the webpage <span style="font-family:courier">https://ant14.solar.pvt</span>. You should get to the screen as shown below:
|-
 
| 3 || 0 || 9 || 9
[[File:AntA-Web-Home.png]]
|-
 
| 4 || 0 || 12 || 12
Ensure that on the left under the SP image that there is a green 'Ready' message.
|-
 
| 5 || 0 || 15 || 15
If there is a Maths Error then follow the following procedure.
|-
 
| 6 || 0 || 18 || 18
Click on the Login tab and enter the username and password.
|-
 
| 7 || 9 || 12 || 21
Click on the Parameter tab to see the following screen:
|-
| 8 || 9 || 15 || 24
|-
| 9 || 9 || 18 || 27
|-
| 10 || 9 || 21 || 30
|-
| 11 || 9 || 24 || 33
|-
| 12 || 9 || 27 || 36
|-
| 13 || 18 || 21 || 39
|-
| 14 || 18 || 24 || 42
|-
| 15 || 31 || 31 || 62
|}


:The actual FEM attenuations applied as the result of a FEMATTN command are given by
[[File:AntA-Web-Param-Opt10-marked.png]]
::HPOL_ATTENUATION=HPOL_BASE+FEMATTN.txt(level)
::VPOL_ATTENUATION=VPOL_BASE+FEMTTTN.txt(level)


:Where Attenuation, Base, and FEMATTN.txt(level) are two elements vectors indicating the settings for the First and Second attenuators.
Click on view next to #10.


<p style="color:#0000FF">'''HATTN first second [antennalist]'''</p>
At the next screen click on view next to Item #10.00:
:Sets the FEM  HPOL_BASE first and second attenuators for the antennas in the list, and overwrites the corresponding  sections in the global “c:\ni-rt\startup\acc.ini” file, as well as in the local “c:\ni-rt\startup\crio.ini” files.


<p style="color:#0000FF">'''VATTN first second [antennalist]'''</p>
[[File:AntA-Web_Opt10.00-marked.png]]
:Sets the FEM  VPOL_BASE first and second attenuators for the antennas in the list, and overwrites the corresponding  sections in the global “c:\ni-rt\startup\acc.ini” file, as well as in the local “c:\ni-rt\startup\crio.ini” files.


<p style="color:#0000FF">'''FSEQ-FILE filename'''</p>
In the Update Value box enter 1070 and click on Change
:Tells ACC to upload to the Hittite synthesizer the frequency sequence located at  “c:\parm\filename”.


<p style="color:#0000FF">'''FSEQ-INIT'''</p>
Click on the arrow near the top of the page to return to menu 10.
:Initializes the Hittite synthesizer according to the settings defined in the [LO Configuration] section of the “c:\ni-rt\startup\acc.ini” file.


<p style="color:#0000FF">'''FSEQ-ON'''</p>
Click on View next to Item #10.38
:Starts the tuning sequence


<p style="color:#0000FF">'''FSEQ-OFF'''</p>
In the Update Value box enter 100 and click on Change.
:Stops the tuning sequence


<p style="color:#0000FF">'''FSEQ-SCRIPT filename'''</p>
=== Preventing the Receiver from Moving During Maintenance ===
:Sends, line by line, to the Hittite synthesizer the command sequence listed in the “c:\parm\filename” script file.
During some types of maintenance, the receiver should not be moved. To prevent this from happening, log into feanta:


<p style="color:#0000FF">'''LO1A-REBOOT'''</p>
:<p style="font-family:courier">ssh antctl@feanta</p>
:Commands the PDU controller to recycle the power on the LO1A Hittite synthesizer


<p style="color:#0000FF">'''LO1B-REBOOT'''</p>
and then issue the command:
:Not implemented yet


<p style="color:#0000FF">'''LO1A-WRITE command'''</p>
:<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl stop</p>
:Sends the specified command to the LO1A Hittite synthesizer


<p style="color:#0000FF">'''LO1B-WRITE command'''</p>
Type <span style="font-family:courier">exit<span> to end the feanta session.
:Sends the specified command to the LO1B Hittite synthesizer


<p style="color:#0000FF">'''SERVICE [antennalist]'''</p>
To reactivate, log back into feanta and send the command:
:Takes the antennas in the list out of subarray1 or subarray2 and drives them to the service position.
:<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl start</p>
:<p style="color:#FF0000">'''Warning:  Once in service position, the serviced antenna should be put in local operation mode in order to avoid it being controlled by a subsequent schedule command.'''</p>


<p style="color:#0000FF">'''SUBARRAY1 antennalist'''</p>
Note that this resets every evening. If a shutdown is required for longer than that then feanta may need to be shutdown.
:Puts all antennas in the list into subarray1. All antennas than are not listed, but currently in subarray1, are taken out from subarray1.
:'''NOTE: As of Dec 03 2015, this command no longer switches by default the LO connector to an alternative source. To force the LO connector to switch switches, one must use the new explicit command SUBARRAY1_SWITCH antennalist'''


<p style="color:#0000FF">'''SUBARRAY2 antennalist'''</p>
== Site Wide Power Outage ==
:Puts all antennas in the list, which are not already in subarray1, into subarray2. In order to move a given antenna from subarray1 to subarray2, one should first redefine subarray1.
Most of the procedures to recover from a site wide power outage are covered above. Below are the the steps required in order.
:'''NOTE: As of Dec 03 2015, this command no longer switches by default the LO connector to an alternative source. To force the LO connector to switch switches, one must use the new explicit command SUBARRAY2_SWITCH antennalist'''


<p style="color:#0000FF">'''SYNC [antennalist]'''</p>
=== 27m Antenna (Antenna A) ===
:Restarts the real-time executable on all cRIOs corresponding to the antenna list.
:'''NOTE: Unlike the general convention, not providing a list of antennas commands all cRIOs to restarts their execution.'''


<p style="color:#0000FF">'''TRACKTABLE filename [antennalist]'''</p>
Refer to the procedure here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Recovering_Antenna_A_from_a_Power_Outage
:Uploads to all antennas in the list the tracking table located at “c:\parm\filename”


<p style="color:#0000FF">'''TRAJ-FILE filename [antennalist]'''</p>
=== 2m Antennas (Antennas 1-13) ===
:Uploads to all cRIOs corresponding to antennas in the list the trajectory file table located at “c:\parm\filename”


<p style="color:#0000FF">'''UNLISTEDCOMMAND  [antennalist]'''</p>
For any antennas that have a communications failure (highlighted in red in the communications section of the Stateframe Display) follow the procedures here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Antenna_Communications_Failure
:Any command not listed above is sent for local execution to all cRIOs corresponding to antennas in the list.


=== Commands handled by cRIOs ===
It may take some time for the CRIOs to restart. If after 20 minutes a CRIO has not restarted, redo the procedure.
'''NOTE:  These commands are selectively sent by ACC to all antennas in the optional argument antennalist, or, if not present, to all antennas in subarray1'''


<p style="color:#0000FF">'''AGC active [low [high [samples]]]'''</p>
Stop the schedule by clicking on the stop button.
:Activates (1) or deactivates (0) the front end automatic gain control loop, which adjust the FEMATTN level when both of the HPOL and VPOL voltages, averaged over the given number of consecutive samples , cross the low and high voltage limits.  Missing parameter values are uploaded from the [FEM AGC] section of the local “c:\ni-rt\startup\crio.ini” file. All parameters provided when an AGC command is issued are saved in the same file for further use.
:'''NOTE: At startup, the AGC loop is activated or not according with the latest active value written in the initialization file.'''


<p style="color:#0000FF">'''AZELOFF azoff eloff'''</p>
Stow the antennas by issuing the command
:Sets the Azimuth and Elevation offsets indicated in the argument list
<pre style="font-family:courier">stow</pre>


<p style="color:#0000FF">'''RADECOFF raoff decoff'''</p>
If some of the antennas did not stow the refer to Antenna trouble shooting: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Antenna_Trouble_Shooting
:Sets the RA and DEC offsets indicated in the argument list


<p style="color:#0000FF">'''FLUSH'''</p>
If an antenna is highlighted in the Power and Attenuation section on the stateframe display then you may need to reload the .ini file to the CRIO as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Warning_on_Power_and_Attenuation
:Flush the existing tracktable from the associated antenna controller


<p style="color:#0000FF">'''ND-ON and ND-OFF'''</p>
== Data Backup ==
:Set on/off the local noise diode.
=== Local IDB File Backup ===
Periodically IDB files will need to be moved from pipeline. Currently these are being stored on NAS4. Typically a year of data will be copied. Follow the procedure below (replace nas4 with the appropriate drive):


<p style="color:#0000FF">'''POSITION azimuth elevation'''</p>
:Login to pipeline. an then issue the command:
:Requests a given azel position
<pre style="font-family:courier">screen -S filecopy</pre>


<p style="color:#0000FF">'''RESTART'''</p>
:Enter the command;
:Reboots the cRIO
<pre style="font-family:courier">cp -r -v /data1/eovsa/fits/IDB/yyyy* /nas4/IDB/</pre>
:where yyyy is the year of the files to copy.
:Press <CRTL>AD to exit the screen


<p style="color:#0000FF">'''DRIVE-RESET'''</p>
:To ensure that the files have been copied properly enter the commands
:Resets Antenna controller


<p style="color:#0000FF">'''STOP'''</p>
<pre style="font-family:courier">du -sc /nas4/IDB/yyyy*</pre>  
:Stops the antenna


<p style="color:#0000FF">'''STOW'''</p>
:and
:Stows the antenna


<p style="color:#0000FF">'''TRACK'''</p>
<pre style="font-family:courier">du -sc /data1/eovsa/fits/IDB/yyyy**</pre>
:Sets antenna in track mode


<p style="color:#0000FF">'''TEC-LOG'''</p>
:Ensure that the file sizes are within a few kB of each other.
:Dumps all TEC register values to the local log file “c:\tec.txt” for debugging purposes


<p style="color:#0000FF">'''TEC-INIT'''</p>
:Update the JSON file from pipeline:
:Initializes the TEC controller with register values hard-coded in the crio code.  These were read from a working controller at some time in the past.


<p style="color:#0000FF">'''TEC$BC'''</p>
<pre style="font-family:courier">sudo nano /common/python/current/EOVSADB.json</pre>
:Reboot the TEC controller to recover from a bad or stuck state.


<p style="color:#0000FF">'''TEC$SC'''</p>
:The contents of the file look like:
:Clear the error status of the TEC controller.  Does nothing other than this, and is purely asthetic.


<p style="color:#0000FF">'''TRAJ-ON and TRAJ-OFF'''</p>
<pre style="font-family:courier">{"EOVSADB":{"1900-01-01":"/nas3/IDB/", "2021-03-01":"/nas4/IDB", "2023-04-01":"/nas5/IDB", "2024-05-01":"/data1/eovsa/fits/IDB/"}, "comment_EOVSADB": "Locations of EOVSA IDB files after the date given in the keys."}</pre>
:Starts/Ends the execution of the trajectory script
:'''NOTE: At startup, the WINDSCRAM loop is activated or not according with the latest active written in the initialization file.'''


<p style="color:#0000FF">'''BSCRAM-ON</p>
:Change the date to the last file the particular drive that the files have been copied to.
:Activate the BRIGHTSCRAM Monitor


<p style="color:#0000FF">'''BSCRAM-OFF'''</p>
=== Caltech IDB File Backup ===
:Deactivate the BRIGHTSCRAM Monitor
IDB files are copied onto two USB drives and mailed to Caltech. The drives hold approximately three months of IDB data. Use the following procedure to copy the files.


<p style="color:#0000FF">'''BSCRAM-CLEAR'''</p>
:Connect the USB drives to your local computer. Make a note of the last file on the disk. Delete all of the IDB, FDB and IFDB files from the drives.
:Takes the antenna out of the BRIGHTSCRAM Active State independently of the brightness sensor state.
:Connect the drive to the USB port at the back of the pipeline machine.
:If the BRIGHTSCRAM Monitor’s operation mode is set to STOW, clearing the BRIGHSCRAM ACTIVE state does not have any effect on the mechanical state of the antenna. If the BRIGHTSCRAM Monitor’s operation mode is set to OFFSET, clearing the BRIGHSCRAM ACTIVE state results in removing the AZEL offsets
:Login to the user account on pipeline.
:'''Note: If the BRIGHTSCRAM Monitor is active, the antenna may get back in the Active State depending on the state of the brightness sensor.'''
:List the available drives by typing the command:
<pre style="font-family:courier">sudo fdisk -l</pre>


<p style="color:#0000FF">'''BSCRAM-SET'''</p>
:A list of drives will appear. Find the line similar to the one below:
:Force the antenna into the BRIGHTSCRAM Active State independently of the brightness sensor state.
<pre style="font-family:courier">/dev/sdc1  2048 7813969919 7813967872  3.7T Microsoft basic data</pre>


<p style="color:#0000FF">'''BSCRAM-WAIT seconds'''</p>
:Note that the device might be different to /dev/sdc1, but it will be the 3.7T drive. In the rest of these instructions assumes that the device is /dev/sdc1. Replace this with whatever is the appropriate device.
:Sets the BRIGHTSCRAM Monitor waiting time before clearing the BRIGHSCRAM ACTIVE state.
:Mount the USB drive:
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed'''
<pre style="font-family:courier">sudo mount /dev/sdc1 /media/IDB-backup1</pre>


<p style="color:#0000FF">'''BSCRAM-OFFSET'''</p>
:Open the IDB backup script using nano:
:Sets the BRIGHTSCRAM operation mode to stow the antenna when in active state.
<pre style="font-family:courier">nano owen/archiveIDB.sh</pre>
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed'''


<p style="color:#0000FF">'''BSCRAM-OFFSET'''</p>
:Find the two lines similar to:
:Sets the BRIGHTSCRAM operation mode to apply offsets
<pre style="font-family:courier">
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed'''
start=$(date -d "2020-09-13" +%Y%m%d)
end=$(date -d "2020-12-31" +%Y%m%d)
</pre>


<p style="color:#0000FF">'''BSCRAM-AZELOFF azoff eloff</p>
:Change the start date to the day after the last date of the previous data copy and the end date to 3 months further on.
:Sets the Azimuth and Elevation Offsets (degrees) for the BRIGHTSCRAM offset operation mode.  
:Press [CTRL][X] and the Y to exit and save the file.
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed. Default values re AZOFF=0 and ELOFF=10'''
:If a screen named filecopy does not exist then issue the following command:
:<p style="color:#FF0000">'''Warning: No action is taken if less than 2 arguments are provided'''</p>
<pre style="font-family:courier">screen -S filecopy</pre>


<p style="color:#0000FF">'''WSCRAM-ON'''</p>
:If the screen does exist then
:Activate the WINDSCRAM Monitor
<pre style="font-family:courier">screen -r filecopy</pre>


<p style="color:#0000FF">'''WSCRAM-OFF'''</p>
:To start the filecopy issue the following commands:
:Deactivate the WINDSCRAM Monitor
<pre style="font-family:courier">cd ~/owen
./archiveIDB.sh
</pre>
 
:You can then press [CTRL][a][d] to exit the screen.
Once the copy has been completed, unmount the drive:
<pre style="font-family:courier">sudo umount /media/IDB-backup1</pre>
 
Repeat the process for the second drive.
 
=== Common Files ===
The common folder on Helios is backed up automatically on Sundays at midnight. This backup is stored on the nas2 drive. To manually back up the folder, issue the following commands from a helios terminal:


<p style="color:#0000FF">'''WSCRAM-LIMIT value'''</p>
<pre style="font-family:courier">screen -S commoncopy</pre>
:Sets the wind speed threshold.
:'''Note: This setting is saved in the crio.ini file and remains persistent across reboots until changed.'''


<p style="color:#0000FF">'''WSCRAM-WAIT seconds'''</p>
:Enter the command:
:Sets the WINDSCRAM Monitor waiting time between checking the wind speed.
<pre style="font-family:courier">rsync -av --delete --progress --log-file=/home/sched/rsynclogs/rsync_common.log -e ssh /common/ user@pipeline:/nas2/common/</pre>
:'''Note: This setting is saved in the crio.ini file and remains persistent across reboots until changed.'''


<p style="color:#0000FF">'''UpdateElevationDiagnostics 1'''</p>
:Press <CRTL>AD to exit the screen
:Requests an update of the elevation trip register.


<p style="color:#0000FF">'''UpdateAzimuthDiagnostics 1'''</p>
Output from rsync is logged in <span style="font-family:courier">/home/sched/rsynclogs/rsync_common.log<span>
:Requests an update of the azimuth trip register.


<p style="color:#0000FF">'''REGWRITE address value'''</p>
=== Crontab Backups ===
:Writes to a specific (new type) antenna register address the specified value.  This command is ignored by the old type antennas.
The crontab files are backed up on nas2 in the crontabs folder.
:For example,
::REGWRITE 23386 2 [antlist]
:may be used to set the controller in velocity mode.  Note that the velocity rate registers must also be set to control the velocity of motion.  The appropriate registers are:
::AzimuthVelocity, or 23585
::ElevationVelocity, or 23605
:Alternatively, one can write to a specific register address by directly sending a command formed by the name of the register (as defined in the M&C document Controller_registers.xlsx) followed the desired value to be written.
:For example one may alternatively set the controller in velocity mode by issuing the command
::RUNMODE 2 [antlist]
:A possible need for velocity mode is to drive an antenna off a hard limit.  For safety, the only way to do that is to set the controller in velocity mode and provide a velocity in the direction to drive off the limit.  For example, if Ant 6 is on an azimuth low hard limit, one can drive it off by the following sequence:
::RUNMODE 2 ANT6
::AZIMUTHVELOCITY 5000 ANT6
:Wait for hard limit to clear.
::AZIMUTHVELOCITY 0 ANT6
:TRACK ANT6


=== Antenna A (Antenna 14) Commands ===
The helios crontab is stored in <span style="font-family:courier">helios_cron</span>


'''Note: Only antenna A is currently in use. In the commands below the value of [ant] is ant14, the value of [rx] is hi or lo (for the receiver), and the value of [lna] can be lv, lh, hv or hh.'''
The pipeline crontab is stored in <span style="font-family:courier">pipeline_cron</span>


<p style="color:#0000FF">'''FRM-HOME [ant]'''</p>
The dpp crontab is stored in <span style="font-family:courier">dpp_cron</span>
:Homes the x-axis (receiver select) and position angle axis.


<p style="color:#0000FF">'''FRM-RX-SEL [rx] [ant]'''</p>
== Location of IDB and Associated Files ==
:Move x and z axes to select receiver.


<p style="color:#0000FF">'''FRM-SET-PA [pa] [ant]'''</p>
{|class="wikitable" style="text-align: center;"
:Set the position angle, [pa] for polarization. Pointing to the south is 0 degrees. The PA can range from -90 to 90 degrees.
|+ style="caption-side:top;"|''IDB File Locations''
!Date Range||Location
|-
|2014 to 2015||nas3/IDB2014-15
|-
|2016-01-01 to 2016-07-31||nas1
|-
|2016-08-01 to 2016-11-30||nas2
|-
|2016-12-01 to 2021-02-28||nas3/IDB
|-
|2021-03-01 to 2021-12-31||nas4/IDB
|-
|}


<p style="color:#0000FF">'''FRM-X-OFFSET [xoff] [ant]'''</p>
{|class="wikitable" style="text-align: center;"
:Offset in x relative to the selected reciever. In effect until a new value is set or the Geo Brick is reset.
|+ style="caption-side:top;"|''FDB File Locations''
!Date Range||Location
|-
|2013-12-19 to 2015012031||nas3/FDB2014-15
|-
|2016-01-01 to 2016-07-31||nas1/FDB
|-
|2016-08-01 to 2016-11-30||nas2/FDB
|-
|2016-12-01 to 2021-02-28||nas3/FDB
|-
|2021-03-01 to 2021-12-31||nas4/FDB
|-
|}


<p style="color:#0000FF">'''FRM-Z-OFFSET [zoff] [ant]'''</p>
{|class="wikitable" style="text-align: center;"
:Offset in z relative to the selected reciever. In effect until a new value is set or the Geo Brick is reset.
|+ style="caption-side:top;"|''IFDB File Locations''
!Date Range||Location
|-
|2014-01-24 to 2015012031||nas3/IFDB2014-15
|-
|2016-01-01 to 2016-07-31||nas1/IFDB
|-
|2016-08-01 to 2016-11-30||nas2/IFDB
|-
|2016-12-01 to 2021-02-28||nas3/IFDB
|-
|2021-03-01 to 2021-12-31||nas4/IFDB
|-
|}


<p style="color:#0000FF">'''FRM-ABS-X [xpos] [ant]'''</p>
== Schedule Command Description ==
:Set to an absolute x position. Not used.


<p style="color:#0000FF">'''FRM-ABS-Z [zpos] [ant]'''</p>
NOTE: All Schedule commands accept as optional arguments a list of antennas to which the command should selectively sent. Accepted syntaxes are:
:Set to an absolute z position. Not used.


<p style="color:#0000FF">'''FRM-KILL [ant]'''</p>
Command ant1 ant2 ant3
:Kill all motors. They will be unpowered.


<p style="color:#0000FF">'''FRM-ENABLE [ant]'''</p>
Command ant1-3
:Enable all motors after a kill.


<p style="color:#0000FF">'''OUTLET [out] [state] [ant]'''</p>
Command subarray1
:Turns the selected outlet on or off. [out] is a value from 1 to 8 and [state] is either on or off.


<p style="color:#0000FF">'''ND-ON [ant]'''</p>
Command subarray2
:Turns the noise diode on via the power strip.


<p style="color:#0000FF">'''ND-OFF [ant]'''</p>
If no antenna list is indicated, the command is sent to all antennas currently in subarray1.
:Turns the noise diode off via the power strip.  


<p style="color:#0000FF">'''RX-SELECT [rx] [ant]'''</p>
These commands can be found in the <span style="font-family:courier">~/Dropbox/EOVSA\ M\&C/EOVSA\ Schedule\ Commands.docx</span> and <span style="font-family:courier">~/Dropbox/OVSA\ Expansion/Design/Antennas/Ant_A\&B_Commands.pdf</span> files.
:Moves the requested receiver to focus and sets the RF switch appropriately.


<p style="color:#0000FF">'''LNA-GATE1 [lna] [vg1] [ant]'''</p>
=== Commands handled directly by ACC ===
:Sets the first gate bias on the selected amplifier to the request voltage ([vg1] in range of -2.0 to 2.0). Will only operate if that amplifier is enabled.


<p style="color:#0000FF">'''LNA-GATE2 [lna] [vg2] [ant]'''</p>
<p style="color:#0000FF">'''ABORT'''</p>
:Sets the second gate bias on the selected amplifier to the request voltage ([vg2] in range of -2.0 to 2.0). Will only operate if that amplifier is enabled.
:Aborts all commands sent to ACC but not yet executed


<p style="color:#0000FF">'''LNA-DRAIN [lna] [vd] [ant]'''</p>
<p style="color:#0000FF">'''CLEAROFF [antenna list]'''</p>
:Sets the drain bias ([vd] in range 0.0 to 2.0) on the selected amplifier. Will only operate if that amplifier is enabled.
:Sets all AzEl or RaDec offsets to zero


<p style="color:#0000FF">'''LNA-ENABLE [lna] [state] [ant]'''</p>
<p style="color:#0000FF">'''DCMATTN HPOLattn VPOLattn [antenna list]'''</p>
:Turn the requested amplifier on or off.
:Indicates the VPOL and HPOL attenuations for the DCM modules indicated in the list. The attenuations are applied on the next second start.
:<p style="color:#FF0000">'''Warning: The command is executed only if the DCM modules are in manual mode (see the DCMAUTO-ON and DCMAUTO-OFF command below)'''</p>
 
<p style="color:#0000FF">'''DCMAUTO-OFF [antenna list]'''</p>
:Sets the DCM modules in the manual attenuation mode. This mode allows the attenuations requested by the DCMATTN to be applied.


=== Local Commands ===
<p style="color:#0000FF">'''DCMAUTO-ON [antenna list]'''</p>
:Sets the DCM modules in the automatic attenuation mode. This mode ignores the manual DCMATTN commands and applies the attenuation set through the DCMOFFSET mechanism.


These commands are all executed locally. Any command with a '$' in front of it is a local command.
<p style="color:#0000FF">'''DCMOFFSET  inc1 inc2…..inc50'''</p>
:Sets the 50 DCM attenuation offset increments to be added to the current list of DCM offset attenuations to be cycled during each second, starting with the next second boundary. The command expects up to 50 arguments. If fewer arguments are provided, the existing set is repeated in the same sequence until all 50 slots are filled. This command is only intended for testing. During normal operations, the DCM offsets states are requested by the DPP computer when needed.
   
   
<p style="color:#0000FF">'''$MK_TABLES [fname] [source]'''</p>
:<p style="color:#FF0000">'''Warning: The command is executed only if the DCM modules are in auto mode (see the DCMAUTO-ON and DCMAUTO-OFF command below).'''</p>
:Creates the tracktable for the named [source], writes it to the filename given by [fname],  for example, sun_tab.radec, pcal_tab.radec, or geosat_tab and stores it in the /parm directory on the ACC. This file can then be sent to the antennas via the TRACKTABLE command.  This must be performed at the start of each scan in order for the antennas to track the source.
:'''NOTE: The DCM offsets are changed on the edge of the next second after a TCP/IP message is received by ACC at the TCP.dpp.port (default port: 6344-set in ACC.ini file ). The message is expected to be a fixed length binary string having the following format: 50 32bit integers (I32)'''


<p style="color:#0000FF">'''$FEM_INIT <antlist>'''</p>
<p style="color:#0000FF">'''DCMOFFSET-CLEAR'''</p>  
:Invokes a sequence of commands to (1) read the current front-end power levels, (2) calculate any attenuation change needed to adjust the power levels to the range 1-4 dBm, and (3) send the attenuation adjustments to the antennas. The result is that the front end power levels are adjusted to this range. It acts on the antennas given in the antenna list <antlist>, or on all antennas in the current subarray if <antlist> is omittedThis command changes the gain calibration, so should only be done prior to the start of a day's observations if possible.  This is part of the System Gain Cal procedure.
:Clears the current list of 50 DCM offset attenuations that are applied when DCMAUTO-ON is set.
:<p style="color:#FF0000">'''Warning: This command clears the offset attenuations for all DCM modules.'''</p>
<p style="color:#0000FF">'''DCMTABLE  [antennalist] filename'''</p>
:Request the antenna list portion of a specific DCM base attenuation table to be uploaded on the respective DCM modules. The DCM table must have 30 columns and 50 rows, each pair of adjacent columns listing the HPOL-VPOL pairs for each of the 50 slots of a tuning sequence. The DCM table text file must be located in the ACC “c:\parm” directory and its default name is “DCM.txt”.
   
:The DCM/table_timeout key in the ACC.ini files have to be manually edited in order to modify the default timeout (ms) of the DCM modules when a table is broadcasted.


<p style="color:#0000FF">'''$PLUSDELAY [nsec]'''</p>
:The actual DCM attenuations for a given tuning slot are calculated based on the following formula
:Relay specific command that adds given delay argument (in nanoseconds) to the Ant 14 low frequency receiver. Delays both X and Y in the current delay center table.  This writes the changed record as a new record in the SQL database.
::<p style="color:#00FF00">DCM_atten[pol,tuning_index]=DCM_base_atten[pol,tuning_index]+DCM_offset[broadcasted]</p>


<p style="color:#0000FF">'''$CAPTURE-1S <stem>'''</p>
<p style="color:#0000FF">'''DPPOFFSET-OFF'''</p>
:Capture 1 second of data on the dpp. <stem> is an optional string to add to the end of the capture filename. This will take a few seconds to complete.
:Ignores DCM offset attenuation recommendations sent by DPP but still allows setting the offsets via the DCMOFFSET schedule command.


<p style="color:#0000FF">'''$WSCRAM-LIMIT [limit]'''</p>
<p style="color:#0000FF">'''DPPOFFSET-ON'''</p>
:Update the 27-m windscram limit. the limit is in miles per hour.
:Applies DCM offset attenuation recommendations sent by DPP but still allows setting the offsets via the DCMOFFSET schedule command.  


<p style="color:#0000FF">'''$SCAN-START <NODATA>'''</p>
:'''NOTE: This is the default behavior of the system after each hardware ACC reboot or after a REBOOT or RESET command is sent via TCP/IP to the emergency 6543 acc.solar.ini port'''
:Starts data collection. Command by itself is normal scan start, while $SCAN-START NODATA means set up scan, but do not take data. The NODATA option is used for some calibrations.


<p style="color:#0000FF">'''$SCAN-RESTART'''</p>
<p style="color:#0000FF">'''FEM-INIT</p>
:This command is for restarting a scan with the same setup as the previously running scan, where only the scan state must be turned on.
:Initialize all front-end module base attenuations with the values read from the ACC initialization file: “c:\ni-rt\startup\acc.ini”.


<p style="color:#0000FF">'''$SCAN-STOP'''</p>
<p style="color:#0000FF">'''FEMATTN level [antennalist]'''</p>
:This command stops a scan.
:Manually selects the front-end attenuation levels for the antennas indicated in the list to be applied on the next second boundary. The attenuation level selects the corresponding entry in the “c:\parms\FEMATTN.txt” attenuation FEM table located on each the cRIOs.
:The attenuation level set by this command is saved in the [FEM AGC] section of the “c:\ni-rt\startup\crio.ini” and it is automatically applied when the module is restarted.
:<p style="color:#FF0000">'''Warning:  The attenuation level setting may be overwritten by the AGC loop, if active.'''</p>


<p style="color:#0000FF">'''$PA-SWEEP [PA] [RATE]'''</p>
:The format of the table is as shown below (column heads are added here for clarity)
:Rotate 27-m focus rotation mechanism to sweep through a given angle range (does nothing if PA adjustment routine is already running). The angle is swept from -[PA] to [PA] at rate of 1-degree-per-[RATE] (s)
{| class="wikitable" style="text-align: center; margin: auto;"
 
|-
<p style="color:#0000FF">'''$PA-TRACK ant14 [CROSSED]'''</p>
! FEMATTN level !! First attenuation !! Second attenuation !! Total attenuation
:Track 27-m focus rotation mechanism to correct for parallactic angle of given antenna (does nothing if antenna not correctly specified). [CROSSED] should have value TRUE or FALSE.
|-
 
| 0 || 0 || 0 || 0
<p style="color:#0000FF">'''$PA-STOP'''</p>
|-
:Aborts a running position-angle sequence (started by $PA-SWEEP or $PA-TRACK commands) that is controlling the Antenna 14 focus rotation mechanism.
| 1 || 0 || 3 || 3
               
|-
<p style="color:#0000FF">'''$TRIPS'''</p>
| 2 || 0 || 6 || 6
:Send commands to update antenna trip information.
|-
| 3 || 0 || 9 || 9
|-
| 4 || 0 || 12 || 12
|-
| 5 || 0 || 15 || 15
|-
| 6 || 0 || 18 || 18
|-
| 7 || 9 || 12 || 21
|-
| 8 || 9 || 15 || 24
|-
| 9 || 9 || 18 || 27
|-
| 10 || 9 || 21 || 30
|-
| 11 || 9 || 24 || 33
|-
| 12 || 9 || 27 || 36
|-
| 13 || 18 || 21 || 39
|-
| 14 || 18 || 24 || 42
|-
| 15 || 31 || 31 || 62
|}


<p style="color:#0000FF">'''$DLASWEEP [ant] [dla] [dlastop] <pol>'''</p>
:The actual FEM attenuations applied as the result of a FEMATTN command are given by
:Starts a relative delay sweep on antenna [ant] (an integer, i.e. ant1), <pol> ('X', 'Y', or if omitted, both) ranging from delay step [dla] to [dlastop].  This will sweep the delay by 1 step per second for delays from [dla] to [dlastop] relative to the current nominal delay.  For example, $DLASWEEP 2 5 10 X will sweep the X delay on ant2 by adding 5 steps up to 10 steps, one step per second.  The start and/or stop delays can be negative, but [dla] must be less than [dlastop].  Note, if [ant] is 0, the delay of the specified polarization is swept for all antennas. Used for some total power tests.
::HPOL_ATTENUATION=HPOL_BASE+FEMATTN.txt(level)
::VPOL_ATTENUATION=VPOL_BASE+FEMTTTN.txt(level)


<p style="color:#0000FF">'''$WAIT [secs]'''</p>
:Where Attenuation, Base, and FEMATTN.txt(level) are two elements vectors indicating the settings for the First and Second attenuators.
:Waits the number of specified seconds before executing the next command.


<p style="color:#0000FF">'''$PCYCLE [dev] [antlist]'''</p>
<p style="color:#0000FF">'''HATTN first second [antennalist]'''</p>
:Cycle the power of some device (antenna controller, fem, or crio). If [dev] is omitted then the antenna controller is cycled. The options for [dev] are ANT, FEM or CRIO.  
:Sets the FEM  HPOL_BASE first and second attenuators for the antennas in the list, and overwrites the corresponding  sections in the global “c:\ni-rt\startup\acc.ini” file, as well as in the local “c:\ni-rt\startup\crio.ini” files.


<p style="color:#0000FF">'''$KATADC_GET'''</p>
<p style="color:#0000FF">'''VATTN first second [antennalist]'''</p>
:Get the standard deviation for each KatADC (assumes frequency tuning is static).
:Sets the FEM  VPOL_BASE first and second attenuators for the antennas in the list, and overwrites the corresponding  sections in the global “c:\ni-rt\startup\acc.ini” file, as well as in the local “c:\ni-rt\startup\crio.ini” files.
:'''Note, takes about 0.2 s for each active ROACH.'''
                                   
<p style="color:#0000FF">'''$REWIND'''</p>
:Get date of first line of current schedule and increment by 1 day, then auto-generate a new schedule.


<p style="color:#0000FF">'''$LNA-INIT'''</p>
<p style="color:#0000FF">'''FSEQ-FILE filename'''</p>
:Get <span style="font-family:courier">LNA_settings.txt</span> file from ACC and send the series of commands needed to set the LNA voltages.
:Tells ACC to upload to the Hittite synthesizer the frequency sequence located at  “c:\parm\filename”.  


<p style="color:#0000FF">'''$SUBARRAY' [antlist]'''</p>
<p style="color:#0000FF">'''FSEQ-INIT'''</p>
:Run the SUBARRRAY1 command if this is the master schedule, otherwise run the SUBARRAY2 command.
:Initializes the Hittite synthesizer according to the settings defined in the [LO Configuration] section of the “c:\ni-rt\startup\acc.ini” file.


== Useful Tools and Utilities ==
<p style="color:#0000FF">'''FSEQ-ON'''</p>
=== Screen Command ===
:Starts the tuning sequence
On linux systems, the screen command allows a program to be run in the background. This is particularly useful for processes that take a long time to complete. In addition it will display output when the screen is activated.


To start a screen session, open up a terminal and issue the command:
<p style="color:#0000FF">'''FSEQ-OFF'''</p>
:Stops the tuning sequence


:<p style="font-family:courier">screen</p>
<p style="color:#0000FF">'''FSEQ-SCRIPT filename'''</p>
:Sends, line by line, to the Hittite synthesizer the command sequence listed in the “c:\parm\filename” script file.


Text will appear and you will be prompted to press space or return. Just press return.
<p style="color:#0000FF">'''LO1A-REBOOT'''</p>
:Commands the PDU controller to recycle the power on the LO1A Hittite synthesizer


Type in the command that you want to be performed. The process will then start.
<p style="color:#0000FF">'''LO1B-REBOOT'''</p>
:Not implemented yet


To scroll up and down within the screen press <span style="font-family:courier"><CRTL> A <ESC></span>. This enters Copy Mode. You can then use the up and down arrows to scroll. Press <ESC> to exit copy mode. Note that you cannot enter commands in copy mode.
<p style="color:#0000FF">'''LO1A-WRITE command'''</p>
 
:Sends the specified command to the LO1A Hittite synthesizer
You can exit the screen by pressing <span style="font-family:courier"><CRTL> A D</span>
The command will still be running.
To re-open the screen at any time simply type:
:<p style="font-family:courier">screen -r</p>


You can have more than one screen running at a time. In this case it is advisable to give a screen a name. For example:
<p style="color:#0000FF">'''LO1B-WRITE command'''</p>
:<p style="font-family:courier">screen -S schedule</p>
:Sends the specified command to the LO1B Hittite synthesizer


will assign the name 'schedule' to the screen. To access this screen after it has been closed, use the command:
<p style="color:#0000FF">'''SERVICE [antennalist]'''</p>
:<p style="font-family:courier">screen -r schedule</p>
:Takes the antennas in the list out of subarray1 or subarray2 and drives them to the service position.
:<p style="color:#FF0000">'''Warning:  Once in service position, the serviced antenna should be put in local operation mode in order to avoid it being controlled by a subsequent schedule command.'''</p>


To list the currently active screens use the command:
<p style="color:#0000FF">'''SUBARRAY1 antennalist'''</p>
:<p style="font-family:courier">screen -ls</p>
:Puts all antennas in the list into subarray1.  All antennas than are not listed, but currently in subarray1, are taken out from subarray1.
:'''NOTE: As of Dec 03 2015, this command no longer switches by default the LO connector to an alternative source. To force the LO connector to switch switches, one must use the new explicit command SUBARRAY1_SWITCH antennalist'''


To terminate a program running in a screen, from within the screen press <span style="font-family:courier"><CRTL> Z</span>
<p style="color:#0000FF">'''SUBARRAY2 antennalist'''</p>
:Puts all antennas in the list, which are not already in subarray1, into subarray2. In order to move a given antenna from subarray1 to subarray2, one should first redefine subarray1.
:'''NOTE: As of Dec 03 2015, this command no longer switches by default the LO connector to an alternative source. To force the LO connector to switch switches, one must use the new explicit command SUBARRAY2_SWITCH antennalist'''


In the example below the ping command was stopped and fives the following output:
<p style="color:#0000FF">'''SYNC [antennalist]'''</p>
:Restarts the real-time executable on all cRIOs corresponding to the antenna list.
:'''NOTE: Unlike the general convention, not providing a list of antennas commands all cRIOs to restarts their execution.'''


[[File:Screen-ping-stop.png]]
<p style="color:#0000FF">'''TRACKTABLE filename [antennalist]'''</p>
:Uploads to all antennas in the list the tracking table located at “c:\parm\filename”


The <span style="font-family:courier">[1]</span> is the job number. To completely terminate it issue the command:
<p style="color:#0000FF">'''TRAJ-FILE filename [antennalist]'''</p>
:Uploads to all cRIOs corresponding to antennas in the list the trajectory file table located at “c:\parm\filename”


kill %1
<p style="color:#0000FF">'''UNLISTEDCOMMAND  [antennalist]'''</p>
:Any command not listed above is sent for local execution to all cRIOs corresponding to antennas in the list.
To close a screen session type <span style="font-family:courier">exit</span>


If a screen is not responding, you can kill it and all programs running within it by pressing  <span style="font-family:courier"><CRTL> A K</span> and then press <span style="font-family:courier">Y</span> when asked if you really want to kill the session.
=== Commands handled by cRIOs ===
'''NOTE: These commands are selectively sent by ACC to all antennas in the optional argument antennalist, or, if not present, to all antennas in subarray1'''


==== Determining if a Screen is Attached to the Current Terminal ====
<p style="color:#0000FF">'''AGC active [low [high [samples]]]'''</p>
To determine if a Screen is attached to the current terminal issue the command:
:Activates (1) or deactivates (0) the front end automatic gain control loop, which adjust the FEMATTN level when both of the HPOL and VPOL voltages, averaged over the given number of consecutive samples , cross the low and high voltage limits.  Missing parameter values are uploaded from the [FEM AGC] section of the local “c:\ni-rt\startup\crio.ini” file. All parameters provided when an AGC command is issued are saved in the same file for further use.
:'''NOTE: At startup, the AGC loop is activated or not according with the latest active value written in the initialization file.'''


:<p style="font-family:courier">echo $STY</p>
<p style="color:#0000FF">'''AZELOFF azoff eloff'''</p>
:Sets the Azimuth and Elevation offsets indicated in the argument list


If the output is a blank line then the attached to the terminal. However if the name of a screen is displayed then that screen is attached. For example the output displayed when the schedule screen is attached will be similar to:
<p style="color:#0000FF">'''RADECOFF raoff decoff'''</p>
:<p style="font-family:courier">17558.schedule</p>
:Sets the RA and DEC offsets indicated in the argument list


==== Screens on Helios ====
<p style="color:#0000FF">'''FLUSH'''</p>
The Helios <span style="font-family:courier">.bashrc</span> and <span style="font-family:courier">.screenrc</span> files have been modified so that the title of the terminal displays the screen name when you enter that screen.
:Flush the existing tracktable from the associated antenna controller


If the Operating system is reinstalled on helios then the following lines should be added to the bottom of the <span style="font-family:courier">.bashrc</span> file if they are not already present.
<p style="color:#0000FF">'''ND-ON and ND-OFF'''</p>
:Set on/off the local noise diode.


:<span style="font-family:courier"># This function sets the title of a Terminal window<br /></span>
<p style="color:#0000FF">'''POSITION azimuth elevation'''</p>
:<span style="font-family:courier">function settitle() {<br /></span>
:Requests a given azel position
::<span style="font-family:courier">if [ -n "$STY" ] ; then        # We are in a screen session<br /></span>
:::<span style="font-family:courier">echo "Setting screen titles to $@"<br /></span>
:::<span style="font-family:courier">printf "\033k%s\033\\" "$@"<br /></span>
:::<span style="font-family:courier">screen -X eval "at \\# title $@" "shelltitle $@"<br /></span>
::<span style="font-family:courier">else<br /></span>
:::<span style="font-family:courier">printf "\033]0;%s\007" "$@"<br /></span>
::<span style="font-family:courier">fi<br /></span>
:<span style="font-family:courier">}</span>


Also add the following lines to the <span style="font-family:courier">.screenrc</span> file if they are not present.
<p style="color:#0000FF">'''RESTART'''</p>
:Reboots the cRIO


:<span style="font-family:courier">#This section will set the title on entering a screen<br /></span>
<p style="color:#0000FF">'''DRIVE-RESET'''</p>
:<span style="font-family:courier">termcapinfo xterm* 'hs:ts=\E]0;:fs=\007:ds=\E]0;\007'<br /></span>
:Resets Antenna controller
:<span style="font-family:courier">defhstatus "Screen $STY"<br /></span>
:<span style="font-family:courier">hardstatus off<br /></span>


Once done, you will either need to restart the bash session or issue the command:
<p style="color:#0000FF">'''STOP'''</p>
:Stops the antenna


:<span style="font-family:courier">source .bashrc</span>
<p style="color:#0000FF">'''STOW'''</p>
:Stows the antenna


Note that after these titles will only be displayed on newly started screens, not ones that are running at the time the scripts were running.
<p style="color:#0000FF">'''TRACK'''</p>
:Sets antenna in track mode


The above code is a slightly modified version of the code found here: https://code-and-hacks.peculier.com/articles/setting-terminal-title-in-gnu-screen/
<p style="color:#0000FF">'''TEC-LOG'''</p>
:Dumps all TEC register values to the local log file “c:\tec.txt” for debugging purposes


=== df Command ===
<p style="color:#0000FF">'''TEC-INIT'''</p>
On linux systems, the df command lists all of the file systems currently mounted on computer.
:Initializes the TEC controller with register values hard-coded in the crio code.  These were read from a working controller at some time in the past.


The command is simply:
<p style="color:#0000FF">'''TEC$BC'''</p>
:<p style="font-family:courier">df</p>
:Reboot the TEC controller to recover from a bad or stuck state.


More usefully, issuing the command:
<p style="color:#0000FF">'''TEC$SC'''</p>
:<p style="font-family:courier">df -h</p>
:Clear the error status of the TEC controller.  Does nothing other than this, and is purely asthetic.


will display the file sizes in 'human readable' format. Below is an example from pipeline of the output of <span style="font-family:courier">df -h</span>:
<p style="color:#0000FF">'''TRAJ-ON and TRAJ-OFF'''</p>
:Starts/Ends the execution of the trajectory script
:'''NOTE: At startup, the WINDSCRAM loop is activated or not according with the latest active written in the initialization file.'''


[[File:Df-output.png]]
<p style="color:#0000FF">'''BSCRAM-ON</p>
:Activate the BRIGHTSCRAM Monitor


<p style="color:#0000FF">'''BSCRAM-OFF'''</p>
:Deactivate the BRIGHTSCRAM Monitor


=== Whatup Program ===
<p style="color:#0000FF">'''BSCRAM-CLEAR'''</p>
The whatup program will display a plot of sources that are currently available. A sample plot is shown below.
:Takes the antenna out of the BRIGHTSCRAM Active State independently of the brightness sensor state.
:If the BRIGHTSCRAM Monitor’s operation mode is set to STOW, clearing the BRIGHSCRAM ACTIVE state does not have any effect on the mechanical state of the antenna. If the BRIGHTSCRAM Monitor’s operation mode is set to OFFSET, clearing the BRIGHSCRAM ACTIVE state results in removing the AZEL offsets
:'''Note: If the BRIGHTSCRAM Monitor is active, the antenna may get back in the Active State depending on the state of the brightness sensor.'''


[[File:Whatup.png]]
<p style="color:#0000FF">'''BSCRAM-SET'''</p>
:Force the antenna into the BRIGHTSCRAM Active State independently of the brightness sensor state.


The program must be run from helios and ipython. To run ensure you are logged into a helios terminal and issue the following commands
<p style="color:#0000FF">'''BSCRAM-WAIT seconds'''</p>
:Sets the BRIGHTSCRAM Monitor waiting time before clearing the BRIGHSCRAM ACTIVE state.
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed'''


:<p style="font-family:courier">cd /common/python/current</p>
<p style="color:#0000FF">'''BSCRAM-OFFSET'''</p>
:<p style="font-family:courier">ipython --pylab</p>
:Sets the BRIGHTSCRAM operation mode to stow the antenna when in active state.
:<p style="font-family:courier">import whatup</p>
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed'''
:<p style="font-family:courier">whatup.whatup()</p>


This will display a plot of sources (Altitude vs Time) visible to the 27m Antenna from the current time for the next 24 hours. The following optional arguments can be supplied:
<p style="color:#0000FF">'''BSCRAM-OFFSET'''</p>
:Sets the BRIGHTSCRAM operation mode to apply offsets
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed'''


:dur - the duration of the plot in hours
<p style="color:#0000FF">'''BSCRAM-AZELOFF azoff eloff</p>
:t  - the UT start time of the plot
:Sets the Azimuth and Elevation Offsets (degrees) for the BRIGHTSCRAM offset operation mode.
:'''Note: This setting is saved in the crio.ini file and remains persistent until changed. Default values re AZOFF=0 and ELOFF=10'''
:<p style="color:#FF0000">'''Warning: No action is taken if less than 2 arguments are provided'''</p>


For example, the following commands
<p style="color:#0000FF">'''WSCRAM-ON'''</p>
:Activate the WINDSCRAM Monitor


:<p style="font-family:courier">from util import Time</p>
<p style="color:#0000FF">'''WSCRAM-OFF'''</p>
:<p style="font-family:courier">whatup.whatup(dur=6, t=Time("2020-10-01 14:00:00"))</p>
:Deactivate the WINDSCRAM Monitor


will display a plot from 2020-10-01 14:00:00 for a duration of 6 hours as shown below:
<p style="color:#0000FF">'''WSCRAM-LIMIT value'''</p>
:Sets the wind speed threshold.
:'''Note: This setting is saved in the crio.ini file and remains persistent across reboots until changed.'''


[[File:Whatup_args.png]]
<p style="color:#0000FF">'''WSCRAM-WAIT seconds'''</p>
:Sets the WINDSCRAM Monitor waiting time between checking the wind speed.
:'''Note: This setting is saved in the crio.ini file and remains persistent across reboots until changed.'''


=== renice: Changing priority of a program ===
<p style="color:#0000FF">'''UpdateElevationDiagnostics 1'''</p>
If, on a linux system, a program is using to many resources, it is possible to use the <span style="font-family:courier">renice></span> command to set it to a different priority.
:Requests an update of the elevation trip register.


From a terminal, type the command:
<p style="color:#0000FF">'''UpdateAzimuthDiagnostics 1'''</p>
:<p style="font-family:courier">ps -elf | grep [program]</p>
:Requests an update of the azimuth trip register.


where <span style="font-family:courier">[program]<span> is the name of the program whose priority you wish to change.
<p style="color:#0000FF">'''REGWRITE address value'''</p>
:Writes to a specific (new type) antenna register address the specified value.  This command is ignored by the old type antennas.
:For example,
::REGWRITE 23386 2 [antlist]
:may be used to set the controller in velocity mode.  Note that the velocity rate registers must also be set to control the velocity of motion.  The appropriate registers are:
::AzimuthVelocity, or 23585
::ElevationVelocity, or 23605
:Alternatively, one can write to a specific register address by directly sending a command formed by the name of the register (as defined in the M&C document Controller_registers.xlsx) followed the desired value to be written.
:For example one may alternatively set the controller in velocity mode by issuing the command
::RUNMODE 2 [antlist]
:A possible need for velocity mode is to drive an antenna off a hard limit.  For safety, the only way to do that is to set the controller in velocity mode and provide a velocity in the direction to drive off the limit.  For example, if Ant 6 is on an azimuth low hard limit, one can drive it off by the following sequence:
::RUNMODE 2 ANT6
::AZIMUTHVELOCITY 5000 ANT6
:Wait for hard limit to clear.
::AZIMUTHVELOCITY 0 ANT6
:TRACK ANT6


Below is an example with output:
=== Antenna A (Antenna 14) Commands ===
<p style="font-family:courier">user@dpp:/$ ps -elf | grep rsync</p>
<p style="font-family:courier">4 S root    <span style="color:#00FF00">22708</span> 21761  0  80  <span style="color:#FF0000">0</span> - 16638 -      18:52 pts/3    00:00:00 sudo rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/</p>
<p style="font-family:courier">4 S root    <span style="color:#00FF00">22709</span> 22708  2  80  <span style="color:#FF0000">0</span> - 47670 -      18:52 pts/3    00:01:25 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/</p>
<p style="font-family:courier">1 S root    <span style="color:#00FF00">22710</span> 22709  1  80  <span style="color:#FF0000">0</span> - 24727 -      18:52 pts/3    00:00:34 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/</p>
<p style="font-family:courier">1 D root    <span style="color:#00FF00">22711</span> 22710  9  80  <span style="color:#FF0000">0</span> - 34724 -      18:52 pts/3    00:04:38 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/</p>


Here we looked for the rsync command and found 4 occurrences. The 8th column (marked here in red) is the priority.
'''Note: Only antenna A is currently in use. In the commands below the value of [ant] is ant14, the value of [rx] is hi or lo (for the receiver), and the value of [lna] can be lv, lh, hv or hh.'''


The priority ranges from -19 (highest priority) to 19 (lowest priority)
<p style="color:#0000FF">'''FRM-HOME [ant]'''</p>
:Homes the x-axis (receiver select) and position angle axis.


To change the priority of a program issue the command:
<p style="color:#0000FF">'''FRM-RX-SEL [rx] [ant]'''</p>
:<p style="font-family:courier">sudo renice -n [pr] -p [PID]</p>
:Move x and z axes to select receiver.


where [pr] is the new priority number and [PID] is the process identification number. The PID is the 4th column across in the display above (marked in green).
<p style="color:#0000FF">'''FRM-SET-PA [pa] [ant]'''</p>
:Set the position angle, [pa] for polarization. Pointing to the south is 0 degrees. The PA can range from -90 to 90 degrees.


=== Caps Lock Toggle Using the Onscreen Keyboard ===
<p style="color:#0000FF">'''FRM-X-OFFSET [xoff] [ant]'''</p>
Occasionally, the caps lock key will get stuck in the on position. if you are logged in remotely, pressing caps lock on your keyboard will not fix this problem. Instead, follow the procedure below.
:Offset in x relative to the selected reciever. In effect until a new value is set or the Geo Brick is reset.


:VNC into helios and click on the available helios terminal.
<p style="color:#0000FF">'''FRM-Z-OFFSET [zoff] [ant]'''</p>
:Offset in z relative to the selected reciever. In effect until a new value is set or the Geo Brick is reset.


:Enter the command <span style="font-family:courier">sudo onboard</span>
<p style="color:#0000FF">'''FRM-ABS-X [xpos] [ant]'''</p>
:Set to an absolute x position. Not used.


:You will then need to enter the helios password. '''<span style="color:#FF0000">Note: If the caps lock is on you will need to press the shift key for any lowercase letters. For uppercase letters there will be no shift. That is, the keys for letters only will be inverted.'''</span>  
<p style="color:#0000FF">'''FRM-ABS-Z [zpos] [ant]'''</p>
:Set to an absolute z position. Not used.


:The following screen will appear. When the caps lock is on, the caps key to the left of the onscreen keyboard is red. Note that the schedule will disappear as only windows that allow keyboard entry will be visible. However, it is still running.
<p style="color:#0000FF">'''FRM-KILL [ant]'''</p>
:Kill all motors. They will be unpowered.


[[File: Onscreen_keyboard_caps_on.png]]
<p style="color:#0000FF">'''FRM-ENABLE [ant]'''</p>
:Enable all motors after a kill.


:Click on the caps lock key to turn it off. The caps lock key should return to being black.
<p style="color:#0000FF">'''OUTLET [out] [state] [ant]'''</p>
:Turns the selected outlet on or off. [out] is a value from 1 to 8 and [state] is either on or off.


:To exit the Onscreen keyboard click on the <span style="font-family:courier">[X]</span> on the upper right of the onscreen keyboard as shown below.
<p style="color:#0000FF">'''ND-ON [ant]'''</p>
:Turns the noise diode on via the power strip.  


[[File: Onscreen_keyboard_close_button.png]]
<p style="color:#0000FF">'''ND-OFF [ant]'''</p>
:Turns the noise diode off via the power strip.  


:The Onscreen Keyboard will still be running in the background. To stop it, click on the terminal window where you started the keyboard and the press [CRTL] C.
<p style="color:#0000FF">'''RX-SELECT [rx] [ant]'''</p>
:Moves the requested receiver to focus and sets the RF switch appropriately.


== Plotting Stateframe Data ==
<p style="color:#0000FF">'''LNA-GATE1 [lna] [vg1] [ant]'''</p>
:Sets the first gate bias on the selected amplifier to the request voltage ([vg1] in range of -2.0 to 2.0). Will only operate if that amplifier is enabled.


It is often useful to be able to access and plot Stateframe data.  
<p style="color:#0000FF">'''LNA-GATE2 [lna] [vg2] [ant]'''</p>
:Sets the second gate bias on the selected amplifier to the request voltage ([vg2] in range of -2.0 to 2.0). Will only operate if that amplifier is enabled.


=== Plotting Stateframe Data using the Stateframe Display ===
<p style="color:#0000FF">'''LNA-DRAIN [lna] [vd] [ant]'''</p>
On the stateframe display, click on the Create tab shown below:
:Sets the drain bias ([vd] in range 0.0 to 2.0) on the selected amplifier. Will only operate if that amplifier is enabled.


[[File:Sf_create_tab.png]]
<p style="color:#0000FF">'''LNA-ENABLE [lna] [state] [ant]'''</p>
:Turn the requested amplifier on or off.


A screen similar to that below will be displayed. If there is already a graph present click on the Clear Graph tab shown below.
=== Local Commands ===


[[File:Sf_clear_tab.png]]
These commands are all executed locally. Any command with a '$' in front of it is a local command.
<p style="color:#0000FF">'''$MK_TABLES [fname] [source]'''</p>
:Creates the tracktable for the named [source], writes it to the filename given by [fname],  for example, sun_tab.radec, pcal_tab.radec, or geosat_tab and stores it in the /parm directory on the ACC.  This file can then be sent to the antennas via the TRACKTABLE command.  This must be performed at the start of each scan in order for the antennas to track the source.


By selecting items one at a time from left to write next to 'Select item to add' you can choose what to plot. The click on 'Add Selected Item' By repeating this process more than on data set can be plotted on a graph at a time.
<p style="color:#0000FF">'''$FEM_INIT <antlist>'''</p>
:Invokes a sequence of commands to (1) read the current front-end power levels, (2) calculate any attenuation change needed to adjust the power levels to the range 1-4 dBm, and (3) send the attenuation adjustments to the antennas. The result is that the front end power levels are adjusted to this range. It acts on the antennas given in the antenna list <antlist>, or on all antennas in the current subarray if <antlist> is omitted.  This command changes the gain calibration, so should only be done prior to the start of a day's observations if possible.  This is part of the System Gain Cal procedure.


=== Using Python to plot Stateframe Data ===
<p style="color:#0000FF">'''$PLUSDELAY [nsec]'''</p>
This section describes, with an example, the procedure for plotting Stateframe data using python. This is useful as it allows time periods longer than an hour to be plotted.
:Relay specific command that adds given delay argument (in nanoseconds) to the Ant 14 low frequency receiver. Delays both X and Y in the current delay center table. This writes the changed record as a new record in the SQL database.


Suppose we wish to plot the vertical polarization power over a 1 hour period from 2020-10-05 00:00 to 2020-10-05 01:00.
<p style="color:#0000FF">'''$CAPTURE-1S <stem>'''</p>
:Capture 1 second of data on the dpp. <stem> is an optional string to add to the end of the capture filename. This will take a few seconds to complete.


Firstly, from a pipeline terminal, access ipython:
<p style="color:#0000FF">'''$WSCRAM-LIMIT [limit]'''</p>
:<p>ipython --pylab</p>
:Update the 27-m windscram limit. the limit is in miles per hour.


Next import the required libraries:
<p style="color:#0000FF">'''$SCAN-START <NODATA>'''</p>
:<p style="font-family:courier">import dbutil as db</p>
:Starts data collection. Command by itself is normal scan start, while $SCAN-START NODATA means set up scan, but do not take data. The NODATA option is used for some calibrations.
:<p style="font-family:courier">from util import Time</p>
:<p style="font-family:courier">import numpy as np</p>


Now set up the cursor:
<p style="color:#0000FF">'''$SCAN-RESTART'''</p>
:<p style="font-family:courier">cursor = db.get_cursor()</p>
:This command is for restarting a scan with the same setup as the previously running scan, where only the scan state must be turned on.


The time range is set as follows (Just replace the times in quotes with new start and end times):
<p style="color:#0000FF">'''$SCAN-STOP'''</p>
:<p style="font-family:courier">trange=Time(['2020-10-05 00:00','2020-10-05 01:00']).lv.astype(int)</p>
:This command stops a scan.


Now we set up a query string which will search the data base:
<p style="color:#0000FF">'''$PA-SWEEP [PA] [RATE]'''</p>
:<p style="font-family:courier">query = 'select Timestamp,Ante_Fron_FEM_VPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' order by Timestamp'</p>
:Rotate 27-m focus rotation mechanism to sweep through a given angle range (does nothing if PA adjustment routine is already running). The angle is swept from -[PA] to [PA] at rate of 1-degree-per-[RATE] (s)


Some explanation here is required.
<p style="color:#0000FF">'''$PA-TRACK ant14 [CROSSED]'''</p>
:Track 27-m focus rotation mechanism to correct for parallactic angle of given antenna (does nothing if antenna not correctly specified). [CROSSED] should have value TRUE or FALSE.


Timestamp is the time for each data point.
<p style="color:#0000FF">'''$PA-STOP'''</p>
:Aborts a running position-angle sequence (started by $PA-SWEEP or $PA-TRACK commands) that is controlling the Antenna 14 focus rotation mechanism.
               
<p style="color:#0000FF">'''$TRIPS'''</p>
:Send commands to update antenna trip information.


Ante_Fron_FEM_VPol_Power is the variable for the VPOL power. The name of each variable can be retrieved by looking at the variables an the Create tab on the stateframe display. Note that except for the last variable, it is only the first 4 characters (or fewer if there are less than 4) that make up the name.
<p style="color:#0000FF">'''$DLASWEEP [ant] [dla] [dlastop] <pol>'''</p>
:Starts a relative delay sweep on antenna [ant] (an integer, i.e. ant1), <pol> ('X', 'Y', or if omitted, both) ranging from delay step [dla] to [dlastop].  This will sweep the delay by 1 step per second for delays from [dla] to [dlastop] relative to the current nominal delay.  For example, $DLASWEEP 2 5 10 X will sweep the X delay on ant2 by adding 5 steps up to 10 steps, one step per second. The start and/or stop delays can be negative, but [dla] must be less than [dlastop]. Note, if [ant] is 0, the delay of the specified polarization is swept for all antennas. Used for some total power tests.


fV66_vD15 is the database from which the data is to be retrieved.
<p style="color:#0000FF">'''$WAIT [secs]'''</p>
:Waits the number of specified seconds before executing the next command.


(I15 % 15) = 3 will give the data for the antenna. I15 denotes that there are 15 antennas. This takes the record number mod 15 and will only extract a record when this equals 3 (antenna 4, as the values here are 0 indexed).  
<p style="color:#0000FF">'''$PCYCLE [dev] [antlist]'''</p>
:Cycle the power of some device (antenna controller, fem, or crio). If [dev] is omitted then the antenna controller is cycled. The options for [dev] are ANT, FEM or CRIO.  


It will also only extract values in the specified time range.
<p style="color:#0000FF">'''$KATADC_GET'''</p>
:Get the standard deviation for each KatADC (assumes frequency tuning is static).
:'''Note, takes about 0.2 s for each active ROACH.'''
                                   
<p style="color:#0000FF">'''$REWIND'''</p>
:Get date of first line of current schedule and increment by 1 day, then auto-generate a new schedule.


Finally we want the data ordered by timestamp.
<p style="color:#0000FF">'''$LNA-INIT'''</p>
:Get <span style="font-family:courier">LNA_settings.txt</span> file from ACC and send the series of commands needed to set the LNA voltages.


Now we retrieve the requested data:
<p style="color:#0000FF">'''$SUBARRAY' [antlist]'''</p>
:<p style="font-family:courier">data, msg = db.do_query(cursor,query)</p>
:Run the SUBARRRAY1 command if this is the master schedule, otherwise run the SUBARRAY2 command.


The data is stored in a dictionary. We can view the keys as follows:
== Useful Tools and Utilities ==
:<p style="font-family:courier">data.keys()</p>
=== Screen Command ===
On linux systems, the screen command allows a program to be run in the background. This is particularly useful for processes that take a long time to complete. In addition it will display output when the screen is activated.


This will produce an output as follows:
To start a screen session, open up a terminal and issue the command:
:<p style="font-family:courier">[u'Timestamp', u'Ante_Fron_FEM_VPol_Power']</p>


We convert the timestamps to numpy times:
<pre style="font-family:courier">screen</pre>
:<p style="font-family:courier">dt = np.array(Time(data['Timestamp'].astype(float), format = 'lv').isot,dtype = 'datetime64')</p>


The labels for the plot can be set if desired:
Text will appear and you will be prompted to press space or return. Just press return.
:<p style="font-family:courier">title('VPOL Power vs Time')</p>
:<p style="font-family:courier">xlabel('Universal Time')</p>
:<p style="font-family:courier">ylabel('Power (dB)')</p>


Finally the data is plotted:
Type in the command that you want to be performed. The process will then start.
:<p style="font-family:courier">plot(dt,data['Ante_Fron_FEM_VPol_Power'])</p>


A sample plot is shown below:
To scroll up and down within the screen press <span style="font-family:courier"><CRTL> A <ESC></span>. This enters Copy Mode. You can then use the up and down arrows to scroll. Press <ESC> to exit copy mode. Note that you cannot enter commands in copy mode.
 
You can exit the screen by pressing <span style="font-family:courier"><CRTL> A D</span>
The command will still be running.
To re-open the screen at any time simply type:
<pre style="font-family:courier">screen -r</pre>


[[File:Sample_sf_plot.png]]
You can have more than one screen running at a time. In this case it is advisable to give a screen a name. For example:
<pre style="font-family:courier">screen -S schedule</pre>


This plot looks rather cluttered. The number of points can be reduced if we modify our query:
will assign the name 'schedule' to the screen. To access this screen after it has been closed, use the command:
:<p style="font-family:courier">query = 'select Timestamp,Ante_Fron_FEM_VPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' and (cast(Timestamp as bigint) % 10) = 0 order by Timestamp'</p>
<pre style="font-family:courier">screen -r schedule</pre>


We then request the data again,convert the timestamps to numpy times and replot the data producing:
To list the currently active screens use the command:
<pre style="font-family:courier">screen -ls</pre>


[[File:Sample_sf_plot_reduced_points.png]]
To terminate a program running in a screen, from within the screen press <span style="font-family:courier"><CRTL> Z</span>


Suppose we want to plot both the HPol Power and VPol power on the same plot. This is not difficult to do. We simply modify our query again:
In the example below the ping command was stopped and fives the following output:
:<p style="font-family:courier">query = 'select Timestamp,Ante_Fron_FEM_VPol_Power,Ante_Fron_FEM_HPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' and (cast(Timestamp as bigint) % 10) = 0 order by Timestamp'</p>


Now HPol has been added and we just send this query as above. If we look at the keys now we see:
[[File:Screen-ping-stop.png]]
:<p style="font-family:courier">[u'Timestamp', u'Ante_Fron_FEM_HPol_Power', u'Ante_Fron_FEM_VPol_Power']</p>


To plot this data as a scatter plot we use the following commands:
The <span style="font-family:courier">[1]</span> is the job number. To completely terminate it issue the command:
:<p style="font-family:courier">hpol, = plot(dt,data['Ante_Fron_FEM_HPol_Power'].astype(float),'o', label='HPOL')</p>
:<p style="font-family:courier">vpol, = plot(dt,data['Ante_Fron_FEM_VPol_Power'],'o', label='VPOL')</p>
:<p style="font-family:courier">legend(handles=[hpol,vpol])</p>


which produces this plot:
<pre style="font-family:courier">kill %1</pre>
To close a screen session type <span style="font-family:courier">exit</span>


[[File:HPOL_VPOL_scatter.png]]
If a screen is not responding, you can kill it and all programs running within it by pressing  <span style="font-family:courier"><CRTL> A K</span> and then press <span style="font-family:courier">Y</span> when asked if you really want to kill the session.


== Other ==
==== Determining if a Screen is Attached to the Current Terminal ====
=== DPP Fix Packets Details ===
To determine if a Screen is attached to the current terminal issue the command:


==== Basic Operation and Monitoring ====
<pre style="font-family:courier">echo $STY</pre>
As of August 2021 the interrupt priority is handled largely automatically. This section describes the updated programs.


The program that handles reassignment of the CPUs and packet monitoring in called <span style="font-family:courier">dpp_fix_packets.py</span> and is located in the <span style="font-family:courier">/common/python/current/</span> folder.
If the output is a blank line then the attached to the terminal. However if the name of a screen is displayed then that screen is attached. For example the output displayed when the schedule screen is attached will be similar to:
<pre style="font-family:courier">17558.schedule</pre>


However this is typically not run directly. Rather it is run from a script on the DPP: <span style="font-family:courier">/home/user/test_svn/shell_scripts/start_fix_packets.sh</span>
==== Screens on Helios ====
The Helios <span style="font-family:courier">.bashrc</span> and <span style="font-family:courier">.screenrc</span> files have been modified so that the title of the terminal displays the screen name when you enter that screen.


This script checks to see if the <span style="font-family:courier">dpp_fix_packets.py</span> program is running. If it is not then it will restart it. Note that the actual line in the script that starts <span style="font-family:courier">dpp_fix_packets.py</span> is as follows:
If the Operating system is reinstalled on helios then the following lines should be added to the bottom of the <span style="font-family:courier">.bashrc</span> file if they are not already present.


<p style="font-family:courier">screen -S fixpackets -d -m python /common/python/current/dpp_fix_packets.py</p>
<pre style="font-family:courier">
# This function sets the title of a Terminal window
function settitle() {
    if [ -n "$STY" ] ; then        # We are in a screen session
        echo "Setting screen titles to $@"
        printf "\033k%s\033\\" "$@"
        screen -X eval "at \\# title $@" "shelltitle $@"
    else
        printf "\033]0;%s\007" "$@"
    fi
}
</pre>


This command starts the <span style="font-family:courier">dpp_fix_packets.py</span> in a screen named "fixpackets" in detatched mode ("-d -m").
Also add the following lines to the <span style="font-family:courier">.screenrc</span> file if they are not present.
<pre style="font-family:courier">#This section will set the title on entering a screen
termcapinfo xterm* 'hs:ts=\E]0;:fs=\007:ds=\E]0;\007'
defhstatus "Screen $STY"
hardstatus off
</pre>


To access the screen, and hence the output of the program simply type <span style="font-family:courier">screen -r fixpackets</span>
Once done, you will either need to restart the bash session or issue the command:
<pre style="font-family:courier">source .bashrc</pre>


This should show output that updates every minute as shown below:
Note that after these titles will only be displayed on newly started screens, not ones that are running at the time the scripts were running.


[[file:Dpp_output.png]]
The above code is a slightly modified version of the code found here: https://code-and-hacks.peculier.com/articles/setting-terminal-title-in-gnu-screen/


'''Note that I will normally show the fixpackets screen in a terminal after I have rebooted the DPP (OG)'''
=== df Command ===
On linux systems, the df command lists all of the file systems currently mounted on computer.


Information is also written to the <span style="font-family:courier">/common/webplots/dpp_fix_packets_log.txt</span> file. This contains the last 20 lines of significant output of the <span style="font-family:courier">dpp_fix_packets.py</span> program. This file is read by the stateframe display. In addition it writes the CPUs currently used by the fix packets program to the <span style="font-family:courier">/common/webplots/dpp_cpu.txt</span> file. This is also read by the stateframe display.
The command is simply:
<pre style="font-family:courier">df</pre>


At the bottom of the stateframe display is a section titled <span style="font-family:courier">Last DPP Fix Packets Messages</span>. This displays the last 3 messages by <span style="font-family:courier">dpp_fix_packets.py</span>. An example is given below:
More usefully, issuing the command:
<pre style="font-family:courier">df -h</pre>


[[file:Stateframe_dpp_msg.png]]
will display the file sizes in 'human readable' format. Below is an example from pipeline of the output of <span style="font-family:courier">df -h</span>:


This will display potentially 4 different types of messages:
[[File:Df-output.png]]


:<span style="font-family:courier">Packet Loss Detected</span>: This notifies that there was a packet loss and the interfaces are being reset.
=== Whatup Program ===
The whatup program will display a plot of sources that are currently available. A sample plot is shown below.


:<span style="font-family:courier">dpp_fix_packets.py has been restarted</span>: Indicates that the fix packets program has restarted. This will normally occur after a reboot of the DPP.
[[File:Whatup.png]]


:<span style="font-family:courier">Resetting CPUs - Using CPUs 18 and 19</span>: Notifies that the CPUs being used were change. Valid CPU pairs are [18 19], [20 21], [21 22].
The program must be run from helios and ipython. To run ensure you are logged into a helios terminal and issue the following commands


:<span style="font-family:courier">DPP REBOOT REQUIRED!</span>: This indicates that all CPU pairs have been used and that the DPP should be rebooted.
<pre style="font-family:courier">cd /common/python/current</p>
ipython --pylab
import whatup
whatup.whatup()
</pre>


==== Startup Script and Automatic Monitoring ====
This will display a plot of sources (Altitude vs Time) visible to the 27m Antenna from the current time for the next 24 hours. The following optional arguments can be supplied:
The <span style="font-family:courier">/home/user/test_svn/shell_scripts/start_fix_packets.sh</span> is run at DPP startup. The following command is placed in the crontab file:


<p style="font-family:courier">@reboot /bin/bash /home/user/test_svn/shell_scripts/start_fix_packets.sh</p>
:dur - the duration of the plot in hours
:t  - the UT start time of the plot


This starts the script on reboot (or startup).
For example, the following commands
<pre style="font-family:courier">
from util import Time</p>
whatup.whatup(dur=6, t=Time("2020-10-01 14:00:00"))
</pre>


Additionally this same script is run every 10 minutes in order to ensure that the program is still running. It will not restart <span style="font-family:courier">dpp_fix_packets.py</span> if it is already running. This command is also present in the crontab file:
will display a plot from 2020-10-01 14:00:00 for a duration of 6 hours as shown below:


<p style="font-family:courier">*/10 * * * * /home/user/test_svn/shell_scripts/start_fix_packets.sh</p>
[[File:Whatup_args.png]]


=== Windscram ===
=== renice: Changing priority of a program ===
A windscram occurs when the wind exceeds 18 miles/hour for 5 minutes. While a windscram can occur at any time, it is only important during a phasecal, as this is typically the only time that the 27m antenna is tracking. The 27m will stow during a windscram. Note that when the wind drops the antenna will not resume tracking. If the wind has dropped for a significant period of time, you can resume 27m operation by issuing the command:
If, on a linux system, a program is using to many resources, it is possible to use the <span style="font-family:courier">renice></span> command to set it to a different priority.
<p style="font-family:courier">track ant14</p>


from the schedule window.
From a terminal, type the command:
<pre style="font-family:courier">ps -elf | grep [program]</pre>


You can check the wind speed history by clicking on temps. The solid gray line is the average wind speed.
where <span style="font-family:courier">[program]<span> is the name of the program whose priority you wish to change.


=== Reloading the crio.ini File ===
Below is an example with output:
<span style="color:#FF0000">'''DO THIS WITH EXTREME CAUTION. BE ABSOLUTELY CERTAIN THAT RELOADING THE CRIO FILE IS REQUIRED.'''</span>
<pre style="font-family:courier">
user@dpp:/$ ps -elf | grep rsync
4 S root      21761  0  80  0 - 16638 -      18:52 pts/3    00:00:00 sudo rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/
4 S root      22708  2  80  0 - 47670 -      18:52 pts/3    00:01:25 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/
1 S root      22710 22709  1  80  0 - 24727 -      18:52 pts/3    00:00:34 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/
1 D root      22711 22710  9  80  0 - 34724 -      18:52 pts/3    00:04:38 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/
</pre>


For antenna 11, see the special case here:
Here we looked for the rsync command and found 4 occurrences. The 8th column (marked here in red) is the priority.


After uploading the new crio.ini file the gains and pointing may also need to be updated.
The priority ranges from -19 (highest priority) to 19 (lowest priority)


==== Manually uploading the crio.ini file ====
To change the priority of a program issue the command:
From helios, open a terminal and type <span style="font-family:courier">cd /home/sched/Dropbox/PythonCode/Current/crio_inis</span>
<pre style="font-family:courier">sudo renice -n [pr] -p [PID]</pre>


For the antenna that needs to be reset, find the most recent '.ini' file. For example, for antenna 10 this may be 'crio10-2019-09-28.ini'. Make a note of this file.
where [pr] is the new priority number and [PID] is the process identification number. The PID is the 4th column across in the display above (marked in green).


Enter the command <span style="font-family:courier">ftp crio10.solar.pvt</span>. Replace crio10 with the apropriate CRIO number.
=== Caps Lock Toggle Using the Onscreen Keyboard ===
Occasionally, the caps lock key will get stuck in the on position. if you are logged in remotely, pressing caps lock on your keyboard will not fix this problem. Instead, follow the procedure below.


Enter the username and password when prompted.
:VNC into helios and click on the available helios terminal.


Enter the following commands:
:Enter the command <span style="font-family:courier">sudo onboard</span>


<span style="font-family:courier">cd ni-rt/startup</span>
:You will then need to enter the helios password. '''<span style="color:#FF0000">Note: If the caps lock is on you will need to press the shift key for any lowercase letters. For uppercase letters there will be no shift. That is, the keys for letters only will be inverted.'''</span>  


<span style="font-family:courier">put crio10-2019-09-28.ini crio.ini</span>
:The following screen will appear. When the caps lock is on, the caps key to the left of the onscreen keyboard is red. Note that the schedule will disappear as only windows that allow keyboard entry will be visible. However, it is still running.


<span style="font-family:courier">bye</span>
[[File: Onscreen_keyboard_caps_on.png]]


replacing 'crio10-2019-09-28.ini' with the appropriate file for the CRIO that needs to be reset.
:Click on the caps lock key to turn it off. The caps lock key should return to being black.


The above commands have reloaded the crio.ini file. The CRIO now needs to be reset. For example, Antenna 10 will be reset by issuing the following commands from the schedule window:
:To exit the Onscreen keyboard click on the <span style="font-family:courier">[X]</span> on the upper right of the onscreen keyboard as shown below.


<span style="font-family:courier">sync ant10</span>
[[File: Onscreen_keyboard_close_button.png]]


<span style="font-family:courier">tracktable sun_tab.radec ant10</span>
:The Onscreen Keyboard will still be running in the background. To stop it, click on the terminal window where you started the keyboard and the press [CRTL] C.


<span style="font-family:courier">track</span>
== Plotting Stateframe Data ==


==== Using ipython to Upload the crio.ini File ====
It is often useful to be able to access and plot Stateframe data.  


From helios, open a terminal and access ipython:
=== Plotting Stateframe Data using the Stateframe Display ===
:<p style="font-family:courier">ipython --pylab</p>
On the stateframe display, click on the Create tab shown below:


Load the crio.py file by entering:
[[File:Sf_create_tab.png]]
:<p style="font-family:courier">import crio</p>


Simply issue the command:
A screen similar to that below will be displayed. If there is already a graph present click on the Clear Graph tab shown below.
:<p style="font-family:courier">crio.reload_crio_ini('ant#')</p>


where # is the antenna number. The most recent crio.ini file will be uploaded for that antenna.
[[File:Sf_clear_tab.png]]
=== Power Meter Setup ===
The user manual for the power meter can be found at https://literature.cdn.keysight.com/litweb/pdf/E4418-90032.pdf


Before use the power meter will need to be zeroed and calibrated.
By selecting items one at a time from left to write next to 'Select item to add' you can choose what to plot. The click on 'Add Selected Item' By repeating this process more than on data set can be plotted on a graph at a time.


1. Ensure that the sensor is not connected to anything.
=== Using Python to plot Stateframe Data ===
This section describes, with an example, the procedure for plotting Stateframe data using python. This is useful as it allows time periods longer than an hour to be plotted.


2. Press the ZERO/CAL button.
Suppose we wish to plot the vertical polarization power over a 1 hour period from 2020-10-05 00:00 to 2020-10-05 01:00.


3. Press the button next to [Zero] displayed on the screen. It will take several seconds to zero.
Firstly, from a pipeline terminal, access ipython:
<pre style="font-family:courier">ipython --pylab</pre>


4. Next remove the SMA adaptor from the end of the sensor and connect the sensor to the POWER REF socket on the power meter as shown below.
Next import the required libraries:
<pre style="font-family:courier">
import dbutil as db
from util import Time
import numpy as np
</pre>


[[File:Power_Meter_Cal.jpg]]
Now set up the cursor:
<pre style="font-family:courier">cursor = db.get_cursor()</pre>


5. Press the button next to [CAL] displayed on the screen. It will take several seconds.
The time range is set as follows (Just replace the times in quotes with new start and end times):
<pre style="font-family:courier">trange=Time(['2020-10-05 00:00','2020-10-05 01:00']).lv.astype(int)</pre>


6. The SMA power sensor can now be disconnected from the POWER REF socket and the SMA adaptor reconnected.
Now we set up a query string which will search the data base:
<pre style="font-family:courier">query = 'select Timestamp,Ante_Fron_FEM_VPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' order by Timestamp'</pre>


=== Moving the New Antennas Manually ===
Some explanation here is required.


Power off the antenna by turning the power switch at the bottom right of the Antenna Control Box.
Timestamp is the time for each data point.
Switch the Maint/Norm Switch to Maint.
Switch the Remote Switch to Remote.


[[File:AntControlBox.png]]
Ante_Fron_FEM_VPol_Power is the variable for the VPOL power. The name of each variable can be retrieved by looking at the variables an the Create tab on the stateframe display. Note that except for the last variable, it is only the first 4 characters (or fewer if there are less than 4) that make up the name.


Remove the block from the hand controller port.
fV66_vD15 is the database from which the data is to be retrieved.
'''Remember to place the block back after you have finished working on the antenna. It will not run in remote without it!'''


[[File:Handcontrollerport.png]]
(I15 % 15) = 3 will give the data for the antenna. I15 denotes that there are 15 antennas. This takes the record number mod 15 and will only extract a record when this equals 3 (antenna 4, as the values here are 0 indexed).  


Connect the hand controller to the port.
It will also only extract values in the specified time range.


[[File:Handcontrollerconnected.png]]
Finally we want the data ordered by timestamp.


Turn the power switch back on.
Now we retrieve the requested data:
The antenna can now be moved to a suitable position using the azimuth and elevation controls on the hand controller.
<pre style="font-family:courier">data, msg = db.do_query(cursor,query)</pre>


[[File:Handcontroller.png]]
The data is stored in a dictionary. We can view the keys as follows:
<pre style="font-family:courier">data.keys()</pre>


=== Moving the Old Antennas Manually ===
This will produce an output as follows:
At the lower right of the control box, there is a panel for controlling the antenna manually as shown below.
<pre style="font-family:courier">[u'Timestamp', u'Ante_Fron_FEM_VPol_Power']</pre>


[[File:Old_Ant_Controller.jpg]]
We convert the timestamps to numpy times:
<pre style="font-family:courier">dt = np.array(Time(data['Timestamp'].astype(float), format = 'lv').isot,dtype = 'datetime64')</pre>


Move the bottom center switch to Local. The antenna can now be positioned using the HA and Dec switches.
The labels for the plot can be set if desired:
<pre style="font-family:courier">
title('VPOL Power vs Time')
xlabel('Universal Time')
ylabel('Power (dB)')
</pre>


=== Antenna Stowing at End of Day ===
Finally the data is plotted:
Antennas 1 to 8 are not stowed after observations. Therefore, the antennas will be highlighted as red as they will still be tracking (see image below). There is no need to take any action for these antennas.
<pre style="font-family:courier">plot(dt,data['Ante_Fron_FEM_VPol_Power'])</pre>


[[File:Stateframe_End_of_Day_Ant.png]]
A sample plot is shown below:


Antenna 11 will need to be stowed manually after observations are complete. To do this, enter the commands below:
[[File:Sample_sf_plot.png]]


:<p style="font-family:courier">stop ant11</p>
This plot looks rather cluttered. The number of points can be reduced if we modify our query:
:<p style="font-family:courier">stow ant11</p>
<pre style="font-family:courier">query = 'select Timestamp,Ante_Fron_FEM_VPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' and (cast(Timestamp as bigint) % 10) = 0 order by Timestamp'</pre>


=== Service Stow ===
We then request the data again,convert the timestamps to numpy times and replot the data producing:
Use this procedure to place the antenna into its service stow position.


<span style="color:#FF0000">'''NOTE: do NOT use the service command. This seems to also reset the CRIO.'''</span>
[[File:Sample_sf_plot_reduced_points.png]]


From the schedule window issue the coommand:
Suppose we want to plot both the HPol Power and VPol power on the same plot. This is not difficult to do. We simply modify our query again:
:<p style="font-family:courier">position 225 15 ant#</p>
<pre style="font-family:courier">query = 'select Timestamp,Ante_Fron_FEM_VPol_Power,Ante_Fron_FEM_HPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' and (cast(Timestamp as bigint) % 10) = 0 order by Timestamp'</pre>
where ant# is the antenna to place into service stow.


=== Stopping and Restarting Helios VNC ===
Now HPol has been added and we just send this query as above. If we look at the keys now we see:
If the helios VNC server needs to be stopped then you will need to find the process ID number (PID#). From a helios terminal issue the following command:
<pre style="font-family:courier">[u'Timestamp', u'Ante_Fron_FEM_HPol_Power', u'Ante_Fron_FEM_VPol_Power']</pre>
:<p style="font-family:courier">ps -A | grep vnc</p>
 
To plot this data as a scatter plot we use the following commands:
<pre style="font-family:courier">hpol, = plot(dt,data['Ante_Fron_FEM_HPol_Power'].astype(float),'o', label='HPOL')
vpol, = plot(dt,data['Ante_Fron_FEM_VPol_Power'],'o', label='VPOL')
legend(handles=[hpol,vpol])
</pre>


You will see a line that looks something like:
which produces this plot:
:<p style="font-family:courier">26626 ?        00:00:00 x11vnc</p>


The number on the left is the PID#, in this case 26626.
[[File:HPOL_VPOL_scatter.png]]
To stop VNC issue the command
:<p style="font-family:courier">kill PID#</p>
where in this case PID# would be 26626


'''<span style="color:#FF0000">Note that doing this will cut the VNC connection to any users that are currently logged in.</span>'''
== Power Meter Setup ==
The user manual for the power meter can be found at https://literature.cdn.keysight.com/litweb/pdf/E4418-90032.pdf


To restart VNC issue the command:
Before use the power meter will need to be zeroed and calibrated.
:<p style="font-family:courier">x11vnc -shared -display :0 -forever -noxrecord -clip 1920x1200+0+0 -bg -usepw -rfbport 20000 -auth /home/sched/.Xauthority</p>


Note that VNC is started when Helios is started. The startup script for VNC is located in: <span style="font-family:courier">/etc/init/x11vnc.conf</span>
1. Ensure that the sensor is not connected to anything.


=== Helios Bash Aliases ===
2. Press the ZERO/CAL button.
The aliases for various bash command can be found in the <span style="font-family:courier">.bash_aliases</span> file


=== Shutting off the 27m Control System ===
3. Press the button next to [Zero] displayed on the screen. It will take several seconds to zero.
At times during maintenance on the 27m antenna it may be necessary to turn off the control system to prevent anyone from moving the antenna. To do this perform the following steps.


:Log into the feanta machine from helios:
4. Next remove the SMA adaptor from the end of the sensor and connect the sensor to the POWER REF socket on the power meter as shown below.
::<p style="font-family:courier">ssh antctl@feanta</p>


:Issue the command (note you can use the up arrow until you find the command):
[[File:Power_Meter_Cal.jpg]]
::<p style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl stop</p>


:Log out of feanta by issuing the command <span style="font-family:courier">exit</span>
5. Press the button next to [CAL] displayed on the screen. It will take several seconds.


:There is a crontask that periodically restarts the control system on helios. Issue the command:
6. The SMA power sensor can now be disconnected from the POWER REF socket and the SMA adaptor reconnected.
::<p style="font-family:courier">crontab -e</span>


:This will allow you to edit the crontab file. Scroll down to find the line that reads:
== Vector Network Analyser Setup ==
::<p style="font-family:courier">1 1,5,9,13,17,21 * * * ssh -t antctl@feanta /home/antctl/starburst/femTools/src/starburstControl start</p>


:Place a # in front of this line so that it reads:
[[File:VNA_Photo.jpg]]
::<p style="font-family:courier">#1 1,5,9,13,17,21 * * * ssh -t antctl@feanta /home/antctl/starburst/femTools/src/starburstControl start</p>


:Press CRTL x and then answer Y to save the file.
=== Basic startup and operation ===
Turn on the VNA using the Power button at the front. Note that there is also a power switch on the back of the VNA. Ensure this is on.


Note that when maintenance has finished you will need to edit the crontab file again and remove the # from that line.
Connect the blue SMA cables to the VNA.


=== Installing Computer Updates ===
Press the power button.
Pipeline, Helios and the DPP require regular updates. To install updates, follow the following procedure:
 
Press the 'BW-Avg Power' soft-key.


:Log in to a terminal on a computer that is to be updated.
Click on Output Power.


:Issue the following command:
Ensure RF-off is checked.
::<p style="font-family:courier">sudo apt update && sudo apt upgrade -y</p>


:Restart the computer by:
Under Power, enter the VNA output Power.
::<p style="font-family:courier">sudo reboot now</p>


=== Setting up SSH Keys ===
Press the 'Freq' soft-key
To access a computer without a password via SSH, you cant set up SSH keys that allow password-less access between computers. These instructions are for linux.


Open a terminal on the local computer. Ensure that you are logged in as the appropriate user. Issue the command:
Enter the start frequency and end frequency.
:<p style="font-family:courier">ssh-keygen -t dsa -f {remote_computer}</p>
where <span style="font-family:courier">{remote_computer}</span> is the name of the computer that you wish to access.


This will create two files:
Connect port 1 to the input of the device to be tested.
:<p style="font-family:courier">{remote_computer}</p>
:<p style="font-family:courier">{remote_computer}.pub</p>


Now use scp to copy the <span style="font-family:courier">{remote_computer}.pub</span> file to the remote computer.
Connect port 2 to the output of the device to be tested.
:<p style="font-family:courier">scp {remote_computer}.pub {user}@{remote_computer}:</p>


Enter the password when prompted. Note that <span style="font-family:courier">{user}</span> is the user name of the account that you wish to access.
Press the 'BW-Avg Power' soft-key.


Log into the remote computer using ssh.
Uncheck RF-off.
:<p style="font-family:courier">ssh {user}@{remote_computer}</p>


Now copy the contents of the <span style="font-family:courier">{remote_computer}.pub</span> file to <span style="font-family:courier">~/.ssh/authorized_keys2</span>
=== Autoscale Display ===
:<p style="font-family:courier">cat {remote_computer}.pub >> ~/.ssh/authorized_keys2</p>


You may need to change permissions on the new file:
Press the 'Scale' soft key.
:<p style="font-family:courier">chmod 600 ~/.ssh/authorized_keys2</p>


Remove the original file:
Click on Auto-Scale Trace.
:<p style="font-family:courier">rm {remote_computer}.pub</p>


Logout from the remote computer:
=== Average Trace ===
:<p style="font-family:courier">exit</p>


Start the ssh agent:
Press the 'BW-Avg Power' soft-key.
:<p style="font-family:courier">eval `ssh-agent -s`</p>


Now add the identity:
Select Moving Average.
:<p style="font-family:courier">ssh-add ~/.ssh/identity_{remote_computer}</p>


You should now be able to log in to the remote computer without a password.
Set Factor. This is the number of sweeps the trace is averaged over.


=== Changing Antenna Settings at the Controller ===
Check On.
At the antenna, place the antenna into standby.


Make sure you select the correct controller (Azimuth or Elevation).
=== Saving a Trace ===


On the controller, press M to enable menu selection.
Press the 'Trace' soft key.


Use the left and right arrows to select the appropriate menu and the up and down arrows to select the appropriate parameters.
Click on Trace Data.


Press M again to edit the chosen parameter.
Click on Ascii


Use the left and right arrows to shift to the digit you want to change and use the up and down arrows to enter the required digit.
Under Contents select Active Trace.


Once the parameter has been updated, press M to get back to menu selection.
Under Output format select dB Mag-Phase.


If setting menu 20 parameters, go to parameter 15.19 and press the up arrow. This option will change from off to on and then back to off. This will save the parameter.
Under Field Separator select Comma.


For any other menus, go to parameter 0.00 and change it to 1000.
Under Decimal select Point.


Press M to exit the menu selection.
Enter the folder and filename.


Return the antenna to operate and reboot the antenna for changes to take affect.
Click on Save.


== Data Analysis ==
== Other ==
=== Installing Suncasa on Ubuntu 22 ===
=== DPP Fix Packets Details ===
Some of the libraries (including python3.8) that are required for suncasa are not part of the Ubuntu 22 distribution. The following is a summary of the instructions to install suncasa on Ubuntu 22 and later versions.


Update Ubuntu and add old repositories:
==== Basic Operation and Monitoring ====
:<p style="font-family:courier">sudo apt update && sudo apt upgrade</p>
As of August 2021 the interrupt priority is handled largely automatically. This section describes the updated programs.
:<p style="font-family:courier">sudo apt install software-properties-common</p>
:<p style="font-family:courier">sudo add-apt-repository ppa:deadsnakes/ppa</p>


Install python3.8:
The program that handles reassignment of the CPUs and packet monitoring in called <span style="font-family:courier">dpp_fix_packets.py</span> and is located in the  <span style="font-family:courier">/common/python/current/</span> folder.
:<p style="font-family:courier">sudo apt install python3.8</p>


Install python 3.8 virtual environment:
However this is typically not run directly. Rather it is run from a script on the DPP: <span style="font-family:courier">/home/user/test_svn/shell_scripts/start_fix_packets.sh</span>
:<p style="font-family:courier">sudo apt-get install python3.8-venv


Create a suncasa python environment:
This script checks to see if the <span style="font-family:courier">dpp_fix_packets.py</span> program is running. If it is not then it will restart it. Note that the actual line in the script that starts <span style="font-family:courier">dpp_fix_packets.py</span> is as follows:
:<p style="font-family:courier">python3.8 -m venv suncasaenv</p>


Activate the suncasa environment:
<pre style="font-family:courier">screen -S fixpackets -d -m python /common/python/current/dpp_fix_packets.py</pre>
:<p style="font-family:courier">source suncasaenv/bin/activate</p>


Install pip, suncasa and ipython:
This command starts the <span style="font-family:courier">dpp_fix_packets.py</span> in a screen named "fixpackets" in detatched mode ("-d -m").
:<p style="font-family:courier">pip install --upgrade pip wheel</p>
:<p style="font-family:courier">pip install suncasa</p>
:<p style="font-family:courier">pip install ipython3</p>


Cleanup the cache so different version of python and ipython are not being used:
To access the screen, and hence the output of the program simply type <span style="font-family:courier">screen -r fixpackets</span>
:<p style="font-family:courier">hash -r</p>


Check that the installation works:
This should show output that updates every minute as shown below:
:<p style="font-family:courier">ipython3</p>
:<p style="font-family:courier">import suncasa</p>
:<p style="font-family:courier">help(suncasa)</p>
:<p style="font-family:courier">import casatasks</p>
:<p style="font-family:courier">help(casatasks)</p>


To exit from the suncasa environment:
[[file:Dpp_output.png]]
:<p style="font-family:courier">deactivate</p>


Exit from ipython:
'''Note that I will normally show the fixpackets screen in a terminal after I have rebooted the DPP (OG)'''
:<p style="font-family:courier">exit</p>


Set up EOVSA packages and site:
Information is also written to the <span style="font-family:courier">/common/webplots/dpp_fix_packets_log.txt</span> file. This contains the last 20 lines of significant output of the <span style="font-family:courier">dpp_fix_packets.py</span> program. This file is read by the stateframe display. In addition it writes the CPUs currently used by the fix packets program to the <span style="font-family:courier">/common/webplots/dpp_cpu.txt</span> file. This is also read by the stateframe display.
:<p style="font-family:courier">printf "import sys \nimport os \nimport sysconfig \nimport casatools \nimport casadata \nimport time \nlogfile='casalog-{}.log'.format(time.strftime('%%Y%%m%%d-%%H',time.localtime())) \ntelemetry_enabled = False \ncrashreporter_enabled = True \ntb=casatools.table() \nospathsep = os.path.sep \nlibpath = sysconfig.get_paths()['purelib'] \nobsdict = {'MJD': 57447.0, 'Name': 'EOVSA', 'Type': 'WGS84', 'Long': -118.287, \n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'Lat': 37.2332, 'Height': 1207.13, 'X': 0.0, 'Y': 0.0, 'Z': 0.0,  \n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'Source': 'Dale Gary'} \nobstable = os.path.join(casadata.datapath,'geodetic','Observatories') \ntb.open(obstable, nomodify=True) \nif 'EOVSA' not in tb.getcol('Name'): \n&nbsp;&nbsp;&nbsp;&nbsp;print('Adding EOVSA to the Observatories') \n&nbsp;&nbsp;&nbsp;&nbsp;tb.close() \n&nbsp;&nbsp;&nbsp;&nbsp;tb.open(obstable, nomodify=False) \n&nbsp;&nbsp;&nbsp;&nbsp;nrows = tb.nrows() \n&nbsp;tb.addrows(1) \n&nbsp;for k in obsdict.keys(): \n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tb.putcell(k, nrows, obsdict[k])&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;\ntb.close() \n" > $HOME/.casa/config.py</p>
:<p style="font-family:courier">echo "sitepackagepath = '$HOME/suncasaenv/lib/python3.8/site-packages'" >> $HOME/.casa/config.py</p>
:<p style="font-family:courier">echo "if sitepackagepath not in sys.path:" >> $HOME/.casa/config.py</p>
:<p style="font-family:courier">echo "&nbsp;&nbsp;&nbsp;&nbsp;sys.path.append(sitepackagepath)"&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;>> $HOME/.casa/config.py</p>


To exit the suncasa environment:
At the bottom of the stateframe display is a section titled <span style="font-family:courier">Last DPP Fix Packets Messages</span>. This displays the last 3 messages by <span style="font-family:courier">dpp_fix_packets.py</span>. An example is given below:
:<p style="font-family:courier">deactivate</p>


Note that you must be in the suncasa environment to use suncasa!
[[file:Stateframe_dpp_msg.png]]


=== EOVSA synoptic Fits Images ===
This will display potentially 4 different types of messages:
This section is mostly to do with how to load an view EOVSA synoptic FITS images.


From pipelne change to the <span style="font-family:courier">/common/python/mapping</span> folder.
:<span style="font-family:courier">Packet Loss Detected</span>: This notifies that there was a packet loss and the interfaces are being reset.


From ipython, issue the following commands to load the required libraries:
:<span style="font-family:courier">dpp_fix_packets.py has been restarted</span>: Indicates that the fix packets program has restarted. This will normally occur after a reboot of the DPP.


:<p style="font-family:courier">from fits2map import *</p>
:<span style="font-family:courier">Resetting CPUs - Using CPUs 18 and 19</span>: Notifies that the CPUs being used were change. Valid CPU pairs are [18 19], [20 21], [21 22].
:<p style="font-family:courier">from plot_map import *</p>


The files can be found at http://www.ovsa.njit.edu/fits/synoptic/. To see what files are available click on the appropriate folder.
:<span style="font-family:courier">DPP REBOOT REQUIRED!</span>: This indicates that all CPU pairs have been used and that the DPP should be rebooted.
 
==== Startup Script and Automatic Monitoring ====
The <span style="font-family:courier">/home/user/test_svn/shell_scripts/start_fix_packets.sh</span> is run at DPP startup. The following command is placed in the crontab file:


To load a particular file you would issue the command:
<pre style="font-family:courier">@reboot /bin/bash /home/user/test_svn/shell_scripts/start_fix_packets.sh</pre>


:<p style="font-family:courier">eomap1 = fits2map("eomap1=fits2map("http://www.ovsa.njit.edu/fits/synoptic/2020/05/19/eovsa_20200519.spw06-10.tb.disk.fits")</p>
This starts the script on reboot (or startup).


In this case it would load a full disk image from 2020-05-19 created from bands 6 to 10 into eomap1.
Additionally this same script is run every 10 minutes in order to ensure that the program is still running. It will not restart <span style="font-family:courier">dpp_fix_packets.py</span> if it is already running. This command is also present in the crontab file:


To view the image issue the command:
<pre style="font-family:courier">*/10 * * * * /home/user/test_svn/shell_scripts/start_fix_packets.sh</pre>


:<p style="font-family:courier">plot_map(eomap1)</p>
=== Windscram ===
A windscram occurs when the wind exceeds 18 miles/hour for 5 minutes. While a windscram can occur at any time, it is only important during a phasecal, as this is typically the only time that the 27m antenna is tracking. The 27m will stow during a windscram. Note that when the wind drops the antenna will not resume tracking. If the wind has dropped for a significant period of time, you can resume 27m operation by issuing the command:
<pre style="font-family:courier">track ant14</pre>


This will produce a plot similar to that below.
from the schedule window.


[[File:Eomap.png]]
You can check the wind speed history by clicking on temps. The solid gray line is the average wind speed.


The image parameters are stored as a dictionary and can be viewed by:
=== Reloading the crio.ini File ===
<span style="color:#FF0000">'''DO THIS WITH EXTREME CAUTION. BE ABSOLUTELY CERTAIN THAT RELOADING THE CRIO FILE IS REQUIRED.'''</span>


:<p style="font-family:courier">eomap1.keys()</p>
For antenna 11, see the special case here:


For more information see http://www.ovsa.njit.edu/wiki/index.php/Mapping_Software
After uploading the new crio.ini file the gains and pointing may also need to be updated.


== Antenna Optical Power at the DCM ==
==== Manually uploading the crio.ini file ====
The following table shows the measured optical power for each antenna at the DCM measured at the given date. Values of HI indicate the power meter saturated.
From helios, open a terminal and type <span style="font-family:courier">cd /home/sched/Dropbox/PythonCode/Current/crio_inis</span>


{| class="wikitable" style="margin:auto"
For the antenna that needs to be reset, find the most recent '.ini' file. For example, for antenna 10 this may be 'crio10-2019-09-28.ini'. Make a note of this file.
|+ Antenna Optical Power
 
|-
Enter the command <span style="font-family:courier">ftp crio10.solar.pvt</span>. Replace crio10 with the apropriate CRIO number.
! Ant # !! Power (dB) !! Date
 
|-
Enter the username and password when prompted.
| 1 || HI || 2022-05-18
 
|-
Enter the following commands:
| 2 || HI || 2022-05-18
 
|-
<pre style="font-family:courier">
| 3 || HI || 2022-05-18
cd ni-rt/startup
|-
put crio10-2019-09-28.ini crio.ini
| 4 || HI || 2022-05-18
bye
</pre>
 
replacing 'crio10-2019-09-28.ini' with the appropriate file for the CRIO that needs to be reset.
 
The above commands have reloaded the crio.ini file. The CRIO now needs to be reset. For example, Antenna 10 will be reset by issuing the following commands from the schedule window:
 
<pre style="font-family:courier">
sync ant10
tracktable sun_tab.radec ant10
track
</pre>
 
==== Using ipython to Upload the crio.ini File ====
 
From helios, open a terminal and access ipython:
:<pre style="font-family:courier">ipython --pylab</pre>
 
Load the crio.py file by entering:
:<pre style="font-family:courier">import crio</pre>
 
Simply issue the command:
:<pre style="font-family:courier">crio.reload_crio_ini('ant#')</pre>
 
where # is the antenna number. The most recent crio.ini file will be uploaded for that antenna.
 
=== Power Meter Setup ===
The user manual for the power meter can be found at https://literature.cdn.keysight.com/litweb/pdf/E4418-90032.pdf
 
Before use the power meter will need to be zeroed and calibrated.
 
1. Ensure that the sensor is not connected to anything.
 
2. Press the ZERO/CAL button.
 
3. Press the button next to [Zero] displayed on the screen. It will take several seconds to zero.
 
4. Next remove the SMA adaptor from the end of the sensor and connect the sensor to the POWER REF socket on the power meter as shown below.
 
[[File:Power_Meter_Cal.jpg]]
 
5. Press the button next to [CAL] displayed on the screen. It will take several seconds.
 
6. The SMA power sensor can now be disconnected from the POWER REF socket and the SMA adaptor reconnected.
 
=== Moving the New Antennas Manually ===
 
Power off the antenna by turning the power switch at the bottom right of the Antenna Control Box.
Switch the Maint/Norm Switch to Maint.
Switch the Remote Switch to Remote.
 
[[File:AntControlBox.png]]
 
Remove the block from the hand controller port.
'''Remember to place the block back after you have finished working on the antenna. It will not run in remote without it!'''
 
[[File:Handcontrollerport.png]]
 
Connect the hand controller to the port.
 
[[File:Handcontrollerconnected.png]]
 
Turn the power switch back on.
The antenna can now be moved to a suitable position using the azimuth and elevation controls on the hand controller.
 
[[File:Handcontroller.png]]
 
=== Moving the Old Antennas Manually ===
At the lower right of the control box, there is a panel for controlling the antenna manually as shown below.
 
[[File:Old_Ant_Controller.jpg]]
 
Move the bottom center switch to Local. The antenna can now be positioned using the HA and Dec switches.
 
=== Antenna Stowing at End of Day ===
Antennas 1 to 8 are not stowed after observations. Therefore, the antennas will be highlighted as red as they will still be tracking (see image below). There is no need to take any action for these antennas.
 
[[File:Stateframe_End_of_Day_Ant.png]]
 
Antenna 11 will need to be stowed manually after observations are complete. To do this, enter the commands below:
 
<pre style="font-family:courier">
stop ant11
stow ant11
</pre>
 
=== Service Stow ===
Use this procedure to place the antenna into its service stow position.
 
<span style="color:#FF0000">'''NOTE: do NOT use the service command. This seems to also reset the CRIO.'''</span>
 
From the schedule window issue the command:
<pre style="font-family:courier">position 225 15 ant#</pre>
where ant# is the antenna to place into service stow.
 
=== Stopping and Restarting Helios VNC ===
If the helios VNC server needs to be stopped then you will need to find the process ID number (PID#). From a helios terminal issue the following command:
<pre style="font-family:courier">ps -A | grep vnc</pre>
 
You will see a line that looks something like:
<pre style="font-family:courier">26626 ?        00:00:00 x11vnc</pre>
 
The number on the left is the PID#, in this case 26626.
To stop VNC issue the command
<pre style="font-family:courier">kill PID#</pre>
where in this case PID# would be 26626
 
'''<span style="color:#FF0000">Note that doing this will cut the VNC connection to any users that are currently logged in.</span>'''
 
To restart VNC issue the command:
<pre style="font-family:courier">x11vnc -shared -display :0 -forever -noxrecord -clip 1920x1200+0+0 -bg -usepw -rfbport 20000 -auth /home/sched/.Xauthority</pre>
 
Note that VNC is started when Helios is started. The startup script for VNC is located in: <span style="font-family:courier">/etc/init/x11vnc.conf</span>
 
=== Helios Bash Aliases ===
The aliases for various bash command can be found in the <span style="font-family:courier">.bash_aliases</span> file
 
=== Shutting off the 27m Control System ===
At times during maintenance on the 27m antenna it may be necessary to turn off the control system to prevent anyone from moving the antenna. To do this perform the following steps.
 
:Log into the feanta machine from helios:
<pre style="font-family:courier">ssh antctl@feanta</pre>
 
:Issue the command (note you can use the up arrow until you find the command):
<pre style="font-family:courier">/home/antctl/starburst/femTools/src/starburstControl stop</pre>
 
:Log out of feanta by issuing the command:
<pre style="font-family:courier">exit</pre>
 
:There is a crontask that periodically restarts the control system on helios. Issue the command:
<pre style="font-family:courier">crontab -e</pre>
 
:This will allow you to edit the crontab file. Scroll down to find the line that reads:
<pre style="font-family:courier">1 1,5,9,13,17,21 * * * ssh -t antctl@feanta /home/antctl/starburst/femTools/src/starburstControl start</pre>
 
:Place a # in front of this line so that it reads:
<pre style="font-family:courier">#1 1,5,9,13,17,21 * * * ssh -t antctl@feanta /home/antctl/starburst/femTools/src/starburstControl start</pre>
 
:Press CRTL x and then answer Y to save the file.
 
Note that when maintenance has finished you will need to edit the crontab file again and remove the # from that line.
 
=== Installing Computer Updates ===
Pipeline, Helios and the DPP require regular updates. To install updates, follow the following procedure:
 
:Log in to a terminal on a computer that is to be updated.
 
:Issue the following command:
<pre style="font-family:courier">sudo apt update && sudo apt upgrade -y</pre>
 
:Restart the computer by:
<pre style="font-family:courier">sudo reboot now</pre>
 
=== Setting up SSH Keys ===
To access a computer without a password via SSH, you cant set up SSH keys that allow password-less access between computers. These instructions are for linux.
 
Open a terminal on the local computer. Ensure that you are logged in as the appropriate user. Issue the command:
<pre style="font-family:courier">ssh-keygen -t dsa -f {remote_computer}</pre>
where <span style="font-family:courier">{remote_computer}</span> is the name of the computer that you wish to access.
 
This will create two files:
:<p style="font-family:courier">{remote_computer}</p>
:<p style="font-family:courier">{remote_computer}.pub</p>
 
Now use scp to copy the <span style="font-family:courier">{remote_computer}.pub</span> file to the remote computer.
<pre style="font-family:courier">scp {remote_computer}.pub {user}@{remote_computer}:</pre>
 
Enter the password when prompted. Note that <span style="font-family:courier">{user}</span> is the user name of the account that you wish to access.
 
Log into the remote computer using ssh.
<pre style="font-family:courier">ssh {user}@{remote_computer}</pre>
 
Now copy the contents of the <span style="font-family:courier">{remote_computer}.pub</span> file to <span style="font-family:courier">~/.ssh/authorized_keys2</span>
<pre style="font-family:courier">cat {remote_computer}.pub >> ~/.ssh/authorized_keys2</pre>
 
You may need to change permissions on the new file:
<pre style="font-family:courier">chmod 600 ~/.ssh/authorized_keys2</pre>
 
Remove the original file:
<pre style="font-family:courier">rm {remote_computer}.pub</pre>
 
Logout from the remote computer:
<pre style="font-family:courier">exit</pre>
 
Start the ssh agent:
<pre style="font-family:courier">eval `ssh-agent -s`</pre>
 
Now add the identity:
<pre style="font-family:courier">ssh-add ~/.ssh/identity_{remote_computer}</pre>
 
You should now be able to log in to the remote computer without a password.
 
=== Changing Antenna Settings at the Controller ===
At the antenna, place the antenna into standby.
 
Make sure you select the correct controller (Azimuth or Elevation).
 
On the controller, press M to enable menu selection.
 
Use the left and right arrows to select the appropriate menu and the up and down arrows to select the appropriate parameters.
 
Press M again to edit the chosen parameter.
 
Use the left and right arrows to shift to the digit you want to change and use the up and down arrows to enter the required digit.
 
Once the parameter has been updated, press M to get back to menu selection.
 
If setting menu 20 parameters, go to parameter 15.19 and press the up arrow. This option will change from off to on and then back to off. This will save the parameter.
 
For any other menus, go to parameter 0.00 and change it to 1000.
 
Press M to exit the menu selection.
 
Return the antenna to operate and reboot the antenna for changes to take affect.
 
== Data Analysis ==
=== Installing Suncasa on Ubuntu 22 ===
Some of the libraries (including python3.8) that are required for suncasa are not part of the Ubuntu 22 distribution. The following is a summary of the instructions to install suncasa on Ubuntu 22 and later versions.
 
Update Ubuntu and add old repositories:
<pre style="font-family:courier">
sudo apt update && sudo apt upgrade
sudo apt install software-properties-common
sudo add-apt-repository ppa:deadsnakes/ppa
</pre>
 
Install python3.8:
<pre style="font-family:courier">sudo apt install python3.8</pre>
 
Install python 3.8 virtual environment:
<pre style="font-family:courier">sudo apt-get install python3.8-venv</pre>
 
Create a suncasa python environment:
<pre style="font-family:courier">python3.8 -m venv suncasaenv</pre>
 
Activate the suncasa environment:
<pre style="font-family:courier">source suncasaenv/bin/activate</pre>
 
Install pip, suncasa and ipython:
<pre style="font-family:courier">
pip install --upgrade pip wheel
pip install suncasa
pip install ipython3
</pre>
 
Cleanup the cache so different version of python and ipython are not being used:
<pre style="font-family:courier">hash -r</pre>
 
Check that the installation works:
<pre style="font-family:courier">
ipython3
import suncasa
help(suncasa)
import casatasks
help(casatasks)
</pre>
 
To exit from the suncasa environment:
<pre style="font-family:courier">deactivate</pre>
 
Exit from ipython:
<pre style="font-family:courier">exit</pre>
 
Set up EOVSA packages and site:
<pre style="font-family:courier">
printf "import sys \nimport os \nimport sysconfig \nimport casatools \nimport casadata \nimport time \nlogfile='casalog-{}.log'.format(time.strftime('%%Y%%m%%d-%%H',time.localtime())) \ntelemetry_enabled = False \ncrashreporter_enabled = True \ntb=casatools.table() \nospathsep = os.path.sep \nlibpath = sysconfig.get_paths()['purelib'] \nobsdict = {'MJD': 57447.0, 'Name': 'EOVSA', 'Type': 'WGS84', 'Long': -118.287, \n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'Lat': 37.2332, 'Height': 1207.13, 'X': 0.0, 'Y': 0.0, 'Z': 0.0,  \n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'Source': 'Dale Gary'} \nobstable = os.path.join(casadata.datapath,'geodetic','Observatories') \ntb.open(obstable, nomodify=True) \nif 'EOVSA' not in tb.getcol('Name'): \n&nbsp;&nbsp;&nbsp;&nbsp;print('Adding EOVSA to the Observatories') \n&nbsp;&nbsp;&nbsp;&nbsp;tb.close() \n&nbsp;&nbsp;&nbsp;&nbsp;tb.open(obstable, nomodify=False) \n&nbsp;&nbsp;&nbsp;&nbsp;nrows = tb.nrows() \n&nbsp;tb.addrows(1) \n&nbsp;for k in obsdict.keys(): \n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tb.putcell(k, nrows, obsdict[k])&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;\ntb.close() \n" > $HOME/.casa/config.py
echo "sitepackagepath = '$HOME/suncasaenv/lib/python3.8/site-packages'" >> $HOME/.casa/config.py
echo "if sitepackagepath not in sys.path:" >> $HOME/.casa/config.py
echo "&nbsp;&nbsp;&nbsp;&nbsp;sys.path.append(sitepackagepath)"&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;>> $HOME/.casa/config.py
</pre>
 
To exit the suncasa environment:
<pre style="font-family:courier">deactivate</pre>
 
Note that you must be in the suncasa environment to use suncasa!
 
=== EOVSA synoptic Fits Images ===
This section is mostly to do with how to load an view EOVSA synoptic FITS images.
 
From pipelne change to the <span style="font-family:courier">/common/python/mapping</span> folder.
 
From ipython, issue the following commands to load the required libraries:
 
<pre style="font-family:courier">
from fits2map import *
from plot_map import *
</pre>
 
The files can be found at http://www.ovsa.njit.edu/fits/synoptic/. To see what files are available click on the appropriate folder.
 
To load a particular file you would issue the command:
 
<pre style="font-family:courier">eomap1 = fits2map("eomap1=fits2map("http://www.ovsa.njit.edu/fits/synoptic/2020/05/19/eovsa_20200519.spw06-10.tb.disk.fits")</pre>
 
In this case it would load a full disk image from 2020-05-19 created from bands 6 to 10 into eomap1.
 
To view the image issue the command:
 
<pre style="font-family:courier">plot_map(eomap1)</pre>
 
This will produce a plot similar to that below.
 
[[File:Eomap.png]]
 
The image parameters are stored as a dictionary and can be viewed by:
 
<pre style="font-family:courier">eomap1.keys()</pre>
 
For more information see http://www.ovsa.njit.edu/wiki/index.php/Mapping_Software
 
== Antenna Optical Power at the DCM ==
The following table shows the measured optical power for each antenna at the DCM measured at the given date. Values of HI indicate the power meter saturated.
 
{| class="wikitable" style="margin:auto"
|+ Antenna Optical Power
|-
! Ant # !! Power (dB) !! Date
|-
|-
| 4 || HI || 2022-05-18
| 1 || HI || 2022-05-18
|-
|-
| 5 || HI || 2022-05-18
| 2 || HI || 2022-05-18
|-
|-
| 6 || HI || 2022-05-18
| 3 || HI || 2022-05-18
|-
|-
| 7 || 3.88 || 2022-05-18
| 4 || HI || 2022-05-18
|-
|-
| 8 || HI || 2022-05-18
| 4 || HI || 2022-05-18
|-
| 5 || HI || 2022-05-18
|-
| 6 || HI || 2022-05-18
|-
| 7 || 3.88 || 2022-05-18
|-
| 8 || HI || 2022-05-18
|-
| 9 || 5.36 || 2022-05-18
|-
| 10 || HI || 2022-05-18
|-
| 11 || 4.40 || 2022-05-18
|-
| 12 || HI || 2022-05-18
|-
| 13 || HI || 2022-05-18
|}
 
== Maintenance ==
=== Routine Maintenance ===
==== Old Antennas (9-11,13) ====
{| class="wikitable"
|+ Greasing
! Antenna
! Last Done
! Next Scheduled
|-
| 9 || 2022-09-02 || 2023-03-02 
|-
| 10 || 2022-09-02 || 2023-03-02
|-
| 11 || 2022-09-02 || 2023-03-02
|-
| 13 || 2022-09-02 || 2023-03-02
|-
|}
 
== Antenna Components ==
=== Spin RF Feeds ===
{| class="wikitable"
! Antenna
! Serial No.
! Tag No.
|-
| 1 || CC2D03Q18R || 52393
|-
| 2 || CC2D01Q18R || 52394
|-
| 3 || CC2D05Q18R || 52395
|-
| 4 || CC2D08Q18R || 52396
|-
| 5 || CC2D07Q18R || 52397
|-
| 6 || CC2D11Q18R || 52398
|-
| 7 || CC2D10Q18R || 52399
|-
| 8 || CC2D12Q18R || 52400
|-
| 9 || CC2D04Q18R || 52401
|-
| 10 || CC2D06Q18R || 52402
|-
|-
| 9 || 5.36 || 2022-05-18
| 11 || DU2D01Q18R || 52403
|-
|-
| 10 || HI || 2022-05-18
| 12 || CC2D09Q18R || 52404
|-
|-
| 11 || 4.40 || 2022-05-18
| 13 || CC2D02Q18R || 52405
|-
|-
| 12 || HI || 2022-05-18
|-
| 13 || HI || 2022-05-18
|}
|}


== Maintenance ==
=== Routine Maintenance ===
==== Old Antennas (9-11,13) ====
{| class="wikitable"
|+ Greasing
! Antenna
! Last Done
! Next Scheduled
|-
| 9 || 2022-09-02 || 2023-03-02 
|-
| 10 || 2022-09-02 || 2023-03-02
|-
| 11 || 2022-09-02 || 2023-03-02
|-
| 13 || 2022-09-02 || 2023-03-02
|-
|}
== Antenna Components ==
=== Antenna 1 ===
=== Antenna 1 ===
{| class="wikitable"
{| class="wikitable"

Latest revision as of 18:20, 30 June 2024

List of Routine Tasks

Daily Tasks

Check the following pages:

http://ovsa.njit.edu/status.php The all-day plot from the previous day is at the bottom of the page. The last 45 minutes of data is at the top right of the page or direct link is here: http://ovsa.njit.edu/flaremon/XSP_latest.png

http://www.ovsa.njit.edu/browser/ This defaults to showing pipeline output from two days previous.

http://ovsa.njit.edu/pointing/ The latest pointing plot(s) at the bottom.

http://ovsa.njit.edu/phasecal/ The latest phasecal vs. frequency is somewhere in the middle, i.e. the bottom of the list of pcf*.png files.

http://ovsa.njit.edu/EOVSA/ant_status.php Current antenna status.

** Ensure that the schedule is running and updating. Check that the stateframe is updating. Check frequently! **

Check that the data files are being updated. Goto the user@dpp terminal and type:

ls /data1/IDB |tail

Check that the adc_plot.py program is running.

Regularly check to see if a flare is in progress (http://ovsa.njit.edu/status.php). If there is a flare in progress you may need to pause the schedule (http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Pausing_and_Adjusting_the_Schedule).

Perform a Phase Calibration


Check that the network monitoring function (fix_packets()) is working on the DPP. It can also be seen as dropouts on the spectrogram (http://ovsa.njit.edu/status.php).

Check the Front End Power on the stateframe display. These values should be between about 0 and 3dBm. If the front end power looks suspicious, you can check it by plotting the front end power vs time (see here for instructions: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Plotting_Stateframe_Data).

If there are any problems with any of the antennas goto http://ovsa.njit.edu/EOVSA/ant_status/ant_status_form.php and fill out the appropriate form.

Weekly Tasks

Perform a Gain Calibration

Check the NJIT Vehicle:

Ensure fluid levels are good.
Check the rodent baits and replace as needed.
Check the engine compartment for signs of rodents.
Drive the vehicle for at least 1/2 hour per week.

Monthly Tasks

Perform a Pointing Calibration

Login Procedures

Remote Login

The computers can be accessed remotely using SSH and VNC. Since I use Linux (Ubuntu) these instruction are for that OS.

Helios

To VNC into Helios, open a terminal and type the following command:

ssh -L 5902:helios.solar.pvt:20000 oweng@ovsa.njit.edu

Note replace oweng with your gateway login name)

Then open Remmina Remote Desktop Client. Make sure VNC is selected at the top left. Type in:

localhost:2

and enter the password when prompted.

The Helios display should now be visible.

Occasionally, the VNC connection will be lost. If this occurs the following procedure need to be performed.

From a new terminal window type:

ssh -L 8887:helios.solar.pvt:22 oweng@ovsa.njit.edu

From another terminal issue the command:

ssh -p 8887 sched@localhost

Now type in:

x11go

Now restart the VNC client.

Note that the VNC connection issue should now be resolved. If you notice it dropping out let Owen know what you were doing at the time.

Pipeline

To log in to pipeline, from a terminal enter the command:

ssh -L 8888:pipeline.solar.pvt:22 oweng@ovsa.njit.edu

Then from a new terminal enter:

ssh -p 8888 user@localhost

Win1

To log in to the win1 machine, from a terminal enter the command:

ssh -L 8889:win1.solar.pvt:5900 oweng@ovsa.njit.edu

Then from a new VPN client enter the hostname:

localhost:8889

DPP

To login to the DPP machine, from a terminal enter the command:

ssh -L 8890:dpp.solar.pvt:5900 oweng@ovsa.njit.edu

Then from a new terminal enter:

ssh -p 8900 user@localhost

Remote File Copy

To copy files using scp (SSH-COPY) through the above tunnels, use the command (this example for port 8888):

scp -P 8888 user@localhost:<path and file to copy> <file destination>

Local Login

If logging into a computer locally on site then the following procedures are used:

Helios

Open the Remmina Remote Desktop Client. Make sure VNC is selected at the top left. Type in:

helios:20000

and enter the password when prompted.

The Helios display should now be visible.

To access a helios terminal, from a new terminal window type:

ssh sched@helios

Pipeline

To log in to pipeline, from a terminal enter the command:

ssh user@pipeline

Win1

To log in to the win1 machine, from a new VPN client enter the hostname:

win1

DPP

To login to the DPP machine, from a terminal enter the command:

ssh user@dpp


Setting up Accounts for Remote Access

Administrators

Log in to the gate way machine and start a superuser prompt:

su

or

sudo su

Then issue the following commands:

useradd -m -s /bin/bash ''username''
usermod -a -G ''username'' ''username''
cd /home/''username''
mkdir .ssh
chown ''username'' .ssh
chmod 700 .ssh

Once the above commands have been entered, ask the user to send you the public ssh key. Once you have this issue the following commands:

echo "''public key''" > .ssh/authorized_keys
chmod 600 .ssh/authorized keys

Note that the public key will be be very long. There can be no new line in the key, and the key should start with 'ssh rsa'. The user should now be able to access the gateway machine.

Linux Users

You must generate a pair of ssh keys to be able to access the gateway machine. From a command prompt issue the following command:

ssh-keygen

This will generate a pair of keys in the .ssh folder. The id_rsa file is the private key. DO NOT SHARE YOUR PRIVATE KEY WITH ANYBODY!

The id_rsa.pub file is the public key. Email this key to Owen or Dale and they will had it to your account. Note that Tohbans will typically be using the guest account. You will be notified once your public key has been added to the authorized_keys file. You should then be able to login.

Repeat this process if you have more than one machine that you wish to log into.

Helios Displays

Schedule Window

The Schedule window shows the currently running schedule as shown below.

The Schedule Window

The left side of the window shows each of the scripts that is to be run. The orange bar shows the task that is currently being run.

The right side of the window shows each command that is to be run in the current script.

At the bottom of the window are a series of buttons. The STOP button will stop at the current script. Once stopped, the remaining buttons will become active. To restart the schedule click on the GO button.

Restarting the schedule window

If the schedule window has locked up then you will need to close it. Click on the X at the top right of the screen.

If this does not work then from a helios terminal type in the command:

ps -elf | grep "schedule"

An output similar to that below will be displayed:

Sched pid.png

Note down the PID for the /current/python/common/schedule.py program, marked in red. Note that the number will be different from the one in this example.

To terminate the program type:

kill -9 PID#

where PID# is the number obtained from the ps command.

If the schedule window gets closed (or you closed it), it will need to be restarted. Follow the procedure below.

From a helios terminal issue the the command:

screen -ls

This will list all of the available screens as shown below.

Screenlist.png

If the schedule is listed (marked in red below)

Screenlist-sched-marked.png

then issue the command:

screen -r schedule

to restore the current screen. Take a screen capture of the terminal window if there are any errors listed and send a copy to Owen or Dale.

If it is not listed then issue the command:

screen -S schedule

to start a new screen.

In either case once the screen is open change to the ~/Dropbox/PythonCode/Current directory:

cd ~/Dropbox/PythonCode/Current

Restart the schedule:

python /common/python/current/schedule.py &

Press <CRTL>AD to exit from screen.

For more information on the screen command see http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Screen_Command

Stateframe Display

The Stateframe display shows the current status of the system as shown below:

Sf display.png

There are problems with any antennas or systems that are highlighted in red. Lines that are marked in yellow designate a warning, but may not be critical.

Lines marked in purple are collapsible sections. Clicking on them will expand or collapse the section.

The tabs near the top of the display bring up different sections and enable graphs to be plotted.

Note that the Log Stateframe box should be marked in blue. If there is a second Stateframe display running this box will be unmarked on the second display.

Restarting the Stateframe Display

If the stateframe window gets closed it will need to be restarted. Follow the procedure below.

From a helios terminal issue the the command:

screen -ls

This will list all of the available screens as shown below.

Screenlist.png

If the stateframe is listed (marked in red below)

Screenlist-sf-marked.png

then issue the command:

screen -r stateframe

to restore the current screen. Take a screen capture of the terminal window if there are any errors listed and send a copy to Owen or Dale.

In either case once the screen is open change to the ~/Dropbox/PythonCode/Current directory:

cd ~/Dropbox/PythonCode/Current

Restart the stateframe display:

python /common/python/current/sf_display.py &

Press <CRTL>AD to exit from screen.

Note that it will take several minutes for the display to come up.

For more information on the screen command see http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Screen_Command

Computer Restart

Helios

To restart Helios, at a terminal enter the command

sudo reboot now

and wait about 5 minutes for it to restart.

Open a terminal and start the dropbox server:

python /home/sched/Downloads/dropbox.py start

Important: Check to see if the time service is running. Enter the command:

chronyc sourcestats

If nothing is displayed, then the time service will need to be started by typing:

sudo systemctl restart chrony.service

Start the x11vnc server by typing:

x11go

Copy the acc0time.txt file to /tmp as follows:

cp /home/sched/Dropbox/PythonCode/Current/acc0time.txt /tmp/

Start the schedule as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Starting_the_schedule_window

Start the Stateframe display as follows as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Restarting_the_Stateframe_Display

Open up a new terminal tab and log into the DPP by typing:

ssh user@dpp

Now issue the command:

ls /data1/IDB | tail 10

Open up a new terminal tab and log into the DPP as above. View the SMP_AFFINITY.sh by typing the command:

cat /home/user/test_svn/shell_scripts/SMP_AFFINITY.sh

Note down the two CPU's that are in use. Issue the following commands:

ipython --pylab
import dpp_plot_packets as dpp
dpp.fix_packets(cpu = [cpu1, cpu2])

where cpu1 and cpu2 are the CPUs that were noted down earlier.

DPP

Tohbans contact Owen or Dale to reboot the DPP!

First, check that the 10 Gb ethernet interfaces are present, by typing the command:

ifconfig

which should show a list of interfaces including enp5s0 and enp7s0. If these are NOT present, type:

sudo modprobe myri10ge

to start the device driver. Then check again that these interfaces are present.

Starting adc_plot

The adc_plot program will need to be restarted. To do this enter the command:

/bin/bash /home/user/test_svn/shell_scripts/adc_plot.sh > /dev/null &

Resetting the Interrupt Priority

The interrupt priority is now automatically reconfigured at startup. There is a 1 minute delay to allow drives to mount and other programs to load prior to the dpp_fix_packets.py program running. Output from the program can be viewed by accessing a DPP terminal and entering the command:

screen -r fixpackets

Significant information is also displayed on the stateframe display on Helios.

Start Data Recording

To start data recording enter:

rmlock

Mounting the dppdata1 disk

Note also that if the DPP reboots it is likely necessary to mount its disk on Pipeline, otherwise the pipeline task will fail. To check, log in to Pipeline and type df. The dppdata1 disk should be present. If it isn't, issue the command from pipeline:

sudo mount -a

ACC

Rebooting the ACC

To reboot the ACC, you will need to cycle the power. Follow the instructions below.

From a web browser, goto the http://pdudigital.solar.pvt page.
Click on the Action button shown below.

Pdudigital actions.png

Then click on Loads.

Pdudigital loads.png

Click on Item 14 - ACC (Array Control Computer)

Pdudigital acc.png

Click on Cycle and then OK when prompted

Pdudigital acc cycle.png

Restarting the ACC software from windows

To bring the ACC back to operation, it needs to be reloaded from windows as detailed below.

From the Windows machine, click on Start and then NI LabVIEW 2015 SP1 and finally EOVSA-LabVIEW 2015.lvproj. Then from the Project Explorer Window click on Targets ==> acc to expand the acc items. Then right click on acc and then click on Connect.

ACC open.png ACC Connect.png

Now click on Startup => ACC Master.vi to open up the ACC Master VI window.Click on the white arrow at the top left of the window.

ACC master option.png ACC start.png

You should see a series of "NO ERROR" messages scrolling in the Initialization Messages window.

ACC no error.png

Finally, from the project explorer window, right click on acc and then click on Disconnect. The ACC Master window can now be closed.

ACC Disconnect.png

Pausing and Adjusting the Schedule

Pausing the Schedule

Occasionally, it may be necessary to pause the schedule. Typically this will need to be done when a flare is in a progress (check here: http://ovsa.njit.edu/flaremon/XSP_latest.png), and observations need to continue. i.e you will not want to move to a calibration. To do this, simply click on Stop on the schedule window. The array will continue to observe the Sun until you click on go again.

Adjusting the Schedule

At times it will be necessary to adjust the schedule, especially if it has been paused or a calibration missed (especially the skycaltest). To adjust the schedule follow the following steps:

If the schedule is not stopped click on stop.

Sched stop.png

Click the items to adjust. These will be highlighted in grey.

Sched select.png

Select the time increment from the top of the schedule and press the up or down keys to adjust the scheduled time.

Sched timeadjust.png

Once done, click on Go to resume the schedule. <

Removing an Item from the Schedule

Occasionally, an item will need to be removed from the schedule, particularly if maintenance is being performed. To remove an item follow the procedure below.

Click on Stop to stop the schedule.

From the menu bar Click on File and then Save

Schedsave.png

Once the save dialogue box appears, just click on Save.

Schedsavedialog.png

Using a text editor open the file /home/sched/Dropbox/PythonCode/Current/solar.scd. You should see the same list as in the schedule. An example is shown below.

2021-03-29 10:06:58 ACQUIRE 1229+020
2021-03-29 10:07:58 LOSELECT
2021-03-29 10:10:58 PHASECAL_LO 1229+020 pcal_lo.fsq
2021-03-29 10:30:58 HISELECT
2021-03-29 10:31:58 PHASECAL 1229+020 pcal_hi-all.fsq
2021-03-29 11:31:58 STOW
2021-03-29 14:37:00 SUN
2021-03-29 15:10:00 ACQUIRE 2253+161
2021-03-29 15:14:00 PHASECAL 2253+161 pcal_hi-all.fsq
2021-03-29 15:40:00 PHASECAL 2253+161 solar.fsq
2021-03-29 15:41:00 SKYCALTEST 2253+161
2021-03-29 15:45:00 SUN
2021-03-29 17:00:00 GAINCALTEST
2021-03-29 17:03:00 SUN
2021-03-29 18:30:00 SOLPNTCAL solar.fsq solpnt.trj
2021-03-29 18:35:00 SUN
2021-03-29 19:50:00 ACQUIRE 2253+161
2021-03-29 19:54:00 PHASECAL 2253+161 pcal_hi-all.fsq
2021-03-29 20:25:00 SUN
2021-03-29 21:30:00 SOLPNTCAL solar.fsq solpnt.trj
2021-03-29 21:35:00 SUN
2021-03-30 00:10:00 ACQUIRE 0319+415
2021-03-30 00:14:00 PHASECAL 0319+415 pcal_hi-all.fsq
2021-03-30 00:45:00 SUN
2021-03-30 01:18:00 STOW
2021-03-30 04:12:55 ACQUIRE 1229+020
2021-03-30 04:13:55 LOSELECT
2021-03-30 04:16:55 PHASECAL_LO 1229+020 pcal_lo.fsq
2021-03-30 04:36:55 HISELECT
2021-03-30 04:37:55 PHASECAL 1229+020 pcal_hi-all.fsq
2021-03-30 05:37:55 STOW

Remove any lines that you need to and then save the file, overwriting the existing solar.scd file.

From the Schedule click on File and then Open and select the solar.scd file.

Once loaded click Go on the schedule to restart it.

Note that clicking Today on the schedule will overwrite any changes!

Viewing Schedules for any Date

A schedule can be viewed for any date using the procedure below.

Ensure you are logged into a helios terminal and in the Dropbox/PythonCode/Current directory.
Access ipython:
ipython --pylab
Enter the following commands:

import whenup from util import Time</span> whenup.make_sched(t=Time('yyyy-mm-dd'))

where yyyy is the year, mm is the month and dd is the day. For example to view the schedule for 2021-08-26 you would enter:
whenup.make_sched(t=Time('2021-08-26'))
The output of this command is given below:
['2021-08-26 11:14:02 ACQUIRE 0319+415',
 '2021-08-26 11:15:02 LOSELECT',
 '2021-08-26 11:18:02 PHASECAL_LO 0319+415 pcal_lo.fsq',
 '2021-08-26 11:38:02 HISELECT',
 '2021-08-26 11:39:02 PHASECAL 0319+415 pcal_hi-all.fsq',
 '2021-08-26 12:39:02 STOW',
 '2021-08-26 14:14:00 SUN',
 '2021-08-26 15:10:00 ACQUIRE 0319+415',
 '2021-08-26 15:14:00 PHASECAL 0319+415 pcal_hi-all.fsq',
 '2021-08-26 15:40:00 PHASECAL 0319+415 solar.fsq',
 '2021-08-26 15:41:00 SKYCALTEST 0319+415',
 '2021-08-26 15:45:00 SUN',
 '2021-08-26 17:00:00 GAINCALTEST',
 '2021-08-26 17:03:00 SUN',
 '2021-08-26 18:30:00 SOLPNTCAL solar.fsq solpnt.trj',
 '2021-08-26 18:35:00 SUN',
 '2021-08-26 19:50:00 ACQUIRE 1229+020',
 '2021-08-26 19:54:00 PHASECAL 1229+020 pcal_hi-all.fsq',
 '2021-08-26 20:25:00 SUN',
 '2021-08-26 21:30:00 SOLPNTCAL solar.fsq solpnt.trj',
 '2021-08-26 21:35:00 SUN',
 '2021-08-27 00:10:00 ACQUIRE 1229+020',
 '2021-08-27 00:14:00 PHASECAL 1229+020 pcal_hi-all.fsq',
 '2021-08-27 00:45:00 SUN',
 '2021-08-27 01:36:00 STOW',
 '2021-08-27 04:50:02 ACQUIRE 2253+161',
 '2021-08-27 04:51:02 LOSELECT',
 '2021-08-27 04:54:02 PHASECAL_LO 2253+161 pcal_lo.fsq',
 '2021-08-27 05:14:02 HISELECT',
 '2021-08-27 05:15:02 PHASECAL 2253+161 pcal_hi-all.fsq',
 '2021-08-27 06:15:02 STOW']

If needed, this can be copied and pasted into the solar.scd file. This is especially useful if the schedule needs to be restarted towards the end of the day. In this case (depending on time of year), the schedule program may load the schedule for the following day. If this occurs and you want to resume the schedule, use whenup with the previous days date and copy the output into the solar.scd file. Make sure you remove all leading spaces, brackets, commas and quotes. Save the file and load the solar.scd from the schedule and click GO.

Checking the adc_plot.py Program

The adc_plot.py program controls the backend gains. This must remain running. To check if it running follow the following procedure:

From the DPP, issue the command:
ls /tmp/*.npy | tail
The list of files will be of the form ADCplotYYYYMMDD_HHMM.npy. The most recent date should be the current day's date.
If the file is not current then issue the command:
ps -elf | grep adc
The output of this command should look similar to:
0 S user     18108 23862  0  80   0 -  2900 wait   20:56 pts/2    00:00:00 /bin/bash /home/user/test_svn/shell_scripts/adc_plot.sh
0 S user     18109 18108 35  80   0 - 708344 poll_s 20:56 pts/2   00:21:57 /common/anaconda2/bin/python /common/python/current/adc_plot.py
1 S user     26081     1  0  80   0 -  7607 poll_s Mar30 ?        00:00:00 SCREEN -S adc_plot
0 S user     27917 18481  0  80   0 -  3285 pipe_w 21:57 pts/6    00:00:00 grep --color=auto adc
If /common/anaconda2/bin/python /common/python/current/adc_plot.py is at the end of the line and the .npy file for the current day is NOT present then issue the command:
kill -9 #####</span>
where ##### is the PID, column 4 of the output above.
Then issue the command:
<pre style="font-family:courier">/bin/bash /home/user/test_svn/shell_scripts/adc_plot.sh
Wait about a minute and then run
ls /tmp/*.npy | tail
and ensure there is a .npy file for the current day.

Calibrations

Reference Calibration

Before a phase calibration can be done, a reference calibration needs to be performed, which will be subsequently used as the reference for the phase calibration.

Either access Helios via VNC computer or login to pipeline. If using helios access a pipeline terminal.

At the prompt type the following command:

python /common/python/current/calwidget.py

The following window will open up:

The calwidget window.

In the date box near top right of the window type in or use the up and down arrows to select the previous days date and hit enter.

Click on the first available scan that does not suffer from a Windscram. Windscrams are marked in red. If a windscram occurred for less than 20% of the scan then it will be marked in yellow and may still be usable. The example below shows a windscram at 22:14:05.

The calwidget window with windscram shown at 22:14:05 highlighted in red.

Select the earliest calibration that does not have a windscram, and then click on 'Analyze as Refcal'. The Sigma map should now be populated as shown below:

The calwidget window with sigma map. It also shows power and phases for Antenna 1 and Frequency Band 12.

The above chart is for the low-band (channels 1 to 12). Yellow blocks indicate bad or unavailable data. Bands 3 and 4 are excluded due to intense RFI at these frequencies. Antenna 5 currently is not operating well, and will be excluded from any analysis. The green blocks indicate that the data may be alright if some points are excluded. Purple blocks indicate the data is good.

Also shown in the above plot is the power and phase for Antenna 1 and band 12. The blue points are the X-polarization and the orange points are the Y-polarization. These should be close to straight lines.

In this case we need to exclude all of Antenna 5 from the calibration. First click on any block for antenna 5 in the range of band 1 to 12. Next check the box 'Apply to all bands'. Move the mouse over to either the Power or Phase plots (either works). We need to exclude all points. Move the mouse slightly before the first point in the chosen plot and press the 'A' key. A green line will appear. next move the mouse slightly past the last point and press the 'B' key. A red line will appear. The screen should look like the figure below.

The calwidget window with antenna 5 having all points flagged for all bands.

Now click on 'Apply time flagging. All of antenna 5's bands should turn yellow.

Once complete, select the associated high band calibration and then click on 'Analyse as refcal'. In this case bands 7 to 52 will be shown on the sigma map as shown in the figure below.

The calwidget window with sigma map. It also shows power and phases for Antenna 8 and Frequency Band 34.

Antenna 5 once again needs to be excluded using the procedure described above. In addition antenna 13 has problems from band 13 to 52. We will remove these channels from the analysis. Ensure 'Apply to all bands is unchecked and select 'Apply to all bands above selected one'. Select band 13. As before select all of the points by pressing 'a' and 'b' at the appropriate points (start and end of the plot). Click on 'Apply Time Flagging'. All of the bands from the selected band up should turn yellow as shown in the figure below.

The calwidget window with Antenna 5 excluded and most of Antenna 13 excluded.

As can be seen, there are still 3 green squares. We can make these good by selecting each one and flagging bad samples. In this example I have selected Antenna 4, Band 23.

Ensure all checkboxes are unchecked. Slelect the box for the antenna and band the you wish to time flag. select (using mouse and a and b keys) up to two ranges of points to exclude. pressing the x key will remove the most resent line chosen. Once you have flagged the ranges, click on 'Apply Time Flagging'. Hopefully the box will turn purple. If not you may need to select different ranges.

The result of this procedure is shown below.

The result of time flagging an individual antenna and band. Antenna 4, Band 13 is now purple.

Repeat this procedure for the remaining bad antennas and bands.

Once completed, select one of the bands of the refcals from list on the left and then click on 'Set as Refcal'. The click on extend selection. NOw select the other refcal. Make sure both are highlighted. Click on 'Set as extended refcal'. Click on 'Save to SQL'.

Phase Calibration

After the reference calibration has been done, the phase calibration can be performed. Click on a good calibration for the high band (one that has not had a windscram and has a reasonable duration). Not that Phase Cals are not performed using the low band.

Then click on 'Analyze as Phasecal'. At the top of the screen click on the 'Sum Pha' tab. The important thing here is that the slopes look good. Below is an example display of the slopes. These slopes are with reference to the Refcal.

The calwidget window showing slopes for each antenna.

In the above display, we can see that all of the slopes look good except for Antenna 4. note that we have excluded Antenna 5 from the observations as these have no reference cal. By moving the mouse over points on antenna 4 the channel is displayed as the x value in the bottom right of the window. In this case, channel 24 and above will be excluded. Ensure 'Apply to all bands above selected one' is checked and click on the antenna 4 and channel 24 box. Select all points and click on 'Apply time flagging' Once done, click on the 'Sum Pha' tab again to ensure the slope now looks okay (See figure below). Once satisfied click on 'Save to SQL'.

The calwidget window showing slopes for each antenna with points excluded on Antenna 4.

Note that source 1331+305 is a weak source, but at some times of the year it is the only one available. In this case there will be a lot of noise in the phase calibration. However it should still be usuable. Typically though, bands 40 and above will be need to be excluded.

Phase Cal has not been Processed

Occasionally the pipeline processing will not run properly. This may cause the phase data to no be processed properly. This will be indicated by strange durations on the phase cal window.

Log in to pipeline and issue the command:

cat /data1/processing/LOG/udb_process_log.txt_''yyyymmdd'' | tail

where yyyymmdd is the year month and day of the calibration data.

If more than 5 lines similar to the output shown below are present, then the lock file will need to be removed.

Fri Jan 22 15:35:01 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 15:40:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 15:45:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 15:50:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 15:55:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 16:00:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 16:05:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 16:10:01 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 16:15:02 2021 /data1/processing/udb_process.lock  Exists, returning
Fri Jan 22 16:20:02 2021 /data1/processing/udb_process.lock  Exists, returning

To remove the lock file simply type:

rmlock

Processing should then resume.

Adjusting the Schedule for Missed Calibration

If at the start of the day the schedule had locked up and part of the calibration has been missed, it is possible to adjust the schedule so that the calibration is still performed by following the procedure below.

Stop the schedule by clicking on the STOP button on the schedule.
While holding down the shift key select the first 5 items in the schedule (ACQUIRE, LOSELECT, PHASECAL_LO, HISELECT, PHASECAL).
Ensure that M (for minutes) near the top of the schedule is selected. Click the +1 button near bottom of the schedule so that the Acquire time is 1 or two minutes after the current time.
Then, if required, select either STOW or SUN and adjust the time so that the Phasecal after HiSelect runs for at least 20 minutes. Note that you can find if a source is still visible by using the whatup program ( http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Whatup_Program ).
Click GO on the schedule.

System Gain Calibration

This procedure is designed to adjust the system gains. This should be performed weekly or whenever the calibrations become poor. The full details can be found at EOVSA System Gain Calibration. The steps below are a summary of that page.

The best time to perform this calibration is immediately after a Solar Point Calibration, as the antennas need to be taken off the sun.

The dBm values in the power and attenuation section of the Stateframe display should be between 1 and 4.

Initially click on the Stop button in the schedule window.

From the Schedule window issue the following commands:

$scan-stop
stow
femauto-off
femattn 0
$fem-init

Wait approximately 1 minute for the new settings to update. The frontend power levels should be between 1-4 dBm. If they aren't then reissue the $fem-init command

Then proceed with:

$subarray1 ant1-14
dcmauto-off ant1-14
fseq-file solar.fsq
fseq-on
$capture-1s dcm

Click on the Clear button and then the Go button.

From a pipeline terminal issue the following commands

ipython --pylab
import roachcal
tbl=roachcal.DCM_calnew('/dppdata1/PRT/PRTyyyymmddhhmmssdcm.dat',dcmattn=10,missing='ant15')

In the above command yyyymmddhhmmss is the year, month, day, hour minute and second of the dcm file. Pressing tab will complete the filename. for the missing field, antenna 15 must be included. Add any other antennas that are not to be included on the gain calibration separated by spaces.

Enter

tbl

to view the contents of the tbl variable that was just created.

Band 1 has recently had bad attenuations. To use older good values for this band issue the command:

tbl = roachcal.override(tbl, bandlist=[1])

Other bands can be excluded by adding the bands to the bandlist (space separated).

It is useful to compare the new table with an existing table to check for errors/glitches. To do this issue the command:

roachcal.compare_tbl(tbl, t=Time('2020-05-08'))

Replace the time with the previous days gain calibration. All of the differences should be close to zero.

Finally:

import cal_header
cal_header.dcm_master_tablesql(tbl)

From the Schedule window click the Stop button and then the Go button.

In the schedule command box enter the command

$scan-start

Frontend Benchtest

The Benchtest is performed whenever components are replaced in the receiver. For a description of how to service the receiver see [[1]].

Setup

Connect the power meter to the receiver as described here [2].

Find the GPIB cable and connect it to the ACC. Run the cable into the lab and connect it to the power meter.

ACC-GPIB.jpg PM-GPIB.jpg

Performing the Calibration

Access the windows (win1) computer.

From the Quicklaunch menu select the E4418B Measurement program.

E4418B ss.png

This should bring up a screen as shown below:

E4418B.png

Change Enum to the appropriate antenna number.

Change Reading to the appropriate polarisation.

From the Helios computer open up the gedit program.

Open the file /home/sched/Dropbox/PythonCode/Current/FEMbenchtest.scd

Edit the first line so that the correct antenna is present. For example, if antenna 5 is to be calibrated then the first line should read similar to:

1 2019-11-08 12:07:00 FEMBENCHTEST ant5

Once edited, save and close the file.

On the Schedule window click on Stop.

Click on File and then Open

Sched-open.png

Select the /home/sched/Dropbox/PythonCode/Current/FEMbenchtest.scd file and open it.

Click on Today

From the Window computer, on the E4418B program click on Start Logging Data

The computer should go through four sequences which display 4 block patterns on the plots in the E4418B program.

Once completed click on Stop

Repeat for the other polarisation if required.

Remember to reload and restart the Solar.scd schedule.

Loading the Calibration to the CRIO

The files created are located in the Dropbox/EOVSA M&C/Test Data/ folder.

Find the most recently created text files and open the first of them in a text editor. An example of a part of the file is shown below:

Powcalfileeg.png

This file need to be edited to remove all but one of the 5 lines for each attenuation. Typically choose the third entry in each data block.

Once the file has been edited and saved, from pipeline change to the folder where the edited files are located.

From ipython, enter the following commands:

import fem_cal as fc
import crio
fc.fem_cal(ant

where ant is the antenna number for the particular calibration.

The latest files for that antenna will be read, and a plot will appear for each polarization with both points and quintic fit. The parameters of the fits will be printed to the screen in a form that can be cut and pasted directly into the crio.ini file for the appropriate antenna

To retrieve the crio.ini file for a given antenna issue the following command in ipython:

crio.save_crio_ini(ant_str='ant#')

where # is the antenna number. Press CRTL Z to exit ipython temporarily.

Open the downloaded ini file in a text editor and copy the new coefficients into this file. Enter fg to get back into ipython.

Finally enter the command

crio.reload_crio_ini(ant_str='ant#')

Update Antenna Pointing

2m Antenna

Access the Pipeline Computer.

From the terminal, start ipython:

ipython --pylab

Import the solpnt_x and Time libraries:

import solpnt_x as sx
from util import Time

Load up the solar pointing scans for a given date and time.

tsolpnt = Time('yyyy-mm-dd HH:MM:SS')
solout = sx.solpnt_xanal(tsolpnt)

To view the beam widths as a function of frequency for each antenna and polarisation:

sx.solpnt_bsize(solout)

Ant4 Bsize.png

To obtain the pointing offsets:

offsets = sx.solpnt_offsets(solout)

This will display the current pointing positions of each antenna. Ideally each antenna should be pointing at the center of the disk. If particular antennas significantly deviate from the center then a correction can be made.

Pointing offsets.png

Pointing offsets2.png

For example, the following command will adjust the pointing offsets for antennas 6 to 8, 10 and 13:

sx.offsets2ants(offsets, ant_str='ant6 ant7 ant8 ant10 ant13')

The newer antennas with the alt-az drives that have had tracking updated will need to be rebooted. From the Schedule Window issue the commands:

reboot 1 ant6-8

tracktable sun_tab.radec 1 ant6-8 track ant6-8

The antenna pointing adjustment is typically performed once per month.

Manually Changing Coefficients

Sometimes an antenna's pointing coefficients will be so far off that a normal pointing calibrations will not work. The coefficients can be reset to an earlier value by using the following procedure.

From a helios terminal enter the following commands:

ipython --pylab
from util import Time
import dbutil as db
trange = Time([datestr1,datestr2]).lv.astype(int)
query = 'select Timestamp,Ante_Cont_PointingCoefficient1,Ante_Cont_PointingCoefficient7 from fV66_vD15 where I15 = # and (cast(Timestamp as bigint) % 86400) = 100 and Timestamp between ' + str(trange[0]) + ' and ' + str(trange[1]) + ' order by Timestamp'
data, msg = db.do_query(cursor,query)
n = len(data['Timestamp'])
for i in range(n):
    print Time(data['Timestamp'][i],format='lv').iso,data['Ante_Cont_PointingCoefficient1'][i],data['Ante_Cont_PointingCoefficient7'][i]

Here datestr1 and datestr is the range of times that are to be searched in the form yyyy-mm-dd HH:MM and # is the antenna number-1

The above code will display a list of pointing coefficients. Select a suitable pair and then from the schedule issue the commands:

pointingcoefficient1 xxx ant#
pointingcoefficient7 xxx ant#

where xxx are the new pointing coefficients and :# is the antenna number.

Star Pointing for the 2m Antennas

Occassionaly, the normal 2m antenna pointing calibration will not work as this only adjusts 2 of the 9 antenna parameters. A more rigorous technique by taking images of stars can be performed.

To begin with an optical telescope must be attached to the side of the dish that needs adjustment. The telescope and camera will need to be shipped from NJIT. Find the mounting bracket and attach this to the dish and then attach the telescope to the bracket as shown in the figures below.

Optical-telescope-Mounting-Bracket.jpg Optical-telescope-on-dish.jpg

Next the telescope needs to be aligned. It does not need to be perfect, but does need to be reasonable close. Ensure the antenna is tracking the sun. Hold your hand below the telescope, beyond the focal point. DO NOT PLACE YOUR HAND AT THE FOCUS AS YOU MAY GET BURNT!

You should see a bright disk surrounded by a dark ring. The disk should be centered and the ring should be a uniform size. Adjust the alignment of the telescope, by tightening and loosening the bolts on the mounting bracket.

From a helios terminal change to the /Dropbox/PythonCode/Star\ Pointing folder.

Enter the following commands:

ipython --pylab
import readbsc as rb
rb.do_stars(Y,M,D,h,m,npts=n)

where Y,M,D,h,m are the year, month, day, hour, minute and second of the start of the observations, and npts is the number of points to observe (you will probably need about 50).

Note that it is a good idea to set the start time well after dark. As soon as you start the appropriate scd file, the antenna will go immediately to the first source.

Enter cd ../Current to change to the Current folder.

Enter nano STARS.ctl to edit this file. You should see text similar to:

$SCAN-STOP
SUBARRAY1 ant7
TRACKTABLE startracktable.radec
TRACK

Change the antenna number to the antenna that the telescope is attached to. Press [CRTL X] to exit and press [Y] to save the file.

Enter nano starpointing.scd to edit the starpointing.scd file (example below).

2021-05-30 03:30:00 STARS
2021-05-30 09:30:00 REWIND

Change the date to the date at which you want to start observations. Press [CRTL X] to exit and press [Y] to save the file.

From the windows laptop find the kjell-lap/Dropbox/PythonCode/Star Pointing folder. Create a folder with date that the observations will be taken in the form yyyy-mm-dd.

Double click on the ASIImg Icon. On the right, scroll down to find the path where the images are to be stored. Click on the folder icon and then select the folder you just created.

Once the last phasecal of the day has been completed, go outside to the antenna where the telescope is connected with the laptop and a small table. Connect the laptop using an extension cord to the power point and connect the camera to one of the USB ports on the laptop. Remove the lens cap from the telescope and move the focus to the mark on the telescope.

If it is not already open double click on the ASIImg icon.

ASIImg icon.png

This will bring up the window shown below. Within this window click on the ASIImg Icon.

ASIImg ASIImg icon.png

This will bring up the capture window as shown below. The controls for the camera are on the right of the window.

ASIImg capture window.png

Scroll down a little on the control section until you find the Path. Click on the folder Icon (marked in red).

ASIImg path select.png

In the file dialog box, ensure that you are in the Dropbox/PythonCode/Star Pointing folder. Right click on the file dialog window and select New and then Folder. Enter a folder name in the form of yyyy-mm-dd , using the current UT days's date.

ASIImg select folder dialog.png

Scroll back up and click on the small red play arrow (marked in the red box below) to connect to the camera.

ASIImg connect button.png

Click on the preview button if it is not already highlighted.

ASIImg preview button.png

Set the Exposure time. Initially, if there is still some light set it to 1 second, as it darkens you can increase the exposure time gradually up to 10 seconds.

ASIImg Exposure.png

Select on continuous.

ASIImg Continuous.png

Click on the large play button. This will change to a stop button.The camera status bar at the bottom should continually update. If it hangs click the stop button and then click the play button again.

ASIImg play.png ASIImg stop.png

By scrolling down on the right, you will be able to see a histogram. In addition, in the left pane you will be able to see the most recently captured image. As it gets dark carefully adjust the focus so that the stars are as focused as possible. Once this is done, place the lens cap on the end of the telescope.

Stop the camera from previewing by clicking the stop button.

To take dark frames, click Capture, and then Auto Run.

ASIImg capture button.png ASIImg autorun.png

A new window will open up as shown below:

ASIImg autorun window.png

Click on the tab below Ordinal and select Dark. Click on the arrow below the Exposure tab and select 10. Click on Frames and change this to 10.

ASIImg Captue Select Dark.png ASIImg Captue Select Exposure.png ASIImg Frames.png

Click on Start. When prompted to Enable Cooler, click No.

ASIImg Captue Start.png ASIImg Captue Cooler.png

Once done, remove the lens cap from the telescope. You can now go inside and log into the laptop via VNC (IP Address: 192.168.24.184:0, the password is the same as for Helios).

Once logged in click on the Reset Button.

ASIImg Captue Reset.png

Now change the Ordinal to Light and set the Frames to 1100

From the Schedule click on File and then Open. Select the starpointing.scd file and then click on GO.

Once the start time of the has been reached, you can click Start on the ASIImg capture window and select No when it prompts to enable cooling. You can now close down the capture Window.

It will now automatically capture images.

Once observing has finished and before the antenna moves to the sun remove the telescope from the antenna or place the lens cap on the end of the telescope, or place the antenna in Stow and power off the antenna controller (new antennas) or CRIO (old antennas) at the Viking Unit. DO NOT ALLOW THE TELESCOPE TO POINT AT THE SUN WITHOUT THE LENS CAP ON!

Bring in the telescope, laptop, cables and camera to the EOVSA building.

Reconnect the windows laptop and then select from the Quickstart menu select MaxIm DL 5.

Quickstart-MaximDL5.png

From the Process Menu, select Set Calibration.

MaxIm-Set Cal.png

Click on the Folder Icon.

MaxIM-Select Folder.png

Select the folder with the dark frames. This will be under the folder you created earlier, and should be the first of two folders. Once Selected, Click OK.

MaxIm-Select Darks.png MaxIm-Select Darks-OK.png

27m Antenna

Only do this if absolutely required. The 27m pointing should only need to be performed at most on an annual basis. It takes 24 hours to complete. If possible, schedule the pointing when there are few active regions on the sun

From a helios terminal, view the calpnt48.scd file by issuing the command:

cat /home/sched/Dropbox/PythonCode/Current/calpnt48.scd

Below are the first few lines of this file:

2019-06-22 10:26:00 ACQUIRE 2136+006
2019-06-22 10:30:00 CALPNTCAL 2136+006 band21.fsq calpnt.trj
2019-06-22 10:55:00 ACQUIRE 2253+161
2019-06-22 10:59:00 CALPNTCAL 2253+161 band21.fsq calpnt.trj
2019-06-22 11:24:00 ACQUIRE 2136+006
2019-06-22 11:28:00 CALPNTCAL 2136+006 band21.fsq calpnt.trj
2019-06-22 11:53:00 ACQUIRE 2253+161
2019-06-22 11:57:00 CALPNTCAL 2253+161 band21.fsq calpnt.trj

The dates and times need to be edited. Use the following equation to compute the new times:

OFFSET = NST - OST
NT = OT + OFFSET

where NST is the sidereal time when you wish to start the calibration, OST is the sidereal time for the first entry in the calpnt48.scd file, NT is a new UT time in the schedule, and OT is the old UT time in the schedule.

The /home/sched/Dropbox/PythonCode/Current/update_calpnt48.py file contains a function that will automatically create a new calpnt48.scd file. To use it issue the following commands from a Helios terminal:

cd /home/sched/Dropbox/PythonCode/Current/
ipython --pylab</p>
from util import Time</p>
import update_calpnt48 as ucp
ucp.update_calpnt48(t2 = Time("yyyy-mm-dd hh:mm"))

where yyyy-mm-dd hh:mm is the approximate UT start date and time for the calibration. If the time is omitted then the current time will be used.

This program will overwrite the calpnt48.scd file. The previous file will be saved as calpnt48.scd.bak

Sources will be replaced if they are outside the following ranges:

HA: -55 to +55 degrees

Alt: Greater than +10 degrees

Az: 35 to 325 degrees

A sample screen output of the program is shown below:

Update calpnt48 output.png

If you just want to see the screen output without overwriting the existing calpnt48.scd file issue the command from ipython:

ucp.update_calpnt48(t2 = Time("yyyy-mm-dd hh:mm", overwrite=False))

Once run, type exit to exit ipython.

Load the new calpnt48.scd file into the schedule and start it. Let it run for about 24 hours.

Adjusting Antenna Delays

Note: Only perform this procedure if absolutely necessary! This should be done either after the evening calibration or before the morning calibration.

Using the Delay Widget

From pipeline, start the delay widget as follows:

python /common/python/current/delay_widget.py

A window similar to the one shown below should appear:

Delay widget startup.png

At the top right, click on File and then Open npz file

Select the most recent file.

You will see a screen that looks similar to that below:

Delay Widget File Loaded.png

Note that if you had a file loaded and different antenna selected, the program will default to antenna 1 but not change the number in the Antenna box.

Select the antenna for which the delays are to be checked.

For the four panels on the left, each cluster of points represents a band. Each cluster in the XY and YX plots needs to be as flat as possible. Also the XX-YY plot on the right need to have all points as flat as possible. The slopes can be adjust by incrementing or decrementing the X delays on the left of the screen.

Repeat this process for any other antennas.

The following should be noted if adjusting the delays on antenna 1:

Adjusting the delays on antenna 1 is essentially the same as adjusting the delays on antenna 14 as antenna 1 is used as a reference for the other antennas. If delays on antenna 1 are adjusted, they will need to be adjusted on all other antennas.
You will also need to adjust the low frequency delays on antenna 1, but no other antennas.

Once done the new delays can be save from the File menu.

Only save the new delays if you are absolutely certain changes need to be made!

Click on Exit to close the application.

Checking that the delays were updated

To see if the delays were updated, perform the following procedure.

From pipeline access ipython:

ipython --pylab

Load the cal_header and and Time modules:

import cal_header as ch
from util import Time

We want to use the dla_censql2table function to create a table of the delays. This is done by:

ch.dla_cen2sqltable(t=Time('yyyy-mm-dd hh:mm'),acc=False)

where yyyy-mm-d hh:mm is the date and time for the last delays (it will look for the first time prior to that specified) and acc=False tells the function not to send values to the ACC.

For example to view delays from the 3rd of November 2020 (or the first date prior to this) you would issue the command:

ch.dla_cen2sqltable(Time('2020-11-01 01:00'),acc=False)

Note that this writes the data to a text file: /tmp/delay_centers.txt

To view this file issue the command:

!cat /tmp/delay_centers.txt

To view an older file, use the ch.dla_cen2sqltable with an earlier time and reissue the cat command. The delays that were changed should be different for the given antennas. Note that if antenna 1 delays were changed, this change will be shown in antenna 14.

Updating SQL Database on the Cloud

Note that you must have a .netrc file in your home on pipeline folder and the permissions set correctly for this to work

When running for the first time, add the following lines to your .bashrc file:

alias loadpyenv3.8='source /home/user/.setenv_pyenv38'
alias loadctl='source /home/user/.setenv_ctl'

To create new entries for the cloud data base, from your pipeline account run the following commands:

bash
loadctl 
ipython
import eovsactl.sql2mysql as s2m
s2m.sync2mysql()
s2m.sqltable2mysql('abin',host='amazonaws.com')
s2m.sqltable2mysql('abin',host='localhost')

The commands above will create a .sql file at /data1/

To send it to the cloud type:

!mysql -h eovsa-db0.cgb0fabhwkos.us-west-2.rds.amazonaws.com -u admin -p eOVSA < /data1/yyyy-mm-dd.sql

The password is the last one in the .netrc file

To check if the file was sent to the cloud, use the python command:

s2m.get_latest_timestamp()

Reprocessing Pipeline Data

Occassionally, pipeline data will need to be reprocessed if it failed or there were bad calibrations.

Creating full disk images

Log in to a pipeline terminal and create a new screen:

screen -S fulldisk

Next run the following command:

/bin/bash /common/python/eovsapy/shellScript/pipeline.sh -c 1 yyyy mm dd > /tmp/test_pipeline.log

where yyyy is the year, mm is the month and dd is the day of the data to be processed.

This will take several hours to run. When completed run the command:

/bin/bash /common/python/eovsapy/shellScript/pipeline_plt.sh -c 1 -e 1 yyyy mm dd > /tmp/test_pipeline_plt.log

This should only take a few seconds to run.

Finally run the following command:

/bin/bash /common/python/eovsapy/shellScript/pipeline_compress.sh -n 1 -O 1 yyyy mm dd > /tmp/test_pipeline_compress.log

Note you can reprocess multiply days by running each day in a separate screen. Remember to assign a different name to each screen and assign a different name to each log file.

Total Power Calibration

To check if a total power calibration has been done on a particular day follow the steps below from a pipeline terminal

ipython --pylab
import cal_header as ch
from util import Time
from stateframe import extract
xml, buf = ch.read_cal(10, Time('yyyy-mm-dd 20:00'))
outtm = Time(extract(buf, xml['SQL_timestamp']), format='lv').iso 
Time(extract(buf, xml['SQL_timestamp']), format='lv').iso
outtm

where yyyy is the year, mm is the month, dd is the day.

The return time should be 20:00 on the date specified. If not then copy the record to the correct time as follows:

ch.copy_cal(10,Time(outtm),Time('yyyy-mm-dd 20:00'))

To rerun the Total Power calibration, exit ipython and enter the command:

/bin/tcsh /home/user/test_svn/shell_scripts/pipeline_allday_fits.csh --clearcache 2023 10 16 > /tmp/test_pipeline_fits.log

Trouble Shooting

General Problems

Temperature Controller

Occassionally a front end temperature will show an error. This is usually because the temperature controller that reports the temperature has locked up. To fix this type the following command in the Schedule window:

tec$bc ant#

where # is the antenna number that needs the temperature controller rebooted.

To clear the temperature error history (that updates every minute) issue the command:

tec$sc ant#

If the above steps do not work, the following command can be issued:

$pcycle fem ant#

This will recycle power to the front end controller. If this does not work you can check the log file from a helios terminal by typing

tail -20 /tmp/schedule.log

A display similar to that below will be shown:

2020-08-17 13:56:03.002 Ant4 attempt #1 to login.
2020-08-17 13:56:03.002 Ant4 Login failed with status code: 401
2020-08-17 13:56:04.002 Ant4 attempt #2 to login.
2020-08-17 13:56:04.002 Ant4 Login successful.
2020-08-17 13:56:04.002 Ant4 Fronttend now off
2020-08-17 13:56:19.002 Ant4 attempt #1 to login.
2020-08-17 13:56:19.002 Ant4 Login successful.
2020-08-17 13:56:20.002 Ant4 Frontend now on

Note that the second line says that the login failed. It will attempt a login in three times. If this fails you can attempt a recycle to issue the command again. If this does not work the front end needs to be reset at the auxiliary box at the antenna. This is done by switching off the two breakers, waiting 10 seconds and then switching them back on. The breakers are shown below.

Auxboxbreakers.jpg

Packet Loss on DPP

The packet loss monitoring has now largely been automated. However it is still a good idea to check to make sure everything is running smoothly.

Details on the new programs and procedures can be found here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#DPP_Fix_Packets_Details

Data Recording on the DPP has Stopped

To Check if the DPP is recording data, from a DPP terminal issue the command:

ls /data1/IDB |tail

This will display the last 10 IDB files that were created. They should have a time stamp about 10 minutes apart and the last file should only be 10 minutes or so old.

If current IDB files are not displayed then firstly check to see if The STATE is On in the phase tracking section of the stateframe is displayed as shown below.

Sf display state.png

If the state is off then simply click Stop on the schedule window and then click on Go. The state should return to On. Check to see if the DPP is creating files after about a minute.

If the DPP is still not recording data or the State was already on then follow the instruction below.

Log in to the DPP computer (user@dpp).
Enter top . A display similar to that below should be shown.

Dpp top.png

Look for dppxmp under “command” column (shown here in the red box). If this is present not the PID# (shown here in the green box. Note that this number will change if dppxmp is restarted).
Press 'q' to exit the top program
If dppxmp is present issue the command:
kill pid#
where PID# is the number noted down previously. This will stop the dppxmp program.
Enter the command rmlock
Check again to see if data recording has recovered
Type “rmlock" on DPP terminal. Check if the data recording has recovered by sending ls /data1/IDB |tail

Restarting the Schedule

If the schedule needs to be restarted then follow the steps below:

Click Stop and then Clear.
Click Today and then Go.

Pipeline Problems

If there is no data showing at http://www.ovsa.njit.edu/browser/ then something has gone wrong with the pipeline processing. Below is a image of what the webpage looks like when an error has occurred.

The 'No Data' errors on the EOVA browser page.

Clicking on the Newest button will refresh the page and upload the latest data. If this does not correct the problem take a note of the date in the web address of the page. Then click on 'Today's Data'. A list of fits files should appear as below:

Example list of files if pipeline processing was successful.

To check to see why the images are not visible, the log files can be inspected. Log on to pipeline and type the command:

crontab -l

The image below show a part of the output. The portion in the red box is the script that generates the full disk image.

Pipeline crontab fdimg.png

To view the programs run by this script issue the command:

cat /common/python/suncasa/shellScript/pipeline_fdimg.bash

and an output similar to that below should be produced:

Pipeline fdimg script.png

Note that the are three log files produced: /tmp/pipeline.log, /tmp/pipeline_plt.log and /tmp/pipeline_compress.log.

By inspecting these files you should be able to determine at what point an error occurred. To view these files type:

cat [logfile]

where [logfile] is the name of the logfile you wish to view.

Bad Front End Attenuation Values

The front end power values on both the horizontal and vertical channels should be between about +1 dBm and +4 dBm. These can be found on the stateframe display as shown below.

Sf display attn.png

If the power deviates significantly from the 1 to 3 dBm range (unless there is a burst in progress or a gaincal test being performed) then the attenuations can be adjusted by issuing the following commands from the Schedule window:

hattn first second ant#

where first and second are the attenuations of the first and second attenuators for the horizontal polarization and ant# is the antenna number. Note that first should always be zero.

Similarly to adjust the vertical attenuators:

vattn first second ant#

Note that no warning will be shown if the power deviates significantly from the acceptable range.

Warning on Power and Attenuation

On the state frame display in the Power and Attenuation section, occasionally an antenna will turn yellow (warning). This will usually be because the 1st attenuator value is not zero. This will occur during a gaincaltest or a burst. The value should be even. If the value is 9, then the CRIO file will most likely need to be be reloaded.

Follow the instructions here http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Reloading_the_crio.ini_File to relaod the crio.ini file

Error on Power and Attenuation

On the state frame display in the Power and Attenuation section, occasionally an antenna will turn red (error). This may happen during a gaincal. However If it occurs outside a gancal and the Power values are reading nan (Not a Number), then it is possible that communications have been lost at the front end. You can try and cycle power to the front end by issuing the command from schedule:

$pcycle fem ant#

If the $pcycle command does not work you can try testing the network connection. From a helios terminal, issue the command:

ping ant#.solar.pvt

where # is the number of the antenna. If you get a message similar to:

From helios.solar.pvt (192.168.24.103) icmp_seq=1 Destination Host Unreachable

then it means that the communications are down. Contact Owen to reset the power at the antenna.

Resetting Attenuation Values

Occasionally, the front end attenuation values may get stuck, typically after a calibration. To reset the attenuations, use the following commands on the schedule:

femauto-off ant#
femattn 0 0 ant#

Schedule Commands not Working

If schedule commands are not working then the ACC may need to be restarted.

To determine if the ACC needs restarting issue a command from Schedule. At the top right of the Stateframe the 'Task' should be updated. if it is not then follow the following procedure:

Go to the Windows computer and from the Quicklaunch menu select 'EOVSA E&C'.
Once running click on 'Reset ACC' and wait about 10 seconds.

Queue Overflow Error

On the Stateframe display, a 'Queue Overflow' Error may occur under the Frequency Tuning bar. To correct this issue type the following command into the Raw Command box on the schedule:

lo1a-reboot

Stop and then restart the schedule.

Bright Scram

A bright scram occurs when the dish becomes more reflective, usually due to ice or water. This will cause more heat to be focused which can result in damage to the feed (burnt feed). A bright scram moves the dish 10 degrees off the Sun. It will the periodically move back to the Sun and remain tracking once the temperature at the feed drops sufficiently.

ONLY PERFORM THE PROCEDURE BELOW IF YOU ARE ABSOLUTELY SURE THAT A BRIGHT SCRAM IS FALSE AND REALLY NEEDS TO BE CLEARED. YOU RISK BURNING THE FEED!

A bright scram can be cleared by issuing the following command from the schedule:

bscram-clear ant#

If an antenna is performing brightscrams erroneously (for example during a phasecal), then an individual antenna can have the brightscram disabled by issuing the following command from the schedule:

bscram-off ant#

To re-enable brightscram on a particular antenna issue the command:

bscram-on ant#

Older Antennas Not Tracking

The older antennas (9-11 and 13) will occasionally seem to stop tracking. This is usually because it has lost where it is pointing. It will move incredibly slowly until it reaches its limit before returning to regular tracking. This process cant take up to about 20 minutes. If it has not resolved it tracking problems in this time, proceed with normal trouble shooting.

Antenna Trouble Shooting

If an antenna in the State-frame Antenna Tracking section is highlighted red, go through the following list.

Reloading the track table

Reload the track table as by issuing the following commands from the schedule

tracktable sun_tab.radec ant#
track ant#

Note that omitting the ant# will resend the commands to all antennas. You can specify more that on antenna.

Stowing the antennas

Attempt to stow the antenna by issuing:

stow ant#

If there are still errors, from the state-frame display, click on the antenna display and then click on the tab for the appropriate antenna.

Antenna at its limits (New Antennas)

If a limit is highlighted you will need to move the antenna from its limit. Firstly issue the command:

runmode 2 ant#

Issue the appropriate command according to the following table:

Co-ord Limit Command
Azimuth High azimuthvelocity -5000 ant6
Low azimuthvelocity 5000 ant6
Elevation High elevationvelocity -5000 ant3
Low elevationvelocity 5000 ant6

Once the limit indicator goes green issue the command:

azimuthvelocity 0 ant#

or

elevationvelocity 0 ant#

Return the antenna to tracking:

track ant#
Antenna at its limits (Old Antennas)

Initially try to stow the antenna:

stow ant#

It may take a while for the antenna to stow.

If the antenna fails to stow, it will need to be manually driven off its limit as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_Old_Antennas_Manually and then try to stow the antenna.

Once stowed, return the antenna to tracking:

track ant#
Bad values for antenna position

If any of the following is true:

on antennas 1 to 8 or 12 the azimuth is outside the range of 0 to 360 degrees,
on antennas 1 to 8 or 12 the elevation is outside the range of 0 to 90 degrees,
on antennas 9 to 11 or 13 the hour angle is outside the range of -180 to 180 degrees,
on antennas 9 to 11 or 13 the declination is outside the range of -90 to 90 degrees,

you can try to issue the following commands:

stop ant#
sync-motion ant#

The antenna should then go to its stow position. Once it is stowed send the commands:

tracktable sun_tab.radec ant#
<pre style="font-family:courier">track ant#

The antenna should resume tracking.

Rebooting the antenna

On the newer antennas (antennas 1 to 8 and 12), access the window computer, click on then Quick launch icon at bottom right and then click on the antenna that is problematic.

Ant Selector.png

A screen window to that below will come up. Ensure that the Enable box at the lower right is checked.

Win Ant Controller.png

One or both of the Permit boxes may be red.

Click on the Reboot Drives button. and wait about 10 seconds. The click on the Drives On Button. It should turn Green. Click on the Operate Button. If this does not turn green you may need to reboot the edge13b server.

Click Exit.

Rebooting the antenna interface on the edge13b server

Whenever an antenna link seems to be down (indicated by the lack of a blinking link light on the edge13b router), note the port that is down (The antenna is labelled on each fibre pair).

Edge13b router.jpg

Refer to it as

fa0/#

where # is the number of the port. E.g., if port 1 is down, it will be referred to as fa0/1.

From Helios, telnet to the switch:

telnet edge13b.admin.pvt

Enter the the password when prompted.

Enter the command:

show inter fa0/1

Edge13b status.png

The first line will show the status. If it is listed as Connected then nothing needs to be done. Enter:

quit

to exit from telnet

If the connection is listed as err-disabled then proceed with the following steps. At the telnet terminal issue the commands:

enable

and enter the password.

configure ter
interface fa0/#

where # is the port number.

shutdown
no shutdown
end

You can then reissue the show inter command to see if the interface is running. The port light should also be blinking on the server.

Issue then command

quit

to exit telnet.

Resetting antenna parameters

If the antenna still will not start goto the following webpage:

http://ant#.solar.pvt

Click Login and then enter the username and password.

Click Parameters and the change Option 10.00 to 1070 and Option 10.38 to 100. Click on change.

Then click on logout.

After the above procedures are completed you will need to reload the track table. This is done from the State Frame display using the following commands (again ensure that ant5 is replaced with the appropriate antenna):

tracktable pcal_tab.radec ant5
font-family:courier">track ant5
Antenna Communications Failure

If an antenna is highlighted in the Communications section of the State-Frame display then the following procedure can be used to correct it.

From the Schedule on Helios enter the command

$pcycle crio ant2

and wait about 2 minutes.

From the Schedule on Helios issue the command

sync ant#

for the newer antennas or

sync-motion ant#

for the older antennas where # is the antenna number.

If this does not resolve the communications problem, then proceed with the procedure below.

Access the win1 computer.

Click on Start then select NI Max.

Start-NIMAX.png

Goto Remote Systems and then select the CRIO that is not communicating.

NIMAX.png

Click the System Settings tab at the bottom of the window. Status should be listed as Connected - Running

NIMAX-settings.png

Click on Refresh to reconnect.

The CRIO will have an IP address in the range of 192.168.24.41 to 192.168.24.53. If it is not working this IP address will be strange. Click Restart.

From the Schedule on Helios issue the command

sync ant#

where # is the antenna number.

If the communications are still not restored, you will need open Labview.

If it is not already open, Click Start then NI Labview 2015.

Start-NI-Labview.png

The LabView start screen will appear after a few seconds.

NI-Labviewstrtscrn.png

Click on the Operate menu option and then select Debug Application or Shared Library.

LV-Op-debug.png

Once the new window opens type in the name of the CRIO in the Machine Name or IP Address box. Then click Refresh. The file startup.rtexe should appear. Click on Connect.

Note that if a message similar to 'No debuggable application found' is displayed you may need to click on refresh several times. When it first reboots it will say it cannot find any debuggable applications, and then at some point it comes back with startup.exe. But if you wait too long it ends up in software safe mode (it will display "Safe Mode" next to Running) and you will need to click on "Restart" in the NI-Max program and click refresh on the Labview program until you see startup.exe, wait for a few seconds and then hit the button to load the debug software.

LV-debugstart.png

In the new window that opens check that the time is updating and that the time is correct an updating and that the Run index is updating. The Exec States should all be set to Run.

Crio-debug.png

At the top of the screen click on the Stop Icon and then the Go icon (the arrow).

From the Schedule on Helios issue the command

sync ant#

or

sync-motion ant#

where # is the antenna number, depending on whether it is a new or old antenna.

To exit from the Debug session, right click on an empty part of the form which will bring up Remote Debugging. Click on this and then select Quit Debug Session.

LV-debug-close.png

If the above procedure has not worked, then from the debug session, right click on an empty part of the window and then click on Remote Debugging and then Show Block Diagram.

LV show block diagram.png

This will bring up the block diagram. Double click on the left bottom icon.

LV comm icon.png

This brings up the cRIO antenna VI.

Crio ant vi.png

Click on the stop button. It should restart in a few seconds automatically. Close the opened windows except for the Debug session (click on an empty part of the form then Remote Debuggingthen Quit Debug Session).

If all else fails, restart the CRIO from the Viking unit.

Restarting the Viking Unit

The Viking units control power to the various systems (Antenna, Front End and CRIO). To recycle power to a particular system, goto the webpage

http://vik#.solar.pvt

where # is the antenna number. Enter the username and password. The following screen should appear:

Viking.png

Note that when the relays are off, power is being supplied to the indicated system. In the image above, all relays are off so each system is powered.

To recycle power to a particular system, click on the circle next to the system. If the circle was red initially, it will go green, and vice-versa. If you are turning the relay on then wait ten seconds before turning the relay off again. Ensure that the relay is Off (red) before logging out.

Ant 12 Cable Wrap

From time to time, Ant 12 may get past its limits and get into the wrong "turn." If this happens, the cables can be unwrapped using the hand controller, but doing that does not reset the "turn" indicator (parameter 20.17). After manually unwrapping in this way, go to the antenna web page (or the Ant12_ACI interface on the win1 machine) and check the value of parameter 20.17. If it says 2, it means it is on the wrong turn (should be 1). In that case, attempting to STOW or TRACK the antenna will only make it try to unwrap and end up stuck at the north limit. If this happens, manually move the antenna back to the south point with the hand controller, and then check the value of parameter 20.17. If it is not now 1, you may have moved the antenna in the wrong direction. Once it is back to 1, check the parameter 20.15, which is the encoder zero. Add or subtract 360 degrees to that value and set the 20.15 parameter to the new value. For example, on 8/17/2021, the encoder zero was -29, so we set it to 331. Next time it happens, we would probably set the value back to -29. In any case, after changing the parameter, the dish should STOW properly.

Receiver Trouble Shooting and Repair

Removing the Front End Module (FEM)

Positioning the Antenna

If working on a newer antenna follow the instructions here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_New_Antennas_Manually

If working on an older antenna follow the instructions here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Moving_the_Old_Antennas_Manually

Removing the FEM

Switch off the power to the receiver at the auxiliary box by pulling down the two breakers.

Auxboxbreakers.jpg

Below is an image of the tools required for removing the receiver.

Rectools.png

Whenever touching the receiver ensure that the Anti-static strap is worn and grounded!

Loosen the nuts on bolts that attach the receiver to the feed almost the entire way but leave them on the bolts. The feed can be pressed forward to give enough room to detach the SMA cables.

Recbolts.png

Carefully disconnect the SMA cables from the feed. Note the position of the horizontal and vertical polarisation cables.

Smacablesfeed.png

Place caps on the end of the SMA cables.

Smacablescapped.png

Carefully remove all of the cables from the back of the receiver.

Reccables.png

Place a cap on the fibre optic port and the fibre optic cable.

Fibrecablecapped.png Fibreportcapped.png

Remove the nuts entirely. Remove the 3 allen bolts.

Recallenbolts.png

The receiver can now be taken into the lab for testing or repair.

Opening the FEM Case

Ensure you are grounded with the anti-static strap!

Remove removing the bolts from the stoppers, but keep the stoppers in place. Once removed the triangular front mounting bracket will slide off.

Recstoppers.png

Recessed into the case are 6 screws that need to be undone. the location of 4 of these are shown in the image below. Loosen the screws using a Phillips head screwdriver. The will no come all the way out.

Reccasescrews.png

Place the receiver on its side and cautiously partially open the case. The SMA cable connecting the two halves together needs to be disconnected before the case can be fully opened. Carefully loosen the SMA cable on the Horizontal polarisation side and disconnect the cable.

Recinternalsmacable.png

Cautiously fully open the case. There is a full replica of the Auxiliary box under the bench. If testing is to be performed then this will need to be connected. Note that the CRIO out at the antenna will also need to be powered on. Ensuring that the power is off, connect the cables to the FEM.

Whenever disconnecting or connecting components to the receiver, ensure that the power is off!

Auxrep.png Cablesconnected.png

Reconnect the SMA cable between the two halves of the receivers.

Power Meter Benchtest

The purpose of this test is to find the relationship between voltage (V) and power (dBm) of the front end. The coefficients for the curve fit need to be placed into the crio.ini file for the appropriate antenna.

The power meter will need to be connected to the either the horizontal or vertical polarization. The power meter is normally kept in the correlator room.

Always have the anti-static cable conected when working on an FEM.

Power Meter 1.jpg

1. Plug in the power meter to a power point.
2. Retrieve the 25 foot serial cable and connect one end to the back of the Power Meter.
Power Meter Back.jpg
3. Retrieve the USB to serial cable. Connect the serial end to the serial cable and the USB end to a USB2 port on helios.
Power Meter Helios.jpg
4. Press the power button on the power meter and wait for it to display the power (in dBm).
5. Press the Cal/Zero button and the the zero softkey (right of the display).
6. Remove the end of the power sensor head.
Power Meter Sensor.jpg Power Meter End Removed.jpg
7. Connect the sensor to the calibration port of the power meter and press the Cal softkey. Wait for the calibration to complete
Power Meter Calibration.jpg
8. Disconnect the sensor from the calibration port and reconnect the end.
9. Disconnect the cable from the RF input of the optical link for the polarization that is to be tested.
FEM RF.jpg Powermeterconnected.jpg
10. Turn on the FEM.
11. From a Helios terminal enter the following commands:
cd Dropbox/PythonCode/owen/
conda activate /common/anaconda2/envs/py3.10
PYTHONPATH=/common/python/
ipython --pylab
import benchtest
12. To start the benchtest enter the following command:
benchtest.benchtest(ant, pol, verbose=True)
where ant is the antenna number, pol is the polarization. For example to perform a benchtest on ant10 H-Pol you would issue the command:
benchtest.benchtest(10, 'H', verbose=True)
13. The benchtest should take about two minutes to complete.
14. If you see the error:
Cannot read from port 6341
just restart the benchtest (step 12)
15. Once complete, turn off the FEM.
16. If required connect the power meter to the other polarization and repeat the benchtest. Ensure you reconnect the RF cable to the optical link.
17. The data file are currently stored in /home/helios/Dropbox/PythonCode/owen. Find the most recent file for each polarization that was just tested.
18. To get the coefficient, in ipython enter the following command:
benchtest.benchtest_anal(filename)
For example:
benchtest.benchtest_anal('20240607T165026_10_H_benchtest.csv')
A plot will be displayed and the coefficients shown in the terminal for the given polarization.

Example PM Benchtest.png

HPol.c0 =  6.0492718
HPol.c1 =  6.6828002
HPol.c2 =  0.0150576
HPol.c3 =  0.3935591
HPol.c4 =  0.0990589
19. Repeat for the other polarization if needed.
20. To upload the coefficents to the crio, first exit ipython and the python3 environment.
exit
source deactivate
source deactivate
21. Change to the <spanstyle="font-family:courier">Current folder, change the python path and Restart ipython.
cd /home/sched/Dropbox/PythonCode/Current
PYTHONPATH=/common/python/current/
ipython --pylab
22. Retrieve the current crio.ini file for the benchtest antenna.
import crio
crio.save_crio_ini(ant_str)
For example, to get the file for antenna 10:
import crio
crio.save_crio_ini('ant10')
23. In a file manager navigate to the /home/sched/Dropbox/PythonCode/Current/crio_inis and double click on the most recent file for the benchtest antenna.
24. Find the block labelled [FEM Power Scale] and replace the HPOL and VPOL values with those from the benchtest. Save the file and exit.
25. From ipyhton, reload the ini file to the crio.
crio.reload_crio_ini(ant_str)
For example, to reload the file for antenna 10:
crio.reload_crio_ini('ant10')



Replacing the LNA

Ensure that power is off to the receiver. The LNA locations is shown below. It is in the same place on the other half of the receiver for the other polarisation.

LNAinrec.jpg

Carefully unsolder the black and red wires connected to the LNA.

Undo the nuts on either side of the LNA. To undo they will move towards the LNA.

Remove the allen bolts fixing the LNA to the case.

Carefully remove the LNA.

Add some silicone heat sink compound to the base of the new LNA.

Repeat the process in reverse to install the new LNA.

Brightscram Adjustment

Occasionally, the brightscram sensors will need to be tested or adjusted. A clear day with full sun is required for this adjustment. Antennas 1 to 8 have a bright scram sensor.

There are two major components to the brightscram sensor: The buffer board and the sensor. The sensor is located on the antenna feed as shown in the image below.

Brightscram sensor.jpg

The sensor needs to be aligned with the point of the feed.

The buffer board is located in the auxiliary box as shown below.

BufferBoard.jpg

Refer to the annotated image below and follow the procedure below to adjust the brightscram settings.

Buf board bscram.jpg

With the antenna pointing at the Sun, measure the voltage between Vsense and Ground.
Measure the voltage between Vtrig (Pin 2 on the U8 chip) and ground.
Adjust this voltage by turning the screw on Trig Adj (labelled VR3 on the board). The Voltage here should be about 0.05 V BELOW that of VSense.
Once done, using the spray container, wet the dish. The dish should move off the sun and return 10 minutes later. If it does not, you will need to adjust Vtrig until it does.

UPS Battery Replacement

Periodically, the batteries on the Uninterruptable Power Supplies (UPS) will need replacing. There are 4 in total: one in each of the four central racks and one in the network rack. The LCD at the front of the UPS will display a message when the batteries need to be replaced as shown below.

UPS Batt Warning.jpg

Below is an annotated image of the UPS front panel showing the important components.

UPS Front Panel.jpg

To remove the battery pack, follow the instructions below.

Undo the three screws on the front chasis.
Disconnect the blue battery connector.
Lift the battery back and pull out. Be careful! It is heavy!.
See the image below of the removed battery pack.

BattPack removed.jpg

Remove the top cover by undoing the screws at either end of the tray. The image below shows the batteries within the tray.

UPS-Batteries.jpg

Resetting the ManLight

Detach the serial cable from the ACC and connect to a serial to USB adapter. Connect this to the laptop.

Check the serial ports in Device manager to obtain the com port number.

Click on Start -> PRD Serial -> main.exe.

Select Setup and change COM1 to the appropriate port.

In the Enables tab disable IP, IT and ITF monitor ports.

Start the program running by clicking on the arrow in the upper left.

In the Control tabs set the following:

'ACC mode pump current 1' to 250 and press the LOAD button.
'AM - EDFA Mode' to ACC - constant current and press the load button.
'LO - loss Output Power Alarm threshold' to 20 and press the load button.

If any load button does not underpress, the GUI is hung up and rebooting the computer may be necessary. In that case you can start where you left off.

Spectrogram on Webpage not updating

If the EOVSA spectrogram on the observing status page is not updating and IDB files are being created then it is likely a corrupted FDB file. To fix this follow the instructions below.

From a dpp terminal change to the /data1/FDB directory
cd /data1/FDB
Use nano to edit the current FDB file
nano FDByyyymmdd.txt
where yyyy is the year, mm is the month and dd is the day for the current date.
Good lines in this file will look similar to:
IDB20240630020518   240629233014 Sun^@^@^@^@^@^@^@^@^@ NormalObserving^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@
   895868450   895896900  1719713118      0  1719713687      0  3802557918.  3802558487.
IDB20240630021517   240629233014 Sun^@^@^@^@^@^@^@^@^@ NormalObserving^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@
   895898450   895903600  1719713718      0  1719713821      0  3802558518.  3802558621.
IDB20240630022119   240630022111 1229+020^@^@^@^@ PHASECAL^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@
   895916550   895942000  1719714080      0  1719714589      0  3802558880.  3802559389.
Bad lines will often have all fields populated with zeros and *'s in them.
Simply delete the bad lines.
Press <CRTL><x> to exit and <y> when prompted to save.
Within 10 minutes the webpage should have updated.

Antenna A Power Outage and Reset

Recycling Power to Antenna A

To recycle power to Antenna A goto http://pduanta.solar.pvt and enter the username and password.

There will be eight devices that can be chosen from. Click Cycle to recycle the power to the appropriate option.

You may need to follow the procedure below to bring Antenna A back to operation.

Recovering Antenna A from a Power Outage

On the Stateframe display click on the CryoRX tab. This will bring up the display shown below.

CryoRXdisp.png

Recycling Power to the FEM

Login to the feanta machine as follows:

ssh antctl@feanta

If the FEM Outlets on the CryoRX window are marked as Off then from a Helios terminal:

Then type in the command:

/home/antctl/starburst/femTools/src/starburstControl start

Otherwise recycle the power to the FEM as follows:

/home/antctl/starburst/femTools/src/starburstControl stop

Wait about 10 seconds and the issue the start command:

/home/antctl/starburst/femTools/src/starburstControl start

Once done type in:

exit

Recycling Power to the Brick

If faults are showing on the Motor section (4th green line down) the Brick power will need to be recycled. To do this issue the following commands from the Schedule Window:

outlet 3 off ant14
outlet 3 on ant14

Restarting the LNAs

From a Helios terminal:

ssh root@lna14.solar.pvt

If you get an error "No route to host" you will need to restart the computer at the 27m antenna by issuing the commands below from the Schedule Window:

outlet 6 off ant14
outlet 6 on ant14

Then issue the command from the terminal:

./killAll python

Then press the up arrow until the most recent python command is found and press enter. Text will scroll up continuously Just type exit even with the text scrolling to exit the ssh session.

From Schedule issue the command:

$lna-init ant14

The Drain Voltage for Hi H will be incorrect (~.61 when it should be 1.2). To correct this, from Schedule issue:

lna drain hh 2.4 ant14

Aligning the Receivers

Only do this once Mark Hodges has confirmed that he does NOT have the external vacuum pump connected!

The receivers must be properly aligned. From Schedule send the command:

frm-home ant14

If the receivers do not home properly, you will need to cycle power on the brick: http://ovsa.njit.edu//wiki/index.php/Owen%27s_Notes#Recycling_Power_to_the_Brick

It will take a few minutes for the FRM to find its home position. Once it has send the command:

frm-set-pa 0 ant14

to zero the positions.

Set the Hi Receiver:

rx-select hi ant14

Ant A Maths Error

Goto the webpage https://ant14.solar.pvt. You should get to the screen as shown below:

AntA-Web-Home.png

Ensure that on the left under the SP image that there is a green 'Ready' message.

If there is a Maths Error then follow the following procedure.

Click on the Login tab and enter the username and password.

Click on the Parameter tab to see the following screen:

AntA-Web-Param-Opt10-marked.png

Click on view next to #10.

At the next screen click on view next to Item #10.00:

AntA-Web Opt10.00-marked.png

In the Update Value box enter 1070 and click on Change

Click on the arrow near the top of the page to return to menu 10.

Click on View next to Item #10.38

In the Update Value box enter 100 and click on Change.

Preventing the Receiver from Moving During Maintenance

During some types of maintenance, the receiver should not be moved. To prevent this from happening, log into feanta:

ssh antctl@feanta

and then issue the command:

/home/antctl/starburst/femTools/src/starburstControl stop

Type exit to end the feanta session.

To reactivate, log back into feanta and send the command:

/home/antctl/starburst/femTools/src/starburstControl start

Note that this resets every evening. If a shutdown is required for longer than that then feanta may need to be shutdown.

Site Wide Power Outage

Most of the procedures to recover from a site wide power outage are covered above. Below are the the steps required in order.

27m Antenna (Antenna A)

Refer to the procedure here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Recovering_Antenna_A_from_a_Power_Outage

2m Antennas (Antennas 1-13)

For any antennas that have a communications failure (highlighted in red in the communications section of the Stateframe Display) follow the procedures here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Antenna_Communications_Failure

It may take some time for the CRIOs to restart. If after 20 minutes a CRIO has not restarted, redo the procedure.

Stop the schedule by clicking on the stop button.

Stow the antennas by issuing the command

stow

If some of the antennas did not stow the refer to Antenna trouble shooting: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Antenna_Trouble_Shooting

If an antenna is highlighted in the Power and Attenuation section on the stateframe display then you may need to reload the .ini file to the CRIO as described here: http://www.ovsa.njit.edu/wiki/index.php/Owen%27s_Notes#Warning_on_Power_and_Attenuation

Data Backup

Local IDB File Backup

Periodically IDB files will need to be moved from pipeline. Currently these are being stored on NAS4. Typically a year of data will be copied. Follow the procedure below (replace nas4 with the appropriate drive):

Login to pipeline. an then issue the command:
screen -S filecopy
Enter the command;
cp -r -v /data1/eovsa/fits/IDB/yyyy* /nas4/IDB/
where yyyy is the year of the files to copy.
Press <CRTL>AD to exit the screen
To ensure that the files have been copied properly enter the commands
du -sc /nas4/IDB/yyyy*
and
du -sc /data1/eovsa/fits/IDB/yyyy**
Ensure that the file sizes are within a few kB of each other.
Update the JSON file from pipeline:
sudo nano /common/python/current/EOVSADB.json
The contents of the file look like:
{"EOVSADB":{"1900-01-01":"/nas3/IDB/", "2021-03-01":"/nas4/IDB", "2023-04-01":"/nas5/IDB", "2024-05-01":"/data1/eovsa/fits/IDB/"}, "comment_EOVSADB": "Locations of EOVSA IDB files after the date given in the keys."}
Change the date to the last file the particular drive that the files have been copied to.

Caltech IDB File Backup

IDB files are copied onto two USB drives and mailed to Caltech. The drives hold approximately three months of IDB data. Use the following procedure to copy the files.

Connect the USB drives to your local computer. Make a note of the last file on the disk. Delete all of the IDB, FDB and IFDB files from the drives.
Connect the drive to the USB port at the back of the pipeline machine.
Login to the user account on pipeline.
List the available drives by typing the command:
sudo fdisk -l
A list of drives will appear. Find the line similar to the one below:
/dev/sdc1   2048 7813969919 7813967872  3.7T Microsoft basic data
Note that the device might be different to /dev/sdc1, but it will be the 3.7T drive. In the rest of these instructions assumes that the device is /dev/sdc1. Replace this with whatever is the appropriate device.
Mount the USB drive:
sudo mount /dev/sdc1 /media/IDB-backup1
Open the IDB backup script using nano:
nano owen/archiveIDB.sh
Find the two lines similar to:
start=$(date -d "2020-09-13" +%Y%m%d)
end=$(date -d "2020-12-31" +%Y%m%d)
Change the start date to the day after the last date of the previous data copy and the end date to 3 months further on.
Press [CTRL][X] and the Y to exit and save the file.
If a screen named filecopy does not exist then issue the following command:
screen -S filecopy
If the screen does exist then
screen -r filecopy
To start the filecopy issue the following commands:
cd ~/owen
./archiveIDB.sh
You can then press [CTRL][a][d] to exit the screen.

Once the copy has been completed, unmount the drive:

sudo umount /media/IDB-backup1

Repeat the process for the second drive.

Common Files

The common folder on Helios is backed up automatically on Sundays at midnight. This backup is stored on the nas2 drive. To manually back up the folder, issue the following commands from a helios terminal:

screen -S commoncopy
Enter the command:
rsync -av --delete --progress --log-file=/home/sched/rsynclogs/rsync_common.log -e ssh /common/ user@pipeline:/nas2/common/
Press <CRTL>AD to exit the screen

Output from rsync is logged in /home/sched/rsynclogs/rsync_common.log

Crontab Backups

The crontab files are backed up on nas2 in the crontabs folder.

The helios crontab is stored in helios_cron

The pipeline crontab is stored in pipeline_cron

The dpp crontab is stored in dpp_cron

Location of IDB and Associated Files

IDB File Locations
Date Range Location
2014 to 2015 nas3/IDB2014-15
2016-01-01 to 2016-07-31 nas1
2016-08-01 to 2016-11-30 nas2
2016-12-01 to 2021-02-28 nas3/IDB
2021-03-01 to 2021-12-31 nas4/IDB
FDB File Locations
Date Range Location
2013-12-19 to 2015012031 nas3/FDB2014-15
2016-01-01 to 2016-07-31 nas1/FDB
2016-08-01 to 2016-11-30 nas2/FDB
2016-12-01 to 2021-02-28 nas3/FDB
2021-03-01 to 2021-12-31 nas4/FDB
IFDB File Locations
Date Range Location
2014-01-24 to 2015012031 nas3/IFDB2014-15
2016-01-01 to 2016-07-31 nas1/IFDB
2016-08-01 to 2016-11-30 nas2/IFDB
2016-12-01 to 2021-02-28 nas3/IFDB
2021-03-01 to 2021-12-31 nas4/IFDB

Schedule Command Description

NOTE: All Schedule commands accept as optional arguments a list of antennas to which the command should selectively sent. Accepted syntaxes are:

Command ant1 ant2 ant3

Command ant1-3

Command subarray1

Command subarray2

If no antenna list is indicated, the command is sent to all antennas currently in subarray1.

These commands can be found in the ~/Dropbox/EOVSA\ M\&C/EOVSA\ Schedule\ Commands.docx and ~/Dropbox/OVSA\ Expansion/Design/Antennas/Ant_A\&B_Commands.pdf files.

Commands handled directly by ACC

ABORT

Aborts all commands sent to ACC but not yet executed

CLEAROFF [antenna list]

Sets all AzEl or RaDec offsets to zero

DCMATTN HPOLattn VPOLattn [antenna list]

Indicates the VPOL and HPOL attenuations for the DCM modules indicated in the list. The attenuations are applied on the next second start.

Warning: The command is executed only if the DCM modules are in manual mode (see the DCMAUTO-ON and DCMAUTO-OFF command below)

DCMAUTO-OFF [antenna list]

Sets the DCM modules in the manual attenuation mode. This mode allows the attenuations requested by the DCMATTN to be applied.

DCMAUTO-ON [antenna list]

Sets the DCM modules in the automatic attenuation mode. This mode ignores the manual DCMATTN commands and applies the attenuation set through the DCMOFFSET mechanism.

DCMOFFSET inc1 inc2…..inc50

Sets the 50 DCM attenuation offset increments to be added to the current list of DCM offset attenuations to be cycled during each second, starting with the next second boundary. The command expects up to 50 arguments. If fewer arguments are provided, the existing set is repeated in the same sequence until all 50 slots are filled. This command is only intended for testing. During normal operations, the DCM offsets states are requested by the DPP computer when needed.

Warning: The command is executed only if the DCM modules are in auto mode (see the DCMAUTO-ON and DCMAUTO-OFF command below).

NOTE: The DCM offsets are changed on the edge of the next second after a TCP/IP message is received by ACC at the TCP.dpp.port (default port: 6344-set in ACC.ini file ). The message is expected to be a fixed length binary string having the following format: 50 32bit integers (I32)

DCMOFFSET-CLEAR

Clears the current list of 50 DCM offset attenuations that are applied when DCMAUTO-ON is set.

Warning: This command clears the offset attenuations for all DCM modules.

DCMTABLE [antennalist] filename

Request the antenna list portion of a specific DCM base attenuation table to be uploaded on the respective DCM modules. The DCM table must have 30 columns and 50 rows, each pair of adjacent columns listing the HPOL-VPOL pairs for each of the 50 slots of a tuning sequence. The DCM table text file must be located in the ACC “c:\parm” directory and its default name is “DCM.txt”.
The DCM/table_timeout key in the ACC.ini files have to be manually edited in order to modify the default timeout (ms) of the DCM modules when a table is broadcasted.
The actual DCM attenuations for a given tuning slot are calculated based on the following formula

DCM_atten[pol,tuning_index]=DCM_base_atten[pol,tuning_index]+DCM_offset[broadcasted]

DPPOFFSET-OFF

Ignores DCM offset attenuation recommendations sent by DPP but still allows setting the offsets via the DCMOFFSET schedule command.

DPPOFFSET-ON

Applies DCM offset attenuation recommendations sent by DPP but still allows setting the offsets via the DCMOFFSET schedule command.
NOTE: This is the default behavior of the system after each hardware ACC reboot or after a REBOOT or RESET command is sent via TCP/IP to the emergency 6543 acc.solar.ini port

FEM-INIT

Initialize all front-end module base attenuations with the values read from the ACC initialization file: “c:\ni-rt\startup\acc.ini”.

FEMATTN level [antennalist]

Manually selects the front-end attenuation levels for the antennas indicated in the list to be applied on the next second boundary. The attenuation level selects the corresponding entry in the “c:\parms\FEMATTN.txt” attenuation FEM table located on each the cRIOs.
The attenuation level set by this command is saved in the [FEM AGC] section of the “c:\ni-rt\startup\crio.ini” and it is automatically applied when the module is restarted.

Warning: The attenuation level setting may be overwritten by the AGC loop, if active.

The format of the table is as shown below (column heads are added here for clarity)
FEMATTN level First attenuation Second attenuation Total attenuation
0 0 0 0
1 0 3 3
2 0 6 6
3 0 9 9
4 0 12 12
5 0 15 15
6 0 18 18
7 9 12 21
8 9 15 24
9 9 18 27
10 9 21 30
11 9 24 33
12 9 27 36
13 18 21 39
14 18 24 42
15 31 31 62
The actual FEM attenuations applied as the result of a FEMATTN command are given by
HPOL_ATTENUATION=HPOL_BASE+FEMATTN.txt(level)
VPOL_ATTENUATION=VPOL_BASE+FEMTTTN.txt(level)
Where Attenuation, Base, and FEMATTN.txt(level) are two elements vectors indicating the settings for the First and Second attenuators.

HATTN first second [antennalist]

Sets the FEM HPOL_BASE first and second attenuators for the antennas in the list, and overwrites the corresponding sections in the global “c:\ni-rt\startup\acc.ini” file, as well as in the local “c:\ni-rt\startup\crio.ini” files.

VATTN first second [antennalist]

Sets the FEM VPOL_BASE first and second attenuators for the antennas in the list, and overwrites the corresponding sections in the global “c:\ni-rt\startup\acc.ini” file, as well as in the local “c:\ni-rt\startup\crio.ini” files.

FSEQ-FILE filename

Tells ACC to upload to the Hittite synthesizer the frequency sequence located at “c:\parm\filename”.

FSEQ-INIT

Initializes the Hittite synthesizer according to the settings defined in the [LO Configuration] section of the “c:\ni-rt\startup\acc.ini” file.

FSEQ-ON

Starts the tuning sequence

FSEQ-OFF

Stops the tuning sequence

FSEQ-SCRIPT filename

Sends, line by line, to the Hittite synthesizer the command sequence listed in the “c:\parm\filename” script file.

LO1A-REBOOT

Commands the PDU controller to recycle the power on the LO1A Hittite synthesizer

LO1B-REBOOT

Not implemented yet

LO1A-WRITE command

Sends the specified command to the LO1A Hittite synthesizer

LO1B-WRITE command

Sends the specified command to the LO1B Hittite synthesizer

SERVICE [antennalist]

Takes the antennas in the list out of subarray1 or subarray2 and drives them to the service position.

Warning: Once in service position, the serviced antenna should be put in local operation mode in order to avoid it being controlled by a subsequent schedule command.

SUBARRAY1 antennalist

Puts all antennas in the list into subarray1. All antennas than are not listed, but currently in subarray1, are taken out from subarray1.
NOTE: As of Dec 03 2015, this command no longer switches by default the LO connector to an alternative source. To force the LO connector to switch switches, one must use the new explicit command SUBARRAY1_SWITCH antennalist

SUBARRAY2 antennalist

Puts all antennas in the list, which are not already in subarray1, into subarray2. In order to move a given antenna from subarray1 to subarray2, one should first redefine subarray1.
NOTE: As of Dec 03 2015, this command no longer switches by default the LO connector to an alternative source. To force the LO connector to switch switches, one must use the new explicit command SUBARRAY2_SWITCH antennalist

SYNC [antennalist]

Restarts the real-time executable on all cRIOs corresponding to the antenna list.
NOTE: Unlike the general convention, not providing a list of antennas commands all cRIOs to restarts their execution.

TRACKTABLE filename [antennalist]

Uploads to all antennas in the list the tracking table located at “c:\parm\filename”

TRAJ-FILE filename [antennalist]

Uploads to all cRIOs corresponding to antennas in the list the trajectory file table located at “c:\parm\filename”

UNLISTEDCOMMAND [antennalist]

Any command not listed above is sent for local execution to all cRIOs corresponding to antennas in the list.

Commands handled by cRIOs

NOTE: These commands are selectively sent by ACC to all antennas in the optional argument antennalist, or, if not present, to all antennas in subarray1

AGC active [low [high [samples]]]

Activates (1) or deactivates (0) the front end automatic gain control loop, which adjust the FEMATTN level when both of the HPOL and VPOL voltages, averaged over the given number of consecutive samples , cross the low and high voltage limits. Missing parameter values are uploaded from the [FEM AGC] section of the local “c:\ni-rt\startup\crio.ini” file. All parameters provided when an AGC command is issued are saved in the same file for further use.
NOTE: At startup, the AGC loop is activated or not according with the latest active value written in the initialization file.

AZELOFF azoff eloff

Sets the Azimuth and Elevation offsets indicated in the argument list

RADECOFF raoff decoff

Sets the RA and DEC offsets indicated in the argument list

FLUSH

Flush the existing tracktable from the associated antenna controller

ND-ON and ND-OFF

Set on/off the local noise diode.

POSITION azimuth elevation

Requests a given azel position

RESTART

Reboots the cRIO

DRIVE-RESET

Resets Antenna controller

STOP

Stops the antenna

STOW

Stows the antenna

TRACK

Sets antenna in track mode

TEC-LOG

Dumps all TEC register values to the local log file “c:\tec.txt” for debugging purposes

TEC-INIT

Initializes the TEC controller with register values hard-coded in the crio code. These were read from a working controller at some time in the past.

TEC$BC

Reboot the TEC controller to recover from a bad or stuck state.

TEC$SC

Clear the error status of the TEC controller. Does nothing other than this, and is purely asthetic.

TRAJ-ON and TRAJ-OFF

Starts/Ends the execution of the trajectory script
NOTE: At startup, the WINDSCRAM loop is activated or not according with the latest active written in the initialization file.

BSCRAM-ON

Activate the BRIGHTSCRAM Monitor

BSCRAM-OFF

Deactivate the BRIGHTSCRAM Monitor

BSCRAM-CLEAR

Takes the antenna out of the BRIGHTSCRAM Active State independently of the brightness sensor state.
If the BRIGHTSCRAM Monitor’s operation mode is set to STOW, clearing the BRIGHSCRAM ACTIVE state does not have any effect on the mechanical state of the antenna. If the BRIGHTSCRAM Monitor’s operation mode is set to OFFSET, clearing the BRIGHSCRAM ACTIVE state results in removing the AZEL offsets
Note: If the BRIGHTSCRAM Monitor is active, the antenna may get back in the Active State depending on the state of the brightness sensor.

BSCRAM-SET

Force the antenna into the BRIGHTSCRAM Active State independently of the brightness sensor state.

BSCRAM-WAIT seconds

Sets the BRIGHTSCRAM Monitor waiting time before clearing the BRIGHSCRAM ACTIVE state.
Note: This setting is saved in the crio.ini file and remains persistent until changed

BSCRAM-OFFSET

Sets the BRIGHTSCRAM operation mode to stow the antenna when in active state.
Note: This setting is saved in the crio.ini file and remains persistent until changed

BSCRAM-OFFSET

Sets the BRIGHTSCRAM operation mode to apply offsets
Note: This setting is saved in the crio.ini file and remains persistent until changed

BSCRAM-AZELOFF azoff eloff

Sets the Azimuth and Elevation Offsets (degrees) for the BRIGHTSCRAM offset operation mode.
Note: This setting is saved in the crio.ini file and remains persistent until changed. Default values re AZOFF=0 and ELOFF=10

Warning: No action is taken if less than 2 arguments are provided

WSCRAM-ON

Activate the WINDSCRAM Monitor

WSCRAM-OFF

Deactivate the WINDSCRAM Monitor

WSCRAM-LIMIT value

Sets the wind speed threshold.
Note: This setting is saved in the crio.ini file and remains persistent across reboots until changed.

WSCRAM-WAIT seconds

Sets the WINDSCRAM Monitor waiting time between checking the wind speed.
Note: This setting is saved in the crio.ini file and remains persistent across reboots until changed.

UpdateElevationDiagnostics 1

Requests an update of the elevation trip register.

UpdateAzimuthDiagnostics 1

Requests an update of the azimuth trip register.

REGWRITE address value

Writes to a specific (new type) antenna register address the specified value.  This command is ignored by the old type antennas.
For example,
REGWRITE 23386 2 [antlist]
may be used to set the controller in velocity mode. Note that the velocity rate registers must also be set to control the velocity of motion. The appropriate registers are:
AzimuthVelocity, or 23585
ElevationVelocity, or 23605
Alternatively, one can write to a specific register address by directly sending a command formed by the name of the register (as defined in the M&C document Controller_registers.xlsx) followed the desired value to be written.
For example one may alternatively set the controller in velocity mode by issuing the command
RUNMODE 2 [antlist]
A possible need for velocity mode is to drive an antenna off a hard limit. For safety, the only way to do that is to set the controller in velocity mode and provide a velocity in the direction to drive off the limit. For example, if Ant 6 is on an azimuth low hard limit, one can drive it off by the following sequence:
RUNMODE 2 ANT6
AZIMUTHVELOCITY 5000 ANT6
Wait for hard limit to clear.
AZIMUTHVELOCITY 0 ANT6
TRACK ANT6

Antenna A (Antenna 14) Commands

Note: Only antenna A is currently in use. In the commands below the value of [ant] is ant14, the value of [rx] is hi or lo (for the receiver), and the value of [lna] can be lv, lh, hv or hh.

FRM-HOME [ant]

Homes the x-axis (receiver select) and position angle axis.

FRM-RX-SEL [rx] [ant]

Move x and z axes to select receiver.

FRM-SET-PA [pa] [ant]

Set the position angle, [pa] for polarization. Pointing to the south is 0 degrees. The PA can range from -90 to 90 degrees.

FRM-X-OFFSET [xoff] [ant]

Offset in x relative to the selected reciever. In effect until a new value is set or the Geo Brick is reset.

FRM-Z-OFFSET [zoff] [ant]

Offset in z relative to the selected reciever. In effect until a new value is set or the Geo Brick is reset.

FRM-ABS-X [xpos] [ant]

Set to an absolute x position. Not used.

FRM-ABS-Z [zpos] [ant]

Set to an absolute z position. Not used.

FRM-KILL [ant]

Kill all motors. They will be unpowered.

FRM-ENABLE [ant]

Enable all motors after a kill.

OUTLET [out] [state] [ant]

Turns the selected outlet on or off. [out] is a value from 1 to 8 and [state] is either on or off.

ND-ON [ant]

Turns the noise diode on via the power strip.

ND-OFF [ant]

Turns the noise diode off via the power strip.

RX-SELECT [rx] [ant]

Moves the requested receiver to focus and sets the RF switch appropriately.

LNA-GATE1 [lna] [vg1] [ant]

Sets the first gate bias on the selected amplifier to the request voltage ([vg1] in range of -2.0 to 2.0). Will only operate if that amplifier is enabled.

LNA-GATE2 [lna] [vg2] [ant]

Sets the second gate bias on the selected amplifier to the request voltage ([vg2] in range of -2.0 to 2.0). Will only operate if that amplifier is enabled.

LNA-DRAIN [lna] [vd] [ant]

Sets the drain bias ([vd] in range 0.0 to 2.0) on the selected amplifier. Will only operate if that amplifier is enabled.

LNA-ENABLE [lna] [state] [ant]

Turn the requested amplifier on or off.

Local Commands

These commands are all executed locally. Any command with a '$' in front of it is a local command.

$MK_TABLES [fname] [source]

Creates the tracktable for the named [source], writes it to the filename given by [fname], for example, sun_tab.radec, pcal_tab.radec, or geosat_tab and stores it in the /parm directory on the ACC. This file can then be sent to the antennas via the TRACKTABLE command. This must be performed at the start of each scan in order for the antennas to track the source.

$FEM_INIT <antlist>

Invokes a sequence of commands to (1) read the current front-end power levels, (2) calculate any attenuation change needed to adjust the power levels to the range 1-4 dBm, and (3) send the attenuation adjustments to the antennas. The result is that the front end power levels are adjusted to this range. It acts on the antennas given in the antenna list <antlist>, or on all antennas in the current subarray if <antlist> is omitted. This command changes the gain calibration, so should only be done prior to the start of a day's observations if possible. This is part of the System Gain Cal procedure.

$PLUSDELAY [nsec]

Relay specific command that adds given delay argument (in nanoseconds) to the Ant 14 low frequency receiver. Delays both X and Y in the current delay center table. This writes the changed record as a new record in the SQL database.

$CAPTURE-1S <stem>

Capture 1 second of data on the dpp. <stem> is an optional string to add to the end of the capture filename. This will take a few seconds to complete.

$WSCRAM-LIMIT [limit]

Update the 27-m windscram limit. the limit is in miles per hour.

$SCAN-START <NODATA>

Starts data collection. Command by itself is normal scan start, while $SCAN-START NODATA means set up scan, but do not take data. The NODATA option is used for some calibrations.

$SCAN-RESTART

This command is for restarting a scan with the same setup as the previously running scan, where only the scan state must be turned on.

$SCAN-STOP

This command stops a scan.

$PA-SWEEP [PA] [RATE]

Rotate 27-m focus rotation mechanism to sweep through a given angle range (does nothing if PA adjustment routine is already running). The angle is swept from -[PA] to [PA] at rate of 1-degree-per-[RATE] (s)

$PA-TRACK ant14 [CROSSED]

Track 27-m focus rotation mechanism to correct for parallactic angle of given antenna (does nothing if antenna not correctly specified). [CROSSED] should have value TRUE or FALSE.

$PA-STOP

Aborts a running position-angle sequence (started by $PA-SWEEP or $PA-TRACK commands) that is controlling the Antenna 14 focus rotation mechanism.

$TRIPS

Send commands to update antenna trip information.

$DLASWEEP [ant] [dla] [dlastop] <pol>

Starts a relative delay sweep on antenna [ant] (an integer, i.e. ant1), <pol> ('X', 'Y', or if omitted, both) ranging from delay step [dla] to [dlastop]. This will sweep the delay by 1 step per second for delays from [dla] to [dlastop] relative to the current nominal delay. For example, $DLASWEEP 2 5 10 X will sweep the X delay on ant2 by adding 5 steps up to 10 steps, one step per second. The start and/or stop delays can be negative, but [dla] must be less than [dlastop]. Note, if [ant] is 0, the delay of the specified polarization is swept for all antennas. Used for some total power tests.

$WAIT [secs]

Waits the number of specified seconds before executing the next command.

$PCYCLE [dev] [antlist]

Cycle the power of some device (antenna controller, fem, or crio). If [dev] is omitted then the antenna controller is cycled. The options for [dev] are ANT, FEM or CRIO.

$KATADC_GET

Get the standard deviation for each KatADC (assumes frequency tuning is static).
Note, takes about 0.2 s for each active ROACH.

$REWIND

Get date of first line of current schedule and increment by 1 day, then auto-generate a new schedule.

$LNA-INIT

Get LNA_settings.txt file from ACC and send the series of commands needed to set the LNA voltages.

$SUBARRAY' [antlist]

Run the SUBARRRAY1 command if this is the master schedule, otherwise run the SUBARRAY2 command.

Useful Tools and Utilities

Screen Command

On linux systems, the screen command allows a program to be run in the background. This is particularly useful for processes that take a long time to complete. In addition it will display output when the screen is activated.

To start a screen session, open up a terminal and issue the command:

screen

Text will appear and you will be prompted to press space or return. Just press return.

Type in the command that you want to be performed. The process will then start.

To scroll up and down within the screen press <CRTL> A <ESC>. This enters Copy Mode. You can then use the up and down arrows to scroll. Press <ESC> to exit copy mode. Note that you cannot enter commands in copy mode.

You can exit the screen by pressing <CRTL> A D The command will still be running. To re-open the screen at any time simply type:

screen -r

You can have more than one screen running at a time. In this case it is advisable to give a screen a name. For example:

screen -S schedule

will assign the name 'schedule' to the screen. To access this screen after it has been closed, use the command:

screen -r schedule

To list the currently active screens use the command:

screen -ls

To terminate a program running in a screen, from within the screen press <CRTL> Z

In the example below the ping command was stopped and fives the following output:

Screen-ping-stop.png

The [1] is the job number. To completely terminate it issue the command:

kill %1

To close a screen session type exit

If a screen is not responding, you can kill it and all programs running within it by pressing <CRTL> A K and then press Y when asked if you really want to kill the session.

Determining if a Screen is Attached to the Current Terminal

To determine if a Screen is attached to the current terminal issue the command:

echo $STY

If the output is a blank line then the attached to the terminal. However if the name of a screen is displayed then that screen is attached. For example the output displayed when the schedule screen is attached will be similar to:

17558.schedule

Screens on Helios

The Helios .bashrc and .screenrc files have been modified so that the title of the terminal displays the screen name when you enter that screen.

If the Operating system is reinstalled on helios then the following lines should be added to the bottom of the .bashrc file if they are not already present.

# This function sets the title of a Terminal window
function settitle() {
    if [ -n "$STY" ] ; then         # We are in a screen session
        echo "Setting screen titles to $@"
        printf "\033k%s\033\\" "$@"
        screen -X eval "at \\# title $@" "shelltitle $@"
    else
        printf "\033]0;%s\007" "$@"
    fi
}

Also add the following lines to the .screenrc file if they are not present.

#This section will set the title on entering a screen
termcapinfo xterm* 'hs:ts=\E]0;:fs=\007:ds=\E]0;\007'
defhstatus "Screen $STY"
hardstatus off

Once done, you will either need to restart the bash session or issue the command:

source .bashrc

Note that after these titles will only be displayed on newly started screens, not ones that are running at the time the scripts were running.

The above code is a slightly modified version of the code found here: https://code-and-hacks.peculier.com/articles/setting-terminal-title-in-gnu-screen/

df Command

On linux systems, the df command lists all of the file systems currently mounted on computer.

The command is simply:

df

More usefully, issuing the command:

df -h

will display the file sizes in 'human readable' format. Below is an example from pipeline of the output of df -h:

Df-output.png

Whatup Program

The whatup program will display a plot of sources that are currently available. A sample plot is shown below.

Whatup.png

The program must be run from helios and ipython. To run ensure you are logged into a helios terminal and issue the following commands

cd /common/python/current</p>
ipython --pylab
import whatup
whatup.whatup()

This will display a plot of sources (Altitude vs Time) visible to the 27m Antenna from the current time for the next 24 hours. The following optional arguments can be supplied:

dur - the duration of the plot in hours
t - the UT start time of the plot

For example, the following commands

from util import Time</p>
whatup.whatup(dur=6, t=Time("2020-10-01 14:00:00"))

will display a plot from 2020-10-01 14:00:00 for a duration of 6 hours as shown below:

Whatup args.png

renice: Changing priority of a program

If, on a linux system, a program is using to many resources, it is possible to use the renice> command to set it to a different priority.

From a terminal, type the command:

ps -elf | grep [program]

where [program] is the name of the program whose priority you wish to change.

Below is an example with output:

user@dpp:/$ ps -elf | grep rsync
4 S root      21761  0  80   0 - 16638 -      18:52 pts/3    00:00:00 sudo rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/
4 S root      22708  2  80   0 - 47670 -      18:52 pts/3    00:01:25 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/
1 S root      22710 22709  1  80   0 - 24727 -      18:52 pts/3    00:00:34 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/
1 D root      22711 22710  9  80   0 - 34724 -      18:52 pts/3    00:04:38 rsync -av --exclude=/dev --exclude=/data1/IDB --exclude=/lost+found --exclude=/media --exclude=/mnt --exclude=/nas1 --exclude=/proc --exclude=/sbdata --delete / /sbdata/dpp-backup/

Here we looked for the rsync command and found 4 occurrences. The 8th column (marked here in red) is the priority.

The priority ranges from -19 (highest priority) to 19 (lowest priority)

To change the priority of a program issue the command:

sudo renice -n [pr] -p [PID]

where [pr] is the new priority number and [PID] is the process identification number. The PID is the 4th column across in the display above (marked in green).

Caps Lock Toggle Using the Onscreen Keyboard

Occasionally, the caps lock key will get stuck in the on position. if you are logged in remotely, pressing caps lock on your keyboard will not fix this problem. Instead, follow the procedure below.

VNC into helios and click on the available helios terminal.
Enter the command sudo onboard
You will then need to enter the helios password. Note: If the caps lock is on you will need to press the shift key for any lowercase letters. For uppercase letters there will be no shift. That is, the keys for letters only will be inverted.
The following screen will appear. When the caps lock is on, the caps key to the left of the onscreen keyboard is red. Note that the schedule will disappear as only windows that allow keyboard entry will be visible. However, it is still running.

Onscreen keyboard caps on.png

Click on the caps lock key to turn it off. The caps lock key should return to being black.
To exit the Onscreen keyboard click on the [X] on the upper right of the onscreen keyboard as shown below.

Onscreen keyboard close button.png

The Onscreen Keyboard will still be running in the background. To stop it, click on the terminal window where you started the keyboard and the press [CRTL] C.

Plotting Stateframe Data

It is often useful to be able to access and plot Stateframe data.

Plotting Stateframe Data using the Stateframe Display

On the stateframe display, click on the Create tab shown below:

Sf create tab.png

A screen similar to that below will be displayed. If there is already a graph present click on the Clear Graph tab shown below.

Sf clear tab.png

By selecting items one at a time from left to write next to 'Select item to add' you can choose what to plot. The click on 'Add Selected Item' By repeating this process more than on data set can be plotted on a graph at a time.

Using Python to plot Stateframe Data

This section describes, with an example, the procedure for plotting Stateframe data using python. This is useful as it allows time periods longer than an hour to be plotted.

Suppose we wish to plot the vertical polarization power over a 1 hour period from 2020-10-05 00:00 to 2020-10-05 01:00.

Firstly, from a pipeline terminal, access ipython:

ipython --pylab

Next import the required libraries:

import dbutil as db
from util import Time
import numpy as np

Now set up the cursor:

cursor = db.get_cursor()

The time range is set as follows (Just replace the times in quotes with new start and end times):

trange=Time(['2020-10-05 00:00','2020-10-05 01:00']).lv.astype(int)

Now we set up a query string which will search the data base:

query = 'select Timestamp,Ante_Fron_FEM_VPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' order by Timestamp'

Some explanation here is required.

Timestamp is the time for each data point.

Ante_Fron_FEM_VPol_Power is the variable for the VPOL power. The name of each variable can be retrieved by looking at the variables an the Create tab on the stateframe display. Note that except for the last variable, it is only the first 4 characters (or fewer if there are less than 4) that make up the name.

fV66_vD15 is the database from which the data is to be retrieved.

(I15 % 15) = 3 will give the data for the antenna. I15 denotes that there are 15 antennas. This takes the record number mod 15 and will only extract a record when this equals 3 (antenna 4, as the values here are 0 indexed).

It will also only extract values in the specified time range.

Finally we want the data ordered by timestamp.

Now we retrieve the requested data:

data, msg = db.do_query(cursor,query)

The data is stored in a dictionary. We can view the keys as follows:

data.keys()

This will produce an output as follows:

[u'Timestamp', u'Ante_Fron_FEM_VPol_Power']

We convert the timestamps to numpy times:

dt = np.array(Time(data['Timestamp'].astype(float), format = 'lv').isot,dtype = 'datetime64')

The labels for the plot can be set if desired:

title('VPOL Power vs Time')
xlabel('Universal Time')
ylabel('Power (dB)')

Finally the data is plotted:

plot(dt,data['Ante_Fron_FEM_VPol_Power'])

A sample plot is shown below:

Sample sf plot.png

This plot looks rather cluttered. The number of points can be reduced if we modify our query:

query = 'select Timestamp,Ante_Fron_FEM_VPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' and (cast(Timestamp as bigint) % 10) = 0 order by Timestamp'

We then request the data again,convert the timestamps to numpy times and replot the data producing:

Sample sf plot reduced points.png

Suppose we want to plot both the HPol Power and VPol power on the same plot. This is not difficult to do. We simply modify our query again:

query = 'select Timestamp,Ante_Fron_FEM_VPol_Power,Ante_Fron_FEM_HPol_Power from fV66_vD15 where (I15 % 15) = 3 and Timestamp between '+str(trange[0])+' and '+str(trange[1])+' and (cast(Timestamp as bigint) % 10) = 0 order by Timestamp'

Now HPol has been added and we just send this query as above. If we look at the keys now we see:

[u'Timestamp', u'Ante_Fron_FEM_HPol_Power', u'Ante_Fron_FEM_VPol_Power']

To plot this data as a scatter plot we use the following commands:

hpol, = plot(dt,data['Ante_Fron_FEM_HPol_Power'].astype(float),'o', label='HPOL')
vpol, = plot(dt,data['Ante_Fron_FEM_VPol_Power'],'o', label='VPOL')
legend(handles=[hpol,vpol])

which produces this plot:

HPOL VPOL scatter.png

Power Meter Setup

The user manual for the power meter can be found at https://literature.cdn.keysight.com/litweb/pdf/E4418-90032.pdf

Before use the power meter will need to be zeroed and calibrated.

1. Ensure that the sensor is not connected to anything.

2. Press the ZERO/CAL button.

3. Press the button next to [Zero] displayed on the screen. It will take several seconds to zero.

4. Next remove the SMA adaptor from the end of the sensor and connect the sensor to the POWER REF socket on the power meter as shown below.

Power Meter Cal.jpg

5. Press the button next to [CAL] displayed on the screen. It will take several seconds.

6. The SMA power sensor can now be disconnected from the POWER REF socket and the SMA adaptor reconnected.

Vector Network Analyser Setup

VNA Photo.jpg

Basic startup and operation

Turn on the VNA using the Power button at the front. Note that there is also a power switch on the back of the VNA. Ensure this is on.

Connect the blue SMA cables to the VNA.

Press the power button.

Press the 'BW-Avg Power' soft-key.

Click on Output Power.

Ensure RF-off is checked.

Under Power, enter the VNA output Power.

Press the 'Freq' soft-key

Enter the start frequency and end frequency.

Connect port 1 to the input of the device to be tested.

Connect port 2 to the output of the device to be tested.

Press the 'BW-Avg Power' soft-key.

Uncheck RF-off.

Autoscale Display

Press the 'Scale' soft key.

Click on Auto-Scale Trace.

Average Trace

Press the 'BW-Avg Power' soft-key.

Select Moving Average.

Set Factor. This is the number of sweeps the trace is averaged over.

Check On.

Saving a Trace

Press the 'Trace' soft key.

Click on Trace Data.

Click on Ascii

Under Contents select Active Trace.

Under Output format select dB Mag-Phase.

Under Field Separator select Comma.

Under Decimal select Point.

Enter the folder and filename.

Click on Save.

Other

DPP Fix Packets Details

Basic Operation and Monitoring

As of August 2021 the interrupt priority is handled largely automatically. This section describes the updated programs.

The program that handles reassignment of the CPUs and packet monitoring in called dpp_fix_packets.py and is located in the /common/python/current/ folder.

However this is typically not run directly. Rather it is run from a script on the DPP: /home/user/test_svn/shell_scripts/start_fix_packets.sh

This script checks to see if the dpp_fix_packets.py program is running. If it is not then it will restart it. Note that the actual line in the script that starts dpp_fix_packets.py is as follows:

screen -S fixpackets -d -m python /common/python/current/dpp_fix_packets.py

This command starts the dpp_fix_packets.py in a screen named "fixpackets" in detatched mode ("-d -m").

To access the screen, and hence the output of the program simply type screen -r fixpackets

This should show output that updates every minute as shown below:

Dpp output.png

Note that I will normally show the fixpackets screen in a terminal after I have rebooted the DPP (OG)

Information is also written to the /common/webplots/dpp_fix_packets_log.txt file. This contains the last 20 lines of significant output of the dpp_fix_packets.py program. This file is read by the stateframe display. In addition it writes the CPUs currently used by the fix packets program to the /common/webplots/dpp_cpu.txt file. This is also read by the stateframe display.

At the bottom of the stateframe display is a section titled Last DPP Fix Packets Messages. This displays the last 3 messages by dpp_fix_packets.py. An example is given below:

Stateframe dpp msg.png

This will display potentially 4 different types of messages:

Packet Loss Detected: This notifies that there was a packet loss and the interfaces are being reset.
dpp_fix_packets.py has been restarted: Indicates that the fix packets program has restarted. This will normally occur after a reboot of the DPP.
Resetting CPUs - Using CPUs 18 and 19: Notifies that the CPUs being used were change. Valid CPU pairs are [18 19], [20 21], [21 22].
DPP REBOOT REQUIRED!: This indicates that all CPU pairs have been used and that the DPP should be rebooted.

Startup Script and Automatic Monitoring

The /home/user/test_svn/shell_scripts/start_fix_packets.sh is run at DPP startup. The following command is placed in the crontab file:

@reboot /bin/bash /home/user/test_svn/shell_scripts/start_fix_packets.sh

This starts the script on reboot (or startup).

Additionally this same script is run every 10 minutes in order to ensure that the program is still running. It will not restart dpp_fix_packets.py if it is already running. This command is also present in the crontab file:

*/10 * * * * /home/user/test_svn/shell_scripts/start_fix_packets.sh

Windscram

A windscram occurs when the wind exceeds 18 miles/hour for 5 minutes. While a windscram can occur at any time, it is only important during a phasecal, as this is typically the only time that the 27m antenna is tracking. The 27m will stow during a windscram. Note that when the wind drops the antenna will not resume tracking. If the wind has dropped for a significant period of time, you can resume 27m operation by issuing the command:

track ant14

from the schedule window.

You can check the wind speed history by clicking on temps. The solid gray line is the average wind speed.

Reloading the crio.ini File

DO THIS WITH EXTREME CAUTION. BE ABSOLUTELY CERTAIN THAT RELOADING THE CRIO FILE IS REQUIRED.

For antenna 11, see the special case here:

After uploading the new crio.ini file the gains and pointing may also need to be updated.

Manually uploading the crio.ini file

From helios, open a terminal and type cd /home/sched/Dropbox/PythonCode/Current/crio_inis

For the antenna that needs to be reset, find the most recent '.ini' file. For example, for antenna 10 this may be 'crio10-2019-09-28.ini'. Make a note of this file.

Enter the command ftp crio10.solar.pvt. Replace crio10 with the apropriate CRIO number.

Enter the username and password when prompted.

Enter the following commands:

cd ni-rt/startup
put crio10-2019-09-28.ini crio.ini
bye

replacing 'crio10-2019-09-28.ini' with the appropriate file for the CRIO that needs to be reset.

The above commands have reloaded the crio.ini file. The CRIO now needs to be reset. For example, Antenna 10 will be reset by issuing the following commands from the schedule window:

sync ant10
tracktable sun_tab.radec ant10
track

Using ipython to Upload the crio.ini File

From helios, open a terminal and access ipython:

ipython --pylab

Load the crio.py file by entering:

import crio

Simply issue the command:

crio.reload_crio_ini('ant#')

where # is the antenna number. The most recent crio.ini file will be uploaded for that antenna.

Power Meter Setup

The user manual for the power meter can be found at https://literature.cdn.keysight.com/litweb/pdf/E4418-90032.pdf

Before use the power meter will need to be zeroed and calibrated.

1. Ensure that the sensor is not connected to anything.

2. Press the ZERO/CAL button.

3. Press the button next to [Zero] displayed on the screen. It will take several seconds to zero.

4. Next remove the SMA adaptor from the end of the sensor and connect the sensor to the POWER REF socket on the power meter as shown below.

Power Meter Cal.jpg

5. Press the button next to [CAL] displayed on the screen. It will take several seconds.

6. The SMA power sensor can now be disconnected from the POWER REF socket and the SMA adaptor reconnected.

Moving the New Antennas Manually

Power off the antenna by turning the power switch at the bottom right of the Antenna Control Box. Switch the Maint/Norm Switch to Maint. Switch the Remote Switch to Remote.

AntControlBox.png

Remove the block from the hand controller port. Remember to place the block back after you have finished working on the antenna. It will not run in remote without it!

Handcontrollerport.png

Connect the hand controller to the port.

Handcontrollerconnected.png

Turn the power switch back on. The antenna can now be moved to a suitable position using the azimuth and elevation controls on the hand controller.

Handcontroller.png

Moving the Old Antennas Manually

At the lower right of the control box, there is a panel for controlling the antenna manually as shown below.

Old Ant Controller.jpg

Move the bottom center switch to Local. The antenna can now be positioned using the HA and Dec switches.

Antenna Stowing at End of Day

Antennas 1 to 8 are not stowed after observations. Therefore, the antennas will be highlighted as red as they will still be tracking (see image below). There is no need to take any action for these antennas.

Stateframe End of Day Ant.png

Antenna 11 will need to be stowed manually after observations are complete. To do this, enter the commands below:

stop ant11
stow ant11

Service Stow

Use this procedure to place the antenna into its service stow position.

NOTE: do NOT use the service command. This seems to also reset the CRIO.

From the schedule window issue the command:

position 225 15 ant#

where ant# is the antenna to place into service stow.

Stopping and Restarting Helios VNC

If the helios VNC server needs to be stopped then you will need to find the process ID number (PID#). From a helios terminal issue the following command:

ps -A | grep vnc

You will see a line that looks something like:

26626 ?        00:00:00 x11vnc

The number on the left is the PID#, in this case 26626. To stop VNC issue the command

kill PID#

where in this case PID# would be 26626

Note that doing this will cut the VNC connection to any users that are currently logged in.

To restart VNC issue the command:

x11vnc -shared -display :0 -forever -noxrecord -clip 1920x1200+0+0 -bg -usepw -rfbport 20000 -auth /home/sched/.Xauthority

Note that VNC is started when Helios is started. The startup script for VNC is located in: /etc/init/x11vnc.conf

Helios Bash Aliases

The aliases for various bash command can be found in the .bash_aliases file

Shutting off the 27m Control System

At times during maintenance on the 27m antenna it may be necessary to turn off the control system to prevent anyone from moving the antenna. To do this perform the following steps.

Log into the feanta machine from helios:
ssh antctl@feanta
Issue the command (note you can use the up arrow until you find the command):
/home/antctl/starburst/femTools/src/starburstControl stop
Log out of feanta by issuing the command:
exit
There is a crontask that periodically restarts the control system on helios. Issue the command:
crontab -e
This will allow you to edit the crontab file. Scroll down to find the line that reads:
1 1,5,9,13,17,21 * * * ssh -t antctl@feanta /home/antctl/starburst/femTools/src/starburstControl start
Place a # in front of this line so that it reads:
#1 1,5,9,13,17,21 * * * ssh -t antctl@feanta /home/antctl/starburst/femTools/src/starburstControl start
Press CRTL x and then answer Y to save the file.

Note that when maintenance has finished you will need to edit the crontab file again and remove the # from that line.

Installing Computer Updates

Pipeline, Helios and the DPP require regular updates. To install updates, follow the following procedure:

Log in to a terminal on a computer that is to be updated.
Issue the following command:
sudo apt update && sudo apt upgrade -y
Restart the computer by:
sudo reboot now

Setting up SSH Keys

To access a computer without a password via SSH, you cant set up SSH keys that allow password-less access between computers. These instructions are for linux.

Open a terminal on the local computer. Ensure that you are logged in as the appropriate user. Issue the command:

ssh-keygen -t dsa -f {remote_computer}

where {remote_computer} is the name of the computer that you wish to access.

This will create two files:

{remote_computer}

{remote_computer}.pub

Now use scp to copy the {remote_computer}.pub file to the remote computer.

scp {remote_computer}.pub {user}@{remote_computer}:

Enter the password when prompted. Note that {user} is the user name of the account that you wish to access.

Log into the remote computer using ssh.

ssh {user}@{remote_computer}

Now copy the contents of the {remote_computer}.pub file to ~/.ssh/authorized_keys2

cat {remote_computer}.pub >> ~/.ssh/authorized_keys2

You may need to change permissions on the new file:

chmod 600 ~/.ssh/authorized_keys2

Remove the original file:

rm {remote_computer}.pub

Logout from the remote computer:

exit

Start the ssh agent:

eval `ssh-agent -s`

Now add the identity:

ssh-add ~/.ssh/identity_{remote_computer}

You should now be able to log in to the remote computer without a password.

Changing Antenna Settings at the Controller

At the antenna, place the antenna into standby.

Make sure you select the correct controller (Azimuth or Elevation).

On the controller, press M to enable menu selection.

Use the left and right arrows to select the appropriate menu and the up and down arrows to select the appropriate parameters.

Press M again to edit the chosen parameter.

Use the left and right arrows to shift to the digit you want to change and use the up and down arrows to enter the required digit.

Once the parameter has been updated, press M to get back to menu selection.

If setting menu 20 parameters, go to parameter 15.19 and press the up arrow. This option will change from off to on and then back to off. This will save the parameter.

For any other menus, go to parameter 0.00 and change it to 1000.

Press M to exit the menu selection.

Return the antenna to operate and reboot the antenna for changes to take affect.

Data Analysis

Installing Suncasa on Ubuntu 22

Some of the libraries (including python3.8) that are required for suncasa are not part of the Ubuntu 22 distribution. The following is a summary of the instructions to install suncasa on Ubuntu 22 and later versions.

Update Ubuntu and add old repositories:

sudo apt update && sudo apt upgrade
sudo apt install software-properties-common
sudo add-apt-repository ppa:deadsnakes/ppa

Install python3.8:

sudo apt install python3.8

Install python 3.8 virtual environment:

sudo apt-get install python3.8-venv

Create a suncasa python environment:

python3.8 -m venv suncasaenv

Activate the suncasa environment:

source suncasaenv/bin/activate

Install pip, suncasa and ipython:

pip install --upgrade pip wheel
pip install suncasa
pip install ipython3

Cleanup the cache so different version of python and ipython are not being used:

hash -r

Check that the installation works:

ipython3
import suncasa
help(suncasa)
import casatasks
help(casatasks)

To exit from the suncasa environment:

deactivate

Exit from ipython:

exit

Set up EOVSA packages and site:

printf "import sys \nimport os \nimport sysconfig \nimport casatools \nimport casadata \nimport time \nlogfile='casalog-{}.log'.format(time.strftime('%%Y%%m%%d-%%H',time.localtime())) \ntelemetry_enabled = False \ncrashreporter_enabled = True \ntb=casatools.table() \nospathsep = os.path.sep \nlibpath = sysconfig.get_paths()['purelib'] \nobsdict = {'MJD': 57447.0, 'Name': 'EOVSA', 'Type': 'WGS84', 'Long': -118.287, \n            'Lat': 37.2332, 'Height': 1207.13, 'X': 0.0, 'Y': 0.0, 'Z': 0.0,  \n            'Source': 'Dale Gary'} \nobstable = os.path.join(casadata.datapath,'geodetic','Observatories') \ntb.open(obstable, nomodify=True) \nif 'EOVSA' not in tb.getcol('Name'): \n    print('Adding EOVSA to the Observatories') \n    tb.close() \n    tb.open(obstable, nomodify=False) \n    nrows = tb.nrows() \n tb.addrows(1) \n for k in obsdict.keys(): \n        tb.putcell(k, nrows, obsdict[k])     \ntb.close() \n" > $HOME/.casa/config.py
echo "sitepackagepath = '$HOME/suncasaenv/lib/python3.8/site-packages'" >> $HOME/.casa/config.py
echo "if sitepackagepath not in sys.path:" >> $HOME/.casa/config.py
echo "    sys.path.append(sitepackagepath)"     >> $HOME/.casa/config.py

To exit the suncasa environment:

deactivate

Note that you must be in the suncasa environment to use suncasa!

EOVSA synoptic Fits Images

This section is mostly to do with how to load an view EOVSA synoptic FITS images.

From pipelne change to the /common/python/mapping folder.

From ipython, issue the following commands to load the required libraries:

from fits2map import *
from plot_map import *

The files can be found at http://www.ovsa.njit.edu/fits/synoptic/. To see what files are available click on the appropriate folder.

To load a particular file you would issue the command:

eomap1 = fits2map("eomap1=fits2map("http://www.ovsa.njit.edu/fits/synoptic/2020/05/19/eovsa_20200519.spw06-10.tb.disk.fits")

In this case it would load a full disk image from 2020-05-19 created from bands 6 to 10 into eomap1.

To view the image issue the command:

plot_map(eomap1)

This will produce a plot similar to that below.

Eomap.png

The image parameters are stored as a dictionary and can be viewed by:

eomap1.keys()

For more information see http://www.ovsa.njit.edu/wiki/index.php/Mapping_Software

Antenna Optical Power at the DCM

The following table shows the measured optical power for each antenna at the DCM measured at the given date. Values of HI indicate the power meter saturated.

Antenna Optical Power
Ant # Power (dB) Date
1 HI 2022-05-18
2 HI 2022-05-18
3 HI 2022-05-18
4 HI 2022-05-18
4 HI 2022-05-18
5 HI 2022-05-18
6 HI 2022-05-18
7 3.88 2022-05-18
8 HI 2022-05-18
9 5.36 2022-05-18
10 HI 2022-05-18
11 4.40 2022-05-18
12 HI 2022-05-18
13 HI 2022-05-18

Maintenance

Routine Maintenance

Old Antennas (9-11,13)

Greasing
Antenna Last Done Next Scheduled
9 2022-09-02 2023-03-02
10 2022-09-02 2023-03-02
11 2022-09-02 2023-03-02
13 2022-09-02 2023-03-02

Antenna Components

Spin RF Feeds

Antenna Serial No. Tag No.
1 CC2D03Q18R 52393
2 CC2D01Q18R 52394
3 CC2D05Q18R 52395
4 CC2D08Q18R 52396
5 CC2D07Q18R 52397
6 CC2D11Q18R 52398
7 CC2D10Q18R 52399
8 CC2D12Q18R 52400
9 CC2D04Q18R 52401
10 CC2D06Q18R 52402
11 DU2D01Q18R 52403
12 CC2D09Q18R 52404
13 CC2D02Q18R 52405

Antenna 1

Component Module Model No. Serial No. Purchase Date Repair Date Install Date
LNA (H) FEM
LNA (V) FEM
Attenuator 1 (H) FEM
Attenuator 2 (H) FEM
Attenuator 1 (V) FEM
Attenuator 2 (V) FEM
Optical Link (H) FEM
Optical Link (V) FEM
Temperature Controller AUX
CRIO ANT

Component Supplier List

Component Model No. Spares On Site Purchase Date Supplier Website Phone No.
LNA LNA-30-00101800-25-10P-MM 2 L3Harris Narada Miteq https://nardamiteq.com/ 631-231-1700
LNA AFS4-00101800-25-10P-12V-4 3 L3Harris Narada Miteq https://nardamiteq.com/ 631-231-1700
Optical Link (1544.47nm) LT-20-M 1 OEQuest https://oequest.com/ 602-343-1496
Optical Link (1562nm) LT-20-M 1 OEQuest https://oequest.com/ 602-343-1496
2CH DWDM Demux Module BWDM21D0CRV11+BWDM21D0CRV13 1 OEQuest https://oequest.com/ 602-343-1496
Inclinometer DAS-90-A 2 Level Developments https://www.leveldevelopments.com/ 312-465-1082
Temperature Controller 145001 (TC-XX-PR-59) Rev 2,4 2 Laird Thermal Systems https://www.lairdthermal.com/ 919-597-7300
CRIO cRIO-9074 1 National Instruments https://www.ni.com/en-us.html 888-280-7645
Mag Switch XS3P12NA340 1 Telemecanique Sensors https://tesensors.com/global/en 888-280-7645
Attenuator