Skip to content

Implement a GEOS algorithm in an extension (#100) #47

Implement a GEOS algorithm in an extension (#100)

Implement a GEOS algorithm in an extension (#100) #47

Triggered via push June 11, 2024 14:21
Status Success
Total duration 18m 44s
Artifacts

CI.yml

on: push
Matrix: test
Fit to window
Zoom out
Zoom in

Annotations

14 warnings
Julia 1 - ubuntu-latest - x64 - push
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v2, actions/cache@4d4ae6ae148a43d0fd1eda1800170683e9882738, pyTooling/Actions/with-post-step@adef08d3bdef092282614f3b683897cefae82ee3, julia-actions/setup-julia@v1. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
Julia 1 - ubuntu-latest - x64 - push
The following actions uses node12 which is deprecated and will be forced to run on node16: actions/checkout@v2. For more info: https://github.blog/changelog/2023-06-13-github-actions-all-actions-will-run-on-node16-instead-of-node12-by-default/
Julia 1.9 - ubuntu-latest - x64 - push
Node.js 16 actions are deprecated. Please update the following actions to use Node.js 20: actions/checkout@v2, actions/cache@4d4ae6ae148a43d0fd1eda1800170683e9882738, pyTooling/Actions/with-post-step@adef08d3bdef092282614f3b683897cefae82ee3, julia-actions/setup-julia@v1. For more information see: https://github.blog/changelog/2023-09-22-github-actions-transitioning-from-node-16-to-node-20/.
Julia 1.9 - ubuntu-latest - x64 - push
The following actions uses node12 which is deprecated and will be forced to run on node16: actions/checkout@v2. For more info: https://github.blog/changelog/2023-06-13-github-actions-all-actions-will-run-on-node16-instead-of-node12-by-default/
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
duplicate docs found for 'GeometryOps.reproject' in src/api.md:59-61 ```@autodocs Modules = [GeometryOps] ```
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
failed to run `@example` block in src/source/methods/barycentric.md:32-100 ```@example barycentric using GeometryOps using GeometryOps.GeometryBasics using Makie using CairoMakie # Define a polygon polygon_points = Point3f[ (0.03, 0.05, 0.00), (0.07, 0.04, 0.02), (0.10, 0.04, 0.04), (0.14, 0.04, 0.06), (0.17, 0.07, 0.08), (0.20, 0.09, 0.10), (0.22, 0.11, 0.12), (0.25, 0.11, 0.14), (0.27, 0.10, 0.16), (0.30, 0.07, 0.18), (0.31, 0.04, 0.20), (0.34, 0.03, 0.22), (0.37, 0.02, 0.24), (0.40, 0.03, 0.26), (0.42, 0.04, 0.28), (0.44, 0.07, 0.30), (0.45, 0.10, 0.32), (0.46, 0.13, 0.34), (0.46, 0.19, 0.36), (0.47, 0.26, 0.38), (0.47, 0.31, 0.40), (0.47, 0.35, 0.42), (0.45, 0.37, 0.44), (0.41, 0.38, 0.46), (0.38, 0.37, 0.48), (0.35, 0.36, 0.50), (0.32, 0.35, 0.52), (0.30, 0.37, 0.54), (0.28, 0.39, 0.56), (0.25, 0.40, 0.58), (0.23, 0.39, 0.60), (0.21, 0.37, 0.62), (0.21, 0.34, 0.64), (0.23, 0.32, 0.66), (0.24, 0.29, 0.68), (0.27, 0.24, 0.70), (0.29, 0.21, 0.72), (0.29, 0.18, 0.74), (0.26, 0.16, 0.76), (0.24, 0.17, 0.78), (0.23, 0.19, 0.80), (0.24, 0.22, 0.82), (0.24, 0.25, 0.84), (0.21, 0.26, 0.86), (0.17, 0.26, 0.88), (0.12, 0.24, 0.90), (0.07, 0.20, 0.92), (0.03, 0.15, 0.94), (0.01, 0.10, 0.97), (0.02, 0.07, 1.00)] # Plot it! # First, we'll plot the polygon using Makie's rendering: f, a1, p1 = poly( polygon_points; color = last.(polygon_points), colormap = cgrad(:jet, 18; categorical = true), axis = (; type = Axis, aspect = DataAspect(), title = "Makie mesh based polygon rendering", subtitle = "CairoMakie" ), figure = (; size = (800, 400),) ) hidedecorations!(a1) ext = GeometryOps.GI.Extent(X = (0, 0.5), Y = (0, 0.42)) a2 = Axis( f[1, 2], aspect = DataAspect(), title = "Barycentric coordinate based polygon rendering", subtitle = "GeometryOps", limits = (ext.X, ext.Y) ) hidedecorations!(a2) p2box = poly!( # Now, we plot a cropping rectangle around the axis so we only show the polygon a2, GeometryOps.GeometryBasics.Polygon( # This is a rectangle with an internal hole shaped like the polygon. Point2f[(ext.X[1], ext.Y[1]), (ext.X[2], ext.Y[1]), (ext.X[2], ext.Y[2]), (ext.X[1], ext.Y[2]), (ext.X[1], ext.Y[1])], # exterior [reverse(Point2f.(polygon_points))] # hole ); color = :white, xautolimits = false, yautolimits = false ) cb = Colorbar(f[2, :], p1.plots[1]; vertical = false, flipaxis = true) # Finally, we perform barycentric interpolation on a grid, xrange = LinRange(ext.X..., 400) yrange = LinRange(ext.Y..., 400) @time mean_values = barycentric_interpolate.( (MeanValue(),), # The barycentric coordinate algorithm (MeanValue is the only one for now) (Point2f.(polygon_points),), # The polygon points as `Point2f` (last.(polygon_points,),), # The values per polygon point - can be anything which supports addition and division Point2f.(xrange, yrange') # The points at which to interpolate ) # and render! hm = heatmap!(a2, xrange, yrange, mean_values; colormap = p1.colormap, colorrange = p1.plots[1].colorrange[], xautolimits = false, yautolimits = false) translate!(hm, 0, 0, -1) # translate the heatmap behind the cropping polygon! f # finally, display the figure ``` exception = MethodError: no method matching poly_convert(::Float32, ::Tuple{typeof(identity), typeof(identity)}) Closest candidates are: poly_convert(!Matched::GeometryBasics.Mesh, ::Any) @ Makie ~/.julia/packages/Makie/We6MY/src/basic_recipes/poly.jl:83 poly_convert(!Matched::AbstractVector{<:AbstractVector{<:Union{Tuple{Vararg{T, N}}, StaticArraysCore.StaticArray{Tuple{N}, T, 1}} where {N, T}}}, ::Any) @ Makie ~/.julia/packages/Makie/We6MY/src/basic_recipes/poly.jl:112 poly_convert(!Matched::AbstractVector{<:Union{Tuple{T, T}, StaticArraysCore.StaticArray{Tuple{2}, T, 1}}}, ::Any) where T @ Makie ~/.julia/packages/Makie/We6MY/src/basic_recipes/poly.jl:104 ... Stacktrace: [1] macro expansion @ ~/.julia/packages/StaticArrays/85pEu/src/broadcast.jl:135 [inlined] [2] __broad
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
duplicate docs found for 'apply' in `@docs` block in src/source/primitives.md:41-48 ```@docs apply applyreduce GeometryOps.unwrap GeometryOps.flatten GeometryOps.reconstruct GeometryOps.rebuild ```
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
duplicate docs found for 'applyreduce' in `@docs` block in src/source/primitives.md:41-48 ```@docs apply applyreduce GeometryOps.unwrap GeometryOps.flatten GeometryOps.reconstruct GeometryOps.rebuild ```
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
duplicate docs found for 'GeometryOps.unwrap' in `@docs` block in src/source/primitives.md:41-48 ```@docs apply applyreduce GeometryOps.unwrap GeometryOps.flatten GeometryOps.reconstruct GeometryOps.rebuild ```
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
duplicate docs found for 'TraitTarget' in `@docs` block in src/source/primitives.md:8-10 ```@docs TraitTarget ```
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
duplicate docs found for 'LinearSegments' in `@docs` block in src/source/transformations/segmentize.md:57-60 ```@docs LinearSegments GeodesicSegments ```
Documentation: ../../../.julia/packages/Documenter/CJeWX/src/utilities/utilities.jl#L46
duplicate docs found for 'GeodesicSegments' in `@docs` block in src/source/transformations/segmentize.md:57-60 ```@docs LinearSegments GeodesicSegments ```
Documentation: ../../../.julia/packages/DocumenterVitepress/7lc1C/src/writer.jl#L669
DocumenterVitepress: un-expanded `@example barycentric` block encountered on page src/source/methods/barycentric.md. The first few lines of code in this node are: ``` using GeometryOps using GeometryOps.GeometryBasics using Makie using CairoMakie # Define a polygon polygon_points = Point3f[ ```
Documentation: ../../../.julia/packages/DocumenterVitepress/7lc1C/src/writer.jl#L827
Unexpected Julia interpolation in the Markdown. This probably means that you have an unbalanced or un-escaped $ in the text. To write the dollar sign, escape it with `\$` We don't have the file or line number available, but we got given the value: `Target` which is of type `Symbol`