data:image/s3,"s3://crabby-images/b1ea8/b1ea857ba6f00ca1aff0c841b15a403479412402" alt="image"
Review: Validation
data:image/s3,"s3://crabby-images/16f97/16f97fc142d62b2f54dd984e7229b55749bdb53d" alt="image"
Where are We?
data:image/s3,"s3://crabby-images/d4be7/d4be79d8fcbf414d4b6c3deef76006e723afeec2" alt="image"
The Big Picture
- Datasets are often large and complex so drawing all of them into a single static view can be overwhelming.
- What options are available to handle such complexity? There are five.
- 1. Change a view over time (this lecture)
-
- Derive new data (Lecture 3)
- 3. Facet data by partitioning into multiple juxtaposed views (this lecture)
-
- Reduce the amount of data (next lecture)
-
- Embed focus and context information within a single view (next lecture)
Change View over Time
- Changing the view over time is the most obvious, popular, and flexible choice in vis design.
- Unavailable in printed visualizations
- Let users modify the view.
- Change the encoding
- Change the arrangement
- Change the order
- Change the viewpoint
- Change which attributes are filtered
- Change the aggregation level
- $\dots$
Changing the Encoding
- Tableau
- Encoding
- Arrangement
- Mark type/size/color
- $\dots$
Changing the Order
- Reordering, often called sorting, is a powerful choice for finding patterns in a dataset by interactively changing the attribute that is used to order the data.
- Widely-used for table datasets
- Order by student_id, order by score, …
- What if there are multiple attributes that can be used for sorting?
Example: LineUp
- Designed to support exploration of tables with many attributes through interactive reordering and realigning.
data:image/s3,"s3://crabby-images/bfc30/bfc305395114deb64d9601307b68792a1a2248ba" alt="image"
- Order universities by 0.25 * (Research) + 0.25 * (Citations) + $\dots$
- Changing the alignment and arrangement of stacked bars:
data:image/s3,"s3://crabby-images/b16a2/b16a254ff9d87c8b9f517c39e1091c9d3fefa14a" alt="image"
Summary: LineUp
data:image/s3,"s3://crabby-images/71ef0/71ef0f5cbf25f55522ca93c126b113280bffb3fb" alt="image"
Animated Transition
- When changing a view, you can provide animated transition.
- A series of frames is generated to smoothly transition from one state to another.
- vs. jump cut (no animation, simply redraw the view)
- https://sanddance.js.org/app/
data:image/s3,"s3://crabby-images/8885b/8885b041bda953b26a6b918d014305e1a3bb2f92" alt="image"
data:image/s3,"s3://crabby-images/af957/af95745cc15d8867203587ce6b4447511ce59c2a" alt="image"
- Benefits:
- Help users maintain a sense of context
- Animation seems cool
- Drawbacks:
- Hard to implement
- Hard to follow if too much change
- Change blindness
- cf. staggered animation
data:image/s3,"s3://crabby-images/efad2/efad2f6451238b3ef25d8be25440c7c0e0a54c82" alt="image"
Staggered Animation
- 1) Color transition + move up
- 2) Move left
data:image/s3,"s3://crabby-images/c79f3/c79f3f4251a31af26b903d994583e1ce72b85065" alt="image"
Select an Element
- Users need to select an element before they change it.
- Design choices:
- What can be a target?
- a bar? a group of bars? an axis? a view? a legend?
- What are the possible selection types?
- selected / not selected
- selected + hovered / selected / hovered / not selected
- {selected, hovered, faded out}!
- How many items can be in the selection at once? one? many?
- What is the default? empty? a default item? all?
Highlight an Element
- Selected elements are highlighted by changing their visual appearance, providing users with immediate visual feedback.
- Design choices for highlighting
- Changing color
- Adding an outline
- Using the size channel
- Using motion coding
- Adding shadows
data:image/s3,"s3://crabby-images/925a4/925a4b0a5820b57a03b30b17ce63185e9b6963f1" alt="image"
Example: Context-Preserving Visual Links
- Links are drawn as curves that are carefully routed between existing elements in a vis.
data:image/s3,"s3://crabby-images/d04db/d04db4447e0f804201b707dae769e1ccb24ffd62" alt="image"
Navigate a View
- Navigation: changing the point of view from which things are drawn
- Only items in the frame are visible
- Three components of navigation:
- Zooming: moves the camera closer to or farther from the plane
- Panning: moves the camera parallel to the plane of the image, either up and down or from side to side
- Rotating: spins the camera around an axis
Zooming
- Geometric zooming: analogous to navigation through the physical world
- Things get bigger but not change.
- Semantic zooming: the representation of the object adapts to the number of pixels available in the image-space region occupied by the object
- Things get bigger and change.
data:image/s3,"s3://crabby-images/0dba1/0dba1d892a7c15a99556e1bfe441017278bc4e1f" alt="image"
Reducing Attributes
- Given 3D data points,
- A slice operation leaves data points that have a specific value on a specific dimension.
- (x, y, z) such that z = 3.0
- Dimensionality is reduced by 1
- A cut operation leaves data points under or over a cutting plane
- (x, y, z) such that ax + by + cz < d
- A project operation multiplies a projection matrix X (linear projection).
Example: Slice and Cut
data:image/s3,"s3://crabby-images/bc62e/bc62ebb928a27f3f3c8f52bed6dd56e687ae914d" alt="image"
Example: Project
- Principal Component Analysis (PCA)
data:image/s3,"s3://crabby-images/34dbd/34dbd6a53a1fa4042e19f904c8620f8effa738e3" alt="image"
Facet into Multiple Views
- Facet: split data into multiple views
- Design choices:
- Do the two views use the same visual encoding?
- Do the two views share data?
- Do the two views share navigation?
- If we pan one view, does the other change?
- How are the two views placed?
Coordinated Views
- Coordinated/linked views: multiple views relevant to each other
- Do the views use the same encoding?
- If yes, shared encoding
- Otherwise, multiform encoding
- How much data is shared between the coordinated views?
- Shared data if all data is shared.
- Overview/detail if one view shows a subset of what is in the other.
- Small multiples if the views show different partitions of the dataset into disjoint pieces.
data:image/s3,"s3://crabby-images/90cdd/90cdd841b8fec6b44a5a79c2c88fca5478f671c7" alt="image"
Example: Exploratory Data Visualizer
- If multiform views are coordinated, we can inspect multiple aspects of the same data at once (with different encodings)
- Called linked highlighting (very common interaction idiom in practice)
data:image/s3,"s3://crabby-images/6362a/6362a39088ebe01aa6ff2b160ad60af50d9f3270" alt="image"
Summary: Exploratory Data Visualizer
data:image/s3,"s3://crabby-images/e7a72/e7a7236865588902603fa90dfe9c31f4577f8d97" alt="image"
Overview/Detail
- In overview/detail, one of the views shows information about the entire dataset to provide an overview of everything.
- e.g., minimaps
data:image/s3,"s3://crabby-images/dfc07/dfc07ec5aa14b55a8ee0fc9c0b412a55d7e9dde8" alt="image"
Example: Bird’s-Eye Maps
data:image/s3,"s3://crabby-images/f6488/f648811ba0c42843237b856e27d941bea1846db7" alt="image"
data:image/s3,"s3://crabby-images/ebd27/ebd27687359d0b4ab41520c4d9a5acc894cec5af" alt="image"
data:image/s3,"s3://crabby-images/40b8f/40b8f782bcecfa3cead03501d1ba07fa837e79b8" alt="image"
Small Multiples
- In small multiples, views share the same encoding but show different data (different set of rows)
data:image/s3,"s3://crabby-images/61f03/61f0327428b60285492945b19cd2016b4fe54bcc" alt="image"
Example: Cerebral
data:image/s3,"s3://crabby-images/aeba7/aeba70925783509a4b6db42b9d04b644ae28b977" alt="image"
Summary: Cerebral
data:image/s3,"s3://crabby-images/c77c4/c77c41894b403af50be009f5c1adc77fdc8094bd" alt="image"
Shared Navigation
- In many overview/detail approaches, navigation is synchronized between the overview and the detail view
data:image/s3,"s3://crabby-images/c4381/c4381dae40ee5fb9217d99f2a1ad165f86d2065c" alt="image"
Partition into Views
- A multiattribute dataset should be partitioned into meaningful groups to be visualized in multiple views.
- = How to create multiples in small multiples?
- How to partition?
- by a categorical attribute (e.g., grouping)
- by a quantitative attribute (e.g., binning)
- by similarity (e.g., clustering)
- How to align partitions?
- List alignment, matrix alignment, and recursive subdivision
data:image/s3,"s3://crabby-images/81411/81411e9b821395bc94e1707b0e91f17ce6c083cc" alt="image"
Example: Grouped Bar Charts (List Alignment)
data:image/s3,"s3://crabby-images/331f0/331f051e02522116e22f76b5e2b0e579539d66b2" alt="image"
Example: Trellis (Matrix Alignment)
- Group by site
- 6 levels
- where the barley was grown
- Group by year
- Map variety to y
- Map yield to x
- Main-effect ordering in (a)
data:image/s3,"s3://crabby-images/b9bcb/b9bcb3c76e9e0177dbab53320284f7db00a9fd54" alt="image"
Example: Trellis
- Color encoding for comparison
data:image/s3,"s3://crabby-images/d273c/d273ca470efd4b1549418936230fa1e17d9f7bcc" alt="image"
Example: HiVE (Recursive Subdivision)
- Visualizing one million property transaction data in London
- House type: Flat (flats), Ter (attached terrace houses), Semi (semidetached house), and Det (fully detached house)
- Time of sale: year/month
- Neighborhood: 33 levels
- How would you visualize this data?
- Split by house type
- Split by neighborhood
- A cell is a heatmap that shows time with years as columns and months rows.
data:image/s3,"s3://crabby-images/81206/8120636aadac888ce54a0dd02e1afe38b67207b0" alt="image"
- Split by neighborhood first
- Split by house type
- A cell is a heatmap that shows time with years as columns and months rows.
data:image/s3,"s3://crabby-images/20181/20181696e8e5574010f68ae758a9d8d16ac3d2a0" alt="image"
- Split by house type (Treemap)
- Split by neighborhood
- A cell is a heatmap that shows time with years as columns and months rows.
data:image/s3,"s3://crabby-images/0a9ca/0a9ca6ab158a3cc00d5262cd847b23d719651185" alt="image"
- Split by house type
- Arrange by neighborhood
data:image/s3,"s3://crabby-images/ef3f1/ef3f13d88314de00ac760a2766d04de184623361" alt="image"
Superimpose Layers
- Superimposed layers: you can place multiple views at the same location
- Design choices:
- How many layers are used?
- How are the layers visually distinguished from each other?
- Is there a small static set of layers that do not change, or are the layers constructed dynamically in response to user selection?
Example: Static Layers
data:image/s3,"s3://crabby-images/ab797/ab7975fc29e79b40576b5f84e3939c680950330a" alt="image"
Example: Superimposed Line Charts
- Shows the scalability issue of superimposition
data:image/s3,"s3://crabby-images/caea6/caea665e48225e1946b19809bb060661302bf230" alt="image"
Example: Horizon Graph
data:image/s3,"s3://crabby-images/3461c/3461c52683996ce4521d7c41ab533b9dfbadec93" alt="image"
Example: Dynamic Layers
- With dynamic layers, a layer with different salience than the rest of the view is constructed interactively.
- Highlight one-hop-away nodes
data:image/s3,"s3://crabby-images/d6ca6/d6ca64d110a8fdf7627539df9c210ac328ba67bd" alt="image"
Summary – Interacting with Views
- Changing a single view (manipulate): encoding, arrangement, order
- Viewpoint: pan, zoom (geometric/semantic), rotate
- Data: slice, cut, and project
- Multiple coordinated views (facet)
- Juxtaposition (multiform, overview/detail, small multiples)
- Partition
- Superimpose (static/dynamic)
data:image/s3,"s3://crabby-images/d9beb/d9beb3b2fdcaca685b1b3583cbe1cc43e8e326e4" alt="image"
댓글남기기