Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
@turf/collect
Advanced tools
@turf/collect is a module from the Turf.js library that allows you to collect properties from one set of features (points) and aggregate them into another set of features (polygons). This is particularly useful for spatial analysis tasks where you need to summarize or aggregate data based on spatial relationships.
Collect properties from points into polygons
This feature allows you to collect properties from a set of point features and aggregate them into polygon features. In this example, the population property from the points is collected into the polygons.
const turf = require('@turf/turf');
const points = turf.featureCollection([
turf.point([0, 0], {population: 200}),
turf.point([2, 2], {population: 300}),
turf.point([2, 0], {population: 150})
]);
const polygons = turf.featureCollection([
turf.polygon([[
[0, 0], [2, 0], [2, 2], [0, 2], [0, 0]
]], {name: 'polygon1'})
]);
const collected = turf.collect(polygons, points, 'population', 'collectedPopulations');
console.log(JSON.stringify(collected, null, 2));
The geostats package provides a range of statistical functions for geospatial data, including classification and aggregation. While it does not directly offer the same point-to-polygon aggregation as @turf/collect, it can be used for similar statistical analysis tasks on geospatial data.
The jsts (JavaScript Topology Suite) package offers a wide range of spatial analysis and geometry operations. It includes functionalities for spatial relationships and operations, but it is more complex and lower-level compared to the specific point-to-polygon aggregation provided by @turf/collect.
Merges a specified property from a FeatureCollection of points into a
FeatureCollection of polygons. Given an inProperty
on points and an outProperty
for polygons, this finds every point that lies within each polygon, collects the
inProperty
values from those points, and adds them as an array to outProperty
on the polygon.
Parameters
polygons
FeatureCollection<Polygon> polygons with values on which to aggregatepoints
FeatureCollection<Point> points to be aggregatedinProperty
string property to be nested fromoutProperty
string property to be nested intoExamples
var poly1 = turf.polygon([[[0,0],[10,0],[10,10],[0,10],[0,0]]]);
var poly2 = turf.polygon([[[10,0],[20,10],[20,20],[20,0],[10,0]]]);
var polyFC = turf.featureCollection([poly1, poly2]);
var pt1 = turf.point([5,5], {population: 200});
var pt2 = turf.point([1,3], {population: 600});
var pt3 = turf.point([14,2], {population: 100});
var pt4 = turf.point([13,1], {population: 200});
var pt5 = turf.point([19,7], {population: 300});
var pointFC = turf.featureCollection([pt1, pt2, pt3, pt4, pt5]);
var collected = turf.collect(polyFC, pointFC, 'population', 'values');
var values = collected.features[0].properties.values
//=values => [200, 600]
//addToMap
var addToMap = [pointFC, collected]
Returns FeatureCollection<Polygon> polygons with properties listed based on outField
This module is part of the Turfjs project, an open source module collection dedicated to geographic algorithms. It is maintained in the Turfjs/turf repository, where you can create PRs and issues.
Install this module individually:
$ npm install @turf/collect
Or install the Turf module that includes it as a function:
$ npm install @turf/turf
4.6.0
@turf/clean-coords
Removes redundant coordinates from any GeoJSON Geometry.
(PR https://github.com/Turfjs/turf/pull/875 - Author @stebogit)@turf/interpolate
Takes a set of points and estimates their 'property' values on a grid using the Inverse Distance Weighting (IDW) method..
(PR https://github.com/Turfjs/turf/pull/832 - Author @stebogit)@turf/clusters-dbscan
Takes a set of Points and partition them into clusters according to DBSCAN's data clustering algorithm.
(PR https://github.com/Turfjs/turf/pull/812 and https://github.com/Turfjs/turf/pull/851 - Author @DenisCarriere)
special mention to this incredibly instructive and fun interactive map by @DenisCarriere 😎👏
@turf/clusters
Provides getCluster
, clusterEach
, and clusterReduce
functions.
(PR https://github.com/Turfjs/turf/pull/847 - Author @DenisCarriere)@turf/boolean-point-on-line
Returns true if a point is on a line. Accepts a optional parameter to ignore the start and end vertices of the linestring.
(PR https://github.com/Turfjs/turf/pull/858 - Author @rowanwins)@turf/boolean-overlap
Takes two features and returns true or false whether or not they overlap, i.e. whether any pair of edges on the two polygons intersect. If there
are any edge intersections, the polygons overlap.
(PR https://github.com/Turfjs/turf/pull/856 and https://github.com/Turfjs/turf/pull/868 - Author @stebogit @tcql)@turf/boolean-equal
Determine whether two geometries of the same type have identical X,Y coordinate values.
(PR https://github.com/Turfjs/turf/pull/869 - Author @stebogit @tcql)centered
param default to true
in @turf/point-grid
(PR https://github.com/Turfjs/turf/pull/836 - Contributor @stebogit)MultiLineString
support for @turf/point-on-line
(PR https://github.com/Turfjs/turf/pull/838 - Contributor @stebogit)@turf/clusters
=> @turf/clusters-kmeans
, plus adds deprecated warning message to @turf/clusters@4.5.2
(See Issue https://github.com/Turfjs/turf/issues/845)@turf/clusters-kmeans
(See Issue https://github.com/Turfjs/turf/issues/850 - Contributor @DenisCarriere)segmentEach
and segmentReduce
functions to @turf/meta
(See Issue https://github.com/Turfjs/turf/issues/850 - Contributor @DenisCarriere)turf-www
; see Issue https://github.com/Turfjs/turf/issues/859
(PR https://github.com/Turfjs/turf/issues/857 + https://github.com/Turfjs/turf/issues/864 + https://github.com/Turfjs/turf/issues/870 - Contributor @DenisCarriere @stebogit)null
Geometry support across TurfJS modules (See Issue https://github.com/Turfjs/turf/issues/853)
(PR https://github.com/Turfjs/turf/issues/866 - Contributor @DenisCarriere)coordEach
/coordReduce
(@turf/meta) 🎉
(PR https://github.com/Turfjs/turf/issues/872 - Contributor @DenisCarriere)bbox
and id
params plus geometry
method to @turf/helpers
(PR https://github.com/Turfjs/turf/issues/877 - Contributor @DenisCarriere)@turf/truncate
to @turf/line-split
splitter
input to avoid approximation errors. Fixed #852
(PR https://github.com/Turfjs/turf/pull/855)@turf-mask
error (See Issue https://github.com/Turfjs/turf/issues/837)
(PR https://github.com/Turfjs/turf/pull/865 - Contributor @thiagoxvo)create-new-module
script error on LICENSE
file creation (See Issue https://github.com/Turfjs/turf/issues/861)
(commit df6986e)@turf/isobands
error on commonProperties
(See Issue https://github.com/Turfjs/turf/issues/831)
(commit 1663f07)FAQs
turf collect module
The npm package @turf/collect receives a total of 470,299 weekly downloads. As such, @turf/collect popularity was classified as popular.
We found that @turf/collect demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.