Releases: jcmgray/quimb
v1.11.2
Enhancements:
- Update the introduction to tensor contraction docs
- Improve efficiency of 1D structured contractions when default
optimizeis used.
Bug fixes:
- fixes for MPS and MPO constructors when L=1, (#314)
- tensor splitting with absorb="left" now correctly marks left indices.
tn.isel: fix bug when value could not be compared to string"r"- truncated svd, make n_chi comparison more robust to different backends
Full Changelog: v1.11.1...v1.11.2
v1.11.1
Enhancements:
- add
create_bondtotensor_canonize_bondandtensor_compress_bondfor optionally creating a new bond between two tensors if they don't already share one. Add as a flag toTensorNetwork1DFlat.compressand related functions (#294). - add
ensure_bonds_existfor ensuring that all bonds in a 1D flat tensor network exist. Use this in thepermute_arraysmethods and optionally in theexpand_bond_dimensionmethod. tn.draw(): permit empty network, and allowcolor=Trueto automatically color all tags.tn.add_tag: add arecord: Optional[dict]kwarg, to allow for easy rewinding of temporary tags without tracking the actual networks.- add
qu.plotas a quick wrapper for callingmatplotlib.pyplot.plotwith thequimbstyle. quimb.schematic: addzorder_deltakwarg for fine adjustments to layering of objects in approximately the same position.operatorbuilder: big performance improvements and fixes for building matrix representations including Z2 symmetry. Add defaultsymmetryandsectoroptions that can be overridden at build time. Add lazy (slow, matrix free) 'apply' method. Addpauli_decomposetransformation. Add experimental PEPO builder for nearest neighbor operators. Add unit tests.
Bug fixes:
- Fix
TensorNetwork2D.compute_plaquette_environmentsformode="zipup"and other boundary contraction methods that use the generic 1D compression algorithms. parse_openqasm2_strallow custom gate names to start with the wordgate(#312).MatrixProductState.gate_with_mpo: fix bug to do with inplace argument (#313).
Full Changelog: v1.11.0...v1.11.1
v1.11.0
Breaking Changes
- move belief propagation to
quimb.tensor.belief_propagation - calling
tn.contract()when an non-zero value has been accrued intotn.exponentnow automatically re-absorbs that exponent. - binary tensor operations that would previously have errored now will align and broadcast
Enhancements:
Tensor: make binary operations (+, -, *, /, **) automatically align and broadcast indices. This would previously error.MatrixProductState.measure: add aseedkwarg- belief propagation, implement DIIS (direct inversion in the iterative subspace)
- belief propagation, unify various aspects such as message normalization and distance.
- belief propagation, add a
plotmethod. - belief propagation, add a
contract_everyoption. - HV1BP: vectorize both contraction and message initialization
- add
qu.plot_multi_series_zoomfor plotting multiple series with a zoomed inset, useful for various convergence plots such as BP - add
infooption totn.gauge_all_simplefor tracking extra information such as number of iterations and max gauge diffs Tensor.gate: addtransposedoptionTensorNetwork.contract: addstrip_exponentoption for return the mantissa and exponent (log10) separately. Compatible withcontract_tags,contract_cumulative,contract_compressedsub modes.tensor_split: addmatrix_svalsoption, ifTrueany returned singular values are put into the diagonal of a matrix (by default,False, they are returned as a vector).- add
Tensor.new_ind_pair_diagfor expanding an existing index into a pair of new indices, such that the diagonal of the new tensor on those indices is the old tensor. TNOptimizer: add 'cautious' ADAMTensorNetwork.pop_tensor: allowtidor tags to be specified.- add an example notebook for converting hyper tensor networks to normal tensor networks, for approximate contraction - https://quimb.readthedocs.io/en/latest/examples/ex_htn_to_tn_2d.html#example-htn-to-2d
- Add SX and SXDG gates by @kevinsung in #277
- Add XXPLUSYY and XXMINUSYY gates by @kevinsung in #279
- Added progbar to qsim, and openqasm2 by @edenian in #288
quimb.experimental.operatorbuilder: fix MPO building for congested operators (#296 and #301), allow arbitrary dtype (#289). Fix building of sparse and matrix representations for non-translationally symmetric operators and operators with trivial (all identity) terms.
Bug fixes:
- fix
MatrixProductState.measureforcupybackend arrays (#276). - fix
linalg.expmdispatch (#275) - fix 'dm' 1d compress method for disconnected subgraphs
- fix docs source lookup in
quimb.tensormodule - fix raw gate copying in
Circuit(#285)
New Contributors
Full Changelog: v1.10.0...v1.11.0
v1.10.0
Enhancements
- tensor network fitting: add
method="tree"for when ansatz is a tree -tensor_network_fit_tree - tensor network fitting: fix
method="als"for complex dtype networks - tensor network fitting: allow
method="als"to use a iterative solver suited to much larger tensors, by default a custom conjugate gradient implementation. -
tensor_network_distanceand fitting: support hyper indices explicitly viaoutput_indskwarg - add
tn.make_overlapandtn.overlapfor computing the overlap between two tensor networks,$\langle O |T \rangle$ , with explicit handling of outer indices to address hyper networks. Addoutput_indstotn.normandtn.make_normalso, as well as thesquaredkwarg. - replace all
numbabased paralellism (prangeand parallel vectorize) with explicit thread pool based parallelism. Should be more reliable and no need to setNUMBA_NUM_THREADSanymore. Remove env varQUIMB_NUMBA_PAR. -
Circuit: adddtypeandconvert_eageroptions.dtypespecifies what the computation should be performed in.convert_eagerspecifies whether to apply this (and anyto_backendcalls) as soon as gates are applied (the default for MPS circuit simulation) or just prior to contraction (the default for exact contraction simulation). -
tn.full_simplify: addcheck_zero(by default set of"auto") option which explicitly checks for zero tensor norms when equalizing norms to avoidlog10(norm)resulting in -inf or nan. Since it creates a data dependency that breaks e.g.jaxtracing, it is optional. -
schematic.Drawing: addshortenkwarg to line drawing and curve drawing and examples to the docs. -
TensorNetwork: add.backendand.dtype_nameproperties.
PRs:
- Circuit: add default dtype and convert_eager options by @jcmgray in #273
- add fit(method="tree") and fix ALS for complex TNs by @jcmgray in #274
Full Changelog: v1.9.0...v1.10.0
v1.9.0
Breaking Changes
- renamed
MatrixProductState.partial_traceandMatrixProductState.ptrto MatrixProductState.partial_trace_to_mpo to avoid confusion with otherpartial_tracemethods that usually produce a dense matrix.
Enhancements:
- add
Circuit.sample_gate_by_gateand related methodsCircuitMPS.reordered_gates_dfs_clusteredandCircuitMPS.get_qubit_distancesfor sampling a circuit using the 'gate by gate' method introduced in https://arxiv.org/abs/2112.08499. - add
Circuit.drawfor drawing a very simple circuit schematic. -
Circuit: by default turn onsimplify_equalize_normsand use agroup_size=10for sampling. This should result in faster and more stable sampling. -
Circuit: usenumpy.random.default_rngfor random number generation. - add
qtn.circ_a2a_randfor generating random all-to-all circuits. - expose
qtn.edge_coloringas top level function and allow layers to be returned grouped. - add docstring for
tn.contract_compressedand by default pick up important settings from the supplied contraction path optimizer (max_bondandcompress_late) - add
Tensor.rand_reducefor randomly removing a tensor index by contracting a random vector into it. One can also supply the value"r"toiselselectors to use this. - add
fit-zipupandfit-projectorshorthand methods to the general 1d tensor network compression function - add
MatrixProductState.compute_local_expectationfor computing many local expectations for a MPS at once, to match the interface for this method elsewhere. These can either be computed via canonicalization (method="canonical"), or via explicit left and right environment contraction (method="envs") - specialize
CircuitMPS.local_expectationto make use of the MPS form. - add
PEPS.product_statefor constructing a PEPS representing a product state. - add
PEPS.vacuumfor constructing a PEPS representing the vacuum state$|000\ldots0\rangle$ . - add
PEPS.zerosfor constructing a PEPS whose entries are all zero. -
tn.gauge_all_simple: improve scheduling and adddampingandtouched_tidsoptions. -
qtn.SimpleUpdateGen: add gauge difference update checking andtolandequilibratesettings. Update.plot()method. Default to a smallcutoff. - add
psi.sample_configuration_clusterfor sampling a tensor network using the simple update or cluster style environment approximation. - add the new example doc Exploring circuit sampling with various methods
v1.8.4
What's Changed
- fix MPS sample handling of RNG seed by @kevinsung in #248
- fix bug in applying MPO lazily to MPS (#246)
New Contributors
- @kevinsung made their first contribution in #248
Full Changelog: v1.8.3...v1.8.4
v1.8.3
Enhancements:
- support for numpy v2.0 and scipy v1.14
- add MPS sampling:
MatrixProductState.sample_configurationandMatrixProductState.sample(generating multiple samples) and use these forCircuitMPS.sampleandCircuitPermMPS.sample. - add basic plot method for [
SimpleUpdate] classes - add
edges_1d_chainfor generating 1D chain edges - operatorbuilder: better coefficient placement for long range / non-local MPO building
Full Changelog: v1.8.2...v1.8.3
v1.8.2
Enhancements:
TNOptimizercan now accept an arbitrary pytree (nested combination of dicts, lists, tuples, etc. withTensorNetwork,Tensoror rawarray_likeobjects as the leaves) as the target object to optimize.TNOptimizercan now directly optimizeCircuitobjects, returning a new optimized circuit with updated parameters.Circuit: add.copy(),.get_params()and.set_params()interface methods.- Update generic TN optimizer docs.
- add
tn.gen_inds_loopsfor generating all loops of indices in a TN. - add
tn.gen_inds_connectedfor generating all connected sets of indices in a TN. - make SVD fallback error catching more generic (by @mlxd in #238)
- fix some windows + numba CI issues.
approx_spectral_functionadd plotting and tracking- add dispatching to various tensor primitives to allow overriding
New Contributors
Full Changelog: v1.8.1...v1.8.2
v1.8.1
Enhancements:
CircuitMPSnow supports multi qubit gates, including arbitrary multi-controls (which are treated in a low-rank manner), and faster simulation via better orthogonality center tracking.- add
CircuitPermMPS, more docs here: https://quimb.readthedocs.io/en/latest/tensor-circuit-mps.html - add
MatrixProductState.gate_nonlocalfor applying a gate, supplied as a raw matrix, to a non-local and arbitrary number of sites. The kwargcontract="nonlocal"can be used to force this method, or the new option"auto-mps"will select this method if the gate is non-local (#230) - add
MatrixProductState.gate_with_mpofor applying an MPO to an MPS, and immediately compressing back to MPS form usingtensor_network_1d_compress - add
MatrixProductState.gate_with_submpofor applying an MPO acting only of a subset of sites to an MPS - add
MatrixProductOperator.from_densefor constructing MPOs from dense matrices, including an only subset of sites - add
MatrixProductOperator.fill_empty_sitesfor 'completing' an MPO which only has tensors on a subset of sites with (by default) identities MatrixProductStateandMatrixProductOperator, now support thesiteskwarg in common constructors, enabling the TN to act on a subset of the fullLsites.- add
TensorNetwork.drape_bond_betweenfor 'draping' an existing bond between two tensors through a third - add
Tensor.new_ind_pair_with_identity - TN2D, TN3D and arbitrary geom classical partition function builders (
TN_classical_partition_function_from_edges) now all supportoutputs=kwarg specifying non-marginalized variables - add simple dense 1-norm belief propagation algorithm
D1BP - add
qtn.enforce_1d_likefor checking whether a tensor network is 1D-like, including automatically adding strings of identities between non-local bonds, expanding applicability oftensor_network_1d_compress - add
MatrixProductState.canonicalizeas (by default non-inplace) version ofcanonize, to follow the pattern of other tensor network methods.canonizeis now an alias forcanonicalize_[note trailing underscore]. - add
MatrixProductState.left_canonicalizeas (by default non-inplace) version ofleft_canonize, to follow the pattern of other tensor network methods.left_canonizeis now an alias forleft_canonicalize_[note trailing underscore]. - add
MatrixProductState.right_canonicalizeas (by default non-inplace) version ofright_canonize, to follow the pattern of other tensor network methods.right_canonizeis now an alias forright_canonicalize_[note trailing underscore].
Bug fixes:
Circuit.apply_gate_raw: fix kwarg bug (#226) by @juliendrapeau- fix for retrieving
opt_einsum.PathInfofor single scalar contraction (#231).
New Contributors
- @juliendrapeau made their first contribution in #226
Full Changelog: v1.8.0...v1.8.1
v1.8.0
Breaking Changes
- all singular value renormalization is turned off by default
TensorNetwork.compress_allnow defaults to using some local gauging
Enhancements:
-
add
quimb.tensor.tensor_1d_compress.pywith functions for compressing generic 1D tensor networks (with arbitrary local structure) using various methods. The methods are:- The 'direct' method:
tensor_network_1d_compress_direct - The 'dm' (density matrix) method:
tensor_network_1d_compress_dm - The 'zipup' method:
tensor_network_1d_compress_zipup - The 'zipup-first' method:
tensor_network_1d_compress_zipup_first - The 1 and 2 site 'fit' or sweeping method:
tensor_network_1d_compress_fit - ... and some more niche methods for debugging and testing.
And can be accessed via the unified function
tensor_network_1d_compress. Boundary contraction in 2D can now utilize any of these methods. - The 'direct' method:
-
add
quimb.tensor.tensor_arbgeom_compress.pywith functions for compressing arbitrary geometry tensor networks using various methods. The methods are:- The 'local-early' method:
tensor_network_ag_compress_local_early - The 'local-late' method:
tensor_network_ag_compress_local_late - The 'projector' method:
tensor_network_ag_compress_projector - The 'superorthogonal' method:
tensor_network_ag_compress_superorthogonal - The 'l2bp' method:
tensor_network_ag_compress_l2bp
And can be accessed via the unified function
tensor_network_ag_compress. 1D compression can also fall back to these methods. - The 'local-early' method:
-
support PBC in
tn2d.contract_hotrg,tn2d.contract_ctmrg,tn3d.contract_hotrgand the new functiontn3d.contract_ctmrg. -
support PBC in
gen_2d_bondsandgen_3d_bonds, withcyclickwarg. -
support PBC in
TN2D_rand_hidden_loopandTN3D_rand_hidden_loop, withcyclickwarg. -
support PBC in the various base PEPS and PEPO construction methods.
-
add
tensor_network_apply_op_opfor applying 'operator' TNs to 'operator' TNs. -
tweak
tensor_network_apply_op_vecfor applying 'operator' TNs to 'vector' or 'state' TNs. -
add
tnvec.gate_with_op_lazymethod for applying 'operator' TNs to 'vector' or 'state' TNs like$x \rightarrow A x$ . -
add
tnop.gate_upper_with_op_lazymethod for applying 'operator' TNs to the upper indices of 'operator' TNs like$B \rightarrow A B$ . -
add
tnop.gate_lower_with_op_lazymethod for applying 'operator' TNs to the lower indices of 'operator' TNs like$B \rightarrow B A$ . -
add
tnop.gate_sandwich_with_op_lazymethod for applying 'operator' TNs to the upper and lower indices of 'operator' TNs like$B \rightarrow A B A^\dagger$ . -
unify all TN summing routines into
tensor_network_ag_sum, which allows summing any two tensor networks with matching site tags and outer indices, replacing specific MPS, MPO, PEPS, PEPO, etc. summing routines. -
add
rand_symmetric_array,rand_tensor_symmetricTN2D_rand_symmetricfor generating random symmetric arrays, tensors and 2D tensor networks.
Bug fixes:
- fix scipy sparse monkey patch for scipy>=1.13 (#222)
- fix autoblock bug where connected sectors were not being merged (#223)
Full Changelog: v1.7.3...v1.8.0