-
-
Notifications
You must be signed in to change notification settings - Fork 104
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
Please add a split method, to iterate over subtensors of the given tensor #825
Comments
BTW if you give me a pointer on how to do this I'd be happy to give it a go. |
Yeah split can be used for this. You'd have to clone the tensor since as you state it takes ownership of input. I think no matter what since Tensors currently own their data, we wouldn't be able to create a iterator over subslice references. You could probably create an iterator that uses clone for each subslice though? 🤔 Might be worth sketching out what the API for it would look like using cloning Since the data is stored behind Arc, cloning is very cheap |
You mean I'd be happy with an iter containing owned slices (not references). I'll try to write a function that is semantically what I'm looking for, albeit inefficient. |
Yep And yeah cloning has a very tiny cost since its just cloning the |
I took a stab at |
Nice! I'm interested in your unstack impl, and I hope to try it out soon. I'm actually interested in the opposite of a concatenate operation, eg. (6, 2) -> [(3, 2), (3, 2)], but after reading #43 (comment) I understood that it applies both ways. I could just first reshape (6, 2) -> (2, 3, 2) and then run unstack, getting [(3, 2), (3, 2)]. As a side note, some interesting new archs may require those (or similar) operations. My motivation so far is this candle/chunk operation. |
I've linked a pr because I think I'd need something different from a shape reduction, because some tensors may require to be split into non-equal dimensions over the same axis and still keep other axes the same. Or in other words, the opposite of concat instead of the opposite of stack. |
Please add a method for splitting on a given axis, returning an iterator over subtensors selected in that axis.
For example, suppose
mytensor
is this2x3
tensor:Then
mytensor.split(0)
should return the iterator of length 2 containing tensors[1, 2, 3]
and[4, 5, 6]
, andmytensor.split(1)
should return the iterator of length 3 containing tensors[1, 4]
,[2, 5]
, and[3, 6]
.Note, this is close to what
select
does (IIUC), butselect
consumes its input and so can't be used to construct an iterator like this.Also, if the general case doesn't seem worth it, I'd be happy just having the function
split_0
which would just split on the first axis.Thanks!
The text was updated successfully, but these errors were encountered: