Skip to main content

Distance Weighted Discrimination for Python

Project description

Overview

This package implements Distance Weighted Discrimination (DWD). DWD For details see (Marron et al 2007, Wang and Zou 2018). Originally implemented in Python by Iain Carmichael. Currently maintained by Kitware, Inc.

The package currently implements:

  • Original DWD formulation solved with Second Order Cone Programming (SOCP) and solved using cvxpy.

  • Genralized DWD (gDWD) and kernel gDWD solved with the Majorization-Minimization algorithm presented in Wang and Zou, 2018.

Marron, James Stephen, Michael J. Todd, and Jeongyoun Ahn. "Distance-weighted discrimination." Journal of the American Statistical Association 102, no. 480 (2007): 1267-1271.

Wang, Boxiang, and Hui Zou. "Another look at distance‐weighted discrimination." Journal of the Royal Statistical Society: Series B (Statistical Methodology) 80, no. 1 (2018): 177-198.

Installation

The DWD package can be installed via pip or github. This package is currently only tested in python 3.6.

$ pip install dwd

Flit is used for packaging, and all package metadata is stored in pyproject.toml. To install this project locally or for development, use flit install or build a pip-installable wheel with flit build.

Example

  from sklearn.datasets import make_blobs, make_circles
  from dwd import DWD, KernGDWD

  # sample sythetic training data
  X, y = make_blobs(n_samples=200, n_features=2,
                    centers=[[0, 0],
                             [2, 2]])

  # fit DWD classifier
  dwd = DWD(C='auto').fit(X, y)

  # compute training accuracy
  dwd.score(X, y)

  0.94

dwd_sep_hyperplane

# sample some non-linear, toy data
X, y = make_circles(n_samples=200, noise=0.2, factor=0.5, random_state=1)

# fit kernel DWD wit gaussian kernel
kdwd = KernGDWD(lambd=.1, kernel='rbf',
                kernel_kws={'gamma': 1}).fit(X, y)

# compute training accuracy
kdwd.score(X, y)

0.915

kern_dwd

For more example code see these example notebooks (including the code to generate the above figures). If the notebooks aren't loading on github you can copy/paste the notebook url into https://nbviewer.jupyter.org/.

Help and Support

Additional documentation, examples and code revisions are coming soon.

Documentation

The source code is located on github: https://github.com/slicersalt/dwd

Testing

Testing is done using nose.

Contributing

We welcome contributions to make this a stronger package: data examples, bug fixes, spelling errors, new features, etc.

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

dwd-1.0.4.tar.gz (214.1 kB view details)

Uploaded Source

Built Distribution

dwd-1.0.4-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file dwd-1.0.4.tar.gz.

File metadata

  • Download URL: dwd-1.0.4.tar.gz
  • Upload date:
  • Size: 214.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.25.1

File hashes

Hashes for dwd-1.0.4.tar.gz
Algorithm Hash digest
SHA256 38c26e9a7b24cb8e491d8238be7d42190aa25f88c01e87a306bf1afc4d47bc3d
MD5 fa1d8d8287ceaa7f78fd006fd4d98323
BLAKE2b-256 875c1acad7093225fd0f053ef3c63db8320b84888f28fee9576c7d10b52359fd

See more details on using hashes here.

File details

Details for the file dwd-1.0.4-py3-none-any.whl.

File metadata

  • Download URL: dwd-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 22.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.25.1

File hashes

Hashes for dwd-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 03f59fb93fdddc7fd48beda90af0bfbc960fc070c6e5a63495812fed8515a4d0
MD5 82385989a8acf2ee1d7772ca22a491a7
BLAKE2b-256 47c78fffe774ed0927f753b5e0f8a898c5211489fe9583ad49251045fd6e6073

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