Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

implement Float32 without losing Float64 precision (rebased) #3681

Merged
merged 94 commits into from
Mar 18, 2024

Conversation

SimonDanisch
Copy link
Member

@SimonDanisch SimonDanisch commented Mar 6, 2024

Cleaned up rebase of #3680, based against breaking-0.21 directly, instead of sd/axis-converts


TODO from #3663 & #3671

  • merge dont use macro for aliases and introduce more variants (Float64 -> d, UInt -> ui) JuliaGeometry/GeometryBasics.jl#214 to make shorthands available
  • adjust convert_arguments pipeline to either let numeric types pass through OR always convert them to Float32/Float64 as appropriate
  • update project functions
  • update data_limits, boundingbox to handle Real inputs, make outputs Float64 or input based (mostly Streamline data_limits and boundingbox #3671)
  • update Axis limits to handle Real inputs, and use Float64 for limits
  • implement Float32Scaling type / scaling logic
  • implement matrix adjustments for scaling
  • implement Float32 conversions in GLMakie
  • implement Float32 conversions in CairoMakie
  • implement Float32 conversions in WGLMakie
  • implement Float32 conversions in RPRMakie
  • clean up order of operations
  • consider adding base + offset tick formatting (e.g. 1e9 + 1 .. 1e9 + 10)
  • consider changing model back to a Float32 matrix
  • go through "layouting/maybe_unused.jl" and restore or delete functions
  • go through TODOs comments
  • add tests
    • test lims[2] - lims[1] < min(eps(lims[1]), eps(lims[2]))
    • test lims << floatmin(Float32) (e.g. 1e-100)
    • test lims >> floatmax(Float32) (e.g. 1e100)
    • test model/transformations with active float32convert
    • test every plot that projects internally (errorbars, h/vspan/lines, bracket, ...)
    • test convert_arguments exhaustively (i.e. @test convert_arguments(a, b) == c)
  • update changelog
  • reconsider BBox() changes (Do we need them?) merge Generalize BBox jkrumbiegel/GridLayoutBase.jl#52
  • consider adding Rect{N, Float32} <-> Rect{N, Float64} conversions (at the end as this is currently a nice way to catch issues)
  • investigate why "space test in transformed axis" changes color
  • position_om_plot and DataInspector
  • BezierPath
  • consider marker metrics in boundingbox(::Scatter)

TODO from testing

  • yticks beyond limits show up in CairoMakie
  • image! and heatmap! cause frame to disappear in CairoMakie
  • mesh! converts Float64 Circle to Float32
  • Axis ticks (text) hidden in GLMakie
  • image! and heatmap! don't show up in GLMakie, CairoMakie

Breaking Changes:

  • data_limits and boundingbox now return Rect3d instead of Rect3f
  • data_limits no longer considers scale! and rotate! / parts of the model matrix
  • boundingbox now considers the full model matrix and transform_func
  • transform_func is now expected to keep the input type or convert to Float64
  • Axis limits are now Float64
  • BBox is overwritten to be a Rect3d. TODO This may clash with GridLayoutBase!
  • to_world(point, matrix, resolution) deprecated for to_world(scene, point) which handles float32convert
  • (internal?) changed projview_to_2d_limits to take a plot and output an observable (i.e. apply float32convert as part of the function)

Related Issues

Unrelated fixes:

This was referenced Mar 6, 2024
@MakieBot
Copy link
Collaborator

MakieBot commented Mar 6, 2024

Compile Times benchmark

Note, that these numbers may fluctuate on the CI servers, so take them with a grain of salt. All benchmark results are based on the mean time and negative percent mean faster than the base branch. Note, that GLMakie + WGLMakie run on an emulated GPU, so the runtime benchmark is much slower. Results are from running:

using_time = @ctime using Backend
# Compile time
create_time = @ctime fig = scatter(1:4; color=1:4, colormap=:turbo, markersize=20, visible=true)
display_time = @ctime Makie.colorbuffer(display(fig))
# Runtime
create_time = @benchmark fig = scatter(1:4; color=1:4, colormap=:turbo, markersize=20, visible=true)
display_time = @benchmark Makie.colorbuffer(fig)
using create display create display
GLMakie 3.37s (3.35, 3.39) 0.01+- 130.50ms (128.95, 131.49) 0.77+- 527.72ms (523.77, 537.53) 4.82+- 7.63ms (7.48, 7.71) 0.08+- 25.53ms (25.39, 26.18) 0.29+-
breaking-0.21 3.33s (3.31, 3.37) 0.02+- 159.40ms (158.01, 161.45) 1.40+- 425.86ms (423.59, 431.27) 2.51+- 7.36ms (7.30, 7.41) 0.04+- 25.41ms (25.38, 25.44) 0.02+-
evaluation 0.99x slower X, 0.04s (2.32d, 0.00p, 0.02std) 1.22x faster✅, -28.9ms (-25.61d, 0.00p, 1.08std) 0.81x slower❌, 101.86ms (26.52d, 0.00p, 3.66std) 0.96x slower X, 0.27ms (4.40d, 0.00p, 0.06std) 1.00x invariant, 0.12ms (0.61d, 0.30p, 0.15std)
CairoMakie 3.04s (2.98, 3.10) 0.05+- 136.46ms (132.92, 138.98) 1.86+- 115.59ms (109.02, 118.67) 3.25+- 7.37ms (7.26, 7.51) 0.08+- 916.42μs (906.73, 937.55) 10.42+-
breaking-0.21 2.92s (2.87, 2.96) 0.03+- 158.17ms (156.40, 160.20) 1.36+- 105.35ms (104.38, 107.48) 1.01+- 7.27ms (7.15, 7.41) 0.09+- 905.43μs (893.62, 913.95) 7.25+-
evaluation 0.96x slower X, 0.12s (3.00d, 0.00p, 0.04std) 1.16x faster✅, -21.71ms (-13.32d, 0.00p, 1.61std) 0.91x slower❌, 10.24ms (4.25d, 0.00p, 2.13std) 0.99x invariant, 0.1ms (1.13d, 0.06p, 0.09std) 0.99x slower X, 10.99μs (1.22d, 0.04p, 8.84std)
WGLMakie 3.80s (3.77, 3.82) 0.02+- 357.15ms (352.00, 366.96) 4.97+- 8.92s (8.83, 9.04) 0.07+- 10.54ms (9.87, 13.29) 1.23+- 70.91ms (69.67, 72.00) 0.89+-
breaking-0.21 3.69s (3.65, 3.71) 0.02+- 167.41ms (163.68, 171.46) 2.81+- 9.19s (9.05, 9.37) 0.10+- 9.78ms (9.62, 10.14) 0.17+- 71.16ms (69.76, 73.22) 1.25+-
evaluation 0.97x slower X, 0.11s (5.26d, 0.00p, 0.02std) 0.47x slower❌, 189.74ms (46.98d, 0.00p, 3.89std) 1.03x faster ✓, -0.27s (-2.97d, 0.00p, 0.09std) 0.93x noisy🤷‍♀️, 0.76ms (0.87d, 0.15p, 0.70std) 1.00x invariant, -0.25ms (-0.23d, 0.67p, 1.07std)

SimonDanisch added a commit that referenced this pull request Mar 7, 2024
I noticed in #3681, that we dont actually have the exact statement from ttf precompile in here.
This should be in here, since it should test if everything is cached and precompiled correctly.
If we want to benchmark compile speed in general without caching, we would need to add some other benchmark, since without this statement, this is neither benchmarking pure precompiled performance, nor pure compilation time.
SimonDanisch added a commit that referenced this pull request Mar 7, 2024
* Add precompile used in ttf benchmark

I noticed in #3681, that we dont actually have the exact statement from ttf precompile in here.
This should be in here, since it should test if everything is cached and precompiled correctly.
If we want to benchmark compile speed in general without caching, we would need to add some other benchmark, since without this statement, this is neither benchmarking pure precompiled performance, nor pure compilation time.

* dont nightly
Comment on lines 88 to 91
function data_limits(p::HLines)
scene = parent_scene(p)
limits = projview_to_2d_limits(scene.camera.projectionview[])
itf = inverse_transform(p.transformation.transform_func[])
xmin, xmax = apply_transform.(itf[1], first.(extrema(limits)))
ymin, ymax = extrema(p[1][])
return Rect3f(Point3f(xmin, ymin, 0), Vec3f(xmax - xmin, ymax - ymin, 0))
return Rect3d(Point3d(NaN, ymin, 0), Vec3d(NaN, ymax - ymin, 0))
end
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just to note - you can now ignore a dimension in limits by setting it to NaN

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice

@asinghvi17
Copy link
Member

I noticed that scatter plots with large markersizes no longer set limits to the full marker. Is this intentional, and should we reverse it?

MWE is:

scatter(Point2f(0); markersize = 5, markerspace = :data)

iTerm2 TVVMY3

@ffreyer
Copy link
Collaborator

ffreyer commented Mar 15, 2024

I noticed that scatter plots with large markersizes no longer set limits to the full marker. Is this intentional, and should we reverse it?

MWE is:

scatter(Point2f(0); markersize = 5, markerspace = :data)

This doesn't work on breaking-0.21 or master either, but I was thinking about adding it since it's the case for meshscatter

Comment on lines +108 to +142
################################################################################

# TODO: remove after GeometryBasics#214
const Point2d = Point2{Float64}
const Point3d = Point3{Float64}
const Point4d = Point4{Float64}
const Vec2d = Vec2{Float64}
const Vec3d = Vec3{Float64}
const Vec4d = Vec4{Float64}
const Rect2d = Rect2{Float64}
const Rect3d = Rect3{Float64}
const Rectd = Rect{N, Float64} where N
const Mat2d = Mat2{Float64}
const Mat3d = Mat3{Float64}
const Mat4d = Mat4{Float64}
export Point2d, Point3d, Point4d, Vec2d, Vec3d, Vec4d, Rect2d, Rect3d

# TODO: move to GeometryBasics?
function GeometryBasics.Rect3{T}(r::Rect2) where {T} # used in text boundingbox
return Rect3{T}(Vec3{T}(origin(r)..., zero(T)), Vec3{T}(widths(r)..., zero(T)))
end

function Base.convert(::Type{Rect{N, T}}, r::Rect{N}) where {N, T}
return Rect{N, T}(r)
end

# TODO: patch GridLayoutBase, probably to use Float64 consistently?
function GridLayoutBase.BBox(left::T1, right::T2, bottom::T3, top::T4) where {T1 <: Real, T2 <: Real, T3 <: Real, T4 <: Real}
mini = (left, bottom)
maxi = (right, top)
T = promote_type(T1, T2, T3, T4, Float32) # Float32 to skip Int outputs
return Rect2{T}(mini, maxi .- mini)
end

################################################################################
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TODO: clean up before merge

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just registering gridlayoutbase 0.10.1 with your bbox change

@SimonDanisch
Copy link
Member Author

I don't know why the benchmarks are suddenly so noisy... Locally, its quite significantly in favor of this PR for all backends :)
I know that there are some open TODOs for this PR, but I will merge this now, to be able to rebase it cleanly against sd/axis-converts.

Local results:

using create display create display
GLMakie
breaking-0.21
evaluation
CairoMakie 4.29s (4.22, 4.36) 0.05+- 142.10ms (137.80, 148.22) 4.39+- 469.90ms (459.07, 479.29) 7.23+- 7.84ms (7.76, 7.99) 0.09+- 947.04μs (916.35, 989.33) 34.79+-
breaking-0.21 4.19s (4.18, 4.20) 0.01+- 170.60ms (166.90, 174.37) 3.44+- 458.92ms (451.21, 470.73) 7.37+- 7.52ms (7.46, 7.62) 0.06+- 920.73μs (894.77, 952.35) 25.76+-
evaluation 0.98x slower X, 0.1s (2.60d, 0.01p, 0.03std) 1.20x faster✅, -28.5ms (-7.23d, 0.00p, 3.91std) 0.98x slower X, 10.99ms (1.51d, 0.04p, 7.30std) 0.96x slower X, 0.31ms (4.17d, 0.00p, 0.07std) 0.97x invariant, 26.31μs (0.86d, 0.21p, 30.28std)
WGLMakie 5.24s (5.12, 5.33) 0.08+- 141.54ms (138.49, 144.27) 2.18+- 9.18s (9.09, 9.25) 0.06+- 7.53ms (7.44, 7.72) 0.11+- 15.25ms (13.80, 16.27) 0.96+-
breaking-0.21 5.20s (5.16, 5.25) 0.03+- 175.00ms (170.77, 178.63) 3.48+- 9.22s (9.15, 9.26) 0.06+- 7.44ms (7.34, 7.56) 0.10+- 14.37ms (12.50, 15.82) 1.38+-
evaluation 0.99x invariant, 0.04s (0.69d, 0.32p, 0.06std) 1.24x faster✅, -33.46ms (-11.53d, 0.00p, 2.83std) 1.00x invariant, -0.03s (-0.54d, 0.42p, 0.06std) 0.99x invariant, 0.09ms (0.89d, 0.20p, 0.11std) 0.94x noisy🤷‍♀️, 0.88ms (0.74d, 0.28p, 1.17std)

@SimonDanisch SimonDanisch merged commit 2176f0f into breaking-0.21 Mar 18, 2024
28 of 34 checks passed
@SimonDanisch SimonDanisch deleted the float64-rebased branch March 18, 2024 10:32
SimonDanisch added a commit that referenced this pull request May 8, 2024
* run CI against this PR

* bump version

* fix circular reference

* remove GeoInterfaceMakie tests for good to avoid circular dependencies

* add poly1

* Rework line shaders for WGLMakie compatability (#3558)

* prototyping

* fix joint with non-uniform linewidths

* fix transform

* add patterns

* fix pattern sampling

* fix truncated join cutoff + some cleanup

* improve pattern overwrite threshhold

* reorganize code

* cleanup

* add function for line vec -> line normal

* don't try to cleanup joints if linewidth difference is critical

* rename some variables

* cleanup comments, restructure linewidth sdf generation

* minor cleanup + notes

* fix orientation problems with truncated joints

* minor performance tweaks + cleanup

* handle line joints in fragment shader & ditch variable linewidths

* improve truncation overlap/gap

* improve pattern adjustments for truncated joints

* cleanup

* reorganize code to reduce memory usage

* mostly fix gap in sharp joints

* explain pattern overwrite a bit more

* use new fragment shader for linesegments

* disable debug rendering

* fix incorrect line placement

* adjust line segments to pattern

* use const over define & fix dots

* tweak debug rendering

* make truncation overlap a bit nicer

* minor cleanup

* fix linestyle in linesegments

* skip rendering at 0 linewidth

* add slight bias to avoid missing pixels

* differentiate different segments in debug render

* make color interpolation continuous at joint

* fix dense line color artifacts

* remove unused

* allocate space for joints

* use sdf for AA + debug render

* add miter joints

* handle colors

* some cleanup + linesegments prep

* fix some errors [skip ci]

* add patterns

* clean up linesegments

* add normal rendering mode

* minor cleanup

* experiment with geometry adjustments

* use rounding to solve joint over/underdraw

* WebGL doesn't like scaling

* smooth out inner edge of truncated join

* remove derivative to reduce float accuracy issues

* improve thin lines

* fix lastlen error

* match buffer sizes to number of drawn segments

* avoid dissipation of lines at high point densities

* calculate uv from quad_sdf1

* reduce number of interleaved buffers

* fix disappearing grid lines

* fix missing preprocessors

* fix pattern artifacts in dense line sections

* cleanup some variables

* allow patterns to adjust to linewidth

* fix AA at line end

* fix nan handling

* discard fully transparent pixels

* fix patterns with nan, reset pattern on nan

* fix size issues

* extrude lines slightly to cleanly close them

* fix pixel skipping?

* cleanup patterns

* remove linewidth from pattern based line adjustments

* consider AA in shape factor

* reset shape_factor if pattern changes segment shape

* minor cleanup

* apply changes to WGLMakie + cleanup

* cleanup pattern overwrite

* use the same AA_RADIUS in fragment shader

* fix linelen transform

* disable debug

* fix line start/end AA

* fix px_per_unit?

* fix px_per_unit?

* reduce line start/end extrusion

* simplify extrusion and shape_factor

* summarize breaking changes

* move miter joint test

* update docstring

* minor cleanup

* enable more tests

* move gappy & friends to Makie

* note change to linestyle scaling

* cleanup

* fix line start/end AA

* remove global var

* disable GeoMakie tests for now

* improve transparency for WGLMakie

* fix problems with 180° change in line direction

* fix directionality

* interpolate colormap in fragment shader

* remove util.vert from line/segments

---------

Co-authored-by: SimonDanisch <[email protected]>

* fix line inversion (#3651)

* fix lines shader

* cleanup debug code

* fix rebase error

* fix pattern connectivity

* some cleanup

* apply changes to WGLMakie

* add test

* fix CairoMakie too

* update changelog

* fix missing start/end segment

* Update CHANGELOG.md

* update comments

---------

Co-authored-by: Simon <[email protected]>

* Documented / validated plot attributes (#3626)

* add second `@recipe` method

* rename function

* implement recipe and keyword validation

* fix some bugs

* rename for clarity

* change Scatter recipe

* use argument symbols correctly

* change Lines

* change linesegments

* do a bunch of plots more

* fix text bugs

* splice in internal attribute after mesh creation

* add allowlist

* fix text

* add attribute deprecation mechanism

* add explanation

* remove `text` for GLMakie

* fix contour volume attributes

* add rasterize to allowlist

* add `enable_depth` to volume

* add `matcap` to mesh

* set `fxaa = false` on scatter, lines, linesegments, text

* move fxaa after mixins

* fix keywords

* remove markersize attribute

* remove invalid markersize

* add depthsorting to attributes for scatter

* fix forwarded attributes

* add absorption to volume

* don't use `used_attributes` for datashader canvas convert

* fix positional args

* image

* add better printing and rudimentary tests

* make allowlist a tuple for fewer allocations

* attribute names tuple instead of set

* make deprecations also a tuple

* avoid intermediate vector to speed up attribute creation

* apply same optimization to blocks

* implement mechanism to augment user docstring

* delete manually written out attribute docs

* use funcsym in docstring

* incorporate attribute docs into docstring again

* use equal

* add changelog

* introduce `DocumentedAttributes` with macro

* add function to access `DocumentedAttributes` of a recipe

* fix module mutation problem for now

* move definition behind PlotType

* return Attributes instead of Dict

* convert wireframe recipe

* close over reference

* don't include prereleases in benchmark, failed with 1.11 alpha

* stringify default expr

* convert arrows

* add docs

* directly convert default exprs to strings

* convert ablines

* print wrong attribute in red

* convert annotations

* convert arc

* remove attributes in arrows docstring

* convert band

* fix escaping issue

* convert barplot

* convert bracket

* fix barplot usage in hist

* convert contourf

* typo

* convert contour

* fix waterfall

* comment out arrows test

* convert datashader

* convert errorbar and rangebar

* convert hvlines

* convert hvspan

* convert pie

* convert rainclouds

* convert scatterlines

* convert series

* convert spy

* convert stairs

* convert stem

* convert streamplot

* convert timeseries

* convert tooltip

* convert tricontourf

* add transformation to allowlist

* convert triplot

* convert volumeslices

* convert voronoiplot

* convert waterfall

* convert boxplot

* convert crossbar

* convert density

* convert qqplot and qqnorm

* convert ecdfplot

* convert hexbin

* convert hist

* convert violin

* improve error message printing

* add docstrings for mutating functions and plot types

* add missing docstrings

* reconnect lines docstring

* move functions out of macro

* fix arrows example and adjust docs

* put necessary functions back into macro

---------

Co-authored-by: Simon <[email protected]>

* Add voxel plot type (#3527)

* create voxel rendering prototype

* enable lighting

* prototype voxel id generation & color handling

* add is_air attribute

* prototype texture mapping

* fix shader reloading

* fix texture mapping

* implement local updates

* optimize render order (depthsorting = false)

* add depthsorting = true

* render z planes first

* add lowclip and highclip

* add refimg tests + some fixes

* fix colorrange

* fix local chunk update

* handle colorrange more efficiently

* handle voxel id data more efficiently

* docstring & formatting

* switch back to lrbt order for uvmap

* add docs

* try fix tests

* fix show

* fix test?

* add missing dimensions

* add arguments for placement and scale

* allow Colon

* add Colon() to local_update

* minor cleanup

* prototype WGLMakie version

* add fallback in CairoMakie

* add RPRMakie fallback

* skip invisible voxels

* fix typo

* rename voxel -> voxels

* update docs, fix placement

* update news

* fix Colorbar for voxels

* enable tests

* fix texture rotation

* cleanup print

* cleanup comment

* generalize array access

* debug WGLMakie

* get voxels rendering in WGLMakie

* fix texture mapping

* activate tests

* fix moving planes, cleanup prints

* add unit tests

* add gap attribute

* tests & docs

* mention potential issues with picking

* fix WGLMakie picking

* fix depthsorting/gap handling

* switch to integer mod

* fix render order

* use RNG

* fix 1.6 3d array syntax

* fix refimage

* Update CHANGELOG.md

* fix julia 1.6

---------

Co-authored-by: Simon <[email protected]>

* implement Float32 without losing Float64 precision (rebased) (#3681)

* implement float64 precision

* remove merge conflicts

* update CairoMakie

* move some code around

* simplify syntax

* add non-Observable apply_transform_and_f32_conversion

* clean up convert_arguments

* update WGLMakie

* fix tests

* patch model to act after f32convert

* fix function name

* update project and plot_to_screen

* fix patch_model

* add first test

* rename file

* fix type after patch_model

* fix ticks beyond limits

* fix image and heatmap conversion

* convert to float types

* update test

* Fix CairoMakie not precompiling

missed a `Makie.` in the image recipe

* update mesh converts

* fix poly convert type

* fix dict access

* fix first test in WGLMakie

* don't use triangle_mesh

* fix incorrect convert_arguments

* fix test

* fix DataInspector error

* add meshscatter + surface to tests, fix convert_arguments for poly

* Fix docs + Makie tests

* Fix 1.6!?

* fix picking test

* update DataInspector

* fix indicator rotation for meshscatter in DataInspector

* fix Vector{<: Integer}, Vector{Float32} -> Vector{Float32} [skip ci]

* fix stackoverflow on mixed tuple types [skip ci]

* fix tuples correctly [skip ci]

* fix geom -> points eltype [skip ci]

* fix geom -> PointBased output type

* fix Rect2 -> points output type [skip ci]

* fix PointBased mesh conversion

* fix PointBased multi-linestrings type [skip ci]

* update bezierpath

* split up conversions

* fix missing Points convert [skip ci]

* fix CellGridBased types [skip ci]

* always convert volumes to float32

* start adding type tests for every convert_arguments

* fix tests

* undo splitting conversions.jl

* test and cleanup mesh conversions

* fix docs

* update & test Annotations

* update & test arrows

* update and test band and bracket

* update & test errorbars and rangebars conversions

* test & update series converts

* make type stable on 1.6

* update & test remaining convert_arguments

* fix & test model application

* add tests for float32convert

* at floatmin/max refimg test

* fix typo

* update text bbox test & add backtrace

* avoid Float32 in data_limits

* fix Polygon -> Bezierpath conversion

* fix WGLMakie meshscatter model patching

* fix Float64 normals

* fix Float64 matrices in Voxels

* test normal and uv types

* fix for 1.6

* make new project method more complete

* clean up some TODOs

* restore text tests

* restore Polar transform tests

* avoid BBox for Axis limits

* fix rectangle zoom, deprecate to_world with matrix inputs

* fix 1.6

* fix Float64 latexstrings

* fix hvlines, hvspan, errorbars, rangebars

* fix & test ablines

* fix other usage of projview_to_2d_limits

* remove dublicated line

* update changelog + cleanup [skip ci]

* fix missing to_value

* consider markersize and offset for scatter data_limits

* fix tests

* revert BBox -> Rect2d changes

* get hist and barplot working

---------

Co-authored-by: ffreyer <[email protected]>
Co-authored-by: Anshul Singhvi <[email protected]>

* Document conversion pipeline (#3719)

* document conversion pipeline

* fix doc build

* fix block

---------

Co-authored-by: SimonDanisch <[email protected]>

* Deprecate `rotations` for `rotation` for Scatter and MeshScatter (#3724)

* deprecate `rotations` for `rotation` for Scatter and MeshScatter

* one more rename

* remove double conversion

* fix cairomakie meshscatter

* fix usage in docs

* remove mat4 code again

* fix CairoMakie rror

* change one more rotations

* fix WGLMakie

* add changelog entry

---------

Co-authored-by: ffreyer <[email protected]>

* fix merge

* update scatter boundingbox (#3716)

* implement scatter boundingbox with marker metrics

* add tests

* always consider marker rotations

* update changelog [skip ci]

* fix data_limits

* fix some more issues

* rotations -> rotation

* Update boundingboxes.jl

---------

Co-authored-by: Simon <[email protected]>

* Change how boundingbox(::Text) is deprecated (#3723)

* change how boundingbox is deprecated

* update changelog

* fix test errors

* fix docs errors and cleanup error message

* fix type instability

* fix function name

* fix function name

* fix boundingbox overwrites

* update changelog

* add types to function args

maybe this allows boundingbox(::MyPlot, space) to work without ::Symbol...

* fix typing

* fully remove :world space

* fix test

* Various fixes for next release (#3731)

* fix error for 2d meshscatter data_limits

* avoid Rect3(::Rect2) constructor

* allow :inspector_label

* allow inspector_clear and inspector_hover too

* fix rect zoom & cleanup to_world

* move inspector attributes to default attributes

* fix NaN handling in limits & deprecate _update_rect

* Update CHANGELOG.md

* Fix some issues with voxels (#3748)

* fix single color

* update to new attribute docs and hide internal attributes

* fix missing voxel planes in Axis3

* use transformationmatrix

* should be normalized

* make view_direction optimization less error prone

* Fix rare missing/duplicate pixels in truncated joint (#3794)

* rework truncated joint discard

* update WGLMakie

* fix non-solid linestyle joints

* Add linecaps and jointstyles (#3771)

* add attributes

* prototype linecap & linestyle in GLMakie

* move code around, add comments

* add capstyle for linesegments

* update WGLMakie

* revert change in padding of uncapped lines

* make sure truncation can't trigger

* update CairoMakie

* add :bevel

* make miter_limit adjustable

* capstyle -> linecap

* update changelog

* add refimg tests

* add example

* fix rendering issue with bevel for continued lines

* use named constants

* add more space to test

* consider miter_limit in CairoMakie as well

* also enable refimg test

* switch to angle based miter_limit

* fix default

* tweak tests

* note change in default miter_limit

* add new attributes to recipes

* rename jointstyle -> joinstyle

* update a few more jointstyles

* Fix rare missing/duplicate pixels in truncated joint (#3794)

* rework truncated joint discard

* update WGLMakie

* fix non-solid linestyle joints

* improve truncated linecap a bit

* regenerate wglmakie bundled

* tweak shape_factor

* restore file

* try fix connected sphere

* add debug refimgs

* more testing

* more testing

* revert debugging

* fix test?

* Cleanup for breaking 0.21 (#3765)

* cleanup temp defitions

* finalize data_limits cleanup

* GeometryBasics should probably be breaking

* adjust other versions

* use newly tagged GeometryBasics

* use breaking gridlayoutbase

* try updating registry

* somehow this is needed?!

* add to missing CI

---------

Co-authored-by: SimonDanisch <[email protected]>

* Unit support for Axes & Recipes, a.k.a axis converts (#3226)

* take over most of the work from #1347

* add typed argument conversion (#3565)

* add typed argument conversion

* fix volume

* add function to get available conversions

* make conversion apply more narrowly

* more cleanly separate recursion in convert_arguments

* clean up

* allow to get axis before creating a plot

* clean up

* fix tests

* bring back dim converts (axis_convert)

* update tests

* fix tests and work around conversion problems

* fix WGLMakie

* fix errors

* clean up conversion pipeline

* fix tests

* add changelog entry

* disable project run

* improve performance slightly

* might as well use array

* tmp

* wip

* implement axis convert recursion

* fix tests

* fix datashader

* fix datashader

* move unitful integration

* fix performance regression!?

* fix merge & new date time improvements

* fix scaling test

* remove test false

* clean up

* converts shouldnt be here

* move axis converts to scene

* further refactor [skip ci]

* finish refactor for AxisConversion type

* allow limit setting and ticks

* make tests less noisy

* cleanup

* clean up and fix unitful/date conversion

* make sure all tests work correctly

* remove rand

* rename, clean up and make axis spec work

* clean up and test new conversion pipeline

* undo feature deletion, don't reintroduce Rect2f

* be explicit about Volume Interval types

* minor docstring cleanup

* try to clarify new conversion docstrings

* remove convert_arguments_typed in favor of types_for_plot_arguments

* fix remaining bugs for conversion simplification

* fix ticks not updating

* fix specapi

* fix qqnorm

* clean up types_for_plot_arguments

* fix tuple conversion

* try to fix compile time regression

* try to fix compile time regression

* clean up and introduce expand_dimensions

* fix #3655 and clean up convert_arguments + add tests

* fix #3509 and add tests for

* clean up observables and more docs

* final rename

* fix docs

* cleanup

* small clean up

* small doc improvements

* improve docs

* fix docs

* try relative link

* try without .md

* take out link

* try fix

---------

Co-authored-by: ffreyer <[email protected]>

* fix comment

* Add wrap recipe tutorial (#3816)

* [Docs] add wrap/redirect recipe tutorial

* fix sentence

* Update docs/tutorials/wrap-existing-recipe.md

Co-authored-by: Anshul Singhvi <[email protected]>

* update

* fix doc build

* add changelog

* fix preview

---------

Co-authored-by: Moelf <[email protected]>
Co-authored-by: Anshul Singhvi <[email protected]>

* only forward attributes usable by recipe

* make sharing of attributes explicit

* ci

* fix RPRMakie material

* small fixes

* fix RPRMakie

* fix series with BezierPath

* fix series conversions

---------

Co-authored-by: Frederic Freyer <[email protected]>
Co-authored-by: Julius Krumbiegel <[email protected]>
Co-authored-by: Anshul Singhvi <[email protected]>
Co-authored-by: Moelf <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Scatter not displaying in the presence large coordinates
5 participants