Skip to main content

Specular differentiation in normed vector spaces and its applications

Project description

Specular Differentiation

PyPI version License

This repository contains the Python package specular_diff and codes for applications:

Installation

You can install the released version directly from PyPI:

pip install specular-differentiation

Introduction

Specular differentiation generalizes classical differentiation. A specular derivative can be understood as the average of the inclination angles of the right and left derivatives. In contrast, a symmetric derivative is the average of the right and left derivatives. Their difference is illustrated as in the following figure.

specular-derivative-animation

Quick start

The following simple example calculates the specular derivative of the ReLU function $f(x) = max(0, x)$ at the origin.

>>> import specular_diff as sd
>>> import numpy as np
>>> 
>>> ReLU = lambda x: np.maximum(x, 0)
>>> sd.specular_derivative(ReLU, x=0.0)
0.41421356237309515

Applications

Specular differentiation is defined in normed vector spaces, allowing for applications in higher-dimensional Euclidean spaces. Two applications are provided in this repository.

Nonsmooth convex optimization

In [2], the specular gradient method is introduced for optimizing nonsmooth convex objective functions.

Initial value problems for ordinary differential equations

In [1], the specular Euler scheme of Type 5 is introduced for solving ODEs numerically, yielding more accurate numerical solutions than classical schemes: the explicit and implicit Euler schemes and the Crank-Nicolson scheme.

ODE-numerical-example

LaTeX notation

To use the specular differentiation symbol in your LaTeX document, please refer to the following instructions.

Setup

Add the following code to your LaTeX preamble (before \begin{document}):

% Required packages
\usepackage{graphicx}
\usepackage{bm}

% Definition of Specular Differentiation symbol
\newcommand\spd[1][.5]{\mathbin{\vcenter{\hbox{\scalebox{#1}{\,$\bm{\wedge}$}}}}}

Usage examples

Use the symbol in your document (after \begin{document}):

% A specular derivative in the one-dimensional Euclidean space
$f^{\spd}(x)$

% A specular directional derivative in normed vector spaces
$\partial^{\spd}_v f(x)$

References

[1] K. Jung. Nonlinear numerical schemes using specular differentiation for initial value problems of first-order ordinary differential equations. arXiv preprint arXiv:??, 2025.

[2] K. Jung. Specular differentiation in normed vector spaces and its applications to nonsmooth convex optimization. arXiv preprint arXiv:??, 2025.

[3] K. Jung and J. Oh. The specular derivative. arXiv preprint arXiv:2210.06062, 2022.

[4] K. Jung and J. Oh. The wave equation with specular derivatives. arXiv preprint arXiv:2210.06933, 2022.

[5] K. Jung and J. Oh. Nonsmooth convex optimization using the specular gradient method with root-linear convergence. arXiv preprint arXiv:2210.06933, 2024.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

specular_differentiation-0.0.7.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

specular_differentiation-0.0.7-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file specular_differentiation-0.0.7.tar.gz.

File metadata

File hashes

Hashes for specular_differentiation-0.0.7.tar.gz
Algorithm Hash digest
SHA256 8c18bb39bf43c26cb248de217c63645b6143407171d15f8c7949f51a7a91bf4e
MD5 1126c895c707e54f732f0f297e93574f
BLAKE2b-256 772fb6701d63c2856f0d67adc6fec06d6ff2935abce4934c132ab946a2d34e64

See more details on using hashes here.

File details

Details for the file specular_differentiation-0.0.7-py3-none-any.whl.

File metadata

File hashes

Hashes for specular_differentiation-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 10589fcb1396be2ec0837260c0a47b4545d392426248987436f9fbb7e2537229
MD5 6584f3885f94f5eabd4ccbfd09a13a9d
BLAKE2b-256 f5e7baab117b08a4c065d451683cabbe744db6c2cca124f75a33b065b2e3123b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page