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

Track All Changes from upstream #45

Open
wants to merge 52 commits into
base: origin
Choose a base branch
from
Open

Track All Changes from upstream #45

wants to merge 52 commits into from

Conversation

MarisaKirisame
Copy link
Collaborator

this is from pytorch commit 1546d2a.

MarisaKirisame and others added 30 commits March 6, 2020 11:57
Implements CheckpointTensor backend
* save

* save

* review

* review

* add back files
* save

* save

* review

* remove outdated file

* save

* can compile again

* save

* save

* up up array

* finsih the overloads

* replace vec[n] with vec.at(n)
* commit

* add more overloads

* fix log

* save
* save

* save

* save

* save

* use release instead of free
Add operator overloads for U-Net
Restore overloads needed for LSTM and GRU
* save

* save

* save
Various overloads for the ACT model
Overloads and changes needed for transformer
Add overloads for Deepspeech and more for ACT
save before change

save before change

add aliaspool design, and add weak/strong pointer discussion

add more code

rebase

add allocator hook

save metadata to prepare for eviction

save

refactor: move log to a seprate file

add file

raii

save

save comment

save

save

save

save

find error, bisecting code

save

save

address review comment

address comment

address comment

fix segfault

save

save

pin

save

save

save

save

save
Tensor slice_backward(const Tensor& grad, IntArrayRef input_sizes, int64_t dim, int64_t start, int64_t end, int64_t step) {
auto grad_input = at::zeros(input_sizes, grad.options());
grad_input.slice(dim, start, end, step).copy_(grad);
return grad_input;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you know what's going on here? Did you just move these from the manual variable type definitions here? If so, we might be able to just directly upstream these hunks.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That is indeed true. It was manual and so I cant overload them. I exposed them to the functions.yaml file for overloading purpose.


namespace at { namespace native {

Tensor checkpoint_add(const Tensor& a, const Tensor& b, c10::Scalar c) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oh boy, was this all written by hand? Hopefully backend fallback can turn this into a 20 line file.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

great news! everytime we need a new operator, we have to edit the yaml files, then wait one hour for recompilation. writing them by hands isnt the bottleneck in comparison...
how does backend fallback deal with mutation though? we have special treatmenet for mutation.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Backend fallback would get the name of the operator in question, so I guess you could check if it is an inplace op or not and do something different in that case.

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

Successfully merging this pull request may close these issues.

5 participants