fixed point taylor sine/cosine approximation model
Show older comments
Can anybody share sine/cosine taylor approx model which is compatible with hdl coder?
2 Comments
Walter Roberson
on 19 Jun 2022
is there a reason why you are not using https://www.mathworks.com/help/fixedpoint/ref/cordicsin.html
Gary
on 21 Jun 2022
Answers (2)
WHy not to use matlab's built-in taylor() expansion fcn: https://www.mathworks.com/help/symbolic/sym.taylor.html?s_tid=doc_ta
E.g.:
syms x
taylor(sin(x), x, pi)
taylor(cos(x), x, pi/2)
20 Comments
Gary
on 20 Jun 2022
Walter Roberson
on 20 Jun 2022
In practice, finite Taylor series get wildly inaccurate outside of the quadrant they were optimized for. If you must use taylor then do argument reduction to move into one quadrant that you have expanded.
Gary
on 20 Jun 2022
Walter Roberson
on 20 Jun 2022
Edited: Walter Roberson
on 21 Jun 2022
Gary
on 21 Jun 2022
Example of how taylor series can get very inaccurate:
syms x
f = sin(x);
t1 = taylor(f, x, 0, 'order', 10)
t2 = taylor(f, x, 0, 'order', 12)
fplot([t1, t2, f], [0 2*pi])
Gary
on 21 Jun 2022
Walter Roberson
on 21 Jun 2022
When I run that model, the sine output is all zero, and the cosine output is a copy of the triangle wave at 50 Hz.
Gary
on 21 Jun 2022
Walter Roberson
on 21 Jun 2022
You have the limitation that you let the sample time of the sawtooth be "automatic". Simulink does not analyze the taylor series blocks to figure out that the function being modeled is periodic and work out the period and adjust the frequency to sample several times per sawtooth cycle. When your simulation time is large enough, Simulink happens to sample at a multiple of 100 Hz, getting the high and low of the sawtooth, corresponding to sampling at integer multiples of 0 and π, giving you all zero for sin and ±1 for cos
Gary
on 22 Jun 2022
Walter Roberson
on 22 Jun 2022
Wrong conclusion! When you set the sample time smaller you will see more error in Simulink.
Gary
on 22 Jun 2022
Walter Roberson
on 22 Jun 2022
You need to set an accuracy goal, and figure out how many taylor terms are needed to achieve the accuracy.
Hmmm... and I just realized that you need to add 1 to the output of the sawtooth in order to move to the 0 2π range as it is currently -π π
Walter Roberson
on 22 Jun 2022
Reminder that you want to change the range upwards by π so you need to add 1 to sawtooth wave, and you re-test
This shows that taylor up to x^7 term is off by 30 by the time you get to 2*pi
syms x
f = sin(x);
t1 = taylor(f, x, 0, 'order', 8)
fplot([t1, f], [0 2*pi])
fplot(t1-f, [0 2*pi])
Your simulink model uses up to x^9, and is off by a bit more than 10 by the time you get to 2*pi .
syms x
f = sin(x);
t1 = taylor(f, x, 0, 'order', 10)
fplot([t1, f], [0 2*pi])
fplot(t1-f, [0 2*pi])
You need order 22 (x^21) to have an error of less than 1/1000
syms x
f = sin(x);
target = 1/1000;
for order = 2:50
t = taylor(f, x, 0, 'order', order);
val_at_end = subs(t, x, 2*pi);
if abs(val_at_end) < target; break; end
end
order
t
fplot([t, f], [0 2*pi])
fplot(t-f, [0 2*pi])
Gary
on 23 Jun 2022
Kiran Kintali
on 4 Jul 2022
HDL Coder supports code generation for single precision trigonometric functions.
Getting Started with HDL Coder Native Floating-Point Support
Taylor series approximation using HDL Coder
If you want to build Taylor series approximation by youself you could build using basic Math operations and sufficient amount of fixed-point conversion.
syms x
f = sin(x);
T2sin = taylor(f, x, 'Order', 2); % T2sin = x
T4sin = taylor(f, x, 'Order', 4); % T4sin = -x^3/6 + x
T6sin = taylor(f, x, 'Order', 6); % T6sin = x^5/120 - x^3/6 + x

On you build such a model you can further use optimizations such as multiplier partitioning, resource sharing and pipelining options to optimize the model for area/performance/latency/power.
2 Comments
Walter Roberson
on 4 Jul 2022
They were already using a model with basic math blocks to calculate Taylor series of sine and cosine. I showed, however, that in their target range 0 to 2π that the error for their model was unacceptable, and that to bring the error to 1/1000 you need taylor order 21.
Gary
on 17 Jul 2022
Categories
Find more on Speed Optimization in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!







