Dirac delta function
Compute derivatives and integrals of expressions involving the Dirac delta and Heaviside functions.
Find the first and second derivatives of the Heaviside function. The result is the Dirac delta function and its first derivative.
syms x diff(heaviside(x), x) diff(heaviside(x), x, x)
ans = dirac(x) ans = dirac(1, x)
Find the indefinite integral of the Dirac delta function. The results returned by
int do not include integration constants.
int(dirac(x), x)
ans = sign(x)/2
Find the integral of the sine function involving the Dirac delta function.
syms a int(dirac(x - a)*sin(x), x, -Inf, Inf)
ans = sin(a)
dirac takes into account assumptions on
variables.
syms x real assumeAlso(x ~= 0) dirac(x)
ans = 0
For further computations, clear the assumptions on x by
recreating it using syms.
syms x
Compute the Dirac delta function of x and
its first three derivatives.
Use a vector n = [0,1,2,3] to specify the order of derivatives.
The dirac function expands the scalar into a vector of the same
size as n and computes the result.
syms x n = [0,1,2,3]; d = dirac(n,x)
d = [ dirac(x), dirac(1, x), dirac(2, x), dirac(3, x)]
Substitute x with 0.
subs(d,x,0)
ans = [ Inf, -Inf, Inf, -Inf]
You can use fplot to plot the Dirac delta
function over the default interval [-5 5]. However,
dirac(x) returns Inf at
x equal to 0, and
fplot does not plot the infinity.
Declare a symbolic variable x and plot the symbolic
expression dirac(x) by using fplot.
syms x fplot(dirac(x))

To handle the infinity at x equal to 0, use
numeric values instead of symbolic values. Set the Inf value to
1 and plot the Dirac delta function by using
stem.
x = -1:0.1:1; y = dirac(x); idx = y == Inf; % find Inf y(idx) = 1; % set Inf to finite value stem(x,y)

For complex values x with nonzero imaginary parts,
dirac returns NaN.
dirac returns floating-point results for numeric
arguments that are not symbolic objects.
dirac acts element-wise on nonscalar inputs.
The input arguments x and n must be
vectors or matrices of the same size, or else one of them must be a scalar. If
one input argument is a scalar and the other one is a vector or a matrix, then
dirac expands the scalar into a vector or matrix of the
same size as the other argument with all elements equal to that scalar.