mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
avutil/softfloat: Move av_sincos_sf() from header to c file
The function is quite big and trigonometric functions should not really be used in speed critical code Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
parent
19ed3e35a5
commit
d3585c53de
@ -37,6 +37,55 @@ static av_const double av_sf2double(SoftFloat v) {
|
|||||||
else return (double)v.mant / (double)(1 << (-v.exp));
|
else return (double)v.mant / (double)(1 << (-v.exp));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void av_sincos_sf(int a, int *s, int *c)
|
||||||
|
{
|
||||||
|
int idx, sign;
|
||||||
|
int sv, cv;
|
||||||
|
int st, ct;
|
||||||
|
|
||||||
|
idx = a >> 26;
|
||||||
|
sign = (idx << 27) >> 31;
|
||||||
|
cv = av_costbl_1_sf[idx & 0xf];
|
||||||
|
cv = (cv ^ sign) - sign;
|
||||||
|
|
||||||
|
idx -= 8;
|
||||||
|
sign = (idx << 27) >> 31;
|
||||||
|
sv = av_costbl_1_sf[idx & 0xf];
|
||||||
|
sv = (sv ^ sign) - sign;
|
||||||
|
|
||||||
|
idx = a >> 21;
|
||||||
|
ct = av_costbl_2_sf[idx & 0x1f];
|
||||||
|
st = av_sintbl_2_sf[idx & 0x1f];
|
||||||
|
|
||||||
|
idx = (int)(((int64_t)cv * ct - (int64_t)sv * st + 0x20000000) >> 30);
|
||||||
|
|
||||||
|
sv = (int)(((int64_t)cv * st + (int64_t)sv * ct + 0x20000000) >> 30);
|
||||||
|
|
||||||
|
cv = idx;
|
||||||
|
|
||||||
|
idx = a >> 16;
|
||||||
|
ct = av_costbl_3_sf[idx & 0x1f];
|
||||||
|
st = av_sintbl_3_sf[idx & 0x1f];
|
||||||
|
|
||||||
|
idx = (int)(((int64_t)cv * ct - (int64_t)sv * st + 0x20000000) >> 30);
|
||||||
|
|
||||||
|
sv = (int)(((int64_t)cv * st + (int64_t)sv * ct + 0x20000000) >> 30);
|
||||||
|
cv = idx;
|
||||||
|
|
||||||
|
idx = a >> 11;
|
||||||
|
|
||||||
|
ct = (int)(((int64_t)av_costbl_4_sf[idx & 0x1f] * (0x800 - (a & 0x7ff)) +
|
||||||
|
(int64_t)av_costbl_4_sf[(idx & 0x1f)+1]*(a & 0x7ff) +
|
||||||
|
0x400) >> 11);
|
||||||
|
st = (int)(((int64_t)av_sintbl_4_sf[idx & 0x1f] * (0x800 - (a & 0x7ff)) +
|
||||||
|
(int64_t)av_sintbl_4_sf[(idx & 0x1f) + 1] * (a & 0x7ff) +
|
||||||
|
0x400) >> 11);
|
||||||
|
|
||||||
|
*c = (int)(((int64_t)cv * ct + (int64_t)sv * st + 0x20000000) >> 30);
|
||||||
|
|
||||||
|
*s = (int)(((int64_t)cv * st + (int64_t)sv * ct + 0x20000000) >> 30);
|
||||||
|
}
|
||||||
|
|
||||||
int main(void){
|
int main(void){
|
||||||
SoftFloat one= av_int2sf(1, 0);
|
SoftFloat one= av_int2sf(1, 0);
|
||||||
SoftFloat sf1, sf2, sf3;
|
SoftFloat sf1, sf2, sf3;
|
||||||
|
@ -175,53 +175,6 @@ static av_always_inline SoftFloat av_sqrt_sf(SoftFloat val)
|
|||||||
/**
|
/**
|
||||||
* Rounding-to-nearest used.
|
* Rounding-to-nearest used.
|
||||||
*/
|
*/
|
||||||
static av_always_inline void av_sincos_sf(int a, int *s, int *c)
|
void av_sincos_sf(int a, int *s, int *c);
|
||||||
{
|
|
||||||
int idx, sign;
|
|
||||||
int sv, cv;
|
|
||||||
int st, ct;
|
|
||||||
|
|
||||||
idx = a >> 26;
|
|
||||||
sign = (idx << 27) >> 31;
|
|
||||||
cv = av_costbl_1_sf[idx & 0xf];
|
|
||||||
cv = (cv ^ sign) - sign;
|
|
||||||
|
|
||||||
idx -= 8;
|
|
||||||
sign = (idx << 27) >> 31;
|
|
||||||
sv = av_costbl_1_sf[idx & 0xf];
|
|
||||||
sv = (sv ^ sign) - sign;
|
|
||||||
|
|
||||||
idx = a >> 21;
|
|
||||||
ct = av_costbl_2_sf[idx & 0x1f];
|
|
||||||
st = av_sintbl_2_sf[idx & 0x1f];
|
|
||||||
|
|
||||||
idx = (int)(((int64_t)cv * ct - (int64_t)sv * st + 0x20000000) >> 30);
|
|
||||||
|
|
||||||
sv = (int)(((int64_t)cv * st + (int64_t)sv * ct + 0x20000000) >> 30);
|
|
||||||
|
|
||||||
cv = idx;
|
|
||||||
|
|
||||||
idx = a >> 16;
|
|
||||||
ct = av_costbl_3_sf[idx & 0x1f];
|
|
||||||
st = av_sintbl_3_sf[idx & 0x1f];
|
|
||||||
|
|
||||||
idx = (int)(((int64_t)cv * ct - (int64_t)sv * st + 0x20000000) >> 30);
|
|
||||||
|
|
||||||
sv = (int)(((int64_t)cv * st + (int64_t)sv * ct + 0x20000000) >> 30);
|
|
||||||
cv = idx;
|
|
||||||
|
|
||||||
idx = a >> 11;
|
|
||||||
|
|
||||||
ct = (int)(((int64_t)av_costbl_4_sf[idx & 0x1f] * (0x800 - (a & 0x7ff)) +
|
|
||||||
(int64_t)av_costbl_4_sf[(idx & 0x1f)+1]*(a & 0x7ff) +
|
|
||||||
0x400) >> 11);
|
|
||||||
st = (int)(((int64_t)av_sintbl_4_sf[idx & 0x1f] * (0x800 - (a & 0x7ff)) +
|
|
||||||
(int64_t)av_sintbl_4_sf[(idx & 0x1f) + 1] * (a & 0x7ff) +
|
|
||||||
0x400) >> 11);
|
|
||||||
|
|
||||||
*c = (int)(((int64_t)cv * ct + (int64_t)sv * st + 0x20000000) >> 30);
|
|
||||||
|
|
||||||
*s = (int)(((int64_t)cv * st + (int64_t)sv * ct + 0x20000000) >> 30);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* AVUTIL_SOFTFLOAT_H */
|
#endif /* AVUTIL_SOFTFLOAT_H */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user