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

Move circuit drawer files to qiskit.visualization.circuit #8306

Merged
merged 34 commits into from
Sep 7, 2022

Conversation

enavarro51
Copy link
Contributor

@enavarro51 enavarro51 commented Jul 6, 2022

Summary

Moves circuit drawer files to circuit sub-directory

Details and comments

This PR adds a new circuit sub-directory to the qiskit.visualization directory and moves all circuit drawer modules along with styles and the circuit-related utility functions to the circuit dir.

These changes were also made,

  • Two functions in the utils.py file that were only used by state_visualization were moved to that module.
  • All other utils functions, except for _trim and matplotlib_close_if_inline which were used by multiple modules, were moved to circuit_utils in the circuit sub-directory.
  • The pulse_visualization.py file was removed since it had been deprecated for a long time. @nkanazawa1989 confirmed this was ok.
  • Two stub files - circuit_visualization and qcstyle.py - were left in qiskit.visualization which just import from circuit.circuit_visualization and circuit.qcstyle, respectively, for backward compatibility.
  • Imports were cleaned up in several modules, including the qiskit.visualization.__init__ module, which included more use of '.' and '..' for directories.

In a future PR, the pulse_v2 files can be moved to the pulse dir. When this is completed and all deprecations delays have passed, the visualization dir will look like this,

visualization
    __init__
    array.py
    bloch.py
    counts_visualization.py
    dag_visualization.py
    exceptions.py
    gate_map.py
    pass_manager_visualization.py
    state_visualization.py
    transition_visualization.py
    utils.py
    -> circuit
    -> pulse
    -> timeline

@enavarro51 enavarro51 requested review from a team, nonhermitian and nkanazawa1989 as code owners July 6, 2022 21:56
@qiskit-bot
Copy link
Collaborator

Thank you for opening a new pull request.

Before your PR can be merged it will first need to pass continuous integration tests and be reviewed. Sometimes the review process can be slow, so please be patient.

While you're waiting, please feel free to review other open PRs. While only a subset of people are authorized to approve pull requests for merging, everyone is encouraged to review open pull requests. Doing reviews helps reduce the burden on the core team and helps make the project's code better for everyone.

One or more of the the following people are requested to review this:

@coveralls
Copy link

coveralls commented Jul 6, 2022

Pull Request Test Coverage Report for Build 3004156037

  • 469 of 585 (80.17%) changed or added relevant lines in 13 files are covered.
  • 57 unchanged lines in 4 files lost coverage.
  • Overall coverage decreased (-0.07%) to 84.298%

Changes Missing Coverage Covered Lines Changed/Added Lines %
qiskit/visualization/circuit_visualization.py 0 1 0.0%
qiskit/visualization/qcstyle.py 0 1 0.0%
qiskit/visualization/transition_visualization.py 0 2 0.0%
qiskit/visualization/state_visualization.py 19 25 76.0%
qiskit/visualization/circuit/_utils.py 328 350 93.71%
qiskit/visualization/circuit/circuit_visualization.py 72 106 67.92%
qiskit/visualization/circuit/qcstyle.py 28 78 35.9%
Files with Coverage Reduction New Missed Lines %
qiskit/tools/visualization.py 1 0%
qiskit/visualization/circuit_visualization.py 1 0%
qiskit/visualization/qcstyle.py 1 0%
qiskit/visualization/pulse/matplotlib.py 54 0%
Totals Coverage Status
Change from base Build 2994503304: -0.07%
Covered Lines: 57808
Relevant Lines: 68576

💛 - Coveralls

Copy link
Contributor

@nkanazawa1989 nkanazawa1989 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems good direction and changes in this PR are reasonable. Removal of the v1 pulse drawer should be fine. Could you please get another approval since I recently don't maintain the visualization module except for pulse drawer.

@1ucian0 1ucian0 added the Community PR PRs from contributors that are not 'members' of the Qiskit repo label Aug 8, 2022
@enavarro51
Copy link
Contributor Author

Just to clarify on the stubs. Do we need to support both
from qiskit.visualization import text and
from qiskit.visualization.text import <something>? Thanks.

