Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Frequency out of range when the format is floating point. #29

Closed
JiaxuanHan-UoS opened this issue Sep 14, 2020 · 7 comments
Closed

Frequency out of range when the format is floating point. #29

JiaxuanHan-UoS opened this issue Sep 14, 2020 · 7 comments

Comments

@JiaxuanHan-UoS
Copy link

Firstly, I set the format of phasors and frequency as integer. Everything is fine and I keep receiving messages about dataframe were received successfully.

When the format of frequency were changed to floating point. The error messages were shown below:
image

According to the suggestions of Steven, I removed exception catching and find the error location is the range filter of frequency. Row 2143 in frame.py.
image

However, I checked the received data with PMU connection tester, and the received FREQ is within the given range(49.9288Hz).
image

Thanks for all discussion!

@poledna
Copy link

poledna commented Sep 14, 2020

I also had the same issue a while back, and my "solution" was to comment out line 2144 and 2145
in master

pypmu/synchrophasor/frame.py

Lines 2144 to 2145 in 66e6c49

if not -32.767 <= freq <= 32.767:
raise ValueError("FREQ must be in range -32.767 <= FREQ <= 32.767.")

Not a pretty solution, but it solved for me. As freq is a number bypassing the if should solve the issue.

in the branch udp-support-v0.1 there is already the commented version, but if you're using TCP i'd suggest keeping with master as it is more up to date with community issues.

pypmu/synchrophasor/frame.py

Lines 2143 to 2145 in 22b6064

if data_format[3]: # FREQ/DFREQ floating point
#raise ValueError("FREQ must be in range -32.767 <= FREQ <= 32.767.")
freq = unpack("!I", pack("!f", float(freq)))[0]

@JiaxuanHan-UoS
Copy link
Author

JiaxuanHan-UoS commented Sep 16, 2020

@poledna
Hi poledna,
I tried your method and received the data frames. But I am pretty sure that my data is incorrect, the frequency is always floating between 50.5Hz. These are the curves of the actual frequency and the decoded frequency.
image

image

And the table in Mysql could also prove this.
image

So did you received the correct data?

@sstevan
Copy link
Contributor

sstevan commented Sep 16, 2020

Hey @JiaxuanHan-UoS,

Would you mind sharing your configuration frame with us?

Also, there is a known issue with FREQ unpacking caused by my misinterpretation as stated here #4
Please try to switch to the bugfix branch and let us know if you are still having these issues.

@JiaxuanHan-UoS
Copy link
Author

@sstevan

Hi Stevan,

I just read issue4 and find there could be some misunderstanding about FREQ definition. If the format of FREQ is integer, the 2-byte string represents deviation and requires the nominal frequency defined in CONFIG-2 to determine the actual frequency. However, if the FREQ is float, the 4-byte string is long enough to represent the accurate value and don't need the nominal frequency in CONFIG-2 to calculate the result.
image
In the above picture, red part means the FREQ in float format (and blue for DFREQ). If we transfer it from hex to decimal:
image
The result is exactly 50.168

@sstevan
Copy link
Contributor

sstevan commented Sep 16, 2020

That is correct. That issue has been already fixed on bugfix branch.
Have you checked the ConfigurationFrame?

If you are using tinyPDC this line will ask for ConfigurationFrame in order to unpack the values:

config = pdc.get_config() # Get configuration from PMU

Please double check your FORMAT field in configuration frame, should look like this:

Data format in data frames, 16-bit flag.
Bits 15–4: Unused
Bit 3: 0 = FREQ/DFREQ 16-bit integer, 1 = floating point
Bit 2: 0 = analogs 16-bit integer, 1 = floating point
Bit 1: 0 = phasors 16-bit integer, 1 = floating point
Bit 0: 0 = phasor real and imaginary (rectangular), 1 = magnitude and angle (polar)

So you should have Bit 3 = 1.

@JiaxuanHan-UoS
Copy link
Author

@sstevan
image
Yes, this is the ConfigurationFrame of my PMU. The format is 0x0009, bit 3 and bit 0 = 1.
image
Just the same with the openPDC configuration.

@JiaxuanHan-UoS
Copy link
Author

JiaxuanHan-UoS commented Sep 16, 2020

Thanks, the problem has been solved after using bug-fix v1.0.1 frame.py scripts

@sstevan sstevan closed this as completed Sep 17, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants