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

3D keyjoints coordinate obatain #6

Open
Brian417-cup opened this issue Oct 25, 2022 · 9 comments
Open

3D keyjoints coordinate obatain #6

Brian417-cup opened this issue Oct 25, 2022 · 9 comments

Comments

@Brian417-cup
Copy link

Hey, I want to know how I can change your code and let them merely obtain 3D coordinates of keyjoints from dogs.

@benjiebob
Copy link
Owner

Hi Brian, thanks for your question. The 3D coordinates for a set of joints are accessible on this line: https://github.com/benjiebob/WLDO/blob/master/wldo_regressor/model.py#L97

These are filtered from the full set returned by SMAL which you can see here: https://github.com/benjiebob/WLDO/blob/master/global_utils/smal_model/smal_torch.py#L188

@Brian417-cup
Copy link
Author

Ok, thanks for your excellent answer! Now, I have obtained the 3D coordinates for a set of joints and visualized them with the code demonstrated in the below picture. However, I wonder whether the three-dimensional coordinates here are those in world space. At the same time, I notice that there are three parameters here about "preds['camera']", I want to know exactly the meaning of these three parameters. I think maybe the meanings of these camera parameters can let me better understand the process of projecting 3D coordinates to 2D key points in the picture.
3d visualization

@mzc421
Copy link

mzc421 commented Nov 10, 2022

1、All the key points I get are zero? Why?
2、I didn't understand how to get a 3D graph. I converted the data in joint3d into a 3D graph. Viewing on meshlab is just a point, not a graph. I'm a novice

@benjiebob
Copy link
Owner

benjiebob commented Nov 10, 2022

@Brian417-cup - you can check how to project the 3D points into the image here.

The network predicts (x, y) translations in the camera frame and depth z. They are applied to the SMAL model like this

The network also obtains the camera focal length as: f = 2700 + 2700 q where q is predicted by the network. It's defined here and applied to the projection function here.

Our paper follows the same parameterization here as 3D-Safari.

@benjiebob
Copy link
Owner

benjiebob commented Nov 10, 2022

@mzc421 - I might need a few extra details to help you debug this.

  1. Please can you try and run the WLDO code on our data (e.g. StanfordExtra). Then check the value of labelled_joints_3d when it is set on this line. This should definitely be non-zero.

  2. Are you trying to view the full animal mesh in Meshlab or just the joints? If you want the mesh, you could use a library like Trimesh to load the vertices and faces (triangles). You can then export, for example as a ply, and load this in MeshLab. For a worked example of exporting SMAL to PLY with Trimesh you can check the SMALify repository.

@mzc421
Copy link

mzc421 commented Nov 10, 2022

View the complete animal grid in Meshlab

@benjiebob
Copy link
Owner

benjiebob commented Nov 10, 2022

image

Are you hoping to see an output such as the blue model as shown in this image? If so, then I think you want to export the mesh to a ply file. My instructions in 2. can help you do that.

@mzc421
Copy link

mzc421 commented Nov 10, 2022

ok,thanks

@mzc421
Copy link

mzc421 commented Nov 10, 2022

The previous problems have been solved. I wonder if the model has saved the animal hair information (texture information) to make it look not single but colorful.Like the picture below:
image

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