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

[Feature Request] Generate Conv3D results on another set of coordinates? #309

Closed
1 task done
Tortoise0Knight opened this issue Jun 5, 2024 · 10 comments
Closed
1 task done

Comments

@Tortoise0Knight
Copy link

Tortoise0Knight commented Jun 5, 2024

Is there an existing issue for this?

  • I have searched the existing issues

Current Behavior

Does TorchSparse support generate Conv3D() results on another set of coordinates? Which means calling forward(input, coords), and the output is a sparse tensor with the same coordinates as coords, but the features are computed with corresponding features on input.

@Tortoise0Knight Tortoise0Knight changed the title [BUG] Generate Conv3D results on another set of coordinates? [feature] Generate Conv3D results on another set of coordinates? Jun 5, 2024
@Tortoise0Knight Tortoise0Knight changed the title [feature] Generate Conv3D results on another set of coordinates? [Feature Request] Generate Conv3D results on another set of coordinates? Jun 5, 2024
@francotheengineer
Copy link

I recommend doing this:

x_A = torchsparse.SparseTensor(feats=feats, coords=coords_A)
x_B = torchsparse.SparseTensor(feats=feats, coords=coords_B)
my_conv_layer = nn.conv(...)
y = my_conv_layer(x_A)
y.C = x_B.C

@Tortoise0Knight
Copy link
Author

I recommend doing this:

x_A = torchsparse.SparseTensor(feats=feats, coords=coords_A)
x_B = torchsparse.SparseTensor(feats=feats, coords=coords_B)
my_conv_layer = nn.conv(...)
y = my_conv_layer(x_A)
y.C = x_B.C

Thank you for answering. But maybe I havn't describe my problem clearly enough.
In my case, for each coordinates $C_B^i$ in x_B, I need to find correspoinding points in x_A within the kernel size and centerd in $C_B^i$. Then use their feats to compute with kernel, and the results stored in $F_B^i$. Is this possible?
You code seems to simply change the coordinates of the result on x_A though.

@francotheengineer
Copy link

I recommend doing this:

x_A = torchsparse.SparseTensor(feats=feats, coords=coords_A)
x_B = torchsparse.SparseTensor(feats=feats, coords=coords_B)
my_conv_layer = nn.conv(...)
y = my_conv_layer(x_A)
y.C = x_B.C

Thank you for answering. But maybe I havn't describe my problem clearly enough. In my case, for each coordinates C B i in x_B, I need to find correspoinding points in x_A within the kernel size and centerd in C B i . Then use their feats to compute with kernel, and the results stored in F B i . Is this possible? You code seems to simply change the coordinates of the result on x_A though.

Is x_A.C == x_B.C ?

@Tortoise0Knight
Copy link
Author

I recommend doing this:

x_A = torchsparse.SparseTensor(feats=feats, coords=coords_A)
x_B = torchsparse.SparseTensor(feats=feats, coords=coords_B)
my_conv_layer = nn.conv(...)
y = my_conv_layer(x_A)
y.C = x_B.C

Thank you for answering. But maybe I havn't describe my problem clearly enough. In my case, for each coordinates C B i in x_B, I need to find correspoinding points in x_A within the kernel size and centerd in C B i . Then use their feats to compute with kernel, and the results stored in F B i . Is this possible? You code seems to simply change the coordinates of the result on x_A though.

Is x_A.C == x_B.C ?

No. They are different coordinates. The purpose of this operation is to transfer the attributes of A to another sets of coordinates B.

@francotheengineer
Copy link

@Tortoise0Knight Ok I think this might help?

x_A = torchsparse.SparseTensor(feats=feats, coords=coords_A)
my_conv_layer = nn.conv(...)
y = my_conv_layer(x_A)

#  Apply the attributes of arbitrary tensors y, onto a tensor with coords_B.
X_B = torchsparse.SparseTensor(feats=y.F, coords=coords_B)

@Tortoise0Knight
Copy link
Author

@Tortoise0Knight Ok I think this might help?

x_A = torchsparse.SparseTensor(feats=feats, coords=coords_A)
my_conv_layer = nn.conv(...)
y = my_conv_layer(x_A)

#  Apply the attributes of arbitrary tensors y, onto a tensor with coords_B.
X_B = torchsparse.SparseTensor(feats=y.F, coords=coords_B)

Sorry. I think your solution is still not what I want. E.g. the y.F possibly not have the same number of points to coords_B. In that case, we can not create the result tensor.
I think this problem needs implementation from the Engine, not user code. For example, https://nvidia.github.io/MinkowskiEngine/convolution.html#MinkowskiEngine.MinkowskiConvolution.forward

@francotheengineer
Copy link

@Tortoise0Knight I don't understand how you can apply features to a difference number of points. Each point needs to have a feature. Is there another library function that does this?

@lverret
Copy link

lverret commented Aug 21, 2024

I think this request refers to the ability to apply a convolution to points that are different from the points of the features.
As far as I understand, torchsparse only supports applying convolutions centered at a set of points x_A using features at x_A (f_A) (red).
But one might be interested in sparse convolutions centered at other points x_B but still using f_A (blue), creating new features for those points:

spcnn

I don't know if other libraries do this.

@Tortoise0Knight
Copy link
Author

I think this request refers to the ability to apply a convolution to points that are different from the points of the features. As far as I understand, torchsparse only supports applying convolutions centered at a set of points x_A using features at x_A (f_A) (red). But one might be interested in sparse convolutions centered at other points x_B but still using f_A (blue), creating new features for those points:

spcnn

I don't know if other libraries do this.

Thank you for clear explanation of what I mean. Minkowski Engine actually can do this. In calling https://nvidia.github.io/MinkowskiEngine/convolution.html#MinkowskiEngine.MinkowskiConvolution.forward, you can give coordinates. If not given, the coordinates of input is used (this is the most common case).

The ability to apply convolution on differents sets of coordinates is very useful. It can be used as a NN replacement for traditional feature extraction like KNN, as I tested on Minkowski Engine.

@francotheengineer
Copy link

@Tortoise0Knight

Thanks for detailing this. I recommend you do some MinkowskiEngine layer, inside your TorchSparse model. You will have to swap between MinkowskiEngine sparse tensors and TorchSparse sparse tensor, but it will work. I've done this before and the speed is pretty good.

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

4 participants