Jump to content

Recommended Posts

Posted

Hi all,

I'm starting using the DSC module, and since it has it's own shared variable data type, I'm forced to use DataSockets for reading and writing data.

So, the DataSocket Read function has a "connection in" interface. This can take (among other things) connection reference from DataSocket Open function, or a DSC Shared Variable wire.

If I use the latter, is the connection closed implicitly, or what? And if this implies Open/Read/Close how much overhead do Open and Close this bring?

Thanks for any insight.

Br, Mike

Posted
If I use the latter, is the connection closed implicitly, or what? And if this implies Open/Read/Close how much overhead do Open and Close this bring?

I haven't used it for a while - but if I remember correctly after the first read/write, it's a pretty similar speed.

Should be pretty easy to test tho.

Posted

Thanks. I gather from your reply, that the connection is closed. You don't get any connections that are permanently open from using calling the Read/Write just once?

Br, Mike

Posted

I'm starting using the DSC module, and since it has it's own shared variable data type, I'm forced to use DataSockets for reading and writing data.

?

I'm not sure what you mean by this. Can you clarify?

Posted

DSC module uses totally different Shared Variable type than LabVIEW base. So, if you want to use functions for monitoring SV value changes, you cannot use LV base functions like "Read Variable" on the same variables. But you can use the DataSocket functions like "DataSocket Read".

Posted

DSC module uses totally different Shared Variable type than LabVIEW base. So, if you want to use functions for monitoring SV value changes, you cannot use LV base functions like "Read Variable" on the same variables. But you can use the DataSocket functions like "DataSocket Read".

I am not sure if that entirely true - you should be able to convert one datatype to another e.g. using a transitionary string and making sure the URLs are correct (as they are different).

Posted

DSC module uses totally different Shared Variable type than LabVIEW base. So, if you want to use functions for monitoring SV value changes, you cannot use LV base functions like "Read Variable" on the same variables. But you can use the DataSocket functions like "DataSocket Read".

This isn't correct. We use functions (actually through the Shared Variable API now) to read and write shared variables, and yes, we use the DSC Module. I'd comment more but I'm not even sure what you are saying.

In any event, I recommend that you use the Shared Variable API functions (available in the more recent versions of LabVIEW), not the DataSocket functions, to read and write shared variables. The performance of the DataSocket functions is not as good as that of the methods available with the Shared Variable API (we've tested them ourselves) and I think it's awkward at best to use the DataSocket API to talk to something that isn't (at least expressly) DataSocket communication. (Yes, the DataSocket API can work with shared variables, but again, why use it?)

Paul

Posted

The Shared Variable API is a bit more polished IHMO and recommend using it over DS as well - better error information etc... Although for reasons that escape me, I have used DS over SV-API for particular use cases in the past.

Posted

But you can set data value monitors only on the DSC shared variable types. So, what you're saying is that it is best to use both, each for its own purpose?

Br, Mike

Posted

But you can set data value monitors only on the DSC shared variable types.

Sorry, I still don't know what you are saying. Do you mean setting alarms? Shared variable binding?

Generally, the DSC Module adds some functionality (e.g., alarms, logging, security) to the shared variable.

Posted

I sorry, I was using EPICS terminology. This is what I mean:

Oh, I see! Yes, as jgcode suggested, you can convert the URLs from one form to the other for use with the different APIs. (You can use the string form and do the conversion.)

In practice, we use each of these where we need them (with the respective APIs). At present we only use the top one for shared variable value change notifications. We haven't encountered any issues with this approach.

Paul

Posted

Network Shared Variables do work with DSC Value Changed Events. Your code snippet shows only single process SV's maybe that is the problem.

Posted

sachsm: I've set the Variable class to almost everything possible, and still the picture looks like this:

post-17162-0-59514200-1331110990.png

Br, Mike

Posted

Ok, I looked at some of my code and it seems that I did use the DSC BV Tag URL to register my network shared variable events.

So you maybe correct that you cannot directly feed in a LV SV URL. But functionally, the BV tag URL can point to any conventional SV type.

post-162-0-21827700-1331129680.png

post-162-0-84977900-1331129680_thumb.png

Also noticed that if I use a LV SV URL and convert it to a string then it seems to work also...

post-162-0-01117000-1331132366_thumb.png

Posted

Also noticed that if I use a LV SV URL and convert it to a string then it seems to work also...

post-162-0-01117000-1331132366_thumb.png

Thanks, I didn't notice this. It will be most useful.

Br, Miha

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.