548 lines
12 KiB
Markdown
548 lines
12 KiB
Markdown
---
|
||
theme: custom-theme
|
||
---
|
||
|
||
# Perception & Color
|
||
|
||
## CAPP 30239
|
||
|
||
data:image/s3,"s3://crabby-images/f4a89/f4a89e7b8fb8af68fb395a9318ac999ed808f790" alt="bg right"
|
||
<!-- photo CC-By https://flickr.com/photos/andreaskrispler/4651412740/ -->
|
||
|
||
---
|
||
|
||
## Today
|
||
|
||
- What matters most when creating a visualization?
|
||
- How does human **perception** factor into visualization design?
|
||
- Understanding **color**, and computational representations of it.
|
||
|
||
---
|
||
|
||
## What is the most important question when creating a visualization?
|
||
|
||
---
|
||
|
||
## What is the most important question when creating a visualization?
|
||
|
||
<ul>
|
||
<li><s>Where will the data come from?</s>
|
||
<li><s>What type of chart do I use?</s></li>
|
||
<li>Who is the audience?</li>
|
||
</ul>
|
||
|
||
---
|
||
|
||
## Audience First
|
||
|
||
- Who are you presenting to?
|
||
- How familiar are they with the data?
|
||
- What is their numerical & visualization literacy?
|
||
- Via what medium will they receive the information?
|
||
- What are you trying to do? (Persuade, Inform, Inspire?)
|
||
|
||
*Only now can we start thinking about data and presentation.*
|
||
|
||
---
|
||
|
||
## Perception
|
||
|
||
- **Selective** - We can only pay attention to so much.
|
||
- **Patterns** - Our brains are pattern-matching machines, audience will benefit from intentional patterns & be distracted by unintentional ones.
|
||
- **Limited working memory** - We hold a very limited set of information in our minds at once.
|
||
|
||
---
|
||
|
||
## What do you see?
|
||
|
||
<div class="container">
|
||
<div class="col">
|
||
|
||
data:image/s3,"s3://crabby-images/3c29b/3c29b232eee6c5d9a35a8259fd1f727b3fe5b9c9" alt=""
|
||
|
||
</div><div class="col">
|
||
|
||
```python
|
||
alt.Chart(random_df).mark_point().encode(
|
||
alt.X("a"),
|
||
alt.Y("c"),
|
||
alt.Color("b"),
|
||
alt.Size("c"),
|
||
alt.Shape("a:N"),
|
||
alt.Fill("b"),
|
||
alt.Opacity("b"),
|
||
)
|
||
```
|
||
</div>
|
||
</div>
|
||
|
||
---
|
||
|
||
## What do you see?
|
||
|
||
<div class="container">
|
||
<div class="col">
|
||
|
||
data:image/s3,"s3://crabby-images/0cd96/0cd96bb228798c945243b8103b667435f237111d" alt=""
|
||
|
||
```
|
||
alt.Chart(random_df).mark_line().encode(
|
||
x="a",
|
||
y="c",
|
||
)`
|
||
```
|
||
|
||
</div>
|
||
</div>
|
||
|
||
---
|
||
|
||
## Effectiveness Revisited
|
||
|
||
data:image/s3,"s3://crabby-images/7cf2d/7cf2dbd2dc7f5a0e44f31c60c86e0649ac406e2b" alt="width:800px"
|
||
|
||
---
|
||
|
||
<div class="container">
|
||
|
||
<div class="col">
|
||
|
||
**Altair Channels**
|
||
|
||
- Position (`X, Y`)
|
||
- Angle (`Angle`)
|
||
- Area (`Radius`, `Size`)
|
||
- Hue, Saturation (`Color`)
|
||
- Texture (`Opacity`, `Fill`)
|
||
- Shape (mark type, `Shape`)
|
||
</div>
|
||
|
||
<div class="col">
|
||
|
||
**What about?**
|
||
- Length
|
||
- Slope
|
||
- Volume
|
||
- Density
|
||
- Connection
|
||
- Containment
|
||
</div>
|
||
</div>
|
||
|
||
---
|
||
|
||
**Derived Properties**
|
||
|
||
|
||
- Length/Area - size of bars (`X`, `Y`)
|
||
- Slope & Density - affected by scale
|
||
- Connection - ex. layering of lines w/ points
|
||
- Containment - achieved with layering
|
||
|
||
What about *volume*?
|
||
|
||
---
|
||
|
||
## Stevens' Power Law
|
||
|
||
Stevens (1975): Human response to sensory stimulus is characterized by a power law with different exponents with different stimuli.
|
||
|
||
perception = (magnitude of sensation)<sup>a</sup>
|
||
|
||
Smaller <sup>a</sup> exponent: harder to perceive changes.
|
||
|
||
Stevens measured values of a by exposing people to varied stimulus and asking them to compare magnitudes.
|
||
|
||
---
|
||
|
||
|
||
<div class="container"><div class="col">
|
||
|
||
data:image/s3,"s3://crabby-images/5a9d0/5a9d0ff3c1f677dd8f134aea4387960702f0bcc3" alt=""
|
||
|
||
</div><div class="col">
|
||
|
||
|
||
| Continuum | Exponent |
|
||
|-|-|
|
||
| Color **Brightness**| 0.33-0.5 |
|
||
| Smell| 0.6 |
|
||
| Loudness | 0.67 |
|
||
| **Depth Perception** | 0.67 |
|
||
| Area | 0.7 |
|
||
| 2D Planar Position | 1.0 |
|
||
| Warmth | 1.3-1.6 |
|
||
| Color **Saturation** | 1.7 |
|
||
| Electric Shock | 3.5 |
|
||
|
||
</div></div>
|
||
|
||
---
|
||
|
||
## 3D Graphs
|
||
|
||
data:image/s3,"s3://crabby-images/e8821/e88215578e234722e74967477ec43d36d46c6f52" alt=""
|
||
|
||
---
|
||
|
||
data:image/s3,"s3://crabby-images/74476/744769ef7baa9ec41ce7686a1f41a5898e465c4d" alt=""
|
||
|
||
---
|
||
|
||
data:image/s3,"s3://crabby-images/8f964/8f964898bff6209e7e58bb1c08bdb39ac7f28bcf" alt=""
|
||
|
||
---
|
||
|
||
## Instead of 3D Graphs
|
||
|
||
- Find other channels: hue & size are good candidates. (bubble chart)
|
||
- Or make multiple 2D graphs with XY/YZ/XZ pairs.
|
||
|
||
data:image/s3,"s3://crabby-images/55971/55971119fb5d0013cf62c95949b2debe9fc02be3" alt="bg left"
|
||
|
||
---
|
||
|
||
## What is Color?
|
||
|
||
Wavelengths of light are perceived as particular colors:
|
||
data:image/s3,"s3://crabby-images/50f43/50f4366357f3aa29e6208792fd423e0dc5cbb821" alt=""
|
||
|
||
What's missing?
|
||
|
||
<!-- credit: https://en.wikipedia.org/wiki/File:Linear_visible_spectrum.svg -->
|
||
|
||
---
|
||
|
||
## Color & the Eye
|
||
|
||
### Rods
|
||
|
||
- spread throughout retina
|
||
- more sensitive in low light conditions
|
||
- brightness ("lightness")
|
||
|
||
### Cones
|
||
|
||
- 3 types with peak sensitivity at different frequencies
|
||
- concentrated in center of eye
|
||
- less sensitive in low light conditions
|
||
- hue & saturation
|
||
|
||
data:image/s3,"s3://crabby-images/f7797/f77978cfbdaeec01e600a30d61b150b07a010801" alt="bg right"
|
||
|
||
<!-- source https://commons.wikimedia.org/wiki/File:Cone-fundamentals-with-srgb-spectrum.svg -->
|
||
|
||
---
|
||
|
||
## Spectrum vs. What We See
|
||
|
||
What we actually see is always a blend of multiple peaks.
|
||
|
||
This is impacted by ambient light conditions, as well as quirks of our visual processing.
|
||
|
||
data:image/s3,"s3://crabby-images/ae42c/ae42ce11972549f19f53ce2ccaa5cae28e591e46" alt="height:400px"
|
||
|
||
In actuality, multiple combinations of light can give same color (**metamers**).
|
||
|
||
---
|
||
|
||
## Chromatic Adaptation
|
||
|
||
data:image/s3,"s3://crabby-images/8d04c/8d04cb1fa1e771b746daf8ae45cc76f7a119c9c4" alt=""
|
||
|
||
Source: Andrew Steele <https://www.youtube.com/channel/UC-XYsDNh4-886rMNLnnwR_w>
|
||
|
||
---
|
||
|
||
## Color Naming
|
||
|
||
Color naming is highly subjective, and research has shown that the ability to name a color correlates highly with the ability to distinguish it.
|
||
|
||
data:image/s3,"s3://crabby-images/491e1/491e1e830e659f43e819a142d2764c47413733f1" alt="bg right"
|
||
|
||
Be particularly careful with blue/green boundaries, as there are significant cultural differences.
|
||
|
||
Source: https://blog.xkcd.com/2010/05/03/color-survey-results/
|
||
|
||
|
||
---
|
||
|
||
## Cultural Considerations
|
||
|
||
data:image/s3,"s3://crabby-images/3fc99/3fc99083a3f38fbcdc2489cca633623ba97d5c61" alt="bg right width:600px"
|
||
|
||
- American audiences associated <span color="red">red</span> & <span color="blue">blue</span> with political parties on any map in a political context.
|
||
- Also international meaning of <span color="red">red</span> & <span color="blue">blue</span> is flipped: red is left, blue is right.
|
||
- Most other colors have contradictory meanings depending on culture. For example, yellow might be chosen to denote success (parts of Africa) or be associated with death (Middle East).
|
||
|
||
<!--Source: https://www.color-meanings.com/color-symbolism-different-cultures/-->
|
||
|
||
<!-- image from wikipedia: UK House of Commons -->
|
||
|
||
---
|
||
|
||
## Color Vision Deficiency
|
||
|
||
More accurate name for what is commonly known as colorblindness.
|
||
|
||
- Red-Green CVD - most common
|
||
- four types: Dueteranomaly and Protanomaly (mild) to Protanopia and Dueteranopia (complete)
|
||
- Tritanomaly/Tritanopia: blue/green and yellow/red confusion.
|
||
- rarest, complete lack of color vision, usually corresponds to other vision issues as well
|
||
|
||
data:image/s3,"s3://crabby-images/86833/868337817237dff11ecc691783a7e20c0f28fa12" alt="bg right width:600px"
|
||
|
||
---
|
||
|
||
## Color on a Page
|
||
|
||
data:image/s3,"s3://crabby-images/663de/663de883cfb2b9723a0bbb298979bbf2efa98064" alt="bg right"
|
||
|
||
Ink absorbs light, so we work with subtractive blending. Our base colors are cyan, magenta, and yellow. To save on ink costs, we throw in black/contrast as well.
|
||
|
||
We call this CMYK color.
|
||
|
||
---
|
||
|
||
## Color on a Screen
|
||
|
||
Screens emit light, which means we use **additive blending** of red, green, and blue light. Every pixel of a screen can emit these three colors in different intensities.
|
||
|
||
|
||
|
||
data:image/s3,"s3://crabby-images/125d9/125d9cee708a71abb159fe33e01a0f350c6f6b8c" alt="bg right"
|
||
|
||
---
|
||
|
||
## Color Spaces
|
||
|
||
Ways of describing a color mathematically, usually have 3 components to match our perception of color:
|
||
|
||
- RGB (early photography)
|
||
- CIE XYZ (1931)
|
||
- HSB/HSV/HSL (1970s)
|
||
|
||
data:image/s3,"s3://crabby-images/17f26/17f261f4d5f80555fc1e5cc93c7da033f9f5f86f" alt="bg right width:700px"
|
||
|
||
<!-- https://commons.wikimedia.org/wiki/File:Rgb-compose-Alim_Khan.jpg -->
|
||
|
||
---
|
||
|
||
A common way to refer to colors is by their intensity in each of these three channels.
|
||
|
||
<span style="color: rgb(0% 100% 0%)">this is 0% red, 100% green, 0% blue intensity (#00ff00)</span>
|
||
<span style="color: rgb(20% 60% 20%)">this is 20% red, 60% green, 20% blue intensity: (#143c14)</span>
|
||
<span style="color: #ff00ff">this is 100% red, 0% green, 100% blue intensity: #ff00ff</span>
|
||
|
||
This is sometimes expressed in hexadecimal:
|
||
|
||
data:image/s3,"s3://crabby-images/7e190/7e190607c2a8a495f91ec1ade12c4f88c9dfcee5" alt="height:120px"
|
||
|
||
data:image/s3,"s3://crabby-images/b2736/b2736a4cf9589fa897a8f9053fa96c77c2b578a5" alt="bg right"
|
||
|
||
---
|
||
|
||
### RGB space as a cube
|
||
|
||
data:image/s3,"s3://crabby-images/0f0e1/0f0e16b28709fd2a01b4d6a8f959067cc5ddaaa7" alt="cube"
|
||
|
||
---
|
||
|
||
### RGB as pair plots
|
||
|
||
data:image/s3,"s3://crabby-images/c38a8/c38a84aca1809862c359dbe8d49ac7d2a6197143" alt="pair plots"
|
||
|
||
Remember this trick for your own 3-dimensional data!
|
||
|
||
---
|
||
|
||
data:image/s3,"s3://crabby-images/78e23/78e23ae2ef092ef167c4bcb570dcebcbd1b7dbdf" alt="height:500px"
|
||
|
||
A slice through the middle of the cube gives colors of comparable brightness. (You may have seen such a triangle in color pickers.)
|
||
|
||
---
|
||
|
||
## HSL
|
||
|
||
data:image/s3,"s3://crabby-images/28f77/28f770fd3752bf783d8b0d4c05999a1dac5efa8f" alt="height:500px"
|
||
|
||
An alternative color space that's very useful for visualization is HSL color space.
|
||
|
||
Hue, Saturation, Lightness | <https://hslpicker.com/>
|
||
|
||
---
|
||
|
||
## Aside: What about "alpha"?
|
||
|
||
You will often see a fourth channel: RGB**A**, HSL**A**.
|
||
|
||
This is known as alpha transparency (translucency).
|
||
|
||
This has to do with how the program in question *blends* the colors. The final pixel values on the screen will still be converted to RGB components.
|
||
|
||
- Use sparingly.
|
||
- Variations are very subtle, and background dependent.
|
||
|
||
<!-- image source: https://upload.wikimedia.org/wikipedia/commons/3/34/RGB_pixels.jpg -->
|
||
|
||
---
|
||
|
||
## CIE (RGB / XYZ / CIELAB)
|
||
|
||
Based on human perception experiments where people would adjust dials to recreate colors out of red, green, and blue light.
|
||
|
||
First from 1920s, revised in 1970s.
|
||
|
||
*Commission internationale de l'éclairage* (Illumination)
|
||
|
||
data:image/s3,"s3://crabby-images/f9488/f9488f7ddb139f57836856c2199900c6b298e665" alt="bg right"
|
||
|
||
---
|
||
|
||
## Screen Gamut
|
||
|
||
Screens can't show the entire range of visible colors accurately, they define a "gamut". Since ~1996 most devices aim at a standard gamut to ensure similar representations of color, but even high end devices are not perfectly aligned.
|
||
|
||
data:image/s3,"s3://crabby-images/22926/22926a68d4583dd97cf245620cef67cfdd51f607" alt="bg right"
|
||
|
||
Projectors (like the one you're likely viewing this on) usually have skewed gamut.
|
||
|
||
Moral of the story: **Consider your medium!**
|
||
|
||
---
|
||
|
||
## What does all this mean for visualization?
|
||
|
||
Color choices should be made with respect to:
|
||
|
||
- medium (screen vs. print, type of screen)
|
||
- audience (culture, vision differences, expectations)
|
||
- differentiability
|
||
|
||
Using HSL to build a palette allows you to choose uniform brightness/saturation and pick hues as close together/far apart as needed.
|
||
|
||
---
|
||
|
||
## Role of Color
|
||
|
||
- **Identify** - Different color per category/actor.
|
||
- opt for distinct hues
|
||
- **Group** - Group like entities using same/like colors.
|
||
- often with similar hues
|
||
- **Layer** - Overlay different information while keeping contrast.
|
||
- saturation differences very important to not overwhelm eye
|
||
- **Highlight** - Call out important/relevant information.
|
||
- brightness and hue differences important
|
||
|
||
---
|
||
|
||
## Color Channels & Data Types
|
||
|
||
### Lightness is perceived as ordered
|
||
|
||
Good for **Ordinal** variables
|
||
|
||
data:image/s3,"s3://crabby-images/c7d57/c7d57f5ebd7b6084adaaa8d134fece32067bd333" alt="height:50px"
|
||
|
||
**Quantitative** (Continuous) variables harder to discern
|
||
|
||
data:image/s3,"s3://crabby-images/2a93d/2a93d94f9a5736809102c693a939905d56746ab8" alt="height:50px"
|
||
|
||
### Hue typically unordered
|
||
|
||
**Nominal** variables.
|
||
|
||
data:image/s3,"s3://crabby-images/db8a8/db8a88c36e5e6cdc2e8026de886318bf8b566964" alt="height:50px"
|
||
|
||
---
|
||
|
||
### Types of Palettes
|
||
|
||
- Qualitative - Nominal data
|
||
- Sequential - Quantitative data
|
||
- Diverging - Data with a meaningful zero-point (increase/decrease, more/less)
|
||
|
||
data:image/s3,"s3://crabby-images/9ef59/9ef5941072a6fb897ca845ae8c18044faa8264ae" alt=""
|
||
|
||
<!-- source: Peter Aldhous, NICAR 2016 -->
|
||
|
||
---
|
||
|
||
### Hue Separation
|
||
|
||
Pick distinct hues for unrelated variables.
|
||
|
||
Grouped schemes can be used where there are relationships among the categories.
|
||
|
||
data:image/s3,"s3://crabby-images/a8595/a8595f77cec304ec95e927cb5460a3fe21f36597" alt="bg left width:600px"
|
||
|
||
<https://vega.github.io/vega/docs/schemes/>
|
||
|
||
---
|
||
|
||
## Color Tips
|
||
|
||
- Aim for no more than ~6 colors that need to be distinguished.
|
||
- Colors should be distinct & differentiable by name.
|
||
- Be mindful of cultural considerations & symbolism.
|
||
- Ensure color schemes chosen appropriately for types of data.
|
||
- "Get it right in black & white"
|
||
|
||
|
||
---
|
||
|
||
## "Get it right in black & white"
|
||
|
||
A common mantra among visual designers.
|
||
|
||
Ensure that your hues have different brightness levels.
|
||
|
||
Ensure that you aren't using hue alone for your image.
|
||
|
||
data:image/s3,"s3://crabby-images/0303f/0303fb04fe8689012c5a97a00f83ed22c1fda718" alt="bg left width:600px"
|
||
|
||
---
|
||
|
||
## Text Legibility
|
||
|
||
An important issue when using colored text and/or backgrounds is **legibility**.
|
||
|
||
Web Content Accessibility Guidelines require a 4.5 color contrast (3:1 for large text).
|
||
|
||
Minimize *saturation* in backgrounds, pick a font color with opposing *lightness*.
|
||
|
||
<https://webaim.org/resources/contrastchecker/>
|
||
|
||
data:image/s3,"s3://crabby-images/c3d5f/c3d5f429659cfa340e9def9f5502789d34626bcf" alt="bg left width:600px"
|
||
|
||
|
||
---
|
||
|
||
## Tools
|
||
|
||
- Vega Schemes: https://vega.github.io/vega/docs/schemes/
|
||
- Contrast/theme exploration: https://schubert-da.github.io/dataviz-palette-tool/
|
||
- Theme exploration for cartography: <https://colorbrewer2.org/>
|
||
- Color-theory based theme creator: https://meodai.github.io/poline/
|
||
- Theme creator w/ theme sharing: https://coolors.co
|
||
- HSL/RGB picker: <https://hslpicker.com/>
|
||
- Contast checker: <https://webaim.org/resources/contrastchecker/>
|
||
|
||
### Color-Blindness
|
||
|
||
- MacOS/iOS app: https://michelf.ca/projects/sim-daltonism/
|
||
- Browser extensions (search "colorblindness" in your browser of choice)
|
||
|
||
---
|
||
|
||
## Acknowledgements & References
|
||
|
||
Thanks to Alex Hale, Andrew McNutt, and Jessica Hullman for sharing their materials.
|
||
|
||
Color space images are from <https://jamie-wong.com/post/color/>, which is an incredible resource if you'd like to go deeper into both the biology and math of color.
|
||
|
||
- https://www.math.csi.cuny.edu/~mvj/GC-DataViz-S23/lectures/L6.html
|
||
- https://en.wikipedia.org/wiki/Stevens%27s_power_law
|
||
- https://colorusage.arc.nasa.gov
|
||
- https://vega.github.io/vega/docs/schemes/
|