Skip to content
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

feat: add source mapping for calibration expansion #370

Merged
merged 41 commits into from
Oct 12, 2024
Merged
Show file tree
Hide file tree
Changes from 34 commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
1a1e8a6
feat: add source mapping for calibration expansion
kalzoo May 4, 2024
3a319f1
chore: improve docs
kalzoo May 7, 2024
e13abf7
fix bug in target range mapping in calibration expansion
kalzoo May 7, 2024
917ba23
WIP: header-aware program calibration expansion
kalzoo May 7, 2024
bf246b3
fix bug in program calibration expansion into header instructions
kalzoo May 9, 2024
277105d
remove unnecessary SourceMapRange trait
kalzoo May 9, 2024
b35f8fe
add source map python bindings
kalzoo May 9, 2024
1bec330
feat!: refactor identifiers out of Calibration and MeasureCalibration…
kalzoo May 9, 2024
ec90415
add and fix py stubs for CalibrationIdentifier and MeasureCalibration…
kalzoo May 9, 2024
2ecf658
reorder bindings file in lex order
kalzoo May 9, 2024
8446b61
add source-map py stubs
kalzoo May 9, 2024
feaa61c
Add py stub for Program.expand_calibrations_with_source_map
kalzoo May 9, 2024
00119a6
chore: docs
kalzoo May 9, 2024
1965440
chore: fmt
kalzoo May 9, 2024
8906a76
refactor instruction calibration expansion so that source maps are on…
kalzoo May 9, 2024
645e1a2
update snapshot
kalzoo May 9, 2024
cafe117
chore: lint
kalzoo May 10, 2024
3216ef3
chore: cleanup
kalzoo Jul 1, 2024
ac63749
add query (lookup) operations for SourceMap
kalzoo Jul 22, 2024
4b61fc8
fix bug in calibration expansion
kalzoo Jul 22, 2024
07ae1d3
chore: lint
kalzoo Jul 22, 2024
78df471
fix range return type
kalzoo Jul 22, 2024
25bd576
add test
kalzoo Jul 22, 2024
f64aa8a
chore: cleanup
kalzoo Jul 22, 2024
d3abce6
chore: fix docs
kalzoo Jul 22, 2024
c97dcca
chore: fix test
kalzoo Jul 22, 2024
8ffb15a
chore: cleanup
kalzoo Jul 22, 2024
2ca8eea
chore: cleanup
kalzoo Jul 22, 2024
8f91186
chore: fix comment
kalzoo Jul 29, 2024
56476ca
fix test
kalzoo Jul 29, 2024
5d9f759
make test more readable
kalzoo Jul 29, 2024
59daee1
chore: fix readme
kalzoo Jul 29, 2024
7a5972c
chore: lint
kalzoo Jul 29, 2024
5d31908
add useful example to Python docs
kalzoo Jul 29, 2024
de94d05
fix doc example
kalzoo Jul 29, 2024
5c05993
fix doc example
kalzoo Jul 29, 2024
a879779
Merge branch 'main' into 366-source-mapping
kalzoo Jul 29, 2024
a298437
chore: lint
kalzoo Jul 29, 2024
9a3b453
Merge branch 'main' into 366-source-mapping
kalzoo Oct 11, 2024
022900a
make InstructionIndex a newtype struct for source mapping
kalzoo Oct 12, 2024
f72ae40
add missing from_ methods to new python bindings
kalzoo Oct 12, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 26 additions & 3 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion quil-py/README-py.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

