-
Notifications
You must be signed in to change notification settings - Fork 47
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
[PR] Saving Inferred 3D Hand Keypoints #89
base: main
Are you sure you want to change the base?
Conversation
This is because Python errors out when the variable starts with a number.
The concatenation doesn't work fyi. |
I am just now testing the solution. Do you know how to make it work? |
I think this works now @dhingratul I am not aware of the precise mechanism of how these values should be mutated mathematically. but given the description
I think this is how it is supposed to work. specifically this piece of code handles this addition for each of the keypoints: # Iterating over all of the samples in the batch:
for i in range(len(pred_keypoints_3d)):
batch_element_keypoints = pred_keypoints_3d[i]
batch_element_cam_t = pred_cam_t_full[i]
for keypoint_idx in range(len(batch_element_keypoints)):
# Adding the camera translation to the keypoints:
batch_element_keypoints[keypoint_idx] += batch_element_cam_t Some input from @geopavlakos would surely be appreciated. I am also pretty sure that this can be done with some simpler numpy calls, but then the understanding of the dimensionality is lost for me. Apparently this could be: pred_keypoints_3d += pred_cam_t_full[:, np.newaxis, :] But it would be great to get a review from someone. |
I am still getting around this, but did you visualize and check ? |
Didn't have time (or the knowledge), I've stopped at running through debugger and seeing the results as numbers. Shapes matched. I think (2,3) and (2,21,3). So adding an empty axis and elementwise adding the last dimension makes sense? |
Based on the discussion in #88 (comment), I think we need some input from @geopavlakos @dhingratul |
So, i visualized the kps, and something seems off with the translation of the points with this current solution. If/when I find a solution, i can post. Otherwise the keypoints generated seem coherent (except for translation to the original image plane) This works for me (partially): |
@dhingratul, could you please share how you visualized the keypoints please? @Kaszanas, I want to import the keypoints to blender for hand animation. Could you please advise? Thanks! |
Sure thing, you need to load the file using a script with the Blender scripting capabilities somehow:
then you need to load the model somehow as well :D If you figure it out let me know @ManaLight Some steps that you might take:
Note that keypoints are supposedly in the OpenPose order: https://github.com/CMU-Perceptual-Computing-Lab/openpose/blob/master/doc/02_output.md#hand-output-format |
As the name suggests.
There were some unused imports in the
demo.pl
.As described in the issues below this should calculate the 3D keypoints and save them with
np.save
.Related:
If you can verify and see if this is the solution for the issues above @geopavlakos.