areaDetector  3-14
EPICS areaDetector framework
Public Member Functions | Protected Attributes | List of all members
NDPluginROIStat Class Reference

Compute statistics on ROIs in an array. More...

#include <NDPluginROIStat.h>

Inheritance diagram for NDPluginROIStat:
NDPluginDriver asynNDArrayDriver

Public Member Functions

 NDPluginROIStat (const char *portName, int queueSize, int blockingCallbacks, const char *NDArrayPort, int NDArrayAddr, int maxROIs, int maxBuffers, size_t maxMemory, int priority, int stackSize, int maxThreads)
 Constructor for NDPluginROIStat; most parameters are simply passed to NDPluginDriver::NDPluginDriver. More...
 
void processCallbacks (NDArray *pArray)
 Callback function that is called by the NDArray driver with new NDArray data. More...
 
asynStatus writeInt32 (asynUser *pasynUser, epicsInt32 value)
 Called when asyn clients call pasynInt32->write(). More...
 
- Public Member Functions inherited from NDPluginDriver
 NDPluginDriver (const char *portName, int queueSize, int blockingCallbacks, const char *NDArrayPort, int NDArrayAddr, int maxAddr, int maxBuffers, size_t maxMemory, int interfaceMask, int interruptMask, int asynFlags, int autoConnect, int priority, int stackSize, int maxThreads, bool compressionAware=false)
 Constructor for NDPluginDriver; most parameters are simply passed to asynNDArrayDriver::asynNDArrayDriver. More...
 
 ~NDPluginDriver ()
 
virtual asynStatus writeFloat64 (asynUser *pasynUser, epicsFloat64 value)
 Called when asyn clients call pasynFloat64->write(). More...
 
virtual asynStatus writeOctet (asynUser *pasynUser, const char *value, size_t maxChars, size_t *nActual)
 Called when asyn clients call pasynOctet->write(). More...
 
virtual asynStatus readInt32Array (asynUser *pasynUser, epicsInt32 *value, size_t nElements, size_t *nIn)
 Called when asyn clients call pasynInt32Array->read(). More...
 
virtual void driverCallback (asynUser *pasynUser, void *genericPointer)
 Method that is called from the driver with a new NDArray. More...
 
virtual void run (void)
 Starts the thread that receives NDArrays from the epicsMessageQueue. More...
 
virtual asynStatus start (void)
 Starts the plugin threads. More...
 
void sortingTask ()
 Method runs as a separate thread, periodically doing NDArray callbacks to downstream plugins. More...
 
- Public Member Functions inherited from asynNDArrayDriver
 asynNDArrayDriver (const char *portName, int maxAddr, int maxBuffers, size_t maxMemory, int interfaceMask, int interruptMask, int asynFlags, int autoConnect, int priority, int stackSize)
 This is the constructor for the asynNDArrayDriver class. More...
 
virtual ~asynNDArrayDriver ()
 
virtual asynStatus readGenericPointer (asynUser *pasynUser, void *genericPointer)
 This method copies an NDArray object from the asynNDArrayDriver to an NDArray pointer passed in by the caller. More...
 
virtual asynStatus writeGenericPointer (asynUser *pasynUser, void *genericPointer)
 This method currently does nothing, but it should be implemented in this base class. More...
 
virtual asynStatus setIntegerParam (int index, int value)
 Sets the value for an integer in the parameter library. More...
 
virtual asynStatus setIntegerParam (int list, int index, int value)
 Sets the value for an integer in the parameter library. More...
 
virtual void report (FILE *fp, int details)
 Report status of the driver. More...
 
virtual asynStatus createFilePath (const char *path, int pathDepth)
 Function to create a directory path for a file. More...
 
virtual asynStatus checkPath ()
 Checks whether the directory specified NDFilePath parameter exists. More...
 
virtual bool checkPath (std::string &filePath)
 Checks whether the directory specified exists. More...
 
virtual asynStatus createFileName (int maxChars, char *fullFileName)
 Build a file name from component parts. More...
 
virtual asynStatus createFileName (int maxChars, char *filePath, char *fileName)
 Build a file name from component parts. More...
 
virtual asynStatus readNDAttributesFile ()
 Create this driver's NDAttributeList (pAttributeList) by reading an XML file This clears any existing attributes from this drivers' NDAttributeList and then creates a new list based on the XML file. More...
 
virtual asynStatus getAttributes (NDAttributeList *pAttributeList)
 Get the current values of attributes from this driver and appends them to an output attribute list. More...
 
virtual void updateTimeStamps (NDArray *pArray)
 
asynStatus incrementQueuedArrayCount ()
 
asynStatus decrementQueuedArrayCount ()
 
int getQueuedArrayCount ()
 
void updateQueuedArrayCount ()
 

Protected Attributes

int NDPluginROIStatFirst
 
int NDPluginROIStatName
 
int NDPluginROIStatUse
 
int NDPluginROIStatReset
 
int NDPluginROIStatBgdWidth
 
int NDPluginROIStatResetAll
 
int NDPluginROIStatDim0Min
 
int NDPluginROIStatDim0Size
 
int NDPluginROIStatDim0MaxSize
 
int NDPluginROIStatDim1Min
 
int NDPluginROIStatDim1Size
 
int NDPluginROIStatDim1MaxSize
 
int NDPluginROIStatDim2Min
 
int NDPluginROIStatDim2Size
 
int NDPluginROIStatDim2MaxSize
 
int NDPluginROIStatMinValue
 
int NDPluginROIStatMaxValue
 
int NDPluginROIStatMeanValue
 
int NDPluginROIStatTotal
 
int NDPluginROIStatNet
 
int NDPluginROIStatTSControl
 
int NDPluginROIStatTSNumPoints
 
int NDPluginROIStatTSCurrentPoint
 
int NDPluginROIStatTSAcquiring
 
int NDPluginROIStatTSMinValue
 
int NDPluginROIStatTSMaxValue
 
int NDPluginROIStatTSMeanValue
 
int NDPluginROIStatTSTotal
 
int NDPluginROIStatTSNet
 
int NDPluginROIStatTSTimestamp
 
int NDPluginROIStatLast
 
- Protected Attributes inherited from NDPluginDriver
int NDPluginDriverArrayPort
 
int NDPluginDriverArrayAddr
 
int NDPluginDriverPluginType
 
int NDPluginDriverDroppedArrays
 
int NDPluginDriverQueueSize
 
int NDPluginDriverQueueFree
 
int NDPluginDriverMaxThreads
 
int NDPluginDriverNumThreads
 
int NDPluginDriverSortMode
 
int NDPluginDriverSortTime
 
int NDPluginDriverSortSize
 
int NDPluginDriverSortFree
 
int NDPluginDriverDisorderedArrays
 
int NDPluginDriverDroppedOutputArrays
 
int NDPluginDriverEnableCallbacks
 
int NDPluginDriverBlockingCallbacks
 
int NDPluginDriverProcessPlugin
 
int NDPluginDriverExecutionTime
 
int NDPluginDriverMinCallbackTime
 
int NDPluginDriverMaxByteRate
 
NDArraypPrevInputArray_
 
- Protected Attributes inherited from asynNDArrayDriver
int NDPortNameSelf
 
int NDADCoreVersion
 
int NDDriverVersion
 
int ADManufacturer
 
int ADModel
 
int ADSerialNumber
 
int ADSDKVersion
 
int ADFirmwareVersion
 
int ADAcquire
 
int ADAcquireBusy
 
int ADWaitForPlugins
 
int NDArraySizeX
 
int NDArraySizeY
 
int NDArraySizeZ
 
int NDArraySize
 
int NDNDimensions
 
int NDDimensions
 
int NDDataType
 
int NDColorMode
 
int NDUniqueId
 
int NDTimeStamp
 
int NDEpicsTSSec
 
int NDEpicsTSNsec
 
int NDBayerPattern
 
int NDCodec
 
int NDCompressedSize
 
int NDArrayCounter
 
int NDFilePath
 
int NDFilePathExists
 
int NDFileName
 
int NDFileNumber
 
int NDFileTemplate
 
int NDAutoIncrement
 
int NDFullFileName
 
int NDFileFormat
 
int NDAutoSave
 
int NDWriteFile
 
int NDReadFile
 
int NDFileWriteMode
 
int NDFileWriteStatus
 
int NDFileWriteMessage
 
int NDFileNumCapture
 
int NDFileNumCaptured
 
int NDFileFreeCapture
 
int NDFileCapture
 
int NDFileDeleteDriverFile
 
int NDFileLazyOpen
 
int NDFileCreateDir
 
int NDFileTempSuffix
 
int NDAttributesFile
 
int NDAttributesStatus
 
int NDAttributesMacros
 
int NDArrayData
 
int NDArrayCallbacks
 
int NDPoolMaxBuffers
 
int NDPoolAllocBuffers
 
int NDPoolPreAllocBuffers
 
int NDPoolNumPreAllocBuffers
 
int NDPoolFreeBuffers
 
int NDPoolMaxMemory
 
int NDPoolUsedMemory
 
int NDPoolEmptyFreeList
 
int NDPoolPollStats
 
int NDNumQueuedArrays
 
class NDArray ** pArrays
 An array of NDArray pointers used to store data in the driver. More...
 
class NDAttributeListpAttributeList
 An NDAttributeList object used to obtain the current values of a set of attributes. More...
 
int threadStackSize_
 
int threadPriority_
 

Additional Inherited Members

- Public Attributes inherited from asynNDArrayDriver
class NDArrayPoolpNDArrayPool
 An NDArrayPool pointer that is initialized to pNDArrayPoolPvt_ in the constructor. More...
 
- Protected Member Functions inherited from NDPluginDriver
virtual void beginProcessCallbacks (NDArray *pArray)
 Method that is normally called at the beginning of the processCallbacks method in derived classes. More...
 
virtual asynStatus endProcessCallbacks (NDArray *pArray, bool copyArray=false, bool readAttributes=true)
 Method that is normally called at the end of the processCallbacks()) method in derived classes. More...
 
virtual asynStatus connectToArrayPort (void)
 Connect this plugin to an NDArray port driver; disconnect from any existing driver first, register for callbacks if enabled. More...
 
virtual asynStatus setArrayInterrupt (int connect)
 Register or unregister to receive asynGenericPointer (NDArray) callbacks from the driver. More...
 
bool throttled (NDArray *pArray)
 

Detailed Description

Compute statistics on ROIs in an array.

Constructor & Destructor Documentation

◆ NDPluginROIStat()

NDPluginROIStat::NDPluginROIStat ( const char *  portName,
int  queueSize,
int  blockingCallbacks,
const char *  NDArrayPort,
int  NDArrayAddr,
int  maxROIs,
int  maxBuffers,
size_t  maxMemory,
int  priority,
int  stackSize,
int  maxThreads 
)

Constructor for NDPluginROIStat; most parameters are simply passed to NDPluginDriver::NDPluginDriver.

After calling the base class constructor this method sets reasonable default values for all of the ROI parameters.

Parameters
[in]portNameThe name of the asyn port driver to be created.
[in]queueSizeThe number of NDArrays that the input queue for this plugin can hold when NDPluginDriverBlockingCallbacks=0. Larger queues can decrease the number of dropped arrays, at the expense of more NDArray buffers being allocated from the underlying driver's NDArrayPool.
[in]blockingCallbacksInitial setting for the NDPluginDriverBlockingCallbacks flag. 0=callbacks are queued and executed by the callback thread; 1 callbacks execute in the thread of the driver doing the callbacks.
[in]NDArrayPortName of asyn port driver for initial source of NDArray callbacks.
[in]NDArrayAddrasyn port driver address for initial source of NDArray callbacks.
[in]maxROIsThe maximum number of ROIs this plugin supports. 1 is minimum.
[in]maxBuffersThe maximum number of NDArray buffers that the NDArrayPool for this driver is allowed to allocate. Set this to -1 to allow an unlimited number of buffers.
[in]maxMemoryThe maximum amount of memory that the NDArrayPool for this driver is allowed to allocate. Set this to -1 to allow an unlimited amount of memory.
[in]priorityThe thread priority for the asyn port driver thread if ASYN_CANBLOCK is set in asynFlags.
[in]stackSizeThe stack size for the asyn port driver thread if ASYN_CANBLOCK is set in asynFlags.
[in]maxThreadsThe maximum number of threads this driver is allowed to use. If 0 then 1 will be used.

Member Function Documentation

◆ processCallbacks()

void NDPluginROIStat::processCallbacks ( NDArray pArray)
virtual

Callback function that is called by the NDArray driver with new NDArray data.

Computes statistics on the ROIs if NDPluginROIStatUse is 1. If NDPluginROIStatNDArrayCallbacks is 1 then it also does NDArray callbacks.

