![Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support](https://cdn.sanity.io/images/cgdhsj6q/production/2cf8fa428fd5329a3f9bc7f76a597ac829bb1b3d-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
d3-contour
Advanced tools
The d3-contour npm package is a part of the D3.js library and is used for generating contour plots, which are a way to represent three-dimensional data in two dimensions using contour lines. These plots are useful for visualizing scalar fields and can be used in various fields such as geography, meteorology, and data science.
Generate Contours
This feature allows you to generate contour plots from a set of values. The `d3.contours` function is used to create a contour generator, which can then be used to compute contours for a given set of values. The `size` method sets the dimensions of the grid, and the `thresholds` method sets the contour levels.
const d3 = require('d3-contour');
const values = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
const contours = d3.contours().size([10, 10]).thresholds([1, 2, 3, 4, 5])(values);
console.log(contours);
Custom Thresholds
This feature allows you to use custom thresholds for generating contours. The `d3.thresholdSturges` function is used to compute thresholds based on Sturges' formula, which is a method for determining the number of bins in a histogram. These thresholds are then used to generate the contours.
const d3 = require('d3-contour');
const values = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
const thresholds = d3.thresholdSturges(values);
const contours = d3.contours().size([10, 10]).thresholds(thresholds)(values);
console.log(contours);
Smoothing Contours
This feature allows you to smooth the contours for a more visually appealing result. The `smooth` method is used to enable or disable smoothing. When smoothing is enabled, the contours are interpolated to create smoother lines.
const d3 = require('d3-contour');
const values = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
const contours = d3.contours().size([10, 10]).smooth(true)(values);
console.log(contours);
Plotly.js is a comprehensive graphing library that supports a wide range of chart types, including contour plots. It offers more advanced features and interactivity compared to d3-contour, making it suitable for more complex visualizations. However, it is also heavier and may require more effort to integrate into a project.
ECharts is a powerful charting and visualization library that supports contour plots among many other chart types. It provides a high level of customization and interactivity, similar to Plotly.js. ECharts is suitable for applications that require a wide variety of chart types and advanced features.
This library computes contour polygons by applying marching squares to a rectangular array of numeric values. For example, here is Maungawhau’s topology (the classic volcano
dataset and terrain.colors
from R):
For each threshold value, the contour generator constructs a GeoJSON MultiPolygon geometry object representing the area where the input values are greater than or equal to the threshold value. The geometry is in planar coordinates, where ⟨i + 0.5, j + 0.5⟩ corresponds to element i + jn in the input values array. Here is an example that loads a GeoTIFF of surface temperatures, and another that blurs a noisy monochrome PNG to produce smooth contours of cloud fraction:
Since the contour polygons are GeoJSON, you can transform and display them using standard tools; see d3.geoPath, d3.geoProject and d3.geoStitch, for example. Here the above contours of surface temperature are displayed in the Natural Earth projection:
Contour plots can also visualize continuous functions by sampling. Here is the Goldstein–Price function (a test function for global optimization) and a trippy animation of sin(x + y)sin(x - y):
Contours can also show the estimated density of point clouds, which is especially useful to avoid overplotting in large datasets. This library implements fast two-dimensional kernel density estimation; see d3.contourDensity. Here is a scatterplot showing the relationship between the idle duration and eruption duration for Old Faithful:
And here is a density contour plot showing the relationship between the weight and price of 53,940 diamonds:
If you use npm, npm install d3-contour
. You can also download the latest release on GitHub. For vanilla HTML in modern browsers, import d3-contour from jsDelivr:
<script type="module">
import {contours} from "https://cdn.jsdelivr.net/npm/d3-contour@4/+esm";
const c = contours(values);
</script>
For legacy environments, you can load d3-contour’s UMD bundle; a d3
global is exported:
<script src="https://cdn.jsdelivr.net/npm/d3-array@3"></script>
<script src="https://cdn.jsdelivr.net/npm/d3-contour@4"></script>
<script>
// Populate a grid of n×m values where -2 ≤ x ≤ 2 and -2 ≤ y ≤ 1.
const n = 256, m = 256, values = new Array(n * m);
for (let j = 0.5, k = 0; j < m; ++j) {
for (let i = 0.5; i < n; ++i, ++k) {
values[k] = goldsteinPrice(i / n * 4 - 2, 1 - j / m * 3);
}
}
// Compute the contour polygons at log-spaced intervals; returns an array of MultiPolygon.
const contours = d3.contours()
.size([n, m])
.thresholds(Array.from({ length: 19 }, (_, i) => Math.pow(2, i + 2)))
(values);
// See https://en.wikipedia.org/wiki/Test_functions_for_optimization
function goldsteinPrice(x, y) {
return (1 + Math.pow(x + y + 1, 2) * (19 - 14 * x + 3 * x * x - 14 * y + 6 * x * x + 3 * y * y))
* (30 + Math.pow(2 * x - 3 * y, 2) * (18 - 32 * x + 12 * x * x + 48 * y - 36 * x * y + 27 * y * y));
}
</script>
# d3.contours() · Source, Examples
Constructs a new contour generator with the default settings.
Computes the contours for the given array of values, returning an array of GeoJSON MultiPolygon geometry objects. Each geometry object represents the area where the input values are greater than or equal to the corresponding threshold value; the threshold value for each geometry object is exposed as geometry.value.
The input values must be an array of length n×m where [n, m] is the contour generator’s size; furthermore, each values[i + jn] must represent the value at the position ⟨i, j⟩. For example, to construct a 256×256 grid for the Goldstein–Price function where -2 ≤ x ≤ 2 and -2 ≤ y ≤ 1:
var n = 256, m = 256, values = new Array(n * m);
for (var j = 0.5, k = 0; j < m; ++j) {
for (var i = 0.5; i < n; ++i, ++k) {
values[k] = goldsteinPrice(i / n * 4 - 2, 1 - j / m * 3);
}
}
function goldsteinPrice(x, y) {
return (1 + Math.pow(x + y + 1, 2) * (19 - 14 * x + 3 * x * x - 14 * y + 6 * x * x + 3 * y * y))
* (30 + Math.pow(2 * x - 3 * y, 2) * (18 - 32 * x + 12 * x * x + 48 * y - 36 * x * y + 27 * y * y));
}
The returned geometry objects are typically passed to d3.geoPath to display, using null or d3.geoIdentity as the associated projection.
# contours.contour(values, threshold) · Source, Examples
Computes a single contour, returning a GeoJSON MultiPolygon geometry object representing the area where the input values are greater than or equal to the given threshold value; the threshold value for each geometry object is exposed as geometry.value.
The input values must be an array of length n×m where [n, m] is the contour generator’s size; furthermore, each values[i + jn] must represent the value at the position ⟨i, j⟩. See contours for an example.
# contours.size([size]) · Source, Examples
If size is specified, sets the expected size of the input values grid to the contour generator and returns the contour generator. The size is specified as an array [n, m] where n is the number of columns in the grid and m is the number of rows; n and m must be positive integers. If size is not specified, returns the current size which defaults to [1, 1].
# contours.smooth([smooth]) · Source, Examples
If smooth is specified, sets whether or not the generated contour polygons are smoothed using linear interpolation. If smooth is not specified, returns the current smoothing flag, which defaults to true.
# contours.thresholds([thresholds]) · Source, Examples
If thresholds is specified, sets the threshold generator to the specified function or array and returns this contour generator. If thresholds is not specified, returns the current threshold generator, which by default implements Sturges’ formula.
Thresholds are defined as an array of values [x0, x1, …]. The first generated contour corresponds to the area where the input values are greater than or equal to x0; the second contour corresponds to the area where the input values are greater than or equal to x1, and so on. Thus, there is exactly one generated MultiPolygon geometry object for each specified threshold value; the threshold value is exposed as geometry.value.
If a count is specified instead of an array of thresholds, then the input values’ extent will be uniformly divided into approximately count bins; see d3.ticks.
# d3.contourDensity() · Source, Examples
Constructs a new density estimator with the default settings.
Estimates the density contours for the given array of data, returning an array of GeoJSON MultiPolygon geometry objects. Each geometry object represents the area where the estimated number of points per square pixel is greater than or equal to the corresponding threshold value; the threshold value for each geometry object is exposed as geometry.value. The returned geometry objects are typically passed to d3.geoPath to display, using null or d3.geoIdentity as the associated projection. See also d3.contours.
The x- and y-coordinate for each data point are computed using density.x and density.y. In addition, density.weight indicates the relative contribution of each data point (default 1). The generated contours are only accurate within the estimator’s defined size.
# density.x([x]) · Source, Examples
If x is specified, sets the x-coordinate accessor. If x is not specified, returns the current x-coordinate accessor, which defaults to:
function x(d) {
return d[0];
}
# density.y([y]) · Source, Examples
If y is specified, sets the y-coordinate accessor. If y is not specified, returns the current y-coordinate accessor, which defaults to:
function y(d) {
return d[1];
}
# density.weight([weight]) · Source
If weight is specified, sets the accessor for point weights. If weight is not specified, returns the current point weight accessor, which defaults to:
function weight() {
return 1;
}
# density.size([size]) · Source, Examples
If size is specified, sets the size of the density estimator to the specified bounds and returns the estimator. The size is specified as an array [width, height], where width is the maximum x-value and height is the maximum y-value. If size is not specified, returns the current size which defaults to [960, 500]. The estimated density contours are only accurate within the defined size.
# density.cellSize([cellSize]) · Source
If cellSize is specified, sets the size of individual cells in the underlying bin grid to the specified positive integer and returns the estimator. If cellSize is not specified, returns the current cell size, which defaults to 4. The cell size is rounded down to the nearest power of two. Smaller cells produce more detailed contour polygons, but are more expensive to compute.
# density.thresholds([thresholds]) · Source, Examples
If thresholds is specified, sets the threshold generator to the specified function or array and returns this contour generator. If thresholds is not specified, returns the current threshold generator, which by default generates about twenty nicely-rounded density thresholds.
Thresholds are defined as an array of values [x0, x1, …]. The first generated density contour corresponds to the area where the estimated density is greater than or equal to x0; the second contour corresponds to the area where the estimated density is greater than or equal to x1, and so on. Thus, there is exactly one generated MultiPolygon geometry object for each specified threshold value; the threshold value is exposed as geometry.value. The first value x0 should typically be greater than zero.
If a count is specified instead of an array of thresholds, then approximately count uniformly-spaced nicely-rounded thresholds will be generated; see d3.ticks.
# density.bandwidth([bandwidth]) · Source, Examples
If bandwidth is specified, sets the bandwidth (the standard deviation) of the Gaussian kernel and returns the estimate. If bandwidth is not specified, returns the current bandwidth, which defaults to 20.4939…. The specified bandwidth is currently rounded to the nearest supported value by this implementation, and must be nonnegative.
# density.contours(data) · Source, Examples
Return a contour(value) function that can be used to compute an arbitrary contour on the given data without needing to recompute the underlying grid. The returned contour function also exposes a contour.max value which represents the maximum density of the grid.
FAQs
Compute contour polygons using marching squares.
The npm package d3-contour receives a total of 2,194,012 weekly downloads. As such, d3-contour popularity was classified as popular.
We found that d3-contour demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.