Skip to main content

A lightweight package for generating visually distinct colours.

Project description

distinctipy logo

tests build codecov DOI Documentation Status

distinctipy is a lightweight python package providing functions to generate colours that are visually distinct from one another.

Commonly available qualitative colormaps provided by the likes of matplotlib generally have no more than 20 colours, but for some applications it is useful to have many more colours that are clearly different from one another. distinctipy can generate lists of colours of any length, with each new colour added to the list being as visually distinct from the pre-existing colours in the list as possible.

Installation

distinctipy is designed for Python 3 and can be installed with pip by running:

python -m pip install distinctipy

Alternatively clone the repo and install it locally:

git clone https://github.com/alan-turing-institute/distinctipy.git
cd distinctipy
python -m pip install .

Optional Dependencies

Starting in version 1.2.1 distinctipy no longer bundles matplotlib, pandas or dev dependencies in the default installation. If you wish to view colours (e.g. with distinctipy.color_swatch) or examples you will need matplotlib and pandas installed. To do this, either install distinctipy with the optional flag:

python -m pip install distinctipy[extras]

⚠️ Warning ⚠️ Previous versions of distinctipy (before 1.3) used [optional] instead of [extras].

Or install them separately:

python -m pip install matplotlib pandas

For developers, to install the stack needed to run tests, generate docs etc. use:

python -m pip install distinctipy[extras,tests,docs]

Usage and Examples

distinctipy can:

  • Generate N visually distinct colours: distinctipy.get_colors(N)
  • Generate colours that are distinct from an existing list of colours: distinctipy.get_colors(N, existing_colors)
  • Generate pastel colours: distinctipy.get_colors(N, pastel_factor=0.7)
  • Select black or white as the best font colour for any background colour: distinctipy.get_text_color(background_color)
  • Convert lists of colours into matplotlib colormaps: distinctipy.get_colormap(colors)
  • Invert colours: distinctipy.invert_colors(colors)
  • Nicely display generated colours: distinctipy.color_swatch(colors)
  • Compare distinctipy colours to other common colormaps: examples.compare_clusters() and examples.compare_colors()
  • Simulate how colours look for someone with colourblindness: colorblind.simulate_colors(colors, colorblind_type='Deuteranomaly')
  • Attempt to generate colours as distinct as possible for someone with colourblindness distinctipy.get_colors(N, existing_colors, colorblind_type="Deuteranomaly")

For example, to create and then display N = 36 visually distinct colours:

import distinctipy

# number of colours to generate
N = 36

# generate N visually distinct colours
colors = distinctipy.get_colors(N)

# display the colours
distinctipy.color_swatch(colors)

More detailed usage and example output can be found in the notebook examples.ipynb and examples gallery.

References

distinctipy was heavily influenced and inspired by several web sources and stack overflow answers. In particular:

Citing distinctipy

If you would like to cite distinctipy, please refer to the upload of the package on Zenodo: https://doi.org/10.5281/zenodo.3985191

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

distinctipy-1.3.4.tar.gz (29.7 kB view details)

Uploaded Source

Built Distribution

distinctipy-1.3.4-py3-none-any.whl (26.7 kB view details)

Uploaded Python 3

File details

Details for the file distinctipy-1.3.4.tar.gz.

File metadata

  • Download URL: distinctipy-1.3.4.tar.gz
  • Upload date:
  • Size: 29.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for distinctipy-1.3.4.tar.gz
Algorithm Hash digest
SHA256 fed97afff1afb73ecaa87c85461021f0ba89fae63067c0125b9673526510aac4
MD5 f5bf5cd679cfb88e510b233774bce2ee
BLAKE2b-256 8c3ce0b90a5bc396e2abaf207d9a41ea8aeab1f41760425262474903bade6a7b

See more details on using hashes here.

File details

Details for the file distinctipy-1.3.4-py3-none-any.whl.

File metadata

  • Download URL: distinctipy-1.3.4-py3-none-any.whl
  • Upload date:
  • Size: 26.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for distinctipy-1.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 2bf57d9d20dbc5c2fd462298573cc963c037f493d04ec61e94cb8d0bf5023c74
MD5 7c9280d4de2cea7d6ab1d0440cb59ede
BLAKE2b-256 0a75fa882538bdb0c8fc4459f1595a761591b827691936d57c08c492676f19bc

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