- 
                Notifications
    You must be signed in to change notification settings 
- Fork 23
Network solvers redesign #242
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
Changes from 29 commits
eef7d0f
              b15d045
              3edcc3d
              8930d80
              9235349
              d70bf03
              c081dfb
              e5047fc
              3f7442f
              8ef353f
              7391c0c
              735fa7e
              1d1dbc0
              b918731
              8928162
              0a4db77
              9abc732
              7719cc2
              751902c
              ddafd9f
              31a86d3
              3882692
              ad874a5
              4a5f686
              ba9c1ef
              33d037a
              80cb696
              558f326
              fc5c4e8
              a5247f4
              c79e834
              72c87cc
              97e7c06
              96cb182
              9c67d05
              1a20572
              287f0b4
              c5e3949
              7e76c6e
              b47ed54
              32626ef
              999206b
              f75d122
              f750ac1
              5628922
              2452869
              53e037e
              8857687
              66da1e2
              File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,32 @@ | ||
|  | ||
| # | ||
| # TupleRegionIterator | ||
| # | ||
| # Adapts outputs to be (region, region_kwargs) tuples | ||
| # | ||
| # More generic design? maybe just assuming RegionIterator | ||
| # or its outputs implement some interface function that | ||
| # generates each tuple? | ||
| # | ||
|  | ||
| mutable struct TupleRegionIterator{RegionIter} | ||
|          | ||
| region_iterator::RegionIter | ||
| end | ||
|  | ||
| region_iterator(T::TupleRegionIterator) = T.region_iterator | ||
|  | ||
| function Base.iterate(T::TupleRegionIterator, which=1) | ||
| state = iterate(region_iterator(T), which) | ||
| isnothing(state) && return nothing | ||
| (current_region, region_kwargs) = current_region_plan(region_iterator(T)) | ||
| return (current_region, region_kwargs), last(state) | ||
| end | ||
|  | ||
| """ | ||
| region_tuples(R::RegionIterator) | ||
|  | ||
| The `region_tuples` adapter converts a RegionIterator into an | ||
| iterator which outputs a tuple of the form (current_region, current_region_kwargs) | ||
| at each step. | ||
| """ | ||
| region_tuples(R::RegionIterator) = TupleRegionIterator(R) | ||
| Original file line number | Diff line number | Diff line change | ||||
|---|---|---|---|---|---|---|
| @@ -0,0 +1,16 @@ | ||||||
|  | ||||||
| function align_indices(tn) | ||||||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 
        Suggested change
       
 since in general ITensor indices are referred to as  | ||||||
| si = siteinds(tn) | ||||||
| ptn = copy(tn) | ||||||
| for v in vertices(tn) | ||||||
| is = inds(tn[v]) | ||||||
| ls = setdiff(is, si[v]) | ||||||
| isempty(ls) && continue | ||||||
| new_is = [first(ls), si[v]...] | ||||||
| if length(ls) >= 2 | ||||||
| new_is = vcat(new_is, ls[2:end]) | ||||||
| end | ||||||
| ptn[v] = permute(tn[v], new_is) | ||||||
| end | ||||||
| return ptn | ||||||
| end | ||||||
This file was deleted.
This file was deleted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A similar change to the function
function ITensors.apply( o, ψ::VidalITensorNetwork; ...)lower down (lime 322) will be necessary to avoid ambiguity and the current failing test.