Building data visualizations

for product

Shirley Wu (@sxywu)

why talk about

dataviz in product?

illumio

contain cyber threats with adaptive segmentation

Illumination

keep track of who's going in and out, and who should actually be allowed in and out

visualization

framework

scale

user

team

1  visualization

workloads
(the "rooms")

traffic
("going in and out")

workloads grouped by labels

1 visualization

first implementation

force within force

+

collision detection

1 visualization

Abuse the force

1 visualization

and this is what we get for abusing the force.

(we're sorry)

1 visualization

how we fixed it

stripped out force layout

replaced it with our own layout algorithm

1 visualization

more performant

more orderly

maintains layout on refresh

1 visualization

1 visualization

lesson learned

customize and optimize
based on user feedback

2  framework

blocked traffic

allowed traffic

take action to allow traffic (turn it green)

1 visualization

2 framework

1 visualization

2 framework

so many user actions

couldn't keep track

of 'em all

1 visualization

2 framework

how we fixed it

recalculated everything on each user action

moved to react and flux

1 visualization

2 framework

no need to keep track

easy to reason about

"it just works"

1 visualization

2 framework

1 visualization

2 framework

lesson learned

start with a stupidly simple approach

3  scale

oh look, spaghetti!

1 visualization

2 framework

3 scale

how we fixed it

aggregated by groups

filtered as user drilled down

1 visualization

2 framework

3 scale

1 visualization

2 framework

3 scale

how we fixed it

stopped recalculating where least performant

replaced arrays with objects in data stores

1 visualization

2 framework

3 scale

loaded only enough data to render screen

lesson learned

optimize only when hit with a performance road block

1 visualization

2 framework

3 scale

1 visualization

2 framework

3 scale

4  user

what we noticed

always edge cases

1 visualization

2 framework

3 scale

4 user

building for want vs. need

lesson learned

get and use real data as often and as early as possible

1 visualization

2 framework

3 scale

4 user

5  team

what we noticed

esoteric visualizations

1 visualization

2 framework

3 scale

4 user

5 team

novel approaches

lesson learned

encourage rapid prototyping and exploration

1 visualization

2 framework

3 scale

4 user

5 team

customize and optimize
based on user expectation

get and use real data as often and as early as possible

start with a stupidly simple approach

optimize only when hit with a performance road block

encourage rapid prototyping and exploration

visualization

user

framework

scale

team

lessons learned

be flexible

explore when necessary

team is the most important

two last things

a survey for compiling experiences

a slack channel
(d3js #dataviz-in-product)
for community

(links on twitter @sxywu)

Thank you 

Especially to:

Alexander Lam
Xianlin Hu, Maxwell Brown, #TeamIllumio
Jana Beck, Ian Johnson, Zan Armstrong, Tony Chu,
Micah Stubbs, Elijah Meeks, Susie Lu,
Jim Vallandingham, Noah Veltman

for all their enthusiasm, support and feedback.

Reject Gifs hall of fame

(because they deserve love and attention too)

Building dataviz for product

By Shirley Wu

Building dataviz for product

In progress

  • 5,205