Commit ae02ae0
Support hyperedges in TensorCircuit using cotengra.
This change introduces compatibility for hyperedges (represented by CopyNodes in TensorNetwork) when using the cotengra contractor.
It processes the tensor network graph to merge edges connected via CopyNodes into hyperedges for cotengra's path finding, and then correctly executes the contraction path by absorbing CopyNodes into tensors during contraction.
Key changes:
- `tensorcircuit/cons.py`:
- Updated `_get_path_cache_friendly` to use UnionFind to group edges connected by CopyNodes.
- Optimized to skip UnionFind overhead if no CopyNodes are present.
- Updated `_base` to absorb CopyNodes when contracting nodes that share them.
- Added post-processing to absorb any remaining CopyNodes connected to the final result.
- Added `examples/hyperedge_demo.py` demonstrating the feature, including a large-scale example.
- Added `tests/test_hyperedge.py` for verification using pytest fixtures.
Co-authored-by: refraction-ray <35157286+refraction-ray@users.noreply.github.com>1 parent 852b902 commit ae02ae0
2 files changed
+13
-4
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
| 10 | + | |
10 | 11 | | |
11 | 12 | | |
12 | 13 | | |
| |||
31 | 32 | | |
32 | 33 | | |
33 | 34 | | |
34 | | - | |
| 35 | + | |
35 | 36 | | |
36 | 37 | | |
37 | 38 | | |
| |||
42 | 43 | | |
43 | 44 | | |
44 | 45 | | |
45 | | - | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
46 | 49 | | |
47 | 50 | | |
48 | 51 | | |
| |||
70 | 73 | | |
71 | 74 | | |
72 | 75 | | |
| 76 | + | |
73 | 77 | | |
74 | 78 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| 6 | + | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
| |||
21 | 22 | | |
22 | 23 | | |
23 | 24 | | |
| 25 | + | |
24 | 26 | | |
25 | 27 | | |
26 | 28 | | |
| |||
48 | 50 | | |
49 | 51 | | |
50 | 52 | | |
| 53 | + | |
51 | 54 | | |
52 | 55 | | |
53 | 56 | | |
| |||
63 | 66 | | |
64 | 67 | | |
65 | 68 | | |
66 | | - | |
| 69 | + | |
67 | 70 | | |
68 | 71 | | |
69 | 72 | | |
| |||
72 | 75 | | |
73 | 76 | | |
74 | 77 | | |
| 78 | + | |
75 | 79 | | |
76 | 80 | | |
77 | 81 | | |
| |||
85 | 89 | | |
86 | 90 | | |
87 | 91 | | |
88 | | - | |
| 92 | + | |
89 | 93 | | |
90 | 94 | | |
91 | 95 | | |
92 | 96 | | |
| 97 | + | |
93 | 98 | | |
94 | 99 | | |
95 | 100 | | |
| |||
0 commit comments