Skip to content

Instantly share code, notes, and snippets.

@kpq
Created May 10, 2017 19:59
Show Gist options
  • Save kpq/d94660a26d1e01a24f382e74d369e4ab to your computer and use it in GitHub Desktop.
Save kpq/d94660a26d1e01a24f382e74d369e4ab to your computer and use it in GitHub Desktop.
For Nadav
yield variety year site
27 Manchuria 1931 University Farm
48.86667 Manchuria 1931 Waseca
27.43334 Manchuria 1931 Morris
39.93333 Manchuria 1931 Crookston
32.96667 Manchuria 1931 Grand Rapids
28.96667 Manchuria 1931 Duluth
43.06666 Glabron 1931 University Farm
55.2 Glabron 1931 Waseca
28.76667 Glabron 1931 Morris
38.13333 Glabron 1931 Crookston
29.13333 Glabron 1931 Grand Rapids
29.66667 Glabron 1931 Duluth
35.13333 Svansota 1931 University Farm
47.33333 Svansota 1931 Waseca
25.76667 Svansota 1931 Morris
40.46667 Svansota 1931 Crookston
29.66667 Svansota 1931 Grand Rapids
25.7 Svansota 1931 Duluth
39.9 Velvet 1931 University Farm
50.23333 Velvet 1931 Waseca
26.13333 Velvet 1931 Morris
41.33333 Velvet 1931 Crookston
23.03333 Velvet 1931 Grand Rapids
26.3 Velvet 1931 Duluth
36.56666 Trebi 1931 University Farm
63.8333 Trebi 1931 Waseca
43.76667 Trebi 1931 Morris
46.93333 Trebi 1931 Crookston
29.76667 Trebi 1931 Grand Rapids
33.93333 Trebi 1931 Duluth
43.26667 No. 457 1931 University Farm
58.1 No. 457 1931 Waseca
28.7 No. 457 1931 Morris
45.66667 No. 457 1931 Crookston
32.16667 No. 457 1931 Grand Rapids
33.6 No. 457 1931 Duluth
36.6 No. 462 1931 University Farm
65.7667 No. 462 1931 Waseca
30.36667 No. 462 1931 Morris
48.56666 No. 462 1931 Crookston
24.93334 No. 462 1931 Grand Rapids
28.1 No. 462 1931 Duluth
32.76667 Peatland 1931 University Farm
48.56666 Peatland 1931 Waseca
29.86667 Peatland 1931 Morris
41.6 Peatland 1931 Crookston
34.7 Peatland 1931 Grand Rapids
32 Peatland 1931 Duluth
24.66667 No. 475 1931 University Farm
46.76667 No. 475 1931 Waseca
22.6 No. 475 1931 Morris
44.1 No. 475 1931 Crookston
19.7 No. 475 1931 Grand Rapids
33.06666 No. 475 1931 Duluth
39.3 Wisconsin No. 38 1931 University Farm
58.8 Wisconsin No. 38 1931 Waseca
29.46667 Wisconsin No. 38 1931 Morris
49.86667 Wisconsin No. 38 1931 Crookston
34.46667 Wisconsin No. 38 1931 Grand Rapids
31.6 Wisconsin No. 38 1931 Duluth
26.9 Manchuria 1932 University Farm
33.46667 Manchuria 1932 Waseca
34.36666 Manchuria 1932 Morris
32.96667 Manchuria 1932 Crookston
22.13333 Manchuria 1932 Grand Rapids
22.56667 Manchuria 1932 Duluth
36.8 Glabron 1932 University Farm
37.73333 Glabron 1932 Waseca
35.13333 Glabron 1932 Morris
26.16667 Glabron 1932 Crookston
14.43333 Glabron 1932 Grand Rapids
25.86667 Glabron 1932 Duluth
27.43334 Svansota 1932 University Farm
38.5 Svansota 1932 Waseca
35.03333 Svansota 1932 Morris
20.63333 Svansota 1932 Crookston
16.63333 Svansota 1932 Grand Rapids
22.23333 Svansota 1932 Duluth
26.8 Velvet 1932 University Farm
37.4 Velvet 1932 Waseca
38.83333 Velvet 1932 Morris
32.06666 Velvet 1932 Crookston
32.23333 Velvet 1932 Grand Rapids
22.46667 Velvet 1932 Duluth
29.06667 Trebi 1932 University Farm
49.2333 Trebi 1932 Waseca
46.63333 Trebi 1932 Morris
41.83333 Trebi 1932 Crookston
20.63333 Trebi 1932 Grand Rapids
30.6 Trebi 1932 Duluth
26.43334 No. 457 1932 University Farm
42.2 No. 457 1932 Waseca
43.53334 No. 457 1932 Morris
34.33333 No. 457 1932 Crookston
19.46667 No. 457 1932 Grand Rapids
22.7 No. 457 1932 Duluth
25.56667 No. 462 1932 University Farm
44.7 No. 462 1932 Waseca
47 No. 462 1932 Morris
30.53333 No. 462 1932 Crookston
19.9 No. 462 1932 Grand Rapids
22.5 No. 462 1932 Duluth
28.06667 Peatland 1932 University Farm
36.03333 Peatland 1932 Waseca
43.2 Peatland 1932 Morris
25.23333 Peatland 1932 Crookston
26.76667 Peatland 1932 Grand Rapids
31.36667 Peatland 1932 Duluth
30 No. 475 1932 University Farm
41.26667 No. 475 1932 Waseca
44.23333 No. 475 1932 Morris
32.13333 No. 475 1932 Crookston
15.23333 No. 475 1932 Grand Rapids
27.36667 No. 475 1932 Duluth
38 Wisconsin No. 38 1932 University Farm
58.16667 Wisconsin No. 38 1932 Waseca
47.16667 Wisconsin No. 38 1932 Morris
35.9 Wisconsin No. 38 1932 Crookston
20.66667 Wisconsin No. 38 1932 Grand Rapids
29.33333 Wisconsin No. 38 1932 Duluth
<!DOCTYPE html>
<meta charset="utf-8">
<style type="text/css">
svg {
border: 1px solid #f0f;
}
.rectangle {
fill: #FF9E2C;
opacity: .5;
}
</style>
<body>
<h1>Barley</h1>
</body>
<script src="https://d3js.org/d3.v4.min.js"></script>
<script>
var margin = {top: 15, right: 40, bottom: 20, left: 40};
var w = 500 - margin.left - margin.right,
h = 400 - margin.top - margin.bottom;
var chart = d3.select("body").append("svg")
.attr("width", w + margin.left + margin.right)
.attr("height", h + margin.top + margin.bottom)
.append("g") //it's actually a g within an svg. technically a reference to my g from here on out
.attr("transform", "translate(" + margin.left + "," + margin.top + ")"); //?
d3.tsv("barley.tsv", ready);
function ready(err, data){
if (err) throw "error loading data";
var barleygroup = data.filter(function(d){
return d.site == "Crookston" && d.year == "1931";
});
var xscale = d3.scalePoint()
.domain(['Manchuria','Glabron','Svansota','Velvet','Trebi','Peatland', 'No. 457', 'No. 475', "No. 462", "Wisconsin No. 38"])
.range([0, w]); //projecting to pixel land
var yscale = d3.scaleLinear()
.domain([0,50])
.range([h,0]);
var xaxis = d3.axisBottom() //means the ticks will go below rather than above
.scale(xscale); //needs to know scale to project along svg
//.tickSize(-h); //optional
//.tickValues(xscale.domain().filter(function(d,i){ return !(i%10); } );
//.orient("bottom");
//var ticks = scale.domain();
var yaxis = d3.axisLeft()
.scale(yscale);
//.tickSize(-w); //creates horiz dashed lines. we want the horizontal line size for the y axis to be the width
chart.append("g") //"g" is the parent group for the ticks
.attr("class", "axis")
.call(xaxis)
.attr("transform", "translate(0," + h + ")"); //moves the x axis down
chart.append("g") //"g" stands for group
.attr("class", "axis") //would give them all a class
.call(yaxis);
var agroup = chart.selectAll("g.a-group") //grab all items that have this a-group characteristic in the svg
.data(barleygroup) //here's my data that I am binding to the element
.enter() //data should enter those elemnts
.append("g")
.attr("class", "a-group")
.attr("transform", function(d) { //d is the element at that index
return "translate(" + xscale(d.variety) + ",0)";
});
agroup.append("rect")
//.attr('r', 5);
.attr("class", "rectangle")
.attr("y", function(d) {
// console.log(h + "!! " + d.yield);
return yscale(d.yield);
})
.attr("width", 5)
.attr("height", function(d){
return h - yscale(d.yield);
// return h;
});
agroup.append("text")
.text(function(d) {
return d.variety + "," + (d.yield);
})
.attr("y", function(d) { return yscale(d.yield) })
.attr("dx", 0) //nudge over 10
.attr("dy", 0);
}
</script>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment