Source code for tad_mctc.autograd.batched
# This file is part of tad-mctc.
#
# SPDX-Identifier: Apache-2.0
# Copyright (C) 2024 Grimme Group
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""
Autograd Utility: Batched
=========================
Batched versions of autograd functions.
"""
from __future__ import annotations
from ..typing import Callable, Tensor
from .internals import jacrev, vmap
__all__ = ["bjacrev"]
[docs]
def bjacrev(
func: Callable[..., Tensor], argnums: int = 0, **kwargs
) -> Callable[..., Tensor]:
"""
Batched Jacobian of a function.
Parameters
----------
func : Callable[..., Tensor]
The function whose result is differentiated.
argnums : int, optional
The variable w.r.t. which will be differentiated. Defaults to 0.
Returns
-------
Callable[..., Tensor]
Batched Jacobian function.
"""
f: Callable = jacrev(func, argnums=argnums, **kwargs) # type: ignore
return vmap(f, in_dims=0, out_dims=0)