On Tue, 2019-10-01 at 12:52 +0200, Felix Fietkau wrote:
> 
> Might be useful, yes. The main issue here is that the period / window
> size has to be hardcoded through the coefficient values, unless we find
> a way to do floating point math, including exp() and cos() at compile
> time, including conversion to fixed point.

Works fine for me?

#include <math.h>
#include <stdio.h>
#include <stdlib.h>

#define E(x) ((int)(exp(x) * (1<<20)))
#define C(x) ((int)(cos(x) * (1<<20)))

int main()
{
        int e2 = E(2);
        int c2 = C(2);

        printf("e2: %d\n", e2);
        printf("whole: %d frac: %d\n", e2 >> 20, e2 & ((1 << 20) - 1));
        printf("c2: %d\n", c2);
        printf("sign: %s whole: %d frac: %d\n", c2 < 0 ? "-" : "", abs(c2) >> 
20, abs(c2) & ((1 << 20) - 1));
}

objdump -dr test:
[...]
0000000000401040 <main>:
  401040:       48 83 ec 08             sub    $0x8,%rsp
  401044:       be 92 39 76 00          mov    $0x763992,%esi           // 
exp(2) * (1<<20)
  401049:       bf 10 20 40 00          mov    $0x402010,%edi
  40104e:       31 c0                   xor    %eax,%eax
  401050:       e8 db ff ff ff          callq  401030 <printf@plt>
  401055:       ba 92 39 06 00          mov    $0x63992,%edx
  40105a:       be 07 00 00 00          mov    $0x7,%esi
  40105f:       31 c0                   xor    %eax,%eax
  401061:       bf 2b 20 40 00          mov    $0x40202b,%edi
  401066:       e8 c5 ff ff ff          callq  401030 <printf@plt>
  40106b:       be 77 57 f9 ff          mov    $0xfff95777,%esi
  401070:       bf 18 20 40 00          mov    $0x402018,%edi
  401075:       31 c0                   xor    %eax,%eax
  401077:       e8 b4 ff ff ff          callq  401030 <printf@plt>
  40107c:       b9 89 a8 06 00          mov    $0x6a889,%ecx            // 
cos(2) * (1<<20)
  401081:       31 d2                   xor    %edx,%edx
  401083:       31 c0                   xor    %eax,%eax
  401085:       be 20 20 40 00          mov    $0x402020,%esi
  40108a:       bf 22 20 40 00          mov    $0x402022,%edi
  40108f:       e8 9c ff ff ff          callq  401030 <printf@plt>
[...]

johannes

Reply via email to