@jakelishman
Copy link
Member

Yeah, I agree nobody should be using these things. It's mostly that we publish our deprecation policy, and so we really ought to stick with it. It's part of the reason I like to push to make sure internal functions are explicitly marked as private.

The correct way would be for us to ensure from qiskit.visualization.text import ... works, but if that's too much effort, let's just ensure from qiskit.visualization import text works, since that provides a backwards-compatible workaround. I think that's a good enough compromise here.

@enavarro51
Copy link
Contributor Author

Ok. Allowing from qiskit.visualization import text only requires another __init__ entry, where allowing
from qiskit.visualization.text import <something> requires a separate stub text.py file. So I'd vote for the former, since it gives the user a way to still access text without knowing about the circuit directory, but leaves a cleaner visualization directory and fewer deprecations at the next step.

Copy link
Member

@jakelishman jakelishman left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for all this, Edwin. I just pushed up a commit to add a comment to the backwards-compatibility shim imports, and to add an upgrade note (just in case). I'll mark this for merge now - I'll override Luciano's hold so it can merge tonight, since his comment was addressed, and there's other visualisation PRs waiting, which I don't want to merge and make you have to rebase this again.

@jakelishman jakelishman dismissed 1ucian0’s stale review September 7, 2022 00:04

changes made, overriding to merge in a more timely manner

@jakelishman jakelishman added Changelog: API Change Include in the "Changed" section of the changelog automerge mod: visualization qiskit.visualization labels Sep 7, 2022
@enavarro51
Copy link
Contributor Author

Thanks, Jake.

@mergify mergify bot merged commit bb52011 into Qiskit:main Sep 7, 2022
ewinston pushed a commit to ewinston/qiskit that referenced this pull request Sep 8, 2022
)

* Add graph and circuit dirs

* Move files to new folders

* Finishing transition to circuit and graph dirs

* Finish import changes

* Positioning files and setting init entries

* Final tweaks to compatibility and lint

* Reduce to circuit dir only

* Cleanup

* Add qcstyle stub for docs

* Merge main conflicts fix

* Lint

* Change test message

* Fix _directive change

* Fix op.condition reference

* Change to _utils and cleanup

* Lint

* Fix _trim and dag_drawer test

* Allow direct import of text, etc.

* Add comment explaining backwards-compatibility imports

* Add release note

Co-authored-by: Jake Lishman <[email protected]>
jakelishman added a commit to jakelishman/qiskit-terra that referenced this pull request Sep 13, 2022
A recent change to the structure of the visualisation module in Qiskit#8306
caused `matplotlib` to be eagerly imported when `qiskit.visualization`
was imported, since the internal `bloch` module was imported in the
`__init__`.  This means that `QuantumCircuit.draw()` in text mode had
ceased working without the visualisation extra installed.

This module doesn't really need to be eagerly imported, and it's faffy
to refactor it all to use lazy imports.
mergify bot added a commit that referenced this pull request Sep 13, 2022
A recent change to the structure of the visualisation module in #8306
caused `matplotlib` to be eagerly imported when `qiskit.visualization`
was imported, since the internal `bloch` module was imported in the
`__init__`.  This means that `QuantumCircuit.draw()` in text mode had
ceased working without the visualisation extra installed.

This module doesn't really need to be eagerly imported, and it's faffy
to refactor it all to use lazy imports.

Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
ewinston added a commit to ewinston/qiskit that referenced this pull request Oct 5, 2022
commit a3076a50524a72f1bc91cb633ec5c67a765ef937
Merge: 06dfe40 b7e6329
Author: Erick Winston <[email protected]>
Date:   Wed Oct 5 09:02:28 2022 -0400

    Merge branch 'main' into controlflow/stochastic_swap

commit 06dfe40
Author: ewinston <[email protected]>
Date:   Tue Oct 4 23:34:42 2022 -0400

    Update qiskit/transpiler/passes/routing/stochastic_swap.py

    Co-authored-by: Jake Lishman <[email protected]>

commit 1487b80
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 23:33:34 2022 -0400

    simplify function and naming of control flow layer transpilation
    function

