-
Notifications
You must be signed in to change notification settings - Fork 32
Expand file tree
/
Copy pathreverse_onearg.jl
More file actions
83 lines (77 loc) · 1.97 KB
/
reverse_onearg.jl
File metadata and controls
83 lines (77 loc) · 1.97 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
## Pullback
struct ChainRulesPullbackPrepSamePoint{SIG,Y,PB} <: DI.PullbackPrep{SIG}
_sig::Val{SIG}
y::Y
pb::PB
end
function DI.prepare_pullback(
strict::Val,
f,
backend::AutoReverseChainRules,
x,
ty::NTuple,
contexts::Vararg{DI.GeneralizedConstant,C};
) where {C}
_sig = DI.signature(f, backend, x, ty, contexts...; strict)
return DI.NoPullbackPrep(_sig)
end
function DI.prepare_pullback_same_point(
f,
prep::DI.NoPullbackPrep,
backend::AutoReverseChainRules,
x,
ty::NTuple,
contexts::Vararg{DI.GeneralizedConstant,C};
) where {C}
DI.check_prep(f, prep, backend, x, ty, contexts...)
_sig = DI.signature(f, backend, x, ty, contexts...; strict=DI.is_strict(prep))
rc = ruleconfig(backend)
y, pb = rrule_via_ad(rc, f, x, map(DI.unwrap, contexts)...)
return ChainRulesPullbackPrepSamePoint(_sig, y, pb)
end
function DI.value_and_pullback(
f,
prep::DI.NoPullbackPrep,
backend::AutoReverseChainRules,
x,
ty::NTuple,
contexts::Vararg{DI.GeneralizedConstant,C},
) where {C}
DI.check_prep(f, prep, backend, x, ty, contexts...)
rc = ruleconfig(backend)
y, pb = rrule_via_ad(rc, f, x, map(DI.unwrap, contexts)...)
tx = map(ty) do dy
unthunk(pb(dy)[2])
end
return y, tx
end
function DI.value_and_pullback(
f,
prep::ChainRulesPullbackPrepSamePoint,
backend::AutoReverseChainRules,
x,
ty::NTuple,
contexts::Vararg{DI.GeneralizedConstant,C},
) where {C}
DI.check_prep(f, prep, backend, x, ty, contexts...)
(; y, pb) = prep
tx = map(ty) do dy
unthunk(pb(dy)[2])
end
return copy(y), tx
end
function DI.pullback(
f,
prep::ChainRulesPullbackPrepSamePoint,
backend::AutoReverseChainRules,
x,
ty::NTuple,
contexts::Vararg{DI.GeneralizedConstant,C},
) where {C}
DI.check_prep(f, prep, backend, x, ty, contexts...)
(; pb) = prep
tx = map(ty) do dy
unthunk(pb(dy)[2])
end
return tx
end