EPICS Home

Experimental Physics and Industrial Control System


 
1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024  <2025 Index 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024  <2025
<== Date ==> <== Thread ==>

Subject: RE: Using AD plugins on asyn port
From: Abdalla Ahmad via Tech-talk <tech-talk at aps.anl.gov>
To: Mark Rivers <rivers at cars.uchicago.edu>, "Johnson, Andrew N." <anj at anl.gov>, "Pearson, Matthew" <pearsonmr at ornl.gov>, "tech-talk at aps.anl.gov" <Tech-talk at aps.anl.gov>
Date: Wed, 23 Jul 2025 09:20:49 +0000

Hi all

 

Thanks for the feedback, I created an IOC with NDDriverStdArrays support, attached is the startup file. The ArrayIn PV is receiving data from my waveform record through an intermediate ‘aao’ record in the attached nd.db database, where the DOL field is set to a waveform of size 200 scanned at 1 second. The IOC boots but when I press acquire on the GUI, the IOC segfaults immediately. I added the gdb output of loading the core dump at the end of the startup file, it always crashes here: https://github.com/areaDetector/NDDriverStdArrays/blob/master/NDDriverStdArraysApp/src/NDDriverStdArrays.cpp#L259 . I used the IOC in the source code but I got the same segfault at the same location. Could it be related to the fact that the array size is 0? I also attached a screenshot of the NDDriverStdArrays UI file. Am I missing something?

 

Best Regards,

Abdalla Al-Dalleh

Control Engineer

SESAME

 

From: Mark Rivers <rivers at cars.uchicago.edu>
Sent: Tuesday, July 22, 2025 7:37 PM
To: Johnson, Andrew N. <anj at anl.gov>; Pearson, Matthew <pearsonmr at ornl.gov>; tech-talk at aps.anl.gov; Abdalla Ahmad <Abdalla.Ahmad at sesame.org.jo>
Subject: RE: Using AD plugins on asyn port

 

That’s a very useful addition.

 

Whether it can be used with NDDriverStdArrays depends on the behavior of the input waveform record you are copying via the aao record.  If it only posts monitors when the waveform is “done” then it could work.  But in some applications the input waveform may process many times with “intermediate results” before it is really done.  One example would be a waveform digitizer with relatively slow sample rate.  The waveform record may be processing multiple times during an acquisition so the operator can see the waveform trace update before it is complete.  Another example is an MCA spectrum which is acquiring for a relative long time.  The waveform will update during acquisition so the operator can see the waveform amplitude grow.  In these cases you probably don’t want the intermediate values of the waveform to be sent to NDDriverStdArrays, you only want to write the final value.  That is where a more sophisticated CA client may be needed.

 

Mark

 

 

From: Johnson, Andrew N. <anj at anl.gov>
Sent: Tuesday, July 22, 2025 11:14 AM
To: Pearson, Matthew <pearsonmr at ornl.gov>; Mark Rivers <rivers at cars.uchicago.edu>; tech-talk at aps.anl.gov; Abdalla Ahmad <Abdalla.Ahmad at sesame.org.jo>
Subject: Re: Using AD plugins on asyn port

 

You can use an aao (array analog output) record to read array data from another record using the DOL input link and write it through the OUT output link to another record. The DOL and OMSL fields were added to it in EPICS 7.0.7.

 

- Andrew

 

-- 

Complexity comes for free, Simplicity you have to work for.

On 7/22/25, 10:24AM, "Tech-talk" <tech-talk-bounces at aps.anl.gov> wrote:

 

Hi,

 

Apologies, I haven’t used that driver myself, and I assumed it would work like the pvaDriver. Mark is right, seems like you need an extra step to copy the waveform data into ArrayIn. One other option might be an array subroutine record.

 

Cheers,

Matt

 

From: Mark Rivers <rivers at cars.uchicago.edu>
Sent: Tuesday, July 22, 2025 8:43 AM
To: Pearson, Matthew <pearsonmr at ornl.gov>; tech-talk at aps.anl.gov; Abdalla Ahmad <Abdalla.Ahmad at sesame.org.jo>
Subject: [EXTERNAL] Re: Using AD plugins on asyn port

 

Hi Abdalla, it is exactly what I need, but it is still unclear how it interfaces with my existing waveform record, i.e. How to pass data from my waveform record to $(P)$(R)ArrayIn. My waveform record already has its INP field set to read input

Hi Abdalla,

 

·          it is exactly what I need, but it is still unclear how it interfaces with my existing waveform record, i.e. How to pass data from my waveform record to $(P)$(R)ArrayIn. My waveform record already has its INP field set to read input from a compress record doing circular buffer at 200 Hz from the hardware.

 

You probably need to use some additional code, for example in Python or SNL.  That code will read from your existing waveform record and write to ArrayIn.  It can also configure the other records in NDDriverStdArrays, and decide when to copy the waveform record.  For example, it may only copy when the waveform record is "full", not on each incremental update.

 

There are examples of Python and IDL code in the NDDriverStdArrays repository.

 

Mark

 


From: Tech-talk <tech-talk-bounces at aps.anl.gov> on behalf of Abdalla Ahmad via Tech-talk <tech-talk at aps.anl.gov>
Sent: Tuesday, July 22, 2025 1:58 AM
To: Pearson, Matthew <
pearsonmr at ornl.gov>; tech-talk at aps.anl.gov <Tech-talk at aps.anl.gov>
Subject: RE: Using AD plugins on asyn port

 

