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

Complex numbers #67

Open
fleimgruber opened this issue Oct 17, 2024 · 7 comments
Open

Complex numbers #67

fleimgruber opened this issue Oct 17, 2024 · 7 comments

Comments

@fleimgruber
Copy link
Contributor

For a channel with these settings (from DEWE GUI):

Name: U_1p_per (Complex)
Description: -
Unit: V
ID: PP1 (Power analysis)
Sampling: Asynchronous
Rate: 1043.6 Hz
Expected rate: 1000.0 Hz
Data structure: Scalar
Data type: Complex (single)

dwdatareader is not able to find a matching key in the dewe_file. Are complex numbers supported?

@fleimgruber
Copy link
Contributor Author

fleimgruber commented Oct 17, 2024

I searched in the official DWDataReader C library and found struct DWComplex in one of the header files. Will look into it.

edit: It seems that the DWDataReader C lib defines a parallel API for complex numbers, e.g. DWGetChannelList -> DWGetComplexChannelList. @costerwi Do you want to have a 2x API surface area increase in dwdatareader? Do you have another idea how complex numbers could be handled with the existing public dwdatareader API? I am interested in adding this feature.

@costerwi
Copy link
Owner

costerwi commented Nov 2, 2024

Sorry for the delay! Do you have an idea to return complex data when it is available?

@fleimgruber
Copy link
Contributor Author

Never mind!

As mentioned in #67 (comment) I see two main approaches:

  1. Add a mirrored API for complex numbers (following the C lib API).
  2. Find a way to add complex numbers to the existing API.

I expect approach 1 to be straight forward, but at the cost of maintaining and exposing more APIs to the users. Approach 2 does not have these downsides, but I am not sure about the best way to check for and integrate complex numbers with the current implementation, e.g. at https://github.com/costerwi/dwdatareader/blob/master/dwdatareader/__init__.py#L394. I have not yet looked into the C lib behavior either. So I guess we should agree on one of the mentioned approaches and I would then go ahead and experiment with it a bit in a PR.

@costerwi
Copy link
Owner

costerwi commented Nov 3, 2024

Yes, I agree that approach 2 would be more convenient for everyone.

@fleimgruber
Copy link
Contributor Author

Thanks for confirming. So next question then would be: how are users expected to refer to channels with complex type? This might depend on complex channel naming in the DEWE file. I have the feeling that users will need to somehow specify "complex" somewhere regardless for it to work.

@costerwi
Copy link
Owner

costerwi commented Nov 3, 2024

Do you have a small example file you can attach? I haven't looked but maybe the complex channels are just the imaginary component of a corresponding real channel of the same name. Python should be able to combine both components when they are available.

@fleimgruber
Copy link
Contributor Author

Just to close the communication loop: I plan to provide an example file and an approach for access (following 1. from #67 (comment)) that I implemented locally.

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

2 participants