-
Notifications
You must be signed in to change notification settings - Fork 142
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
WIP [Fix,Enh]: Enable control over fitting window size and time between fits #892
base: main
Are you sure you want to change the base?
Conversation
Codecov Report
@@ Coverage Diff @@
## main #892 +/- ##
==========================================
+ Coverage 30.20% 36.22% +6.02%
==========================================
Files 452 199 -253
Lines 39208 11811 -27397
==========================================
- Hits 11841 4279 -7562
+ Misses 27367 7532 -19835
|
This is very good. It is nice to verify with numbers this we've been going through. In the past we've tried to solve this problem in many different ways. One of the most promising ways was to try to tackle your last point with a new approach. But that will also bring more delays, etc... so: the stage of development of the whole feature is more or less clear. I would suggest to think at which point you want the functionality to be shipped, and we'll go from there. If it is, "as is", well ok. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is a few things in the code which I'd comment on, just to try to help you improve your coding skills if you're interested, let me know. Otherwise I see no problem.
You are more than welcome to leave some comments :) |
I guess this might be something we could discuss tomorrow in a bit more detail. |
Some new insides on that matter: This seem to be a problem.
I'm not quite sure yet how it works, but this potentially leaves an empty part of matDataMerged, since it is not necessarily filled until the end. |
Not sure. |
I agree with you, this does not seem to be an issue. I created a little toy example with the same merging algorithm as in the plugin and played around with a sine of 100 samples and different window sizes. It seems to work very nice, also for different iterations. The example can be found here RDoerfel@a9b3ae4 Following are some of the results. So it does not look like there are any chunks left out. The vertical line indicates the end of the vector. Also after multiple repetitions, it looks still good. Here are configurations I tested. One Sine has 100 samples, so all the results are basically as expected. I repeated the for loop with the merging stuff for 5 times to see if on a later stage things go wrong, but everything looks good.
|
I think I did exactly the same thing as you did.... :)
…--
Juan
On Mon, Apr 18, 2022 at 7:58 AM Ruben Dörfel ***@***.***> wrote:
Not sure. I remember going to that specific part of the code. I was
suspicious that under specific window lengths, some data could've been
padded with zeros at the beginning or at the end. I did try to investigate
if this was the case and it all seemed to work. Being all eigen structs is
a bit of a double edge sword. They are well tested and solid, but perhaps
we're not using them correctly. I think I discussed this problems with
@LorenzE <https://github.com/LorenzE>, and for sure with @gabrielbmotta
<https://github.com/gabrielbmotta>. In the end it seemed to work. I can't
remember the tests I made, or how deep they were. Maybe you find something
that I missed.
I agree with you, does not seem to be an issue. I created a little toy
example with the same merging algorithm as in the plugin and played around
with a sine of 100 samples and different window sizes. It seems to work
very nice, also for different iterations. The example can be found [here](
***@***.***
<RDoerfel@a9b3ae4>
Here are some of the results. So it does not look like there are any
chunks left out. (The vertical line indicates the end of the vector.) Also
after multiple repetitions it looks still good.
[image: Figure_1]
<https://user-images.githubusercontent.com/40984141/163804912-d3098597-27fc-4bb2-bfa8-0299f7f5227d.png>
—
Reply to this email directly, view it on GitHub
<#892 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ACEKMIDDCXFVQ7OZKMGOPETVFVE7BANCNFSM5P773RGA>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
Great! So it is verified from two independent sites :) |
Here is a screenshot of what I was thinking. You can now set the window size (could discuss if we want to ditch it), and the time between fits. The time between fits is not super accurate since it is time between fits + time one fit needs. However, it is still around this time and allows to set slower fitting periods. The time between fits is limited by the window size. The time between fits is currently counted using the size of data poping from the buffer. Potantially, one could use QElapsedTimer to have accurate timing. However, this might introduce some other issues, and I'm not sure if it should be used that way. What do you think @juangpc @gabrielbmotta? Could this improve the fitting on a Pi? |
I'd leave it. Since it is in a menu inside the settings, I don't think it hurts to have it right now. |
This PR addresses issue #891. So far, I was not able to reproduce the issue using the FiffSimulator. Also investigated the influence of window size on error and gof and could not find any indication for the observed behavior. See comments for results of the mentioned investigation.
This PR closes #891.