Thanks Matt, it is exactly what I need, but it is still unclear how it interfaces with my existing waveform record, i.e. How to pass data from my waveform record to $(P)$(R)ArrayIn. My waveform record already has its INP field set to read input from a compress record doing circular buffer at 200 Hz from the hardware.

 

Best Regards,

Abdalla Al-Dalleh

Control Engineer

SESAME

 

From: Pearson, Matthew <pearsonmr at ornl.gov>
Sent: Monday, July 21, 2025 5:01 PM
To: Abdalla Ahmad <Abdalla.Ahmad at sesame.org.jo>; tech-talk at aps.anl.gov
Subject: RE: Using AD plugins on asyn port

 

Hi Abdalla,

 

This might be what you need:

https://areadetector.github.io/areaDetector/NDDriverStdArrays/NDDriverStdArraysDoc.html

 

It monitors a waveform record and can turn it into an NDArray, which can then be processed by other areaDetector plugins as needed. It doesn’t connect to the Asyn port that is producing the waveform data directly, but instead sets up a channel access monitor.

 

Cheers,

Matt

 

From: Tech-talk <tech-talk-bounces at aps.anl.gov> On Behalf Of Abdalla Ahmad via Tech-talk
Sent: Monday, July 21, 2025 3:14 AM
To: tech-talk at aps.anl.gov
Subject: [EXTERNAL] Using AD plugins on asyn port

 

Hi Is there a way to apply AD plugins on a waveform record processed from asyn port without rewriting an asynNDArrayDriver class? i. e. , something to be done in the st. cmd maybe? Best Regards, Abdalla Al-Dalleh Control Engineer SESAME ‍ ‍ ‍ ‍ ‍ ‍

 

Hi

 

Is there a way to apply AD plugins on a waveform record processed from asyn port without rewriting an asynNDArrayDriver class? i.e., something to be done in the st.cmd maybe?

 

Best Regards,

Abdalla Al-Dalleh

Control Engineer

SESAME

 

#!../../bin/linux-x86_64/ioc

dbLoadDatabase "dbd/ioc.dbd"
ioc_registerRecordDeviceDriver pdbbase

< iocBoot/ioc/envPaths

epicsEnvSet("PREFIX", "NDSA:")
epicsEnvSet("PORT",   "NDSA")
epicsEnvSet("QSIZE",  "20")
epicsEnvSet("NELEMENTS", 200)
epicsEnvSet("FTVL", "FLOAT")
epicsEnvSet("TYPE", "Float32")
epicsEnvSet("EPICS_DB_INCLUDE_PATH", "$(ADCORE)/db")
dbLoadRecords("db/test.db")

NDDriverStdArraysConfig("$(PORT)", $(QSIZE), 0, 0)
dbLoadRecords("$(NDDRIVERSTDARRAYS)/db/NDDriverStdArrays.template","P=$(PREFIX),R=cam1:,PORT=$(PORT),ADDR=0,TIMEOUT=1,NELEMENTS=$(NELEMENTS),TYPE=$(TYPE),FTVL=$(FTVL)")

# asynSetTraceMask $(PORT) 0 0xFF
# asynSetTraceInfoMask $(PORT) 0 0x7

NDStdArraysConfigure("Image1", 3, 0, "$(PORT)", 0)
dbLoadRecords("NDStdArrays.template", "P=$(PREFIX),R=image1:,PORT=Image1,ADDR=0,TIMEOUT=1,NDARRAY_PORT=$(PORT),TYPE=$(TYPE),FTVL=$(FTVL),NELEMENTS=$(NELEMENTS)")

iocInit

dbpf NDSA:cam1:PoolUsedMem.SCAN Passive
dbpf NDSA:image1:EnableCallbacks 1
dbpf NDSA:image1:ArrayCallbacks 1

======

Core dump with GDB

Core was generated by `./bin/linux-x86_64/ioc iocBoot/ioc/st.cmd'.
Program terminated with signal SIGSEGV, Segmentation fault.
#0  0x00007f33834b2a1d in NDDriverStdArrays::writeXXXArray<float> (pasynUser=<optimized out>, nElements=1, pValue=<optimized out>, this=0x990070) at ../NDDriverStdArrays.cpp:259
259	    for (i=numDimensions-1; i>0; i--) {
[Current thread is 1 (Thread 0x7f33786d4700 (LWP 114206))]

Attachment: nd.db
Description: nd.db

Attachment: nd-gui.png
Description: nd-gui.png


Replies:
Re: Using AD plugins on asyn port Mark Rivers via Tech-talk
References:
Using AD plugins on asyn port Abdalla Ahmad via Tech-talk
RE: Using AD plugins on asyn port Pearson, Matthew via Tech-talk
RE: Using AD plugins on asyn port Abdalla Ahmad via Tech-talk
Re: Using AD plugins on asyn port Mark Rivers via Tech-talk
RE: Using AD plugins on asyn port Pearson, Matthew via Tech-talk
Re: Using AD plugins on asyn port Johnson, Andrew N. via Tech-talk
RE: Using AD plugins on asyn port Mark Rivers via Tech-talk

Navigate by Date:
Prev: RE: Using AD plugins on asyn port Mark Rivers via Tech-talk
Next: Re: Using AD plugins on asyn port Mark Rivers via Tech-talk
Index: 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024  <2025
Navigate by Thread:
Prev: RE: Using AD plugins on asyn port Mark Rivers via Tech-talk
Next: Re: Using AD plugins on asyn port Mark Rivers via Tech-talk
Index: 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  2023  2024  <2025