From c1b63f0a3d0308535f7bef7cf6f706cf80a55a18 Mon Sep 17 00:00:00 2001 From: Jarrett Revels Date: Wed, 8 Aug 2018 14:50:38 +0100 Subject: [PATCH] fix constructor ambiguity introduced by #337 (#342) --- src/dual.jl | 12 ++++++++++-- test/DualTest.jl | 3 +++ 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/src/dual.jl b/src/dual.jl index 4beed70e..1d50a3dd 100644 --- a/src/dual.jl +++ b/src/dual.jl @@ -45,9 +45,18 @@ end @inline Dual{T}(value::Real, partials::Tuple{}) where {T} = Dual{T}(value, Partials{0,typeof(value)}(partials)) @inline Dual{T}(value::Real, partials::Real...) where {T} = Dual{T}(value, partials) @inline Dual{T}(value::V, ::Chunk{N}, p::Val{i}) where {T,V<:Real,N,i} = Dual{T}(value, single_seed(Partials{N,V}, p)) - @inline Dual(args...) = Dual{Nothing}(args...) +function Dual{T,V,N}(x::Real) where {T,V,N} + Base.depwarn("Dual{$T,$V,$N}(x::Real) is deprecated, use `convert(Dual{$T,$V,$N}, x)` instead.", :Dual) + return convert(Dual{T,V,N}, x) +end + +function Dual{T,V}(x::Real) where {T,V} + Base.depwarn("Dual{$T,$V}(x::Real) is deprecated, use `convert(Dual{$T,$V}, x)` instead.", :Dual) + return convert(Dual{T,V}, x) +end + ############################## # Utility/Accessor Functions # ############################## @@ -315,7 +324,6 @@ end Base.convert(::Type{Dual{T,V,N}}, d::Dual{T}) where {T,V<:Real,N} = Dual{T}(convert(V, value(d)), convert(Partials{N,V}, partials(d))) Base.convert(::Type{Dual{T,V,N}}, x::Real) where {T,V<:Real,N} = Dual{T}(convert(V, x), zero(Partials{N,V})) Base.convert(::Type{D}, d::D) where {D<:Dual} = d -(::Type{D})(x::Real) where {D<:Dual} = convert(D, x) Base.float(d::Dual{T,V,N}) where {T,V,N} = convert(Dual{T,promote_type(V, Float16),N}, d) Base.AbstractFloat(d::Dual{T,V,N}) where {T,V,N} = convert(Dual{T,promote_type(V, Float16),N}, d) diff --git a/test/DualTest.jl b/test/DualTest.jl index 0312ce5e..e3cfc61f 100644 --- a/test/DualTest.jl +++ b/test/DualTest.jl @@ -54,6 +54,9 @@ for N in (0,3), M in (0,4), V in (Int, Float32) ################ @test Dual{TestTag()}(PRIMAL, PARTIALS...) === FDNUM + @test Dual(PRIMAL, PARTIALS...) === Dual{Nothing}(PRIMAL, PARTIALS...) + @test Dual(PRIMAL) === Dual{Nothing}(PRIMAL) + @test typeof(Dual{TestTag()}(widen(V)(PRIMAL), PARTIALS)) === Dual{TestTag(),widen(V),N} @test typeof(Dual{TestTag()}(widen(V)(PRIMAL), PARTIALS.values)) === Dual{TestTag(),widen(V),N} @test typeof(Dual{TestTag()}(widen(V)(PRIMAL), PARTIALS...)) === Dual{TestTag(),widen(V),N}