Avatar

Please consider registering
guest

sp_LogInOut Log In sp_Registration Register

Register | Lost password?
Advanced Search

— Forum Scope —




— Match —





— Forum Options —





Minimum search word length is 3 characters - maximum search word length is 84 characters

sp_Feed Topic RSS sp_TopicIcon
Obtaining Constant Values ​​from Prosys OPC UA Simulation Server.
December 10, 2024
16:00, EET
Avatar
miya2024
Member
Members
Forum Posts: 4
Member Since:
December 9, 2024
sp_UserOfflineSmall Offline

I created the following sample object tree to verify Historical Access using Prosys OPC UA Simulation Server.

Sample::FolderType
└Terminal001::FolderType
└Terminal001.FICS-AW0001::BaseObjectType
├NodeId ns=3;s=Terminal001.FICS-AW0001.PV::BaseDataVariableType①
└NodeId ns=3;s=Terminal001.FICS-AW0002.PV::BaseDataVariableType②

In the Value tab of ①, I set the simulation Value Type to Counter.
In the Value tab of ②, I set the simulation Value Type to Constant (123.0).

The version of Prosys OPC UA Simulation Server I am using is as follows.
Product Version 5.4.6-18
SDK Version 4.10.4.-14

I defined ReadRawModifiedDetails as follows, and used UaClient.historyRead() to get historical data from the Prosys OPC UA Simulation Server.

The following sdk is used:
prosys-opc-ua-sdk-client-5.2.8-159.jar

When I retrieved historical data under these conditions, I was able to retrieve data for ①Terminal001.FICS-AW0001.PV, which had changes in the data, but I was unable to retrieve data for ②Terminal001.FICS-AW0002.PV, which had no changes in the data.

ReadRawModifiedDetails

ReadRawModifiedDetails details = new ReadRawModifiedDetails(false,
startTime,
endTime,
UnsignedInteger.valueOf(200),
true);

HistoryReadResult[] results = client.historyRead(details,
TimestampsToReturn.Source,
false,
nodesToRead);

https://reference.opcfoundation.org/Core/Part11/v104/docs/6.4.3
According to this URL, ReadRawModifiedDetails
“Specifies the details used to perform a “raw” or “modified” history read.”
There is no mention that unchanged data cannot be read.

Is it because the implementation of Prosys OPC UA Simulation Server is such that unchanged data (Constant(123.0)) cannot be read?

Thanks,
Miya

December 11, 2024
10:03, EET
Avatar
Matti Siponen
Moderator
Members

Moderators
Forum Posts: 349
Member Since:
February 11, 2020
sp_UserOfflineSmall Offline

Hello,

Simulation Server version 5.4.6 is already rather old. We would recommend you to update to the newest version, which is 5.5.2.

I’m not certain if Nodes with Constant Simulation support reading history in the version you’re currently using, but I checked that the newest version does support that. Just make sure that the timestamp of the Node with constant value is within the time range specified for reading history and Simulation Server should return that value.

December 11, 2024
15:21, EET
Avatar
miya2024
Member
Members
Forum Posts: 4
Member Since:
December 9, 2024
sp_UserOfflineSmall Offline

Hello Matty,

I am very grateful for your quick response.

Based on your advice,
I changed to Prosys OPC Simulation Server version 5.5.2.
Unfortunately, the phenomenon did not change.

This time I am repeatedly collecting data for Constant Value Parameters every minute.

After further verification, I found that when I changed the Initial Value of Value Parameters in the Value tab of Simulation Server from 123.0 to 123.1,
or changed the Array Size from 0 to 1,
I was able to obtain data only for that one time.

Judging from that situation, I suspect that only data that is constantly changing, such as Value Type being Counter, can be obtained.

The Prosys OPC Simulation Server I use is the Free Edition,
but are there any restrictions such as not being able to obtain data that does not change with the Free Edition?

Thanks,
Miya

December 11, 2024
15:44, EET
Avatar
Matti Siponen
Moderator
Members

Moderators
Forum Posts: 349
Member Since:
February 11, 2020
sp_UserOfflineSmall Offline

Hello,

Can you be more specific on what you mean with “This time I am repeatedly collecting data for Constant Value Parameters every minute”? Are you reading history once every minute? What is the range defined by startTime and endTime for these reads?

The are no limitations in the Free Edition that would change how reading history works for a Node with Constant Simulation.

If the initial Value of the Node with Constant Simulation is not in the range of the history read, it is to be expected that you won’t receive it while reading history for that range. The fact that you get data after you have changed the Value of the Node might suggest that the range of your history read operation just doesn’t typically contain any Values, which is completely normal, if the Value hasn’t changed on the time period covered by the range.

Note, that Constant Simulation is not like other Simulation types that would generate history based on the Simulation parameters. For Nodes with Constant Simulation, history contains only the Values of the Node either set in Simulation Server or written by Clients.

December 12, 2024
3:21, EET
Avatar
miya2024
Member
Members
Forum Posts: 4
Member Since:
December 9, 2024
sp_UserOfflineSmall Offline

Hello Matty,

> Can you be more specific on what you mean with “This time I am repeatedly collecting data for Constant Value Parameters every minute”?
> Are you reading history once every minute?
> What is the range defined by startTime and endTime for these reads?

As you say, the history is read once every minute.
The startTime and endTime are specified for the most recent minute.