commit 5477c50
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 21:44:18 2022 -0400

    replace "maxind" with "deepest_index"

commit 02e704f
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 21:40:06 2022 -0400

    simplify determining idle qubits

commit 753a637
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 20:39:11 2022 -0400

    fix layer bug

    this fixes a bug where gates were dropped if they shared a layer with a
    control flow op.

commit 4dd68a9
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 11:48:01 2022 -0400

    remove _idle_wires function

commit d74b6ee
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 11:40:22 2022 -0400

    remove utils function for getting qubit order

commit 56029b1
Merge: 9d16884 53e215c
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 09:30:58 2022 -0400

    Merge branch 'main' into controlflow/stochastic_swap

commit 9d16884
Author: Erick Winston <[email protected]>
Date:   Tue Oct 4 03:00:22 2022 -0400

    make sure stochastic swap child instances get new seeds

commit dc5b23c
Author: Erick Winston <[email protected]>
Date:   Fri Sep 30 04:39:29 2022 -0400

    linting. fix merge error.

commit 302320d
Author: Erick Winston <[email protected]>
Date:   Fri Sep 30 04:32:39 2022 -0400

    merged main and renabled checkmap tests

commit 8ec9259
Merge: cb32908 3c9d8d5
Author: Erick Winston <[email protected]>
Date:   Fri Sep 30 04:14:53 2022 -0400

    Merge branch 'main' into controlflow/stochastic_swap

commit cb32908
Author: Erick Winston <[email protected]>
Date:   Fri Sep 30 02:28:01 2022 -0400

    updated to allow cf blocks with different registers than containing
    circuit.

commit fb0496e
Author: Erick Winston <[email protected]>
Date:   Thu Sep 29 15:38:28 2022 -0400

    fix while loop test

commit 463a466
Author: Erick Winston <[email protected]>
Date:   Wed Sep 28 14:26:14 2022 -0400

    simplify dadnode handling of swap and cz

commit 4f1af5b
Author: Erick Winston <[email protected]>
Date:   Thu Sep 8 13:16:15 2022 -0400

    remove merge artifact

commit 3133949
Merge: 3c85677 53231fb
Author: Erick Winston <[email protected]>
Date:   Thu Sep 8 13:15:18 2022 -0400

    Merge branch 'test_merge' into controlflow/stochastic_swap

commit 53231fb
Author: Erick Winston <[email protected]>
Date:   Thu Sep 8 12:24:55 2022 -0400

    remove redefiing coupling map in control flow context

commit 0161913
Author: Erick Winston <[email protected]>
Date:   Wed Jul 20 09:56:28 2022 -0400

    add controlflow handling to stochastic swap pass

