Releases: luukvdmeer/sfnetworks
Releases · luukvdmeer/sfnetworks
Version 0.6.5
This is a support release for the older version 0.6
Bug fixes
- The
print()
method for sfnetwork objects now correctly prints networks with active edges that are spatially implicit. Refs #256. - The
print()
method for sfnetwork objects no longer uses the deprecated functiontibble::trunc_mat()
. Refs #247. to_spatial_contracted()
now correctly handles group indices that are not ordered. Refs #243. Thanks @MattArran.
Maintenance
- The usage of
igraph::adjacent_vertices()
andigraph::incident_edges()
insideto_spatial_smooth()
is now aligned to updates in igraph v2.1.1 that changed the zero-based indexing of the return to one-based indexing. This alignment is done dynamically, without forcing the most recent igraph version as required dependency. Refs #282. Thanks @krlmlr. - Whenever the installed igraph version is >= 2.1.0,
igraph::get_edge_ids()
is used instead of the deprecatedigraph::get.edge.ids()
insideto_spatial_smooth()
.
Version 0.6.4
New features
- The sfnetwork() construction function now has an argument message which can be set to FALSE when the network validity checks should not print informational messages to the console. Refs #261.
Maintenance
- Code and documentation was updated where needed to align with changes in base R and/or package dependencies. No changes to program logic or behavior.
Version 0.6.3
Bug fixes
- Argument names of sfnetwork S3 methods for
sf::st_geometry()
,sf::st_bbox()
,sf::st_m_range()
andsf::st_set_precision()
are updated to be consistent with their corresponding generic functions in sf. - Arguments
active
and...
are removed from the sfnetwork S3 method forsf::st_precision()
to be consistent with its corresponding generic function in sf.
Refactoring
- Argument
active
is removed from the sfnetwork S3 method forsf::st_crs()
to be consistent with the above-mentioned change regardingsf::st_precision()
(since both CRS and precision can not differ between nodes and edges).
Version 0.6.2
Bug fixes
- The
to_spatial_contracted()
morpher now correctly handles cases for undirected networks in which only loop edges are created after contraction. Refs #237.
Refactoring
- The
to_spatial_contracted()
morpher now directly returns the original network when none of the contraction groups contain more than one node.
Other
- Umbrella packages tidyverse and spatstat are no longer suggested packages. Only individual members of these packages are now suggested packages.
- Updated unit tests.
Version 0.6.1
Bug fixes
- Unit tests in
test_join.R
now successfully run also on R-devel.
Refactoring
- Updated plot algorithm to be faster and more efficient. Refs #226.
Version 0.6.0 "Coerde"
New features
- Updates to
to_spatial_smooth()
morpher:- Argument
summarise_attributes
added to summarise attribute values of concatenated edges. Refs #120. - Argument
require_equal
added to specify if and which attributes should be checked for equality before removing a pseudo node. Refs #124. - Argument
protect
added to specify nodes that should never be removed, even if they are a pseudo node. Refs #177. - Concatenated edges after smoothing are now allowed to cross themselves. Refs #117.
- Argument
- Updates to
st_network_cost()
:- Duplicated nodes are now accepted in the
to
argument. Refs #183. - Cost matrix output now contains units. Refs #119.
- Argument
direction
added to specify if outbound, inbound or all edges should be considered. This replaces the argumentmode
fromigraph::distances()
. The default is "out", while before it was "all". For undirected networks this argument is ignored.
- Duplicated nodes are now accepted in the
- Edge measure function gained an argument
degrees
which can be set toTRUE
to return angles in degrees instead of radians. - By default
st_network_paths()
now encodes nodes by their name, whenever a name attribute is present in the nodes table. This can be disabled by settinguse_names = FALSE
. Refs #154. - Functions
sf::st_precision()
andsf::st_set_precision()
now have a method forsfnetwork
objects, such that coordinate precision can be queried and set. Refs #209. - Functions
sf::st_intersection()
andsf::st_difference()
now have a method forsfnetwork
objects, such that networks can be spatially clipped. The method forsf::st_crop()
now uses the same workflow. These functions do not work yet on edges of undirected networks. Refs #133. - Function
sf::st_drop_geometry()
is now a generic and therefore got ansfnetwork
method. - Several other sf functions got an
sfnetwork
method, merely to be consistent in the type of functions we provide a method for. Only those functions that mutate the geometry column of an sf object in such a way that would break the valid spatial network structure are not supported. - Methods for
sf::st_coordinates()
,sf::st_bbox()
andsf::st_crs()
gained anactive
argument such that this information can be extracted from any network element without first activating it. Refs #215.
Bug fixes
- Rd files do not contain code anymore that is incompatible with HTML5. Refs #221.
- Print methods now return x invisibly. Refs #217.
Refactoring
- Error messages when edge measure or query functions are applied to a network with active nodes, or when node measure or query functions are applied to a network with active edges, are now more informative. Refs #216.
- Calculating straight-line distances of edges is now more performant. Refs #180.
- Edge measure function
edge_circuity()
does not return units objects anymore, since circuity is unitless.
Community
- Vignettes updated to showcase new features.
- Code of conduct updated according to newer template.
- Contributing guidelines extended with templates for commit messages.
- Master branch renamed to main, and protected from directed pushes.
Version 0.5.5
- Adjusted the code used to check the version of PROJ on attach. In particular, the new approach tests only
sf::sf_extSoftVersion()["proj.4"]
sincesf::sf_extSoftVersion()["PROJ"]
might not be defined for sf < 1.0. Refs #198 and #200. - Adjusted one of the vignettes following the changes in
dplyr
1.0.8. Ref #202. Thanks @romainfrancois. - Removed conflicting URL from package documentation
spatial_edge_measures
Version 0.5.4
Changelog
- A startup message is included to urge users of PROJ <= 6 to recreate the CRS for the
Roxel
dataset. Refs #190 and fixed with #193 - Example using GraphML in vignette 1 has been removed provisionally to address #194
Version 0.5.3
Changelog
- Addition of the
n_active
andn_inactive
arguments to the print method of an sfnetwork object. The arguments define how many rows are printed for respectively the active and inactive network element. The values of these arguments can also be set globally by running e.g.options(sfn_max_print_active = 1, sfn_max_print_inactive = 2)
. Refs #157 - The example dataset
Roxel
is updated to comply with recent updates on the way a CRS is specified in an sf object. Refs #167 - GitHub Actions workflows are updated to comply with new developments.
- Documentation updates:
Version 0.5.2
Changelog
- Compatibility with
s2
by adding as2::as_s2_geography()
method for sfnetwork objects. In the new version ofsf
, thes2
package will be used for geometric operations involving longitude-latitude coordinates, see here. - Bug fixes:
- When setting
length_as_weight = TRUE
in the sfnetwork construction function, the added weight column now preserves specification of units. st_network_blend()
now internally usessf::st_cast()
instead ofsfheaders::sfc_cast()
to avoid errors with some CRS specifications.
- When setting
- Documentation updates:
- Extended documentation for the shortest paths functions.
- Clear mention in vignettes that
tidygraph
behavior regarding theweight
attribute settings is sometimes differing fromigraph
.