API reference
DifferentiationInterfaceTest
— ModuleDifferentiationInterfaceTest
Testing and benchmarking utilities for automatic differentiation in Julia.
Entry points
DifferentiationInterfaceTest.Scenario
— TypeScenario{op,pl_op,pl_fun}
Store a testing scenario composed of a function and its input + output for a given operator.
This generic type should never be used directly: use the specific constructor corresponding to the operator you want to test, or a predefined list of scenarios.
Type parameters
op
: one of:pushforward
,:pullback
,:derivative
,:gradient
,:jacobian
,:second_derivative
,:hvp
,:hessian
pl_op
: either:in
(forop!(f, result, backend, x)
) or:out
(forresult = op(f, backend, x)
)pl_fun
: either:in
(forf!(y, x)
) or:out
(fory = f(x)
)
Constructors
Scenario{op,pl_op}(
f, x, [t], contexts...;
prep_args, res1, res2, name
)
Scenario{op,pl_op}(
f!, y, x, [t,] contexts...;
prep_args, res1, res2, name
)
Default values:
prep_args =
the result ofzero
applied to each execution argumentres1 = res2 = nothing
name = nothing
Fields
f::Any
: functionf
(ifpl_fun==:out
) orf!
(ifpl_fun==:in
) to applyy::Any
: primal outputx::Any
: primal inputt::Union{Nothing, NTuple{N, T} where {N, T}}
: tangents (if applicable)contexts::Tuple
: contexts (if applicable)res1::Any
: first-order result of the operator (if applicable)res2::Any
: second-order result of the operator (if applicable)prep_args::NamedTuple
: named tuple of arguments passed to preparation, without the function - the required keys are a subset of(; y, x, t, contexts)
depending on the operatorname::Union{Nothing, String}
: name of the scenario for display in test sets and dataframes
DifferentiationInterfaceTest.test_differentiation
— Functiontest_differentiation(
backends::Vector{<:ADTypes.AbstractADType};
...
) -> Union{Nothing, DataFrames.DataFrame}
test_differentiation(
backends::Vector{<:ADTypes.AbstractADType},
scenarios::Vector{<:Scenario};
testset_name,
correctness,
type_stability,
allocations,
benchmark,
excluded,
detailed,
logging,
isapprox,
atol,
rtol,
scenario_intact,
sparsity,
reprepare,
ignored_modules,
function_filter,
skip_allocations,
count_calls,
benchmark_test,
benchmark_seconds,
benchmark_aggregation,
adaptive_batchsize
) -> Union{Nothing, DataFrames.DataFrame}
Apply a list of backends
on a list of scenarios
, running a variety of different tests and/or benchmarks.
Return
This function always creates and runs a @testset
, though its contents may vary.
- if
benchmark == :none
, it returnsnothing
. - if
benchmark != :none
, it returns aDataFrame
of benchmark results, whose columns correspond to the fields ofDifferentiationBenchmarkDataRow
.
Positional arguments
backends::Vector{<:AbstractADType}
: the backends to testscenarios::Vector{<:Scenario}
: the scenarios on which to test these backends. Defaults to a standard set of first- and second-order scenarios, whose contents are not part of the public API and may change without notice.
Keyword arguments
testset_name=nothing
: how to display the test set
Test categories:
correctness=true
: whether to compare the differentiation results with the theoretical values specified in each scenariotype_stability=:none
: whether (and how) to check type stability of operators with JET.jl.allocations=:none
: whether (and how) to check allocations inside operators with AllocCheck.jlbenchmark=:none
: whether (and how) to benchmark operators with Chairmarks.jl
For type_stability
, allocations
and benchmark
, the possible values are :none
, :prepared
or :full
. Each setting tests/benchmarks a different subset of calls:
kwarg | prepared operator | unprepared operator | preparation |
---|---|---|---|
:none | no | no | no |
:prepared | yes | no | no |
:full | yes | yes | yes |
Misc options:
excluded::Vector{Symbol}
: list of operators to exclude, such asFIRST_ORDER
orSECOND_ORDER
detailed=false
: whether to create a detailed or condensed testsetlogging=false
: whether to log progress
Correctness options:
isapprox=isapprox
: function used to compare objects approximately, with the standard signatureisapprox(x, y; atol, rtol)
atol=0
: absolute precision for correctness testing (when comparing to the reference outputs)rtol=1e-3
: relative precision for correctness testing (when comparing to the reference outputs)scenario_intact=true
: whether to check that the scenario remains unchanged after the operators are appliedsparsity=false
: whether to check sparsity patterns for Jacobians / Hessiansreprepare::Bool=true
: whether to modify preparation before testing when the preparation arguments have the wrong size
Type stability options:
ignored_modules=nothing
: list of modules that JET.jl should ignorefunction_filter
: filter for functions that JET.jl should ignore (with a reasonable default)
Benchmark options:
count_calls=true
: whether to also count function calls during benchmarkingbenchmark_test=true
: whether to include tests which succeed iff benchmark doesn't errorbenchmark_seconds=1
: how long to run each benchmark forbenchmark_aggregation=minimum
: function used to aggregate sample measurements
Batch size options
adaptive_batchsize=true
: whether to cap the backend's preset batch size (when it exists) to prevent errors on small inputs
test_differentiation(
backend::ADTypes.AbstractADType,
args...;
kwargs...
) -> Union{Nothing, DataFrames.DataFrame}
Shortcut for a single backend.
DifferentiationInterfaceTest.benchmark_differentiation
— Functionbenchmark_differentiation(
backends,
scenarios::Vector{<:Scenario};
testset_name,
benchmark,
excluded,
logging,
count_calls,
benchmark_test,
benchmark_seconds,
benchmark_aggregation,
adaptive_batchsize
) -> Union{Nothing, DataFrames.DataFrame}
Shortcut for test_differentiation
with only benchmarks and no correctness or type stability checks.
Specifying the set of scenarios is mandatory for this function.
Utilities
DifferentiationInterfaceTest.FIRST_ORDER
— ConstantFIRST_ORDER = [:pushforward, :pullback, :derivative, :gradient, :jacobian]
List of all first-order operators, to facilitate exclusion during tests.
DifferentiationInterfaceTest.SECOND_ORDER
— ConstantSECOND_ORDER = [:hvp, :second_derivative, :hessian]
List of all second-order operators, to facilitate exclusion during tests.
DifferentiationInterfaceTest.DifferentiationBenchmarkDataRow
— TypeDifferentiationBenchmarkDataRow
Ad-hoc storage type for differentiation benchmarking results.
Fields
backend::ADTypes.AbstractADType
: backend used for benchmarkingscenario::Scenario
: scenario used for benchmarkingoperator::Symbol
: differentiation operator used for benchmarking, e.g.:gradient
or:hessian
prepared::Union{Nothing, Bool}
: whether the operator had been preparedcalls::Int64
: number of calls to the differentiated function for one call to the operatorsamples::Int64
: number of benchmarking samples takenevals::Int64
: number of evaluations used for averaging in each sampletime::Any
: aggregated runtime over all samples, in secondsallocs::Any
: aggregated number of allocations over all samplesbytes::Any
: aggregated memory allocated over all samples, in bytesgc_fraction::Any
: aggregated fraction of time spent in garbage collection over all samples, between 0.0 and 1.0compile_fraction::Any
: aggregated fraction of time spent compiling over all samples, between 0.0 and 1.0
See the documentation of Chairmarks.jl for more details on the measurement fields.
Internals
This is not part of the public API.
Base.zero
— Methodzero(scen::Scenario)
Return a new Scenario
identical to scen
except for the first- and second-order results which are set to zero.
DifferentiationInterfaceTest.allocfree_scenarios
— Methodallocfree_scenarios()
Create a vector of Scenario
s with functions that do not allocate.
DifferentiationInterfaceTest.batchify
— Methodbatchify(scen::Scenario)
Return a new Scenario
identical to scen
except for the tangents tang
and associated results res1
/ res2
, which are duplicated (batch mode).
Only works if scen
is a pushforward
, pullback
or hvp
scenario.
DifferentiationInterfaceTest.cachify
— Methodcachify(scen::Scenario)
Return a new Scenario
identical to scen
except for the function f
, which is made to accept an additional cache argument to store the result before it is returned.
If tup=true
the cache is a tuple of arrays, otherwise just an array.
DifferentiationInterfaceTest.change_function
— Methodchange_function(scen::Scenario, new_f)
Return a new Scenario
identical to scen
except for the function f
which is changed to new_f
.
DifferentiationInterfaceTest.closurify
— Methodclosurify(scen::Scenario)
Return a new Scenario
identical to scen
except for the function f
which is made to close over differentiable data.
DifferentiationInterfaceTest.complex_scenarios
— Methodcomplex_scenarios()
Create a vector of first-order Scenario
s with complex-valued array types and holomorphic functions only.
DifferentiationInterfaceTest.complex_sparse_scenarios
— Methodcomplex_sparse_scenarios()
Create a vector of Jacobian Scenario
s with complex-valued array types and holomorphic functions only.
DifferentiationInterfaceTest.component_scenarios
— Functioncomponent_scenarios()
Create a vector of Scenario
s with component array types from ComponentArrays.jl.
DifferentiationInterfaceTest.constantify
— Methodconstantify(scen::Scenario)
Return a new Scenario
identical to scen
except for the function f
, which is made to accept an additional constant argument by which the output is multiplied. The output and result fields are updated accordingly.
DifferentiationInterfaceTest.constantorcachify
— Methodconstantorcachify(scen::Scenario)
Return a new Scenario
identical to scen
except for the function f
, which is made to accept an additional "constant or cache" argument.
DifferentiationInterfaceTest.default_scenarios
— Methoddefault_scenarios()
Create a vector of Scenario
s with standard array types.
DifferentiationInterfaceTest.flux_isapprox
— Functionflux_isapprox(x, y; atol, rtol)
Approximate comparison function to use in correctness tests with gradients of Flux.jl networks.
DifferentiationInterfaceTest.flux_scenarios
— Functionflux_scenarios(rng=Random.default_rng())
Create a vector of Scenario
s with neural networks from Flux.jl.
DifferentiationInterfaceTest.gpu_scenarios
— Functiongpu_scenarios()
Create a vector of Scenario
s with GPU array types from JLArrays.jl.
DifferentiationInterfaceTest.lux_isapprox
— Functionlux_isapprox(x, y; atol, rtol)
Approximate comparison function to use in correctness tests with gradients of Lux.jl networks.
DifferentiationInterfaceTest.lux_scenarios
— Functionlux_scenarios(rng=Random.default_rng())
Create a vector of Scenario
s with neural networks from Lux.jl.
DifferentiationInterfaceTest.sparse_scenarios
— Methodsparse_scenarios()
Create a vector of Scenario
s with sparse array types, focused on sparse Jacobians and Hessians.
DifferentiationInterfaceTest.static_scenarios
— Functionstatic_scenarios()
Create a vector of Scenario
s with static array types from StaticArrays.jl.