-
Notifications
You must be signed in to change notification settings - Fork 546
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
Multiple mistakes appeared in the code while I was trying to refactor it and enforce type checking. Can someone just answer those questions? #337
Comments
Thanks @Sharcoux we'll take a look at this soon! |
I really appreciate you running the lint and investigating these. Most of them seem to be Kalman filter code so I wonder if @xanderkoo would take a look. #4 and #6 are perplexing, and I'll look into them more. #7 is probably old code that was meant for the offline video analysis. |
Hi there. @jeffhuang we came to understand the www part. We're finishing testing all the changes and fixing all potential errors. |
Fantastic, thank you so much! If you could scope down the PR to individual fixing, that would be much appreciated. It's harder for us to review lengthier PRs as we'd have to test each fix separately. |
Ok, we finished fixing everything. We had trouble fixing the webpack bundle but solved it easily with vite that is much faster for building anyway and is probably going to be the future of webpack. About doing individual fixes, it's a bit hard. We didn't implement new features that we could separate from the rest. We just removed duplicated code, add typing and modern code style, and the rest of the evolutions were just consequences of these changes. When the types didn't match, we noticed some errors that we fixed. The original code was also using mjs files, but not importing them as module, but polluting the global environment with a "webgazer" variable instead, which is generally considered a bad practice. Our next steps will be to simplify the API for users of the lib. I find the current version a bit harsh to use for newcomers. |
I am trying to use the webgazer.setStaticVideo api, and encounter the #7 problem. This works in tag 2.0.0, for developers have naming convention problems, and use "videoStream" as both a global variable and the input of function "async function init(videoStream)", that caused the problems in following updates. @jeffhuang you guys may fix this. |
If you want to try, I did a major refacto on my pull request #345 I wanted to go yet a bit further because I think that the data structure for clicks and move is confusing. Having those multiple arrays make it hard to understand the relationship between the data. I also realized that we could probably train a model to get better results. I was gonna do that but ran out of free time. |
I will tell you after I try, Thank you guys. |
Well seems the #7 wrong data type problem not solved. I used a virtual OBS camera to send video stream to normal api instead of using setStaticVideo. Anyway thanks for the response. You may consider write a demo about using "setStaticVideo " later? |
I'm not sure about your exact problem, but the api has changed and you can send the video stream as parameter of the start function. Did that not work? |
Ok, here are the list of problems I noticed in the code:
I'm trying to solve all of that, but I need some help with the following issues I'm not sure about how to solve:
1st problem
WebGazer/src/worker_scripts/util.js
Line 389 in d309e07
y[i] = [y[i]]
: this will transform anumber[][]
array into a number[][][] array. I would be surprised if that was intentional, provided the comment above. My guess is that the intended code was:2nd problem
WebGazer/src/worker_scripts/util.js
Line 381 in d309e07
z
is supposed to be of typenumber[]
while thesub
method expects a parameter of typenumber[][]
. In another file, I noticed the exact same code with that single difference: there was that extra line before:I guess that this is the correct version?
3rd problem
WebGazer/src/util_regression.mjs
Line 157 in d309e07
mCoefficients[i] = solution[i]
:mCoefficients
is of typenumber[]
butsolution
is of typenumber[][]
. I have no idea how this is supposed to be solved. Should I just takesolution[i][i]
?4th problem
WebGazer/src/util_regression.mjs
Line 151 in d309e07
if (mCoefficients.length * n !== mCoefficients.length)
: This can only be true ifn === 1
. Is it what we want to test instead?Anyway, the line above that define the value of
n
is completely stupid:const n = (mCoefficients.length !== 0 ? mCoefficients.length / mCoefficients.length : 0)
This is equivalent to
mCoefficients.length ? 1 : 0
. In short, those 2 lines could be simplified withif(mCoefficients.length)
. However, there is absolutely no relation with Array length being a multiple of m...5th problem
WebGazer/src/util_regression.mjs
Line 50 in d309e07
H
is being declared twice. Which one is the correct value?6th problem
WebGazer/src/index.mjs
Line 311 in d309e07
d
is of type string. This will lead to really problematic consequences in theget
andgetTrueIndex
methods7th problem
WebGazer/src/index.mjs
Line 639 in d309e07
debugVideoLoc
has to be a MediaStream, because we callgetTracks()
on it. But it is a string, here...The text was updated successfully, but these errors were encountered: