src
diagnostic_updater
__init__.py
Go to the documentation of this file.
1
#! /usr/bin/env python
2
#
3
# Software License Agreement (BSD License)
4
#
5
# Copyright (c) 2012, Willow Garage, Inc.
6
# All rights reserved.
7
#
8
# Redistribution and use in source and binary forms, with or without
9
# modification, are permitted provided that the following conditions
10
# are met:
11
#
12
# * Redistributions of source code must retain the above copyright
13
# notice, this list of conditions and the following disclaimer.
14
# * Redistributions in binary form must reproduce the above
15
# copyright notice, this list of conditions and the following
16
# disclaimer in the documentation and/or other materials provided
17
# with the distribution.
18
# * Neither the name of the Willow Garage nor the names of its
19
# contributors may be used to endorse or promote products derived
20
# from this software without specific prior written permission.
21
#
22
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33
# POSSIBILITY OF SUCH DAMAGE.
34
35
# -*- coding: utf-8 -*-
36
37
"""
38
`diagnostic_updater` contains assorted Python classes to assist in diagnostic
39
publication. These libraries are commonly used by device drivers as part of the diagnostics
40
toolchain. The main parts of `diagnostic_updater` are:
41
42
- :class:`DiagnosticStatusWrapper`, a wrapper providing
43
convenience functions for working with :class:`diagnostics_msgs.msg.DiagnosticStatus`.
44
45
- :class:`Updater`, a class for managing periodic publishing of the
46
:class:`DiagnosticStatusWrapper` output by a set of :class:`DiagnosticTask`.
47
48
- :class:`TopicDiagnostic` and :class:`HeaderlessTopicDiagnostic` for calculating and
49
publishing statistics on timestamps and publication frequencies, and
50
their corresponding :class:`DiagnosedPublisher` and :class:`HeaderlessDiagnosedPublisher`
51
to update the statistics automatically when publications are made to a topic.
52
53
Example uses of these classes can be found in `src/example.py`.
54
"""
55
56
from
._diagnostic_status_wrapper
import
*
57
from
._diagnostic_updater
import
*
58
from
._update_functions
import
*
59
from
._publisher
import
*
60
61
__all__ = [
62
'DiagnosticStatusWrapper'
,
63
'DiagnosticTask'
,
64
'FunctionDiagnosticTask'
,
65
'CompositeDiagnosticTask'
,
66
'DiagnosticTaskVector'
,
67
'Updater'
,
68
'HeaderlessTopicDiagnostic'
,
69
'TopicDiagnostic'
,
70
'DiagnosedPublisher'
,
71
'FrequencyStatusParam'
,
72
'FrequencyStatus'
,
73
'TimeStampStatusParam'
,
74
'TimeStampStatus'
,
75
'Heartbeat'
,
76
]
diagnostic_updater
Author(s): Kevin Watts, Brice Rebsamen
, Jeremy Leibs, Blaise Gassend
autogenerated on Tue May 6 2025 02:17:37