-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.html
73 lines (62 loc) · 4.74 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link rel="stylesheet" href="style.css">
<title>Visualization</title>
</head>
<body>
<header id="nav-stuff">
<h2><a href="#hero">Three Visualizations</a></h2>
<nav>
<li><a href="#about">About</a></li>
<li><a href="#viz-one">Viz One</a></li>
<li><a href="#viz-two">Viz Two</a></li>
<li><a href="#viz-three">Viz Three</a></li>
</nav>
</header>
<section class="about" id="about">
<h3 class="title">About the assignment</h3>
<p class="text-matter"><br><br>Below are three visualizations of the same dataset––the population of immigrants, split up on the basis of country of origin, living in the USA in ~2014-15. The data is taken from the 2015 1-year American Community Survey (ACS).<br><br>
These visualizations have been undertaken moreso as an exploration of the technical work of handling and representing data in Javascript than any exercise in the art of data visualization, or a foray into the work of data visualization as art.<br><br>
All of the visualizations below were created using the D3 library of Javascript. The coloring of the elements of all three is randomized, using a function and an array of predefined color values.<br><br>
If you would like to see which immigrant population is represented by which visual element, simply hover your mouse over it.
</p>
<hr>
</section>
<section class="viz-one" id="viz-one">
<h3>Viz One</h3>
<div id="vizOne">
</div>
<p class="text-matter">
Circles are notoriously unreliable as graphic representations of data. All the same, they are compelling visual analogies for cluster or buckets of quantified stuff.<br><br>
Within data visualization communities, it is conventionally held that circles need to be scaled by area rather than radius, so as to better match how we (the eye and the brain) perceive the size of circles. Nevertheless, the visualization above, whose circles are indeed scaled by area (using D3's square root scale), does not bear much resemblance with <a href="#viz-three">visualization three</a> below, which is the most graphically accurate.<br><br>
Where this visualization succeeds, though, is in the logarithmic scaling of the x-axis, which controls the circles' distribution along the x-axis as well as the numerical ticks along the x-axis. This scaling squeezes portions of the dataset along a logarithmic curve, which helps to show that the far preponderance of immigrant nationalities falls between the 20k and 500k ticks, while the actual majority in terms of population reside in the nine or so countries to the right (or greater than) the ~700k mark.
</p>
</section>
<section class="viz-two" id="viz-two">
<h3>Viz Two</h3>
<div id="vizTwo">
</div>
<p class="text-matter">
This visualization is a circle pack. As far as visualizations go, it is not necessarily the best use of space, and doesn't particularly represent the populations too well. What circle packing is well suited for is the representation of hierarchy or density. This visualization, for example, has an almost biological look to it——each inner sphere has a cellular look to it, while the parent sphere almost looks like some sort of organism. Overall, it confers an organic feel to the data——communities and people interlocking and co-existing in the more general context of the country, the former comprising and coloring the makeup of the latter.<br><br>
From a technical point of view, the majority of the work that went into this visualization revolved around handling the data. In order to create a circle pack, it is necessary to make the data hierarchical (it was no initially). This was accomplished using D3's nest and hierarchy methods, as well as a handful of submethods chained within these latter two.
</p>
</section>
<section class="viz-three" id="viz-three">
<h3>Viz Three</h3>
<div id="vizThree">
</div>
<p class="text-matter">
This visualization, a bar chart, is the most pedestrian and recognizable of the three, and yet it is also the most effective at faithfully representing the data.
</p>
</section>
<script src="https://d3js.org/d3.v4.min.js"></script>
<script src="https://d3js.org/d3-scale-chromatic.v1.min.js"></script>
<script src="vizOne.js"></script>
<script src="vizTwo.js"></script>
<script src="vizThree.js"></script>
</body>
</html>