pcdsdevices.lodcm.CrystalTower2
- class pcdsdevices.lodcm.CrystalTower2(prefix, *args, **kwargs)
- LODCM Crystal Tower 2. - Has the second Si and C crystals and a diode behind the crystals. - Ophyd Device Components - Attribute - Class - Suffix - Docs - Kind - Notes - z2 (FCpt) - {self._hutch_prefix}:MON:MMS:10- LOM Xtal2 Z - normal - x2 (FCpt) - {self._hutch_prefix}:MON:MMS:11- LOM Xtal2 X - normal - y2 (FCpt) - {self._hutch_prefix}:MON:MMS:12- LOM Xtal2 Y - normal - th2 (FCpt) - {self._hutch_prefix}:MON:MMS:13- LOM Xtal2 Theta - normal - chi2 (FCpt) - {self._hutch_prefix}:MON:MMS:14- LOM Xtal2 Chi - normal - h2n (FCpt) - {self._hutch_prefix}:MON:MMS:15- LOM Xtal2 Hn - normal - diode2 (FCpt) - {self._hutch_prefix}:MON:MMS:21- LOM Xtal2 PIPS - normal - x2_retry_deadband (FCpt) - EpicsSignalRO- {self._hutch_prefix}:MON:MMS:11.RDBD- Retry Deadband for x2 - omitted - z2_retry_deadband (FCpt) - EpicsSignalRO- {self._hutch_prefix}:MON:MMS:10.RDBD- Retry Deadband for z2 - omitted - h2n_state - :H2N- hinted - y2_state - :Y2- normal - chi2_state - :CHI2- normal - diamond_reflection - EpicsSignalRO- :T2C:REF- Tower 2 Diamond crystal reflection - normal - silicon_reflection - EpicsSignalRO- :T2Si:REF- Tower 2 Silicon crystal reflection - normal - x2C (FCpt) - X2 motor offset for C [mm] - normal - x2Si (FCpt) - X2 motor offset for Si [mm] - normal - y2C (FCpt) - Y2 motor offset for C [mm] - normal - y2Si (FCpt) - Y2 motor offset for Si [mm] - normal - chi2C (FCpt) - Chi 2 motor offset for C [deg] - normal - chi2Si (FCpt) - Chi 2 motor offset for Si [deg] - normal - h2nC (FCpt) - H2n motor offset for C [mm] - normal - h2nSi (FCpt) - H2n motor offset for Si [mm] - normal - Methods - configure(d: Dict[str, Any]) Tuple[Dict[str, Any], Dict[str, Any]]
- Configure the device for something during a run - This default implementation allows the user to change any of the - configuration_attrs. Subclasses might override this to perform additional input validation, cleanup, etc.- Parameters:
- d (dict) – The configuration dictionary. To specify the order that the changes should be made, use an OrderedDict. 
- Returns:
- (old, new) tuple of dictionaries 
- Where old and new are pre- and post-configure configuration states. 
 
 
 - describe() OrderedDictType[str, Dict[str, Any]]
- Provide schema and meta-data for - read().- This keys in the - OrderedDictthis method returns must match the keys in the- OrderedDictreturn by- read().- This provides schema related information, (ex shape, dtype), the source (ex PV name), and if available, units, limits, precision etc. - Returns:
- data_keys (OrderedDict) – The keys must be strings and the values must be dict-like with the - event_model.event_descriptor.data_keyschema.
 
 - get(**kwargs)
- Get the value of all components in the device - Keyword arguments are passed onto each signal.get(). Components beginning with an underscore will not be included. 
 - get_material()
- Get the current material. - Returns:
- material (str) – Material of the crystal. 
- Raises:
- ValueError – When the material could not be determined or is something else other than - Sior- C.
 
 - get_reflection()
- Get crystal’s reflection. - Tries to get the reflection depending on the material in use. - Returns:
- reflection (tuple) 
- Raises:
- ValueError – When cannot determine the reflection. 
 
 - is_diamond()
- Check if tower 2 is with Diamond (C) material. 
 - is_silicon()
- Check if tower 2 is with Silicon (Si) material. 
 - post_elog_status()
- Post device status to the primary elog, if possible. 
 - read() OrderedDictType[str, Dict[str, Any]]
- Read data from the device. - This method is expected to be as instantaneous as possible, with any substantial acquisition time taken care of in - trigger().- The - OrderedDictreturned by this method must have identical keys (in the same order) as the- OrderedDictreturned by- describe().- By convention, the first key in the return is the ‘primary’ key and maybe used by heuristics in - bluesky.- The values in the ordered dictionary must be dict (-likes) with the keys - {'value', 'timestamp'}. The- 'value'may have any type, the timestamp must be a float UNIX epoch timestamp in UTC.- Returns:
- data (OrderedDict) – The keys must be strings and the values must be dict-like with the keys - {'value', 'timestamp'}
 
 - read_configuration() OrderedDictType[str, Dict[str, Any]]
- Dictionary mapping names to value dicts with keys: value, timestamp - To control which fields are included, change the Component kinds on the device, or modify the - configuration_attrslist.
 - screen()
- Open a screen for controlling the device. - Default behavior is the typhos screen, but this method can be overridden for more specialized screens. 
 - stage_group_instances() Iterator[OphydObject]
- Yields an iterator of subdevices that should be staged. 
 - stop(*, success=False)
- Stop the Device and all (instantiated) subdevices 
 - summary()
 - trigger() StatusBase
- Trigger the device and return status object. - This method is responsible for implementing ‘trigger’ or ‘acquire’ functionality of this device. - If there is an appreciable time between triggering the device and it being able to be read (via the - read()method) then this method is also responsible for arranging that the- StatusBaseobject returned by this method is notified when the device is ready to be read.- If there is no delay between triggering and being readable, then this method must return a - StatusBaseobject which is already completed.- Returns:
- status (StatusBase) – - StatusBaseobject which will be marked as complete when the device is ready to be read.
 
 - Attributes - configuration_attrs
 - connected
 - hints
 - kind