CS 725/825 - Spring 2018 - Homework 3 - Scatterplot
Hussam Hallak
1. What is the type of mark used in the scatterplot?
2. List the channels, the attribute they are mapped to, and the data type of that attribute.
Answer
The type of marks used in the scatter plot is a point. The channels are the horizontal and vertical spacial positions which encode quantitative attributes which are the number of passing touchdowns (TDs) and the number of rushing TDs for each player. The data type for both TDs is attribute. Each point represents a player, an item or an entity.
Edit the chart to use the color hue channel to express the "Conf" attribute (there are 11 conferences) and use the size channel to express another attribute in the dataset.
Similar to what I have done for the bar charts, I added this line of code:
var color = d3.scaleOrdinal(d3.schemeCategory20);
I also added this line in the section of the code //draw dots
which gives colors to the dots based on the "Conf" value
.style("fill", function(d) { return color(d.Conf)})
I also added the size channel to the mix by adding this line of code under the //draw dots
section, which changes the radius of the dot or point based on a value that combines values from two different columns in the data file:
.attr("r", function(d) { return d.Pct * d.Rate * 0.0005})
I have absolutely no idea what Pct and Rate are, but I tried with a couple of different attributes like Attempts and others. They all do not seem to make the difference in points' sizes obvious enough. I tried using the logScale on them, but that did not help so I commented its code. I finally tried multiplying the Rate and Pct and multiplying that by 0.0005 and that gave the best possible result. This is the section of the code //draw dots
:
// draw dots
g.selectAll(".dot")
.data(data)
.enter().append("circle")
.attr("class", "dot")
.attr("r", function(d) { return d.Pct * d.Rate * 0.0005})
.attr("cx", xMap)
.attr("cy", yMap)
.style("fill", function(d) { return color(d.Conf)})
3. After your changes, list the channels, the attribute they are mapped to, and the data type of that attribute.
Answer
The channels are the horizontal and vertical spacial positions which encode quantitative attributes which are the number of passing touchdowns (TDs) and the number of rushing TDs for each player. The data type for both TDs is attribute. Each point represents a player, an item or an entity. Another channel is the color hue which is an identity channel that encodes the conference which is a categorical attribute, which is an item as far as data type. Another channel is size which encodes Pct * Rate * k where k = 0.0005 and this attribute is quantitative and its data type is attribute. In this case, the value is new quatitative attribute that is constructed from the two existing quatitative attributes Pct and Rate.
https://d3js.org/d3.v4.min.js
https://d3js.org/d3-scale-chromatic.v1.min.js