SDH::cDSA is the end user interface class to access the DSACON32m, the tactile sensor controller of the SDH. More...
#include <dsa.h>
Classes | |
struct | sContactInfo |
Structure to hold info about the contact of one sensor patch. More... | |
struct | sControllerInfo |
A data structure describing the controller info about the remote DSACON32m controller. More... | |
struct | sMatrixInfo |
A data structure describing a single sensor matrix connected to the remote DSACON32m controller. More... | |
struct | sResponse |
data structure for storing responses from the remote DSACON32m controller More... | |
struct | sSensitivityInfo |
Structure to hold info about the sensitivity settings of one sensor patch. More... | |
struct | sSensorInfo |
A data structure describing the sensor info about the remote DSACON32m controller. More... | |
struct | sTactileSensorFrame |
A data structure describing a full tactile sensor frame read from the remote DSACON32m controller. More... | |
Public Types | |
enum | eDSAErrorCode { E_SUCCESS, E_NOT_AVAILABLE, E_NO_SENSOR, E_NOT_INITIALIZED, E_ALREADY_RUNNING, E_FEATURE_NOT_SUPPORTED, E_INCONSISTENT_DATA, E_TIMEOUT, E_READ_ERROR, E_WRITE_ERROR, E_INSUFFICIENT_RESOURCES, E_CHECKSUM_ERROR, E_CMD_NOT_ENOUGH_PARAMS, E_CMD_UNKNOWN, E_CMD_FORMAT_ERROR, E_ACCESS_DENIED, E_ALREADY_OPEN, E_CMD_FAILED, E_CMD_ABORTED, E_INVALID_HANDLE, E_DEVICE_NOT_FOUND, E_DEVICE_NOT_OPENED, E_IO_ERROR, E_INVALID_PARAMETER, E_INDEX_OUT_OF_BOUNDS, E_CMD_PENDING, E_OVERRUN, E_RANGE_ERROR } |
error codes returned by the remote DSACON32m tactile sensor controller More... | |
typedef UInt16 | tTexel |
data type for a single 'texel' (tactile sensor element) More... | |
Public Member Functions | |
cDSA (int debug_level, char const *_tcp_adr, int _tcp_port=13000, double _timeout=1.0) | |
cDSA (int debug_level=0, int port=1, char const *device_format_string="/dev/ttyS%d") | |
void | Close (void) |
Set the framerate of the remote DSACON32m controller to 0 and close connection to it. More... | |
unsigned long | GetAgeOfFrame (sTactileSensorFrame *frame_p) |
double | GetContactArea (int m) |
sContactInfo | GetContactInfo (int m) |
const sControllerInfo & | GetControllerInfo (void) const |
Return a reference to the sControllerInfo read from the remote DSACON32m controller. More... | |
const sTactileSensorFrame & | GetFrame () const |
return a reference to the latest tactile sensor frame without reading from remote DSACON32m More... | |
int | GetMatrixIndex (int fi, int part) |
const sMatrixInfo & | GetMatrixInfo (int m) const |
Return a reference to the sMatrixInfo of matrix m read from the remote DSACON32m controller. More... | |
sSensitivityInfo | GetMatrixSensitivity (int matrix_no) |
UInt16 | GetMatrixThreshold (int matrix_no) |
const sSensorInfo & | GetSensorInfo (void) const |
Return a reference to the sSensorInfo read from the remote DSACON32m controller. More... | |
tTexel | GetTexel (int m, int x, int y) const |
void | Open (void) |
(Re-)open connection to DSACON32m controller, this is called by the constructor automatically, but is still usefull to call after a call to Close() More... | |
struct cDSA::sSensitivityInfo | SDH__attribute__ ((__packed__)) |
struct cDSA::sControllerInfo | SDH__attribute__ ((__packed__)) |
struct cDSA::sSensorInfo | SDH__attribute__ ((__packed__)) |
struct cDSA::sMatrixInfo | SDH__attribute__ ((__packed__)) |
void | SetFramerate (UInt16 framerate, bool do_RLE=true, bool do_data_acquisition=true) |
void | SetFramerateRetries (UInt16 framerate, bool do_RLE=true, bool do_data_acquisition=true, unsigned int retries=0, bool ignore_exceptions=false) |
void | SetMatrixSensitivity (int matrix_no, double sensitivity, bool do_all_matrices=false, bool do_reset=false, bool do_persistent=false) |
void | SetMatrixThreshold (int matrix_no, UInt16 threshold, bool do_all_matrices=false, bool do_reset=false, bool do_persistent=false) |
const sTactileSensorFrame & | UpdateFrame () |
read the tactile sensor frame from remote DSACON32m and return a reference to it. A command to query the frame (periodically) must have been sent before. More... | |
~cDSA () | |
Destructur: clean up and delete dynamically allocated memory. More... | |
Static Public Member Functions | |
static char const * | ErrorCodeToString (eDSAErrorCode error_code) |
static char const * | ErrorCodeToString (UInt16 error_code) |
Public Attributes | |
bool | m_read_another |
struct VCC_EXPORT cDSA::sTactileSensorFrame | SDH__attribute__ |
Protected Member Functions | |
void | ParseFrame (sResponse *response, sTactileSensorFrame *frame_p) |
void | QueryControllerInfo (sControllerInfo *_controller_info) |
void | QueryMatrixInfo (sMatrixInfo *_matrix_info, int matrix_no) |
void | QueryMatrixInfos (void) |
void | QuerySensorInfo (sSensorInfo *_sensor_info) |
void | ReadControllerInfo (sControllerInfo *_controller_info) |
void | ReadFrame (sTactileSensorFrame *frame_p) |
void | ReadMatrixInfo (sMatrixInfo *_matrix_info) |
void | ReadResponse (sResponse *response, UInt8 command_id) |
void | ReadSensorInfo (sSensorInfo *_sensor_info) |
struct cDSA::sResponse | SDH__attribute__ ((__packed__)) |
void | WriteCommand (UInt8 command) |
void | WriteCommandWithPayload (UInt8 command, UInt8 *payload, UInt16 payload_len) |
Protected Attributes | |
double | calib_pressure |
double | calib_voltage |
see calib_pressure More... | |
cSerialBase * | com |
the communication interface to use More... | |
tTexel | contact_area_cell_threshold |
threshold of texel cell value for detecting contacts with GetContactArea More... | |
tTexel | contact_force_cell_threshold |
threshold of texel cell value for detecting forces with GetContactForce More... | |
sControllerInfo | controller_info |
the controller info read from the remote DSACON32m controller More... | |
cDBG | dbg |
A stream object to print coloured debug messages. More... | |
bool | do_RLE |
flag, true if data should be sent Run Length Encoded by the remote DSACON32m controller More... | |
double | force_factor |
additional calibration factor for forces in GetContactForce More... | |
sTactileSensorFrame | frame |
the latest frame received from the remote DSACON32m controller More... | |
sMatrixInfo * | matrix_info |
the matrix infos read from the remote DSACON32m controller More... | |
int | nb_cells |
The total number of sensor cells. More... | |
long | read_timeout_us |
default timeout used for reading in us More... | |
sSensorInfo | sensor_info |
the sensor info read from the remote DSACON32m controller More... | |
UInt32 | start_dsa |
cSimpleTime | start_pc |
int * | texel_offset |
an array with the offsets of the first texel of all matrices into the whole frame More... | |
Private Member Functions | |
void | FlushInput (long timeout_us_first, long timeout_us_subsequent) |
void | Init (int debug_level) |
void | ReadAndCheckErrorResponse (char const *msg, UInt8 command_id) |
double | VoltageToPressure (double voltage) |
Private Attributes | |
bool | acquiring_single_frame |
flag, true if user requested acquiring of a single frame. Needed for DSACON32m firmware-bug workaround. More... | |
Friends | |
VCC_EXPORT std::ostream & | operator<< (std::ostream &stream, cDSA::sResponse const &response) |
SDH::cDSA is the end user interface class to access the DSACON32m, the tactile sensor controller of the SDH.
Class to communicate with the tactile sensor controller DSACON32m of the SDH
typedef UInt16 cDSA::tTexel |
enum cDSA::eDSAErrorCode |
error codes returned by the remote DSACON32m tactile sensor controller
cDSA::cDSA | ( | int | debug_level = 0 , |
int | port = 1 , |
||
char const * | device_format_string = "/dev/ttyS%d" |
||
) |
Constructor for cDSA. This constructs a cDSA object to communicate with the remote DSACON32m controller within the SDH via RS232.
The connection is opened and established, and the sensor, controller and matrix info is queried from the remote DSACON32m controller. This initialization may take up to 9 seconds, since the DSACON32m controller needs > 8 seconds for "booting". If the SDH is already powered for some time then this will be much quicker.
debug_level | - the level of debug messages to be printed:
|
port | - the RS232 port to use for communication. (port 0 = ttyS0 = COM1, port 1 = ttyS1 = COM2, ...) |
device_format_string | - a format string (C string) for generating the device name, like "/dev/ttyS%d" (default) or "/dev/ttyUSB%d". Must contain a d where the port number should be inserted. This char array is duplicated on construction. When compiled with VCC (MS-Visual C++) then this is not used. |
cDSA::cDSA | ( | int | debug_level, |
char const * | _tcp_adr, | ||
int | _tcp_port = 13000 , |
||
double | _timeout = 1.0 |
||
) |
Constructor for cDSA. This constructs a cDSA object to communicate with the remote DSACON32m controller within the SDH via TCP/IP (ethernet).
The connection is opened and established, and the sensor, controller and matrix info is queried from the remote DSACON32m controller. This initialization may take up to 9 seconds, since the DSACON32m controller needs > 8 seconds for "booting". If the SDH is already powered for some time then this will be much quicker.
debug_level | - the level of debug messages to be printed:
|
_tcp_adr | : The tcp host address of the SDH. Either a numeric IP as string or a hostname |
_tcp_port | : the tcp port number on the SDH to connect to |
_timeout | : The timeout to use:
|
cDSA::~cDSA | ( | ) |
void cDSA::Close | ( | void | ) |
|
static |
|
inlinestatic |
|
private |
Cleanup communication line: read all available bytes with timeout_us_first timeout in us for first byte and timeout_us_subsequent timeoutin us for subsequent bytes
timeout_us_first | - timeout in us for first byte |
timeout_us_subsequent | - timeout in us for subsequent bytes |
The push mode of the DSACON32m must be switched off on call since else the method will not return.
|
inline |
double cDSA::GetContactArea | ( | int | m | ) |
cDSA::sContactInfo cDSA::GetContactInfo | ( | int | m | ) |
Return a sContactInfo struct (force,cog_x,cog_y,area) of contact force and center of gravity and contact area of that force for matrix with index m
|
inline |
Return a reference to the sControllerInfo read from the remote DSACON32m controller.
|
inline |
|
inline |
|
inline |
Return a reference to the sMatrixInfo of matrix m read from the remote DSACON32m controller.
cDSA::sSensitivityInfo cDSA::GetMatrixSensitivity | ( | int | matrix_no | ) |
Send command to get matrix sensitivity. Returns sensitivities of matrix no matrix_no.
A struct is returned containing the members error_code - see DSACON32 Command Set Reference Manual adj_flags - see DSACON32 Command Set Reference Manual cur_sens - the currently set sensitivity as float 0.0 .. 1.0 fact_sens - the factory sensitivity as float 0.0 .. 1.0
Raises a cDSAException in case of invalid responses from the remote DSACON32m controller.
UInt16 cDSA::GetMatrixThreshold | ( | int | matrix_no | ) |
Send command to get matrix threshold. Returns threshold of matrix no matrix_no.
Raises a cDSAException in case of invalid responses from the remote DSACON32m controller.
|
inline |
Return a reference to the sSensorInfo read from the remote DSACON32m controller.
cDSA::tTexel cDSA::GetTexel | ( | int | m, |
int | x, | ||
int | y | ||
) | const |
|
private |
void cDSA::Open | ( | void | ) |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
private |
|
protected |
|
protected |
|
protected |
Read any response from the remote DSACON32m, expect the command_id as command id
|
protected |
struct cDSA::sControllerInfo cDSA::SDH__attribute__ | ( | (__packed__) | ) |
struct cDSA::sSensorInfo cDSA::SDH__attribute__ | ( | (__packed__) | ) |
struct cDSA::sMatrixInfo cDSA::SDH__attribute__ | ( | (__packed__) | ) |
struct cDSA::sSensitivityInfo cDSA::SDH__attribute__ | ( | (__packed__) | ) |
|
protected |
void cDSA::SetFramerate | ( | UInt16 | framerate, |
bool | do_RLE = true , |
||
bool | do_data_acquisition = true |
||
) |
Set the framerate for querying full frames.
framerate | - rate of frames. |
do_RLE | - flag, if true then use RLE (run length encoding) for sending frames |
do_data_acquisition | - flag, enable or disable data acquisition. Must be true if you want to get new frames |
Use framerate>0 and do_data_acquisition=true to make the remote DSACON32m in SDH send frames at the highest possible rate (for now: 30 FPS (frames per second)).
void cDSA::SetFramerateRetries | ( | UInt16 | framerate, |
bool | do_RLE = true , |
||
bool | do_data_acquisition = true , |
||
unsigned int | retries = 0 , |
||
bool | ignore_exceptions = false |
||
) |
Set the framerate for querying full frames.
framerate | - rate of frames. 0 will make the remote DSACON32m in SDH stop sending frames, any value > 0 will make the remote DSACON32m in SDH send frames at the highest possible rate (for now: 30 FPS (frames per second)). |
do_RLE | - flag, if true then use RLE (run length encoding) for sending frames |
do_data_acquisition | - flag, enable or disable data acquisition. Must be true if you want to get new frames |
retries | - number of times the sending will be retried in case of an error (like timeout while waiting for response) |
ignore_exceptions | - flag, if true then exceptions are ignored in case of error. After retries tries the function just returns even in case of an error |
void cDSA::SetMatrixSensitivity | ( | int | matrix_no, |
double | sensitivity, | ||
bool | do_all_matrices = false , |
||
bool | do_reset = false , |
||
bool | do_persistent = false |
||
) |
Send command to set matrix sensitivity to sensitivity as float 0.0 .. 1.0. If do_all_matrices is true then the sensitivity is set for all matrices. If do_reset is true then the sensitivity is reset to the factory default. If do_persistent is true then the sensitivity is saved persistently to configuration memory and will thus remain after the next power off/power on cycle and will become the new factory default value. If do_persistent is false (default) then the value will be reset to default on the next power off/power on cycle
Raises a cDSAException in case of invalid responses from the remote DSACON32m controller.
void cDSA::SetMatrixThreshold | ( | int | matrix_no, |
UInt16 | threshold, | ||
bool | do_all_matrices = false , |
||
bool | do_reset = false , |
||
bool | do_persistent = false |
||
) |
Send command to set matrix threshold to threshold as integer [0 .. 4095] (0 is minimum, 4095 is maximum threshold). If do_all_matrices is true then the threshold is set for all matrices. If do_reset is true then the threshold is reset to the factory default. If do_persistent is true then the threshold is saved persistently to configuration memory and will thus remain after the next power off/power on cycle and will become the new factory default value. If do_persistent is false (default) then the value will be reset to default on the next power off/power on cycle
Raises a cDSAException in case of invalid responses from the remote DSACON32m controller.
|
inline |
|
private |
|
friend |
|
private |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
bool cDSA::m_read_another |
flag, if True then the ReadFrame() function will read tactile sensor frames until a timeout occurs. This will ignore intermediate frames as long as new ones are available. This was usefull some time in the past, or if you have a slow computer that cannot handle incoming frames fast enough. If False then any completely read valid frame will be reported. With new computers and fast communication like via TCP this should remain at "False".
|
protected |
|
protected |
|
protected |
struct VCC_EXPORT cDSA::sTactileSensorFrame cDSA::SDH__attribute__ |
|
protected |
|
protected |
|
protected |