Giter VIP home page Giter VIP logo

xir's Introduction

XIR

XIR is an intermediate representation language for quantum circuits.

Features

  • Simple. Easy to learn, write, and understand.

  • Modular. Compose observables, gates, and entire XIR programs.

  • Flexible. Declare or define your own gates and observables.

Installation

XIR requires Python version 3.7 or above. Installation of XIR, as well as all dependencies, can be done using pip:

pip install quantum-xir

Examples

A curated selection of XIR scripts can be found in the Examples page of the Sphinx documentation; however, the example below demonstrates a general overview of the syntax:

// Include additional script
use my_declarations;

// Declare custom gates
gate RX(theta) [w1];
gate RY(theta) [w1];
gate RZ(theta) [w1];
gate Toffoli [w1, w2, w3];

// Declare a function
func sin(x);

// Declare observables
obs X [w1]; obs Y [w1]; obs Z [w1];

// Declare outputs
out sample(shots) [0..8];
out expval(observable) [w1, w2];
out amplitude(state) [0..8];

// Define a composite gate.
gate R3T(theta)[a, b, c, d]:
    RX(theta: -2.3932854391951004) | [a];
    RY(theta) | [b];
    RZ(pi / sin(3 * 4 / 2 - 2)) | [c];
    Toffoli | [b, c, d];
end;

// Define an observable.
obs XYZ [w1, w2]:
    -1.6, X[w1];
    0.73, Y[w1] @ Z[w2];
end;

// Apply the gate twice.
R3T(1.23) | [0, 1, 2, 3];
R3T(theta: 3.21) | [4..8];

// Compute various outputs.
sample(shots: 1000) | [0..8];
expval(observable: XYZ) | [0, 3];
amplitude(state: [0, 1, 0, 1, 0, 0, 1, 1]) | [0..8];

Contributing to XIR

We welcome contributions - simply fork the XIR repository, and then make a pull request containing your contribution. All contributors to XIR will be listed as authors on the releases. See our changelog for more details.

We also encourage bug reports, suggestions for new features and enhancements, and even links to cool projects or applications built on XIR. Visit the contributions page to learn more about sharing your ideas with the XIR team.

Support

If you are having issues, please let us know by posting the issue on our GitHub issue tracker.

Authors

XIR is the work of many contributors.

License

XIR is free and open source, released under the Apache License, Version 2.0.

xir's People

Contributors

bastianzim avatar doctorperceptron avatar github-actions[bot] avatar mandrenkov avatar puzzleshark avatar thisac avatar

Stargazers

 avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

xir's Issues

Control wires are not accounted for in program wires

Expected behavior

When calling program.wires on programs containing control gates, the control wire is missing.

As an example consider the following XIR script:

xir_script = """
gate _gate_1_[0, 1]:
    CRX(0.4) | [0, 1];
end;

ctrl[0] _gate_1_ | [1, 2];
"""

We would the expect the following

>>> import xir
>>> program = xir.parse_script(xir_script)
>>> program.wires
{0, 1, 2}

Actual behavior

The actual output is:

>>> import xir
>>> program = xir.parse_script(xir_script)
>>> program.wires
{1, 2}

i.e the control wire is not accounted for

Additional information

This impacts the way wire options are passed to scripts for PennyLane tapes that contain control gates: https://github.com/XanaduAI/pennylane-xanadu-cloud/pull/4

Source code

import xir

xir_script = """
gate _gate_1_[0, 1]:
    CRX(0.4) | [0, 1];
end;

ctrl[0] _gate_1_ | [1, 2];
"""

program = xir.parse_script(xir_script)
print(program.wires)

Tracebacks

No response

  • I have searched existing GitHub issues to make sure the issue does not already exist.

Bug: unable to build from pypi source tarball

Feature details

Hi there,

while I was working on a Spack recipe for StrawberryFields, I have noticed one small issue about the XIR repo:
the tarball from pypi does not contain requirements.txt, hence the build fails; I resorted to using the github tarball for now.

For reference my Spack PR: spack/spack#34849

Implementation

No response

How important would you say this feature is?

1: Not important. Would be nice to have.

Additional information

No response

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.