Skip to content
Tom Willemsen edited this page Sep 24, 2019 · 34 revisions

FZJ fermi chopper (used on MERLIN, MAPS, MARI)

This device has a relatively complex IOC due to some communication issues we have had with the chopper. The following things are non-standard:

  • Custom checksum algorithm in stream device. This is specific to this style of fermi chopper.
  • aSub record to parse a response string from the hardware.
  • aSub record to decide how to send the speed setpoint to the device
  • aSub record to decide whether a given command is allowed to be sent
  • SNL state machine to ensure that setpoints and their readbacks stay in sync (for both gate width and phase delay)
  • There is logic in the DB records to prevent sending a speed setpoint that is equal to the current speed setpoint readback.
  • There is (equipment) safety logic in the IOC. For more details see below.

Settings

Depending on which specific fermi chopper system is being used, there are slight variations in the communications protocol of the choppers. The expected settings are:

Beamline INST macro MHZ macro Drive parameters
MERLIN merlin 50.4 "Merlin small parameters" or "Merlin large parameters" (*)
MARI merlin (**) 50.4 "Merlin large parameters" (***)
MAPS maps 18.0 The controller on MAPS does not support changing parameters

(*) I believe this choice depends on which physical rotor is installed into the chopper

(**) The controller on MARI is identical to MERLIN's from a communications perspective - hence re-using merlin's communications code.

(***) I believe the "HET/MARI" parameters refer to a very old version of the hardware, before the chopper was upgraded to be more like Merlin's. Chopper group may be able to give a more definitive answer.

Diagnostic logs

The logs for the fermi chopper are kept in C:\Instrument\var\logs\ioc\FERMCHOP_01-<date>. These logs contain the following information:

  • All commands that are used to start the driver. Whenever the driver first starts, there will be a large block of epicsEnvSet commands. The startup process is finished when an epics> prompt comes up in the log (there will be lots of commands in between - these can be ignored)
  • Communication conditions and problems, for example unexpected replies from the chopper. These messages may include parts of the raw (hexadecimal) response from the chopper.
  • Information about the chopper state (e.g. interlock statuses, temperatures out of range) when they transition between valid/invalid states. These messages are prefixed with Chopper status:
  • Information about actions that the driver is taking to ensure the settings stay correct. There is a state machine that detects when the chopper forgets it's settings and resends the correct settings. These messages are prefixed with Keep SP and RBV in sync.
  • Messages regarding whether certain commands were accepted by the driver. These messages are prefixed with commandCheck. The driver will reject commands (and print a message in the log) if:
    • The user attempts to spin up the chopper with the bearings off
    • The user attempts to resend a "spin-up" command while the chopper is set and spinning at 600Hz. This is a mitigation for the 600Hz issue experienced on Merlin, details further down this page.
    • The user attempts to switch off the magnetic bearings while the actual chopper speed is >10Hz.
    • When the driver sends a command successfully, it will also print a message in the log with the numeric command that it has send. The translation for these numeric commands is
      • 1: Switch drive on/stop mode
      • 2: Switch drive off
      • 3: Switch drive on/run mode
      • 4: Switch magnetic bearings on
      • 5: Switch magnetic bearings off
      • 6: Use MERLIN large chopper parameters
      • 7: Use MARI chopper parameters
      • 8: Use MERLIN small chopper parameters

Unexpected Delay / Speed / Gate Width settings

Delay: high and low byte ordering

The delay setpoint can be wrong if the high byte and low byte of the setpoint are received in the wrong order. The observed behaviour in this state is that the setpoint readback will appear to be correct, but the actual delay will home in on a different (incorrect) value. Resending the delay setpoint in the correct order fixes this state.

This problem has been solved by defining the order of the packets in the stream device protocol, including an appropriate wait between them. For more details, see #2628.

Gate width setpoint readback is wrong

Occasionally the device will get confused and reset its gate width to a semi-random value. Resending the gate width causes it to pick up the correct value again. This problem is mitigated in the driver by having a state machine which keeps the gate width and gate width readback in sync.

Set commands are ignored

Sometimes the chopper crate simply ignores a setpoint which was sent. Unfortunately the crate does not respond to a set command so we can't tell if there was a comms error. This problem is mitigated in the driver by having state machines which keep the setpoints and their readbacks in sync for gate width, phase delay and chopper speed.

Additionally, the chopper speed is now put under run control as part of Merlin's set_ei script to make it more obvious if the chopper speed isn't in the expected range.

600Hz issue [Specific to Merlin]

