:py:mod:`phoenix6.hardware.parent_device` ========================================= .. py:module:: phoenix6.hardware.parent_device Module Contents --------------- Attributes ~~~~~~~~~~ .. autoapisummary:: phoenix6.hardware.parent_device.DEFAULT_CONTROL_RATE_PERIOD_SEC phoenix6.hardware.parent_device.T .. py:data:: DEFAULT_CONTROL_RATE_PERIOD_SEC :value: '0.01' .. py:class:: SupportsSendRequest Bases: :py:obj:`Protocol` Represents any type that can be used to send a control request to a device. .. py:property:: name :type: str .. py:property:: control_info :type: dict .. py:method:: with_update_freq_hz(new_update_freq_hz: phoenix6.units.hertz) -> SupportsSendRequest .. py:data:: T .. py:class:: ParentDevice(device_id: int, model: str, canbus: phoenix6.canbus.CANBus) Bases: :py:obj:`phoenix6.hardware.traits.common_device.CommonDevice` Base class of Phoenix devices. This holds the base information for the devices, and can be used as a generic type to hold onto a collection of multiple devices. Constructor for a device :param deviceId: ID of the device :type deviceId: int :param model: Model of the device :type model: str :param canbus: CANbus the device is on :type canbus: CANBus .. py:property:: device_id :type: int Gets the ID of this device. :returns: ID of this device :rtype: int .. py:property:: network :type: phoenix6.canbus.CANBus Gets the network this device is on. :returns: The network this device is on :rtype: CANBus .. py:property:: device_hash :type: int Gets a number unique for this device's hardware type and ID. This number is not unique across networks. This can be used to easily reference hardware devices on the same network in collections such as maps. :returns: Hash of this device :rtype: int .. py:property:: control_request :type: SupportsSendRequest Get the latest applied control. :returns: Latest applied control :rtype: SupportsSendRequest .. py:property:: has_reset_occurred :type: bool Check if the device has reset since the previous call to this routine :returns: True if device has reset :rtype: bool .. py:property:: is_connected :type: bool Returns whether the device is still connected to the robot. This is equivalent to refreshing and checking the latency of the Version status signal. :param max_latency_seconds: The maximum latency of the Version status signal before the device is reported as disconnected :type max_latency_seconds: float :returns: True if the device is connected :rtype: bool .. py:method:: get_reset_occurred_checker() -> Callable[[], bool] Get a lambda that checks for device resets. :returns: A lambda that checks for device resets :rtype: Callable[[], bool] .. py:method:: optimize_bus_utilization(optimized_freq_hz: phoenix6.units.hertz = 4.0, timeout_seconds: phoenix6.units.second = 0.1) -> phoenix6.status_code.StatusCode Optimizes the device's bus utilization by reducing the update frequencies of its status signals. All status signals that have not been explicitly gven an update frequency using BaseStatusSignal.set_update_frequency will be slowed down. Note that if other status signals in the same frame have been given an update frequency, the update frequency will be honored for the entire frame. This function only needs to be called once on this device in the robot program. Additionally, this method does not necessarily need to be called after setting the update frequencies of other signals. To restore the default status update frequencies, call reset_signal_frequencies. Alternatively, remove this method call, redeploy the robot application, and power-cycle the device on the bus. The user can also override individual status update frequencies using BaseStatusSignal.set_update_frequency. :param optimized_freq_hz: The update frequency to apply to the optimized status signals. A frequency of 0 Hz will turn off the signals. Otherwise, the minimum supported signal frequency is 4 Hz (default). :type optimized_freq_hz: hertz, optional :param timeout_seconds: Maximum amount of time to wait for each status frame when performing the action :type timeout_seconds: second, optional :returns: Status code of the first failed update frequency set call, or OK if all succeeded. :rtype: StatusCode .. py:method:: optimize_bus_utilization_for_all(*devices: phoenix6.hardware.traits.common_device.CommonDevice | list[phoenix6.hardware.traits.common_device.CommonDevice], optimized_freq_hz: phoenix6.units.hertz = 4.0) -> phoenix6.status_code.StatusCode :staticmethod: Optimizes the bus utilization of the provided devices by reducing the update frequencies of their status signals. All status signals that have not been explicitly given an update frequency using BaseStatusSignal.set_update_frequency will be slowed down. Note that if other status signals in the same status frame have been given an update frequency, the update frequency will be honored for the entire frame. This function only needs to be called once in the robot program for the provided devices. Additionally, this method does not necessarily need to be called after setting the update frequencies of other signals. To restore the default status update frequencies, call reset_signal_frequencies_for_all. Alternatively, remove this method call, redeploy the robot application, and power-cycle the devices on the bus. The user can also override individual status update frequencies using BaseStatusSignal.set_update_frequency. This will wait up to 0.100 seconds (100ms) for each status frame. :param devices: Devices for which to optimize bus utilization. :type devices: tuple[CommonDevice | list[CommonDevice], ...] :param optimized_freq_hz: The update frequency to apply to the optimized status signals. A frequency of 0 Hz will turn off the signals. Otherwise, the minimum supported signal frequency is 4 Hz (default). This must be specified using a named parameter at the end of the parameter list. :type optimized_freq_hz: hertz, optional :returns: Status code of the first failed optimize call, or OK if all succeeded :rtype: StatusCode .. py:method:: reset_signal_frequencies(timeout_seconds: phoenix6.units.second = 0.1) -> phoenix6.status_code.StatusCode Resets the update frequencies of all the device's status signals to the defaults. This restores the default update frequency of all status signals, including status signals explicitly given an update frequency using BaseStatusSignal.set_update_frequency and status signals optimized out using optimize_bus_utilization. :param timeout_seconds: Maximum amount of time to wait for each status frame when performing the action :type timeout_seconds: second, optional :returns: Status code of the first failed update frequency set call, or OK if all succeeded. :rtype: StatusCode .. py:method:: reset_signal_frequencies_for_all(*devices: phoenix6.hardware.traits.common_device.CommonDevice | list[phoenix6.hardware.traits.common_device.CommonDevice]) -> phoenix6.status_code.StatusCode :staticmethod: Resets the update frequencies of all the devices' status signals to the defaults. This restores the default update frequency of all status signals, including status signals explicitly given an update frequency using BaseStatusSignal.set_update_frequency and status signals optimized out using optimize_bus_utilization_for_all. This will wait up to 0.100 seconds (100ms) for each status frame. :param devices: Devices for which to restore default update frequencies. :type devices: tuple[CommonDevice | list[CommonDevice], ...] :returns: Status code of the first failed restore call, or OK if all succeeded :rtype: StatusCode