The `quil` package provides tools for constructing, manipulating, parsing, and printing [Quil](https://github.com/quil-lang/quil) programs. Internally, it is powered by [quil-rs](https://github.com/rigetti/quil-rs).

This package is still in early development and breaking changes should be expected between minor versions.
This package is still in development and breaking changes should be expected between minor versions.

# Documentation

Expand Down
96 changes: 90 additions & 6 deletions quil-py/quil/instructions/__init__.pyi
Original file line number Diff line number Diff line change
Expand Up @@ -826,11 +826,8 @@ class UnaryLogic:
class Calibration:
def __new__(
cls,
name: str,
parameters: Sequence[Expression],
qubits: Sequence[Qubit],
identifier: CalibrationIdentifier,
instructions: Sequence[Instruction],
modifiers: Sequence[GateModifier],
) -> Self: ...
@property
def name(self) -> str: ...
Expand All @@ -845,6 +842,10 @@ class Calibration:
@qubits.setter
def qubits(self, qubits: Sequence[Qubit]) -> None: ...
@property
def identifier(self) -> CalibrationIdentifier: ...
@identifier.setter
def identifier(self, identifier: CalibrationIdentifier) -> None: ...
@property
def instructions(self) -> List[Instruction]: ...
@instructions.setter
def instructions(self, instructions: Sequence[Instruction]) -> None: ...
Expand Down Expand Up @@ -873,11 +874,55 @@ class Calibration:
def __copy__(self) -> Self:
"""Returns a shallow copy of the class."""

class CalibrationIdentifier:
def __new__(
cls,
name: str,
parameters: Sequence[Expression],
qubits: Sequence[Qubit],
modifiers: Sequence[GateModifier],
) -> Self: ...
@property
def name(self) -> str: ...
@name.setter
def name(self, name: str) -> None: ...
@property
def parameters(self) -> List[Expression]: ...
@parameters.setter
def parameters(self, parameters: Sequence[Expression]) -> None: ...
@property
def qubits(self) -> List[Qubit]: ...
@qubits.setter
def qubits(self, qubits: Sequence[Qubit]) -> None: ...
@property
def modifiers(self) -> List[GateModifier]: ...
@modifiers.setter
def modifiers(self, modifiers: Sequence[GateModifier]) -> None: ...
def to_quil(self) -> str:
"""Attempt to convert the instruction to a valid Quil string.

Raises an exception if the instruction can't be converted to valid Quil.
"""
...
def to_quil_or_debug(self) -> str:
"""Convert the instruction to a Quil string.

If any part of the instruction can't be converted to valid Quil, it will be printed in a human-readable debug format.
"""
def __deepcopy__(self, _: Dict) -> Self:
"""Creates and returns a deep copy of the class.

If the instruction contains any ``QubitPlaceholder`` or ``TargetPlaceholder``, then they will be replaced with
new placeholders so resolving them in the copy will not resolve them in the original.
Should be used by passing an instance of the class to ``copy.deepcopy``
"""
def __copy__(self) -> Self:
"""Returns a shallow copy of the class."""

class MeasureCalibrationDefinition:
def __new__(
cls,
qubit: Optional[Qubit],
parameter: str,
identifier: MeasureCalibrationIdentifier,
instructions: Sequence[Instruction],
) -> Self: ...
@property
Expand All @@ -889,6 +934,10 @@ class MeasureCalibrationDefinition:
@parameter.setter
def parameter(self, parameter: str) -> None: ...
@property
def identifier(self) -> MeasureCalibrationIdentifier: ...
@identifier.setter
def identifier(self, identifier: MeasureCalibrationIdentifier) -> None: ...
@property
def instructions(self) -> List[Instruction]: ...
@instructions.setter
def instructions(self, instructions: Sequence[Instruction]) -> None: ...
Expand All @@ -913,6 +962,41 @@ class MeasureCalibrationDefinition:
def __copy__(self) -> Self:
"""Returns a shallow copy of the class."""

class MeasureCalibrationIdentifier:
def __new__(
cls,
qubit: Optional[Qubit],
parameter: str,
) -> Self: ...
@property
def qubit(self) -> Optional[Qubit]: ...
@qubit.setter
def qubit(self, qubit: Optional[Qubit]) -> None: ...
@property
def parameter(self) -> str: ...
@parameter.setter
def parameter(self, parameter: str) -> None: ...
def to_quil(self) -> str:
"""Attempt to convert the instruction to a valid Quil string.

Raises an exception if the instruction can't be converted to valid Quil.
"""
...
def to_quil_or_debug(self) -> str:
"""Convert the instruction to a Quil string.

If any part of the instruction can't be converted to valid Quil, it will be printed in a human-readable debug format.
"""
def __deepcopy__(self, _: Dict) -> Self:
"""Creates and returns a deep copy of the class.

If the instruction contains any ``QubitPlaceholder`` or ``TargetPlaceholder``, then they will be replaced with
new placeholders so resolving them in the copy will not resolve them in the original.
Should be used by passing an instance of the class to ``copy.deepcopy``
"""
def __copy__(self) -> Self:
"""Returns a shallow copy of the class."""

class CircuitDefinition:
def __new__(
cls,
Expand Down
Loading