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.3.tar.gz (214.0 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for dwd-1.0.3.tar.gz
Algorithm Hash digest
SHA256 9d7846141989d187f20e5983819bac48198821895b3f9f0318437b54ca153d31
MD5 3028c8986569cb64d09ce643ffbbf822
BLAKE2b-256 091e1b35d8d51a950e0643bbfb6cddd1d98754b2d02ba136abc4c9e70a99bdbd

See more details on using hashes here.

File details

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

File metadata

  • Download URL: dwd-1.0.3-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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 63aebd2cdf1d4e933fb2b9e72b7dae6fc70688a7924822e32c30a62b35d722dc
MD5 ad931635d13b19116f0aa0c28d20c235
BLAKE2b-256 b5369a047d79b6a0c741ffcb7a79c5fa494564b6d20f709a505c7266f993aeea

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