data:image/s3,"s3://crabby-images/b1ea8/b1ea857ba6f00ca1aff0c841b15a403479412402" alt="image"
Networks and Trees
- A network (or graph) is made up of nodes and links and specifies the relationship between two or more nodes.
- Trees do not have cycles.
- Nodes and links can have attributes independently.
- Example: social network on Facebook
- Node: accounts (people, organizations, or pages)
- Link: friendship (or subscription)
- Node attributes: name, photo, website_url, …
- Link attributes: last interaction time, …
Network Visualization in InfoVis
- Network visualization is one of the oldest research areas in InfoVis.
- Flight network
- Road network (junctions and roads)
- World Wide Web
- Social networks
- Biological pathways
- Bitcoin Transactions
- Artificial Neural Networks
Two Families of Visualization
- Node link diagram
- Uses the connection channels
- Adjacency Matrix
- The big question: which is better?
- Scalability
- Effectiveness
- Interactivity
data:image/s3,"s3://crabby-images/f924a/f924a793dd0e31dd63b69a82be56ab91b33b8c1b" alt="image"
Node Link Diagram
- In a node link diagram, nodes are drawn as point marks and the links connecting them are drawn as line marks.
- Triangular vertical node link layout
- Spline radial layout
data:image/s3,"s3://crabby-images/0c0e2/0c0e2047dce6938a45bfca09710ae8df88c79eb2" alt="image"
Vertical Node-Link Layout
- Root on the top
- Leaves on the bottom
- Vertial spatial position shows depth
- Horizon tal spatial position does not encode an attribute.
- Chosen by a layout algorithm
data:image/s3,"s3://crabby-images/abd28/abd287ce12971544b969d034644b30df3d1b4f5a" alt="image"
Horizontal Node-Link Layout
data:image/s3,"s3://crabby-images/fd695/fd69547917543b92d46da8b0a2bc80a621380f6d" alt="image"
data:image/s3,"s3://crabby-images/2e368/2e36810317bf77e45ab60fcaf37aed85f9e3fc2d" alt="image"
Radial Layout
- The distance away from the center shows depth
- Vertical & horizontal spatial positions are chosen by a layout algorithm to avoid overlap.
data:image/s3,"s3://crabby-images/c0c24/c0c2474d000d611e12edb883247e9208ab24e850" alt="image"
Scalability
- The naïve node-link diagrams are useful for a tree with a few hundred nodes.
- For bigger trees, we need aggregate edges.
- Toward Better Scalability
data:image/s3,"s3://crabby-images/57016/57016e498d40df04b8973968164ee6a93f5fd60b" alt="image"
Networks
- What tasks do users want to perforn on graphs?
- Task taxonomy of graph visualization
- Topology-based tasks (can be well supported by node link diagrams)
- Find the set of nodes adjacent to a node.
- How many nodes are adjacent to a node?
- Attribute-based tasks
- Find the nodes having a specific attribute value.
- Browsing tasks
- See Lee et al., “Task taxonomy for graph visualization” for more details.
Node-link Diagrams for Graphs
- How to determine the position of nodes?
data:image/s3,"s3://crabby-images/427d2/427d2dc978fba26f89640a720b3fa283d6280a15" alt="image"
Graph Drawing
- Graph drawing is a research area that aims to find a “good” 2D dep i ction of networks.
- What is a “good” network layout? (= quality measures)
- Minimize the number of edge crossings
- Display the symmetries of the graph
- Minimize the number of bends along the edges
- Maximize the smallest angle between two edges incident on the same vertex
- Minimize the sum of edge length and the maximum length of an edge
- Minimize the area of the drawing by producing a compact graph
- …
- Many graph drawing algorithms are NP complete and seem not to have a polynomial time algorithm.
- So, we use approximation instead.
- Force-directed graph drawing is a class of algorithms that are based on a physical model
- We define forces among the set of nodes/links.
- We find a layout with minimum energy by simulating the movements of nodes/edges.
What are the “Forces”?
- Attractive forces are applied to
- the two endpoints of an edge toward each other
- all nodes toward the center of the viewbox
- Repulsive forces are applied to
- each pair of nodes that are not neighbors
- Forces applied to a node are summed up and used to compute the next position of the node (after a very small fraction of time = simulation)
Force-Directed Layout
- Assign random initial positions to nodes
- Compute the force applied to each node
- Compute dx and dy
- Slightly move the nodes towards dx , dy
- Repeat 2-4 until the layout is stabilized (equilibrium state).
- Strengths:
- Good quality
- Easy to implement
- Intuitive
- Flexible
- Interactive
- Weaknesses:
- Non-deterministic
- spatial memory cannot be exploited across different runs of the algorithm
- Scalability (hairball)
- Poor local minima
- Continual bouncing
data:image/s3,"s3://crabby-images/f8201/f820179dc696c83bf613d18541c8602241286eac" alt="image"
Toward Better Scalability
- Multilevel scalable force directed placement (sfdp)
- Generate simplified graphs: 𝐺 0 𝐺 1 𝐺 𝑙
- Graph coarsening
- Edge collapsing
- Place 𝐺 𝑙
- Use 𝐺 𝑘 1 to place 𝐺 𝑘
- For more information, see “Efficient, High Quality Force Directed Graph Drawing” by Yifan Hu.
- Multilevel Scalable Force-directed Placement
data:image/s3,"s3://crabby-images/aa97a/aa97a17ac1df0a2af12b457f70ec7dceaebed7ba" alt="image"
data:image/s3,"s3://crabby-images/c0514/c0514946710580b0da3554bb7e169792629f9368" alt="image"
DeepDrawing
- Traditional graph drawing algorithms take long time.
- Sometimes we need to run the algorithm several times to obtain a desired layout (by tuning some parameters)
- Can we accelerate this process using deep learning?
- Wang et al., “DeepDrawing : A Deep Learning Approach to Graph Drawing”(TVCG 2019)
data:image/s3,"s3://crabby-images/83c49/83c496d9de0cbb59f74c2209d66951f7a802c30f" alt="image"
data:image/s3,"s3://crabby-images/61165/6116517ee96af4bc62b9d5161ee901d47a9ed992" alt="image"
Adjacency Matrix
- All of the nodes in the network are laid out along the vertical and horizontal edges of a square region.
- Links between two nodes are indicated by coloring an area mark in the cell in the matrix that is the intersection between their row and column.
- Additional information about nodes and edges can be encoded by coloring matrix.
- The matrix becomes symmetric for an undirected graph.
data:image/s3,"s3://crabby-images/3386a/3386a45acb1108b47cd6920e37aa4857981dad95" alt="image"
data:image/s3,"s3://crabby-images/fa482/fa4829ab749308cb51f88fc354cc383bbda76a10" alt="image"
data:image/s3,"s3://crabby-images/57f8a/57f8a91d742508b7dc3743bf031aa4bdc25065c4" alt="image"
Node-link Diagram vs Adjacency Matrix
data:image/s3,"s3://crabby-images/ab1a6/ab1a69e9174cc477bd521f5307bf047b5553ad39" alt="image"
data:image/s3,"s3://crabby-images/e7126/e71268c0d1f4a954df27e03f28c97b2bbc83f11a" alt="image"
NodeTrix Idiom
- Node-link diagrams are good for revealing the global structure.
- Adjacency matrices are good for revealing the local structure.
- Can we use both at the same time?
- Social network data: globally sparse and locally dense
- Nathalie Henry, Jean Daniel Fekete, and Michael J. McGuffin, “ NodeTrix : A Hybrid Visualization of Social Networks” (InfoVis 2007)
- Identify communities
- Identify central actors
data:image/s3,"s3://crabby-images/80cb7/80cb7316516f63ef4f39b7d7e4bc8a7e72f7e3cd" alt="image"
data:image/s3,"s3://crabby-images/dbc77/dbc77d631971a2b6985145369670550191f804a3" alt="image"
data:image/s3,"s3://crabby-images/1ec57/1ec570e895a9f3c87e731c5de6472ba15d1ee086" alt="image"
Enclosure
- Containment marks can be used to visualize the hierarchiy in data.
- Only works for trees (no cycles)
data:image/s3,"s3://crabby-images/993f6/993f649bf4ef29d3bf36cc87da2eae945387d8aa" alt="image"
Treemaps
- The hierarchical relationships are shown with containment rather than connection.
- All of the children of a tree node are enclosed within the area allocated that node, creating a nested layout.
- The size of the nodes is mapped to some attribute of the node.
data:image/s3,"s3://crabby-images/585c9/585c922640d0be3a0ee244adfbcf8f518bb0b784" alt="image"
data:image/s3,"s3://crabby-images/4ec7e/4ec7ea5cd071025d3dcf3f99c958c09b61b37e5c" alt="image"
data:image/s3,"s3://crabby-images/f0ce7/f0ce74c146cfb78059face18f850d9d6026ae055" alt="image"
Neighborhood Preserving Treemaps
- Can we reflect the neighborhood relationship in a Treemap layout?
- Duarte et al., “Nmap: A Novel Neighborhood Preservation Space filling Algorithm” (InfoVis 2014)
- e.g., cities in Korea have a hierarchy
data:image/s3,"s3://crabby-images/bbc21/bbc21e59e2189d644e02b39beb580b9a075eb327" alt="image"
State Aware Treemaps
data:image/s3,"s3://crabby-images/a6611/a6611a1a30be0485c350cd259913efa3860d01a9" alt="image"
data:image/s3,"s3://crabby-images/6c90c/6c90c02b79f7ae0855b0c171fe03fe50ed6ce0ab" alt="image"
Idioms for Tree Data
data:image/s3,"s3://crabby-images/1c99d/1c99da83e58e531e369ca14c2a95326661fa0163" alt="image"
GrouseFlocks
- Compound network: a network + tree
- Cluster hierarchy atop original network.
- Connection marks for original network, containment marks for cluster hierarchy.
data:image/s3,"s3://crabby-images/fc7ed/fc7ed6d216264c5927614d6eed007ff63e7276a7" alt="image"
Summary: Arrange Networks and Trees
- A node-link diagram uses connection marks.
- Force-directed layout
- Intuitive, topology understanding, unsearchable, no order, not scalable
- An adjacency matrix uses area marks in 2D matrix alignment.
- Detailed Task, estimating # of nodes, searchable, better scalability, unfamiliar
- A Treemap uses area marks and containment with rectilinear layout.
data:image/s3,"s3://crabby-images/7a3b8/7a3b80cfd426e598084ab62a6c0330f1aa827854" alt="image"
댓글남기기