Wolfram Function Repository
Instant-use add-on functions for the Wolfram Language
Function Repository Resource:
Find the numerical derivative of a list of values or pairs of values
| ResourceFunction["ListD"][data] finds the derivative of a list of data. | |
| ResourceFunction["ListD"][data,type] finds the derivative of a list of data using the method type. | 
| "WindowSize" | 1 | the number of extra points to use to find a linear fit | 
Find the derivative of data sampled from a function:
| In[1]:= | ![data = Table[Sin[2 Pi x/20], {x, 0., 20}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/745ae00218c3974c.png) | 
| Out[1]= |  | 
| In[2]:= | ![d = ResourceFunction["ListD"][data]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/660c7131a49ff0c1.png) | 
| Out[2]= |  | 
| In[3]:= | ![ListPlot[{data, d}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/7ec53e4e67258fdf.png) | 
| Out[3]= |  | 
Find the derivative of {x,y} data sampled from a function:
| In[4]:= | ![data2 = Table[{x, Sin[x]}, {x, 0., 2 Pi, 0.2}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/0a62a70f42029408.png) | 
| Out[4]= |  | 
| In[5]:= | ![d2 = ResourceFunction["ListD"][data2]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/174e152a6e81cce8.png) | 
| Out[5]= |  | 
| In[6]:= | ![ListPlot[{data2, d2}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/5739f6553dd89908.png) | 
| Out[6]= |  | 
The default method, "Center" generates new points between each of the original x-values using values from both sides to approximate the derivative:
| In[7]:= | ![ResourceFunction["ListD"][{{0., 0}, {1, 1}}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/169cb9bd2b897241.png) | 
| Out[7]= |  | 
The method, "Forward" generates new points at each of the original x-values using the next values to determine the derivative:
| In[8]:= | ![ResourceFunction["ListD"][{{0, 0}, {1, 1}}, "Forward"]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/1b98ce6906ab15d6.png) | 
| Out[8]= |  | 
The method, "Backward" generates new points at each of the original x-values using the previous values to determine the derivative:
| In[9]:= | ![ResourceFunction["ListD"][{{0, 0}, {1, 1}}, "Backward"]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/7a07106d6fbff3dc.png) | 
| Out[9]= |  | 
The method, "Fourier" is appropriate for larger sets of oscillatory data:
| In[10]:= | ![data = Table[Sin[7 Pi x/100], {x, 0., 100}];
d = ResourceFunction["ListD"][data, "Fourier"];](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/30ed342fd49bbcf0.png) | 
| In[11]:= | ![ListPlot[{data, d}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/40dffe76290466a0.png) | 
| Out[11]= |  | 
A small amount of noise in data can create significant errors in ListD:
| In[12]:= | ![data3 = Table[{x, Sin[x] + RandomReal[{-0.1, 0.1}]}, {x, 0., 2 Pi, 0.1}];
ListPlot[{data3, ResourceFunction["ListD"][data3]}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/30f08dcda82938b5.png) | 
| Out[13]= |  | 
By increasing the "WindowSize" the derivative is established by from the best local fit to the points:
| In[14]:= | ![ListPlot[{data3, ResourceFunction["ListD"][data3, "WindowSize" -> 8]}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/4c8a4b65ba70bff6.png) | 
| Out[14]= |  | 
Smoothing the data first to remove noise has a similar effect but often produces less smooth results for the same amount of smoothing:
| In[15]:= | ![ListPlot[{data3, ResourceFunction["ListD"][MovingAverage[data3, 8]]}]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/010be515bc931fd7.png) | 
| Out[15]= |  | 
The "Fourier" method is only supported for regularly sampled data:
| In[16]:= | ![ResourceFunction["ListD"][{{0, 0}, {1, 1}, {3, 1}}, "Fourier"]](https://www.wolframcloud.com/obj/resourcesystem/images/081/081a7167-088d-4a88-8790-6fba88931b10/1a1f2827f39e2257.png) | 
| Out[16]= |  | 
This work is licensed under a Creative Commons Attribution 4.0 International License