Skip to main content

A package for the Helstrom Quantum Centroid classifier

Project description

Build Status Build status CircleCI Documentation Status codecov PyPi Status Downloads

Helstrom Quantum Centroid Classifier

The Helstrom Quantum Centroid (HQC) classifier is a quantum-inspired supervised classification approach for data with binary classes (ie. data with 2 classes only). By quantum-inspired, we mean a classification process which employs and exploits Quantum Theory.

It is inspired by the quantum Helstrom observable which acts on the distinguishability between quantum patterns rather than classical patterns of a dataset.

The HQC classifier is based on research undertaken by Giuseppe Sergioli, Roberto Giuntini and Hector Freytes, in their paper:

Sergioli G, Giuntini R, Freytes H (2019) A new quantum approach to binary classification. PLoS ONE 14(5): e0216224.
https://doi.org/10.1371/journal.pone.0216224

This Python package includes the option to vary four hyperparameters which are used to optimize the performance of the HQC classifier:

  • There is an option to rescale the dataset.
  • There are two options to choose how the classical dataset is encoded into quantum densities: inverse of the standard stereographic projection or amplitude encoding method.
  • There is an option to choose the number of copies to take for the quantum densities.
  • There are two options to assign class weights to the quantum Helstrom observable terms: equiprobable or weighted.

These hyperparameters are used in combination together to hypertune and optimize the accuracy of the HQC classifier to a given dataset.

The package also includes an option for parallel computing using Joblib and an option to split datasets into subsets or batches for optimal speed performance. Parallelization is performed over the two classes and subset splits or batches.

It is shown in the paper by Sergioli G, Giuntini R and Freytes H that the HQC classifier, on average, outperforms a variety of commonly used classifiers over 14 real-world and artificial datasets, in particular when the hyperparameter, number of copies, is increased. A summary of the performances of the different classifiers examined are shown in the table below:

Rank Classifier Average Success Rate (%)
1 HelstromQuantumCentroid4 72.80
2 HelstromQuantumCentroid3 65.13
3 GaussianNB 58.00
4 HelstromQuantumCentroid2 57.07
5 HelstromQuantumCentroid1 56.60
5 QuadraticDiscriminantAnalysis 56.60
6 GradientBoostingClassifier 52.73
7 ExtraTreesClassifier 51.93
8 KNeighborsClassifier 51.47
9 NearestCentroid 49.13
10 RandomForestClassifier 45.87
11 QuantumNearestMeanCentroid 43.93
12 AdaBoostClassifier 42.93
13 LinearDiscriminantAnalysis 42.00
14 LogisticRegression 36.40
15 BernoulliNB 17.40

*Average success rate is the average number of datasets where the specified classifier outperforms the other classifiers over 14 real-world and artificial datasets. HelstromQuantumCentroidn is the HQC classifier corresponding to the n number of copies taken for the quantum densities.

The HQC classifier is a true probabilistic classifier, ie. a classifier which gives the class membership probability estimates for each sample without having to use any scaling methods. This means that the probability estimates (from predict_proba) are consistent with the scores (from predict).

Source Code

The Python package's source code for the HQC classifier is available here: https://github.com/leockl/helstrom-quantum-centroid-classifier/blob/master/hqc/hqc.py

Documentation

The documentation, including how to install the Python package, how to use the Python package and how the HQC classifier algorithm works, are available here: https://helstrom-quantum-centroid-classifier.readthedocs.io/en/latest/

License

This Python package is licensed under the BSD 3-Clause License, available here: https://github.com/leockl/helstrom-quantum-centroid-classifier/blob/master/LICENSE

References

Sergioli G, Giuntini R, Freytes H (2019) A new quantum approach to binary classification. PLoS ONE 14(5): e0216224. https://doi.org/10.1371/journal.pone.0216224

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hqc-0.1.4.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

hqc-0.1.4-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file hqc-0.1.4.tar.gz.

File metadata

  • Download URL: hqc-0.1.4.tar.gz
  • Upload date:
  • Size: 10.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/50.0.3 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.1

File hashes

Hashes for hqc-0.1.4.tar.gz
Algorithm Hash digest
SHA256 ef03310a497196f5d085833205cebd74c0f820aa1cfd5935add1964245395a23
MD5 d0545fe6cf1fb8724df983e09612bbb8
BLAKE2b-256 ab9609c62515143307c5c58dc63adadd8925f6187d7bc629e7e8b6e60e40ef13

See more details on using hashes here.

File details

Details for the file hqc-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: hqc-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/50.0.3 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.1

File hashes

Hashes for hqc-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 41e6008c68a8922ac6cb44073eb09b51fce2c1c8e4714cc345016933b5f4965a
MD5 e04519837ae15c190068e527dbcd66ce
BLAKE2b-256 adbb2c5b81f5ad2d150e6f2a9d365b99e1600e91e4a88403bef37e136adbdf99

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page