fixed point taylor sine/cosine approximation model
Mostra commenti meno recenti
Can anybody share sine/cosine taylor approx model which is compatible with hdl coder?
2 Commenti
Walter Roberson
il 19 Giu 2022
is there a reason why you are not using https://www.mathworks.com/help/fixedpoint/ref/cordicsin.html
Gary
il 21 Giu 2022
Risposte (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 Commenti
Gary
il 20 Giu 2022
Walter Roberson
il 20 Giu 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
il 20 Giu 2022
Walter Roberson
il 20 Giu 2022
Modificato: Walter Roberson
il 21 Giu 2022
Gary
il 21 Giu 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
il 21 Giu 2022
Walter Roberson
il 21 Giu 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
il 21 Giu 2022
Walter Roberson
il 21 Giu 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
il 22 Giu 2022
Walter Roberson
il 22 Giu 2022
Wrong conclusion! When you set the sample time smaller you will see more error in Simulink.
Gary
il 22 Giu 2022
Walter Roberson
il 22 Giu 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
il 22 Giu 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
il 23 Giu 2022
Kiran Kintali
il 4 Lug 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 Commenti
Walter Roberson
il 4 Lug 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
il 17 Lug 2022
Categorie
Scopri di più su Code Generation in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!