Parameters
[in]pArrayThe NDArray from the callback.

Implements NDPluginDriver.

◆ writeInt32()

asynStatus NDPluginROIStat::writeInt32 ( asynUser *  pasynUser,
epicsInt32  value 
)
virtual

Called when asyn clients call pasynInt32->write().

For other parameters it calls NDPluginDriver::writeInt32 to see if that method understands the parameter. For all parameters it sets the value in the parameter library and calls any registered callbacks.

Parameters
[in]pasynUserpasynUser structure that encodes the reason and address.
[in]valueThe value to write.
Returns
asynStatus

Reimplemented from NDPluginDriver.

Member Data Documentation

◆ NDPluginROIStatBgdWidth

int NDPluginROIStat::NDPluginROIStatBgdWidth
protected

◆ NDPluginROIStatDim0MaxSize

int NDPluginROIStat::NDPluginROIStatDim0MaxSize
protected

◆ NDPluginROIStatDim0Min

int NDPluginROIStat::NDPluginROIStatDim0Min
protected

◆ NDPluginROIStatDim0Size

int NDPluginROIStat::NDPluginROIStatDim0Size
protected

◆ NDPluginROIStatDim1MaxSize

int NDPluginROIStat::NDPluginROIStatDim1MaxSize
protected

◆ NDPluginROIStatDim1Min

int NDPluginROIStat::NDPluginROIStatDim1Min
protected

◆ NDPluginROIStatDim1Size

int NDPluginROIStat::NDPluginROIStatDim1Size
protected

◆ NDPluginROIStatDim2MaxSize

int NDPluginROIStat::NDPluginROIStatDim2MaxSize
protected

◆ NDPluginROIStatDim2Min

int NDPluginROIStat::NDPluginROIStatDim2Min
protected

◆ NDPluginROIStatDim2Size

int NDPluginROIStat::NDPluginROIStatDim2Size
protected

◆ NDPluginROIStatFirst

int NDPluginROIStat::NDPluginROIStatFirst
protected

◆ NDPluginROIStatLast

int NDPluginROIStat::NDPluginROIStatLast
protected

◆ NDPluginROIStatMaxValue

int NDPluginROIStat::NDPluginROIStatMaxValue
protected

◆ NDPluginROIStatMeanValue

int NDPluginROIStat::NDPluginROIStatMeanValue
protected

◆ NDPluginROIStatMinValue

int NDPluginROIStat::NDPluginROIStatMinValue
protected

◆ NDPluginROIStatName

int NDPluginROIStat::NDPluginROIStatName
protected

◆ NDPluginROIStatNet

int NDPluginROIStat::NDPluginROIStatNet
protected

◆ NDPluginROIStatReset

int NDPluginROIStat::NDPluginROIStatReset
protected

◆ NDPluginROIStatResetAll

int NDPluginROIStat::NDPluginROIStatResetAll
protected

◆ NDPluginROIStatTotal

int NDPluginROIStat::NDPluginROIStatTotal
protected

◆ NDPluginROIStatTSAcquiring

int NDPluginROIStat::NDPluginROIStatTSAcquiring
protected

◆ NDPluginROIStatTSControl

int NDPluginROIStat::NDPluginROIStatTSControl
protected

◆ NDPluginROIStatTSCurrentPoint

int NDPluginROIStat::NDPluginROIStatTSCurrentPoint
protected

◆ NDPluginROIStatTSMaxValue

int NDPluginROIStat::NDPluginROIStatTSMaxValue
protected

◆ NDPluginROIStatTSMeanValue

int NDPluginROIStat::NDPluginROIStatTSMeanValue
protected

◆ NDPluginROIStatTSMinValue

int NDPluginROIStat::NDPluginROIStatTSMinValue
protected

◆ NDPluginROIStatTSNet

int NDPluginROIStat::NDPluginROIStatTSNet
protected

◆ NDPluginROIStatTSNumPoints

int NDPluginROIStat::NDPluginROIStatTSNumPoints
protected

◆ NDPluginROIStatTSTimestamp

int NDPluginROIStat::NDPluginROIStatTSTimestamp
protected

◆ NDPluginROIStatTSTotal

int NDPluginROIStat::NDPluginROIStatTSTotal
protected

◆ NDPluginROIStatUse

int NDPluginROIStat::NDPluginROIStatUse
protected

The documentation for this class was generated from the following files: