21#ifndef PQ_WAVE_UTILS_H_
22#define PQ_WAVE_UTILS_H_
24#include "pq_phase_utils.h"
25#include "pq_fixed32_trig.h"
29inline q0_32u_t squareWave(
const q0_32u_t& t,
const q0_32u_t& skew)
31 return (t <= skew) ? FIXED_32_MAX : 0;
34inline q0_32u_t triangleWave(
const q0_32u_t& t,
const q0_32u_t& skew)
37 fixed32Divide(t, skew) :
38 fixed32Divide(FIXED_32_MAX - t, FIXED_32_MAX - skew);
41inline q0_32u_t sineWave(
const q0_32u_t& t,
const q0_32u_t& skew)
43#if defined(PQ_ARCH_32BITS)
48 if (skew == HALF_FIXED_32_MAX)
55 phase32 = fixed32Divide(t, skew) / 2;
60 phase32 = fixed32Divide(t - skew, FIXED_32_MAX - skew) / 2 + HALF_FIXED_32_MAX;
63 return static_cast<uint32_t
>(HALF_FIXED_32_MAX - cos32(phase32));
69 if (skew == HALF_FIXED_32_MAX)
71 phase16 =
static_cast<uint16_t
>(t >> 16);
76 phase16 =
static_cast<uint16_t
>((
static_cast<uint64_t
>(t) << 15) / skew);
81 phase16 =
static_cast<uint16_t
>((
static_cast<uint64_t
>(t - skew) << 15) / (FIXED_32_MAX - skew)) + HALF_FIXED_16_MAX;
90 return static_cast<uint32_t
>(
static_cast<uint16_t
>(HALF_FIXED_16_MAX-1) - cos16(phase16)) << 16;