Я пытаюсь реализовать алгебру max-plus semiring в Julia (0.6.2), следуя этой статье:
http://www.mit.edu/~kepner/pubs/JuliaSemiring_HPEC2013_Paper.pdf
Определение типа для чисел max-plus и определения всех соответствующих операторов, взятые прямо из упомянутой выше статьи, следующие:
# define max-plus number type
immutable MPNumber{T} <: Number
val::T
end
+(a::MPNumber, b::MPNumber) = MPNumber(max(a.val, b.val))
*(a::MPNumber, b::MPNumber) = MPNumber(a.val + b.val)
show(io::IO, k::MPNumber) = show(io, k.val)
zero{T}(::MPNumber{T}) = MPNumber(typemin(T))
one{T}(::MPNumber{T}) = MPNumber(zero(T))
promote_rule{T<:Number}(::Type{MPNumber}, ::Type{T}) = MPNumber
mparray(A::Array) = map(MPNumber, A)
array{T}(A::Array{MPNumber{T}}) = map(x->x.val, A)
Базовые тесты сложения и умножения max-plus работают просто отлично, например,
MPNumber(1) + MPNumber(1)
дает MPNumber(1)
, как и ожидалось. Макс-плюс матрица возведения в степень, как показано в статье, также работает как шарм:
A = mparray(Array([[1, 2] [3, 4]]))
A*A
дает
2×2 Array{MPNumber{Int64},2}:
MPNumber{Int64}(5) MPNumber{Int64}(7)
MPNumber{Int64}(6) MPNumber{Int64}(8)
Однако, когда я пытаюсь умножить вектор с максимальным плюсом на матрицу с максимальным плюсом,
A = mparray(Array([[1, 2] [3, 4]]))
x = mparray([1, 2])
A*x
Я получаю следующую ошибку:
MethodError: Cannot `convert` an object of type Int64 to an object of type MPNumber{Int64}
This may have arisen from a call to the constructor MPNumber{Int64}(...) since type constructors fall back to convert methods.
Stacktrace:
[1] generic_matvecmul!(::Array{MPNumber{Int64},1}, ::Char, ::Array{MPNumber{Int64},2}, ::Array{MPNumber{Int64},1}) at ./linalg/matmul.jl:434
[2] Ac_mul_B(::Array{MPNumber{Int64},1}, ::Array{MPNumber{Int64},2}) at ./linalg/rowvector.jl:227
Я все еще довольно новичок в Джулии, поэтому мне трудно разобраться, что именно здесь идет не так и как это можно исправить. Любая помощь будет высоко ценится.