|
4 | 4 |
|
5 | 5 | @register Base.signbit(x)
|
6 | 6 | ModelingToolkit.derivative(::typeof(signbit), args::NTuple{1,Any}, ::Val{1}) = 0
|
7 |
| - |
8 | 7 | ModelingToolkit.derivative(::typeof(abs), args::NTuple{1,Any}, ::Val{1}) = IfElse.ifelse(signbit(args[1]),-one(args[1]),one(args[1]))
|
| 8 | +function ModelingToolkit.derivative(::typeof(min), args::NTuple{2,Any}, ::Val{1}) |
| 9 | + x, y = args |
| 10 | + IfElse.ifelse(x < y, one(x), zero(x)) |
| 11 | +end |
| 12 | +function ModelingToolkit.derivative(::typeof(min), args::NTuple{2,Any}, ::Val{2}) |
| 13 | + x, y = args |
| 14 | + IfElse.ifelse(x < y, zero(y), one(y)) |
| 15 | +end |
| 16 | +function ModelingToolkit.derivative(::typeof(max), args::NTuple{2,Any}, ::Val{1}) |
| 17 | + x, y = args |
| 18 | + IfElse.ifelse(x > y, one(x), zero(x)) |
| 19 | +end |
| 20 | +function ModelingToolkit.derivative(::typeof(max), args::NTuple{2,Any}, ::Val{2}) |
| 21 | + x, y = args |
| 22 | + IfElse.ifelse(x > y, zero(y), one(y)) |
| 23 | +end |
9 | 24 |
|
10 | 25 | @register IfElse.ifelse(x,y,z::Any)
|
11 | 26 | ModelingToolkit.derivative(::typeof(IfElse.ifelse), args::NTuple{3,Any}, ::Val{1}) = 0
|
|
0 commit comments