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

Make certain delta contractions return views of the original ITensor storage #570

Open
mtfishman opened this issue Feb 3, 2021 · 2 comments
Assignees
Labels
performance Issues related to performance
Milestone

Comments

@mtfishman
Copy link
Member

Right now, delta contractions like randomITensor(i, j) * delta() and randomITensor(i, j) * delta(dag(j), j') make copies of the ITensor. However, we've decided that they should avoid copying the ITensor storage, so should return views to the tensor storage (like doing replaceinds). This would technically be breaking so we'll do it for the v0.2 release.

@mtfishman mtfishman added the performance Issues related to performance label Feb 3, 2021
@mtfishman mtfishman added this to the v0.2 milestone Feb 3, 2021
@mtfishman mtfishman self-assigned this Feb 3, 2021
@mtfishman
Copy link
Member Author

Also see discussion in PR #569.

@mtfishman
Copy link
Member Author

mtfishman commented Apr 6, 2021

Also see issue #618 for a proposal on how to do this in a way that is not too confusing in terms of floating point operations and the view behavior. So in that proposal, the current behavior of delta would remain, and a A * delta(One()) could be a non-copying contraction of A.

@emstoudenmire emstoudenmire mentioned this issue Apr 28, 2021
7 tasks
@mtfishman mtfishman modified the milestones: v0.2, v0.3 Apr 28, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
performance Issues related to performance
Projects
None yet
Development

No branches or pull requests

1 participant