I can read 60 pieces of fluctuating data, such as Counter.
I cannot obtain static data, such as Constant (123.0).
When I check with the VSCode debugger, the DataValues are empty, as shown below.

HistoryReadResult@157 “HistoryReadResult [StatusCode=”GOOD (0x00000000) “The operation succeeded.””, ContinuationPoint=”null”, HistoryData=”ExtensionObject [typeId=null, encodeType=null, object=HistoryData [DataValues=”[]”]]”]”

> The are no limitations in the Free Edition that would change how reading history works for a Node with Constant Simulation.

I’ve got it.

> If the initial Value of the Node with Constant Simulation is not in the range of the history read

I don’t understand this part. In this case, does the range mean the time range of the most recent minute?

I’m using ReadRawModifiedDetails and UaClient.historyRead() to obtain historical data, but
can ReadRawModifiedDetails obtain data that has not changed over the last minute?
Is my understanding correct in the first place?

I’m coming to the conclusion that it may not be possible to obtain historical data that has not changed using ReadRawModifiedDetails and UaClient.historyRead().
Am I wrong?

Thanks,
Miya

December 12, 2024
11:43, EET
Avatar
Bjarne Boström
Moderator
Moderators
Forum Posts: 1032
Member Since:
April 3, 2012
sp_UserOfflineSmall Offline

Hi,

The ‘Constant’ value simulation behaves differently than the other signals. The name choice could maybe be better (history-wise ‘Point’ would be more descriptive). All other signals define a function of time, which is then (also) used in HistoryRead to simulate (potentially infinite amounts of) history data for given node (based on the simulation interval). Constant value only has a single datapoint i.e. when that value was given in the UI (or after a restart the time of start). If you change the value for the constant node, then the previous value is stored in a memory-only history buffer (upto 10000 last values). One use-case is that you could potentially use another Client to write values in order to produce more advanced simulations.

Also, seems we might have a bug regarding the “Bounding Values” (https://reference.opcfoundation.org/Core/Part11/v105/docs/4.6) that you set to true in the ReadRawModifiedDetails (the last parameter). Thus, if there are no values in the given range, we return 0 values (when per spec instead we should read e.g. the start bound before the given range as the boundary value, since there was no value for that exact timestamp).

December 13, 2024
13:59, EET
Avatar
miya2024
Member
Members
Forum Posts: 4
Member Since:
December 9, 2024
sp_UserOfflineSmall Offline

Hello Bjarne,

> All other signals define a function of time, which is then (also) used in
> HistoryRead to simulate (potentially infinite amounts of) history data for
> given node (based on the simulation interval).

I’ve got it.

> Constant value only has a single datapoint i.e. when that value was given in
> the UI (or after a restart the time of start).
> If you change the value for the constant node, then the previous value is
> stored in a memory-only history buffer (upto 10000 last values).

I’ve got it.

> One use-case is that you could potentially use another Client to write values
> in order to produce more advanced simulations.

Yes, there is a way to do that.

However, since I only needed to read data that didn’t change,
I set the Value Type on the Value tab to Square, retrieved the trapezoid graph data,
and was able to successfully read the data that didn’t change.

***** ***** ***** ****
* * * * * *
***** ***** *****

Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:13.0000000 GMT (1734089340), 2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:14.0000000 GMT (1734089340), 2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:15.0000000 GMT (1734089340), 2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:16.0000000 GMT (1734089340), -2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:17.0000000 GMT (1734089340), -2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:18.0000000 GMT (1734089340), -2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:19.0000000 GMT (1734089340), -2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:20.0000000 GMT (1734089340), -2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:21.0000000 GMT (1734089340), 2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:22.0000000 GMT (1734089340), 2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:23.0000000 GMT (1734089340), 2.0
Terminal001.FICS-AW0002.PV , GOOD , 12/13/24 11:29:24.0000000 GMT (1734089340), 2.0

I was able to dispel my concerns that ReadRawModifiedDetails and UaClient.historyRead()
might not be able to retrieve unchanged historical data.

> Also, seems we might have a bug regarding the “Bounding Values”
> (https://reference.opcfoundation.org/Core/Part11/v105/docs/4.6) that you set
> to true in the ReadRawModifiedDetails (the last parameter).
>
> Thus, if there are no values in the given range, we return 0 values (when per
> spec instead we should read e.g. the start bound before the given range as
> the boundary value, since there was no value for that exact timestamp).

Understood, thank you for the useful information.

Thank you both.

Thanks,
Miya

Forum Timezone: Europe/Helsinki

Most Users Ever Online: 1919

Currently Online:
37 Guest(s)

Currently Browsing this Page:
1 Guest(s)

Top Posters:

Heikki Tahvanainen: 402

hbrackel: 144

rocket science: 88

pramanj: 86

Francesco Zambon: 83

Ibrahim: 78

Sabari: 62

kapsl: 57

gjevremovic: 49

Xavier: 43

Member Stats:

Guest Posters: 0

Members: 749

Moderators: 7

Admins: 1

Forum Stats:

Groups: 3

Forums: 15

Topics: 1529

Posts: 6471

Newest Members:

misty3446453365, KelsonzFu, Kelsonz, lienbelisario, erick34s63346, Kaitlyntvsl, lonaerskine7, KTP21ideft, Georgecotag, alycerollins59

Moderators: Jouni Aro: 1026, Pyry: 1, Petri: 0, Bjarne Boström: 1032, Jimmy Ni: 26, Matti Siponen: 349, Lusetti: 0

Administrators: admin: 1