Skip to main content

Specular differentiation in normed vector spaces and its applications

Project description

Specular Differentiation

PyPI version Python 3.10 License CodeFactor CodeQL Advanced

The Python package specular implements Specular differentiation which generalizes classical differentiation. This implementation strictly follows the definitions, notations, and results in [1] and [2].

A specular derivative (the red line) can be understood as the average of the inclination angles of the right and left derivatives. In contrast, a symmetric derivative (the purple line) is the average of the right and left derivatives. Their difference is illustrated as in the following figure.

specular-derivative-animation

Also, specular includes the following applications:

Installation

Dependencies

specular-differentiation requires:

  • Python 3.11 or later
  • NumPy 2.2.5 or later

User installation

The package is available on PyPI:

pip install specular-differentiation

Quick start

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

>>> import specular
>>> 
>>> ReLU = lambda x: max(x, 0)
>>> specular.derivative(ReLU, x=0)
0.41421356237309515

Tutorial

Detailed usage examples can be found in the tutorial document.

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], three methods are proposed for optimizing nonsmooth convex objective functions:

  • the specular gradient (SPEG) method.
  • the stochastic specular gradient (SSPEG) method.
  • the hybrid specular gradient (HSPEG) method.

The following example compares the three proposed methods with the classical methods: gradient descent (GD), Adaptive Moment Estimation (Adam), and Broyden-Fletcher-Goldfarb-Shanno (BFGS).

ODE-example

Initial value problems for ordinary differential equations

In [1], seven schemes are proposed for solving ODEs numerically:

  • the specular Euler scheme of Type 1~6.
  • the specular trigonometric scheme.

The following example shows that the specular Euler schemes of Type 5 and 6 yield more accurate numerical solutions than classical schemes: the explicit and implicit Euler schemes and the Crank-Nicolson scheme.

ODE-example

LaTeX symbol

To use the symbol for specular differentiation 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\sd[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^{\sd}(x)$

% A specular directional derivative in normed vector spaces
$\partial^{\sd}_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.11.1.tar.gz (17.0 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.11.1-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for specular_differentiation-0.11.1.tar.gz
Algorithm Hash digest
SHA256 adb705a01d61701375bce64011c608db4df7c287fccb3c0642ddd044f001efb2
MD5 24166e47ce83244791d34f483490dd82
BLAKE2b-256 e06d2c3ba3d7a4b35567068d3ae66e15f093ed1d30fb5e849300e83d8c8c20db

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for specular_differentiation-0.11.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d40de9e87fbf948ccc43d8ff8dd4f8300c2b2299477a97141517b947c8696c59
MD5 55e5ade9220d3a4840233e7fce27338f
BLAKE2b-256 0508ef70990ce069f6b0c4f58f3cdd1eafdcaf7fb760fac7e24721fbb48fb8df

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