From 3406c8b7b21b21575412d4c7b05f5ef10258ed26 Mon Sep 17 00:00:00 2001 From: Raynel Sanchez <87539502+raynelfss@users.noreply.github.com> Date: Fri, 14 Jun 2024 16:34:36 +0200 Subject: [PATCH] Add: rust-native method to obtain Operstion objects. --- .../accelerate/src/target_transpiler/mod.rs | 52 ++++++++++++++----- 1 file changed, 38 insertions(+), 14 deletions(-) diff --git a/crates/accelerate/src/target_transpiler/mod.rs b/crates/accelerate/src/target_transpiler/mod.rs index 3138893e2b6c..744e7af34a37 100644 --- a/crates/accelerate/src/target_transpiler/mod.rs +++ b/crates/accelerate/src/target_transpiler/mod.rs @@ -517,14 +517,10 @@ impl Target { /// name. This also can also be the class for globally defined variable with /// operations. #[pyo3(text_signature = "(instruction, /)")] - pub fn operation_from_name(&self, py: Python<'_>, instruction: String) -> PyResult { - if let Some(gate_obj) = self._gate_name_map.get(&instruction) { - Ok(gate_obj.to_object(py)) - } else { - Err(PyKeyError::new_err(format!( - "Instruction {:?} not in target", - instruction - ))) + fn operation_from_name(&self, instruction: String) -> PyResult { + match self.get_operation_from_name(&instruction) { + Ok(instruction) => Ok(instruction.to_owned()), + Err(e) => Err(PyKeyError::new_err(e.message)), } } @@ -543,16 +539,12 @@ impl Target { /// Raises: /// KeyError: If qargs is not in target #[pyo3(text_signature = "(/, qargs=None)")] - fn operations_for_qargs( - &self, - py: Python<'_>, - qargs: Option, - ) -> PyResult> { + fn operations_for_qargs(&self, qargs: Option) -> PyResult> { // Move to rust native once Gates are in rust Ok(self .operation_names_for_qargs(qargs)? .into_iter() - .map(|x| self._gate_name_map[x].to_object(py)) + .map(|x| self._gate_name_map[x].to_owned()) .collect()) } @@ -1075,6 +1067,23 @@ impl Target { Ok(res) } + /// Returns rust-native operation instances present in the Target that affect the provided qargs. + pub fn ops_from_qargs( + &self, + qargs: &Option, + ) -> Result, TargetKeyError> { + match self.op_names_for_qargs(qargs) { + Ok(operations) => Ok(operations + .into_iter() + .filter_map(|oper| match &self._gate_name_map[oper] { + TargetOperation::Normal(normal) => Some(normal), + _ => None, + }) + .collect()), + Err(e) => Err(e), + } + } + /// Gets all the qargs used by the specified operation name. Rust native equivalent of ``BaseTarget.qargs_for_operation_name()`` pub fn qargs_for_op_name( &self, @@ -1093,6 +1102,21 @@ impl Target { } } + /// Gets the instruction object based on the operation name + pub fn get_operation_from_name( + &self, + instruction: &String, + ) -> Result<&TargetOperation, TargetKeyError> { + if let Some(gate_obj) = self._gate_name_map.get(instruction) { + Ok(gate_obj) + } else { + Err(TargetKeyError::new_err(format!( + "Instruction {:?} not in target", + instruction + ))) + } + } + /// Rust-native method to get all the qargs of a specific Target object pub fn get_qargs(&self) -> Option>> { let qargs: IndexSet<&Option> = self.qarg_gate_map.keys().collect();