Functions for User Sensors
Restore Functions for Sensor Parameters
integer ierr = GET_U_SENS_IPAR(integer isens, sens_index, integer var)
integer ierr = GET_U_SENS_FPAR(integer isens, sens_index, float var)
integer isens = GET_U_NUMSENS(integer sens_id)
GET_U_NUMSENS
function:ierr = GET_U_SENS_IPAR(GET_U_NUMSENS(sens_id),sens_index,var)
Read/Write Functions of Working Array Buffers
integer ierr =SET_U_SENS_VALUE (integer isens,integer sens_index,float var)
integer ierr =GET_U_SENS_VALUE(integer isens,integer sens_index,float var
The user variables are stored and retrieved from a buffer of sensor
isens
, using buffer index sens_index
.
GET_U_NUMSENS
to translate a sensor number
into its ID, or if a sensor identifier is needed.integer isens = GET_U_SENS_ID(integer sens_id
Set and Check Global Activation Flags
The same mechanisms used to activate and deactivate standard Radioss sensors can be used with user sensors. This way, they can activate springs, interfaces, rigid walls, or other sensors using a specific user condition. Additionally, the user sensor may form part of a hierarchy of Radioss sensors (ex: logical sensors) or use standard sensors as input.
integer ierr = SET_U_SENS_ACTI(integer isens)
This function activates user sensors
isens
. The activation time is set as current time. The sensor activation will actually be delayed one cycle to preserve a hierarchical sensor activation order in parallel processing.float dtime = GET_U_SENS_ACTI(integer isens)
This function returns a time delay sine the first activation of sensor number
isens
. Ifdtime
> 0, the sensor is active. Use this to check the state of standard sensors or other user sensors that were activated byGET_U_SENS_ACTI
.User sensors may activate Radioss variables only by specialized functions, which include:- Access Functions to Radioss Time and Cyle Variables
-
float Time = GET_U_TIME()
- Returns the actual simulation time.
integer Ncyc = GET_U_CYCLE()
- Returns the actual cycle number.
- Accelerator Access Functions
-
integer ierr = GET_U_ACCEL(integer iacc, float ax, float ay, float az)
- Provides access to Radioss accelerometer
values.Note: ax, ay, az are acceleration components.
integer iacc = GET_U_NUMACC(integer acc_id)
- Restores accelerometer number from its identifier.
- Nodal Value Access Functions
- These allow access to node coordinates (x, y, z); node
displacement componentss (dx, dy, dz); node velocity
components (vx, yx, vx); and node acceleration components
(ax, ay, az). All use an internal node number (not a node
identifier) as an argument.
integer ierr = GET_U_NOD_X(integer inode, float x, float y, float z)
integer ierr = GET_U_NOD_D(integer inode, float dx, float dy, float dz)
integer ierr = GET_U_NOD_V(integer inode, float vx, float vy, float vz)
integer ierr = GET_U_NOD_A(integer inode, float ax, float ay, float az
inode
from a node identifiernode_id
. Call this function once and store the result in a local variable.integer inode = GET_U_NUMNOD(node_id)
SPMD Compatibility: User Sensor based on Node
SET_U_SENS_SPMD_NODE_LIST
function. This function, called by
the Starter, distributes a list of nodes on all SPMD domains: integer ierr = SET_U_SENS_SPMD_NODE_LIST(integer node_list, integer size)
node_list
- List of nodes, based on the node identifier.
size
- Number of nodes.