Skip to content
This repository was archived by the owner on Mar 4, 2025. It is now read-only.
/ QrandomSelection Public archive

This repository contains the source code of research paper titled: "A Generalized Quantum Algorithm for Assuring Fairness in Random Selection Among 2ⁿ Participants."

Notifications You must be signed in to change notification settings

mr-ravin/QrandomSelection

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

QrandomSelection

This repository contains the source code for the research paper titled "A Generalized Quantum Algorithm for Assuring Fairness in Random Selection Among 2ⁿ Participants." The paper was published in SN Computer Science (Springer Nature Journal) on March 14, 2020.

📜 Research Paper Details

📖 Cite this Paper:

Kumar, R. A Generalized Quantum Algorithm for Assuring Fairness in Random Selection Among 2N Participants.  
SN COMPUT. SCI. 1, 86 (2020). https://doi.org/10.1007/s42979-020-0091-z

🔧 Development Details

📦 Dependencies

qiskit: 0.46.0
pylatexenc: 2.10

📥 Installation

Install using pip:

pip install qrandom

Or directly from GitHub:

pip install git+https://github.com/mr-ravin/QrandomSelection.git

🚀 Usage Guide

🎲 Random Selection Using a Quantum Circuit

Generate a quantum circuit for 'N' participants:

import qrandom
res = qrandom.select(8)  # 8 represents the total number of participants.

🖼 Visualizing the Quantum Circuit

Save the pictorial representation of the quantum circuit:

import qrandom
qrandom.vis_circuit(8, "file_name.png")  # Saves the circuit diagram for 8 participants as file_name.png

fig 1

Fig. 1 Quantum Circuit for 8 participants.


⚖️ License

Copyright (c) 2018 Ravin Kumar
Website: https://mr-ravin.github.io

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation 
files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, 
modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the 
Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the 
Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE 
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.