commit 072c550
Author: Junye Huang <[email protected]>
Date:   Thu Sep 8 14:22:12 2022 +0200

    Add common usage explanations and code examples to qiskit.visualization module API page (Qiskit#8569)

    * add draft

    * revert unintended changes

    * revert unintended changes

    * add example usage

    * add common keyword arguments section

    * add sections to apis

    * fix internal links

    * remove generated hist figure

    * lint

    * use matplotlib instead of Matplotlib in class reference

    * change to a valid denisty matrix in examples

    * import from qiskit.visualization instead of qiskit.tools.visualization

    * remove unintended changes

    * split counts and state visualizations

    * remove overview and prerequisite headings

    * move common kwargs sections to the top level

    * remove link to api table

    * remove apis headings

    * remove extra blank lines

    * remove extra blank lines

    * minor twig on the counts to make them 1000 shots in total

    * add an intro sentence before the example for common kwargs

    Co-authored-by: Luciano Bello <[email protected]>
    Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>

commit 64bbeff
Author: Takashi Imamichi <[email protected]>
Date:   Thu Sep 8 19:38:53 2022 +0900

    Add an error check for Sampler (Qiskit#8678)

    * add an error check for sampler

    * update

    * Update qiskit/primitives/base_sampler.py

    Co-authored-by: Julien Gacon <[email protected]>

    * remove a duplicate check

    * update an error messgage

    Co-authored-by: Julien Gacon <[email protected]>

commit bb41815
Author: Luciano Bello <[email protected]>
Date:   Thu Sep 8 00:52:46 2022 +0200

    Remove deprecated pulse-builder contexts (Qiskit#8697)

    * Remove qiskit.pulse.builder.inline as deprecated in 0.18.0 (2021-07-13)

    * remove imports

    * remove test

    * Remove qiskit.pulse.builder.pad as deprecated in 0.18.0 (2021-07-13)

    * reno

    * Reword removal note

    Co-authored-by: Jake Lishman <[email protected]>

commit ee0a4f1
Author: Manoel Marques <[email protected]>
Date:   Wed Sep 7 14:35:47 2022 -0400

    Improve HHL/Shor deprecated messages (Qiskit#8699)

commit ea4ebed
Author: a-matsuo <[email protected]>
Date:   Wed Sep 7 17:33:53 2022 +0900

    Include primitive's run_options (Qiskit#8694)

    * include primitive's run_options

    * rename to get_local_run_options

commit a842f40
Author: Edwin Navarro <[email protected]>
Date:   Tue Sep 6 18:12:00 2022 -0700

    Move circuit drawer files to `qiskit.visualization.circuit` (Qiskit#8306)

    * Add graph and circuit dirs

    * Move files to new folders

    * Finishing transition to circuit and graph dirs

    * Finish import changes

    * Positioning files and setting init entries

    * Final tweaks to compatibility and lint

    * Reduce to circuit dir only

    * Cleanup

    * Add qcstyle stub for docs

    * Merge main conflicts fix

    * Lint

    * Change test message

    * Fix _directive change

    * Fix op.condition reference

    * Change to _utils and cleanup

    * Lint

    * Fix _trim and dag_drawer test

    * Allow direct import of text, etc.

    * Add comment explaining backwards-compatibility imports

    * Add release note

    Co-authored-by: Jake Lishman <[email protected]>

commit f4a5241
Author: Ikko Hamamura <[email protected]>
Date:   Tue Sep 6 00:37:43 2022 +0900

    Default run_options for Primitives (Qiskit#8513)

    * Add run_options to Primitives

    * rm unnecessary comments

    * initial commit of Settings dataclass

    * Revert "initial commit of Settings dataclass"

    This reverts commit 96b8479.

    * fix lint, improve docs, don't return self

    Co-authored-by: Julien Gacon <[email protected]>
    Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>

commit a8e553c
Author: a-matsuo <[email protected]>
Date:   Mon Sep 5 21:05:35 2022 +0900

    Gradients with the primitives (Qiskit#8528)

    * added the gradients with the primitives

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * add run_options and supported gate

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * added unittests

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * lint

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix based on the comments

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * add spsa gradient

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * simplify + async

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * added gradient variance

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * lint

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * added the run_options field

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix lint

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix based on comments

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * wip fix2

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * lint

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix epsilon and doc

    * lint

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix

    * Update qiskit/algorithms/gradients/base_sampler_gradient.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * Update qiskit/algorithms/gradients/base_sampler_gradient.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * Update qiskit/algorithms/gradients/base_estimator_gradient.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * Update qiskit/algorithms/gradients/base_sampler_gradient.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * Update qiskit/algorithms/gradients/base_estimator_gradient.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * Update qiskit/algorithms/gradients/base_estimator_gradient.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * change epsilon error

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * Update qiskit/algorithms/gradients/estimator_gradient_result.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * Update qiskit/algorithms/gradients/sampler_gradient_result.py

    Co-authored-by: Takashi Imamichi <[email protected]>

    * add gradient test

    * added batch size in spsa gradients

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * fix

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * lint

    * Update qiskit/algorithms/gradients/lin_comb_estimator_gradient.py

    Co-authored-by: Julien Gacon <[email protected]>

    * add operator tests

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * consistent name

    * rewrite spsa

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

    * use algorithm job

    Co-authored-by: Ikko Hamamura <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>
    Co-authored-by: Julien Gacon <[email protected]>
    Co-authored-by: Takashi Imamichi <[email protected]>

commit 879f7ba
Author: dalin27 <[email protected]>
Date:   Mon Sep 5 05:02:11 2022 +0300

    fixed issue 8670 by inverting qubits_coordinates and coupling_map (Qiskit#8671)

commit 3c85677
Merge: 33e0007 e9913e8
Author: Erick Winston <[email protected]>
Date:   Thu Sep 8 12:30:39 2022 -0400

    Merge branch 'main' into controlflow/stochastic_swap

commit 33e0007
Author: Erick Winston <[email protected]>
Date:   Thu Sep 8 12:24:55 2022 -0400

    remove redefiing coupling map in control flow context

commit cd9c5cf
Merge: ca4f477 aca01eb
Author: ewinston <[email protected]>
Date:   Sat Sep 3 02:15:59 2022 -0400

    Merge branch 'main' into controlflow/stochastic_swap

commit ca4f477
Author: Erick Winston <[email protected]>
Date:   Fri Sep 2 16:15:08 2022 -0400

    remove breakpoint

commit ee78880
Author: Erick Winston <[email protected]>
Date:   Fri Sep 2 16:13:38 2022 -0400

    fix check_map

commit ef35278
Author: Erick Winston <[email protected]>
Date:   Fri Sep 2 01:13:12 2022 -0400

    add check_map to tests. tests passing

commit 349dca4
Author: Erick Winston <[email protected]>
Date:   Thu Sep 1 11:29:47 2022 -0400

    add check_map

commit cb1398d
Author: Erick Winston <[email protected]>
Date:   Wed Aug 31 22:29:37 2022 -0400

    convert up to for loop

commit 3169afd
Author: Erick Winston <[email protected]>
Date:   Tue Aug 30 15:54:53 2022 -0400

    lint

commit 2b8d5bb
Author: Erick Winston <[email protected]>
Date:   Mon Aug 29 16:02:12 2022 -0400

    rmove `continue` handling. raise error on unsupported control flow op.

commit 12fb4bc
Author: Erick Winston <[email protected]>
Date:   Mon Aug 29 15:55:44 2022 -0400

    remove DAGCircuit.control_flow_ops

commit 9a0ad5c
Merge: 09f8490 82e38d1
Author: ewinston <[email protected]>
Date:   Fri Aug 12 10:46:41 2022 -0400

    Merge branch 'main' into controlflow/stochastic_swap

commit 09f8490
Author: Erick Winston <[email protected]>
Date:   Wed Jul 20 09:56:28 2022 -0400

    add controlflow handling to stochastic swap pass
jakelishman added a commit to jakelishman/qiskit-terra that referenced this pull request Nov 16, 2022
This was erroneously broken by Qiskitgh-8306 and not detected by lint because
of the existence of `qiskit.visualization.__getattr__`.  This reinstates
the functionality using the deprecated old instruction drawers.
mergify bot added a commit that referenced this pull request Nov 16, 2022
This was erroneously broken by gh-8306 and not detected by lint because
of the existence of `qiskit.visualization.__getattr__`.  This reinstates
the functionality using the deprecated old instruction drawers.

Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
mergify bot pushed a commit that referenced this pull request Nov 16, 2022
This was erroneously broken by gh-8306 and not detected by lint because
of the existence of `qiskit.visualization.__getattr__`.  This reinstates
the functionality using the deprecated old instruction drawers.

Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
(cherry picked from commit da1a7e3)
mergify bot added a commit that referenced this pull request Nov 16, 2022
This was erroneously broken by gh-8306 and not detected by lint because
of the existence of `qiskit.visualization.__getattr__`.  This reinstates
the functionality using the deprecated old instruction drawers.

Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
(cherry picked from commit da1a7e3)

Co-authored-by: Jake Lishman <[email protected]>
Cryoris pushed a commit to Cryoris/qiskit-terra that referenced this pull request Jan 12, 2023
This was erroneously broken by Qiskitgh-8306 and not detected by lint because
of the existence of `qiskit.visualization.__getattr__`.  This reinstates
the functionality using the deprecated old instruction drawers.

Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Changelog: API Change Include in the "Changed" section of the changelog Community PR PRs from contributors that are not 'members' of the Qiskit repo mod: visualization qiskit.visualization
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

6 participants