Numeric.AD и проблема набора текста
Я пытаюсь работать с Numeric.AD и пользовательским типом Expr. Я хочу рассчитать символический градиент введенного пользователем выражения. Первое испытание с постоянным выражением работает хорошо:
calcGrad0 :: [Expr Double]
calcGrad0 = grad df vars
where
df [x,y] = eval (env [x,y]) (EVar "x"*EVar "y")
env vs = zip varNames vs
varNames = ["x","y"]
vars = map EVar varNames
Это работает:
>calcGrad0
[Const 0.0 :+ (Const 0.0 :+ (EVar "y" :* Const 1.0)),Const 0.0 :+ (Const 0.0 :+ (EVar "x" :* Const 1.0))]
Однако, если я вытащу выражение в качестве параметра:
calcGrad1 :: [Expr Double]
calcGrad1 = calcGrad1' (EVar "x"*EVar "y")
calcGrad1' e = grad df vars
where
df [x,y] = eval (env [x,y]) e
env vs = zip varNames vs
varNames = ["x","y"]
vars = map EVar varNames
я получил
Could not deduce (a ~ AD s (Expr a1))
from the context (Num a1, Floating a)
bound by the inferred type of
calcGrad1' :: (Num a1, Floating a) => Expr a -> [Expr a1]
at Symbolics.hs:(60,1)-(65,29)
or from (Mode s)
bound by a type expected by the context:
Mode s => [AD s (Expr a1)] -> AD s (Expr a1)
at Symbolics.hs:60:16-27
`a' is a rigid type variable bound by
the inferred type of
calcGrad1' :: (Num a1, Floating a) => Expr a -> [Expr a1]
at Symbolics.hs:60:1
Expected type: [AD s (Expr a1)] -> AD s (Expr a1)
Actual type: [a] -> a
In the first argument of `grad', namely `df'
In the expression: grad df vars
Как я могу получить GHC, чтобы принять это?
2 ответа
Я думаю, вы забыли применить лифт, чтобы преобразовать Expr
для AD s Expr
,
Если вы заинтересованы в использовании рекламного пакета для символической дифференциации. Прослеженный пакет Леннарта Огюсссона работает хорошо.
Когда GHC не может вывести сигнатуру равенства типов для допустимой функции, как в вашем случае, решение состоит в том, чтобы дать функции сигнатуру типа. Я не знаю интерфейс к этой библиотеке. Тем не менее, я думаю, что правильная подпись calcGrad1 :: (Num a, Floating a) => Expr a -> [Expr a]
,