forked from Qiskit/qiskit
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Operator.compose should allow indices (qiskit-community/qiskit-aqua#1144
) * 1) modified PrimitiveOp._check_zero_for_composition_and_expand, so that it expands shorter operator with identity 2) implemented OperatorBase.expand 3) defined abstract method OperatorBase.identity, and implemented in child classes of OperatorBase (TODO check if implementation makes sense for every class) 4) created tests for composing Operators of different dimensions * CircuitStateFn.tensor did not set is_measurement parameter (hence always default to False), even if tensored instances were is_measurement=True * Added test for expand method on StateFn subclasses * 1) PauliOp.permute implemented 2) test_permute_on_primitive_op implemented. It checks correctness and consistency of permute implementations. * 1) permute implemented for MatrixOp 2) added testcase for MatrixOp permute, to check consistency with PauliOp.permute and CircuitOp.permute * identity renamed to identity_operator in OperatorBase * OperatorBase.expand renamed to expand_to_dim * expand_to_dim overridden for PrimitiveOps * 1) expand_to_dim implemented for each subclass of OperatorBase 2) removed identity_operator * OperatorStateFn permute implemented * 1) permute for TensoredOp 2) extended documentation * 1) TensoredOp.permute moved to ListOp.permute 2) ListOp.permute uses CircuitOps instead of MatrixOps for permutations * permute defined abstract in OperatorBase * composition of PrimitiveOp with ComposedOp prepends the ComposedOp.oplist with PrimitiveOp * Revert "composition of PrimitiveOp with ComposedOp prepends the ComposedOp.oplist with PrimitiveOp" * 1) compose in MatrixOp, PauliOp and CircuitOp enhanced, to be consistent with ComposedOp.compose 2) test_compose_consistency added to verify the consistency * DRY applied * Test if ListOp.permute is consistent with PrimitiveOp permute methods * test for expand_to_dim on ListOps * 1) changed signature of compose to allow permutations on operators 2) permutation on operators included in compose method * refactoring * unit test for compose with indices * refactoring and fixed linting * 1) StateFn.compose expands the shorter operators with identity 2) refactored _check_zero_for_composition_and_expand 3) unit test for new composition features of StateFns 4) fixing style * 1) expand_to_dim renamed to expand_with_identities (expand_to_dim was misleading, because its parameter is not the target dimension, but the number or qubits to add to operator) 2) documentation for the new features improved * permute implemented for DictStateFn * 1) VectorStateFn.to_dict_fn and DictStateFn.to_vector_state_fn implemented 2) VectorStateFn permute implemented 3) unit tests for the new functionality * implemented custom function to decompose permutations into transpositions, to avoid import of sympy * explaining comment for CircuitStateFn.expand_with_identity * expand_with_identity made private and renamed to _expand_dim (expand_with_identity is misleading for implementations in DictStateFn and VectorStateFn, where zeros are used for expansion) * 1) Compose method has only one set of permutation indices (for other operator). 2) Added new argument front=False in compose method. If front==True, return other.compose(self), but only after expansion and permutation is performed. * 1) modified test_op_construction because of changes in compose signature 2) fix in CircuitOp.compose * _check_zero_for_composition_and_expand renamed to _expand_shorter_operator_and_permute, to be more self-explanatory * VectorStateFn.permute reimplemented for better performance * removed duplicate method to_vector_state_fn (to_matrix_op was already defined) * new_self instead of self in EvolvedOp * test_op_construction refactored * raise AquaError in ListOp.permute, if ListOp contains operators with different num_qubit Co-authored-by: Manoel Marques <manoelmrqs@gmail.com> Co-authored-by: Julien Gacon <gaconju@gmail.com> Co-authored-by: Manoel Marques <Manoel.Marques@ibm.com> Co-authored-by: Steve Wood <40241007+woodsp-ibm@users.noreply.github.com>
- Loading branch information
1 parent
c812b78
commit 8cb37fe
Showing
15 changed files
with
449 additions
and
95 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.