At 600Hz, the chopper exhibits strange behaviour:

  • If the speed setpoint is already 600Hz and a speed setpoint of 600Hz is resent, the chopper gets confused. The phase delay will appear to be zero forever. To get out of this state, need to send a different setpoint, wait for the actual device speed to drop (e.g. to 599Hz), and then 600Hz can be set successfully. This problem is mitigated in the driver by not sending a speed setpoint which is equal to the current speed setpoint readback.
  • If the device is at 600Hz and already spinning, sending the "switch drive on and run" command causes the same bug as above. This problem is mitigated in the driver by disallowing the "switch drive on and run" command from being sent if the chopper speed is >595Hz and the setpoint readback is 600Hz and the drive generator is already on.

For more details, see #2741

Won't phase correctly / delay is fluctuating

Synchrotron off

The phase delay of the chopper is a delay between the synchrotron pulse and the the chopper being in a specific position. If the synchrotron is not running the delay will appear to fluctuate wildly as there is no reference synchrotron pulse. This should rectify itself without intervention and the chopper will re-phase once the synchrotron timing pulse comes back online.

Won't phase correctly (unknown causes)

Occasionally the chopper will get into a state where it can't phase correctly. The symptom is that the phase readback fluctuates wildly and never settles on the phase setpoint. We are unsure of the root cause. Sending the chopper to a different speed setpoint and then back to the original setpoint seems to let the chopper phase correctly.

When plotting the phase using the instrument archive, you may see a "beating" pattern like below. Here the amplitude of the oscillation is ~30us, a typical phase window would be ~10us so this will result in the DAE vetoing a percentage of frames based on the chopper being "out of phase" at that time.

Drive turns off unexpectedly

There are a variety of hardware & software conditions that can cause the chopper to spin down.

Hardware / firmware conditions

Firstly, check in the "advanced" tab of the OPI - any of the following will cause the device to spin down:

  • Interlock open (the scientists know how to reset this)
    • Note, the interlock only has to report "open" for a moment for the chopper to spin down. If the vacuum gauge is faulty, it may trip the interlock momentarily, which will cause the chopper to spin down but when subsequently looking at the OPI the interlock will appear OK. If this is the case then contact the chopper group as this is a hardware fault and is not something we can compensate for in software.
  • Electronics or motor temperatures too hot (not sure where the firmware limit is - may be 50C according to manual but this is not clear)
  • A few other (less common) conditions indicated by red interlock LEDs on the OPI

Software conditions

There are (equipment) safety checks in the IOC which will cause the IOC to request a spin down. Hitting any of these conditions will cause a message to be logged containing the words this will cause the chopper to spin down - this can be searched for in the log file if it is believed that the IBEX driver has caused the chopper to spin down.

  • If the electronics temperatures or motor temperatures go above 45 Celsius.
    • Electronics overheats occur somewhat frequently on Merlin, especially during hot weather.
    • Need to wait for create to cool sufficiently and then spin the chopper back up as normal.
    • Instrument scientists aware of this and know how to reset it.
  • If the auto zero voltages are out of range (absolute value higher than 3 volts)
  • If the actual chopper speed is above 606Hz
  • If the magnetic bearing is off while the chopper is at speed

Crate does not respond / Crate responds infrequently

VISA vs Asyn serial [Specific to Maps]

An issue was seen when first commissioning the MAPS fermi under EPICS. Symptoms were very odd:

  • Cannot communicate using VISA nor Asyn under EPICS
  • If chopper crate and instrument PC are power cycled, may need to run labview driver once before epics can talk. We are still not sure why this is.
  • If EPICS+Visa is subsequently run, it will upset the comms and will need to run the labview to "clear" the error

Shortened status command [Specific to Maps]

On MAPS, the crate's communications layer can fail, causing the device to ignore the standard polling command (#0000000$). To recover from this state, send the shortened command 0$ repeatedly until you get a response. The IOC should automatically do this whenever it detects no response to the standard command.

Chopper refuses to spin up

IOC command logic

There is logic in the IOC to prevent sending commands which would put the chopper into a disallowed state. For example, it is not permitted to send "switch drive on and run" if the magnetic bearings are off. Check the IOC log - there should be entries saying either "...sending command to device..." or "...refusing to send command to device...".

Chopper veto stuck on

Veto cable not properly plugged in

Ask DAE experts to unplug and re-plug in the veto cable.

Chopper phase fluctuating causing intermittent veto

If you are getting a fluctuating fermi chopper veto, e.g. it is vetoing 50% of frames, it may be because the phase is fluctuating in and out of range. See section above about delay fluctuating for possible resolutions.

Chopper run control settings incorrect

Configurations have been reloaded

The set_ei script (at least on Merlin) puts the chopper under run control. If a config is reloaded then these settings will be lost. To recover, simply re-run set_ei.

Clone this wiki locally