fft.cmake 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859
  1. function(fft PROJECT)
  2. #######################################
  3. #
  4. # CFFT F32
  5. #
  6. if (CONFIGTABLE AND CFFT_F32_16)
  7. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_16)
  8. if (HELIUM OR MVEF)
  9. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_16)
  10. else()
  11. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_16)
  12. endif()
  13. endif()
  14. if (CONFIGTABLE AND CFFT_F32_32)
  15. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_32)
  16. if (HELIUM OR MVEF)
  17. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_32)
  18. else()
  19. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_32)
  20. endif()
  21. endif()
  22. if (CONFIGTABLE AND CFFT_F32_64)
  23. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_64)
  24. if (HELIUM OR MVEF)
  25. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_64)
  26. else()
  27. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_64)
  28. endif()
  29. endif()
  30. if (CONFIGTABLE AND CFFT_F32_128)
  31. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_128)
  32. if (HELIUM OR MVEF)
  33. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_128)
  34. else()
  35. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_128)
  36. endif()
  37. endif()
  38. if (CONFIGTABLE AND CFFT_F32_256)
  39. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_256)
  40. if (HELIUM OR MVEF)
  41. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_256)
  42. else()
  43. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_256)
  44. endif()
  45. endif()
  46. if (CONFIGTABLE AND CFFT_F32_512)
  47. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_512)
  48. if (HELIUM OR MVEF)
  49. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_512)
  50. else()
  51. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_512)
  52. endif()
  53. endif()
  54. if (CONFIGTABLE AND CFFT_F32_1024)
  55. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_1024)
  56. if (HELIUM OR MVEF)
  57. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_1024)
  58. else()
  59. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_1024)
  60. endif()
  61. endif()
  62. if (CONFIGTABLE AND CFFT_F32_2048)
  63. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_2048)
  64. if (HELIUM OR MVEF)
  65. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_2048)
  66. else()
  67. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_2048)
  68. endif()
  69. endif()
  70. if (CONFIGTABLE AND CFFT_F32_4096)
  71. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  72. if (HELIUM OR MVEF)
  73. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_4096)
  74. else()
  75. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_4096)
  76. endif()
  77. endif()
  78. #######################################
  79. #
  80. # CFFT F16
  81. #
  82. if (CONFIGTABLE AND CFFT_F16_16)
  83. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_16)
  84. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_16)
  85. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_16)
  86. endif()
  87. if (CONFIGTABLE AND CFFT_F16_32)
  88. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_32)
  89. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_32)
  90. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_32)
  91. endif()
  92. if (CONFIGTABLE AND CFFT_F16_64)
  93. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_64)
  94. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_64)
  95. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_64)
  96. endif()
  97. if (CONFIGTABLE AND CFFT_F16_128)
  98. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_128)
  99. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_128)
  100. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_128)
  101. endif()
  102. if (CONFIGTABLE AND CFFT_F16_256)
  103. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_256)
  104. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_256)
  105. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_256)
  106. endif()
  107. if (CONFIGTABLE AND CFFT_F16_512)
  108. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_512)
  109. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_512)
  110. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_512)
  111. endif()
  112. if (CONFIGTABLE AND CFFT_F16_1024)
  113. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_1024)
  114. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_1024)
  115. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_1024)
  116. endif()
  117. if (CONFIGTABLE AND CFFT_F16_2048)
  118. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_2048)
  119. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_2048)
  120. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_2048)
  121. endif()
  122. if (CONFIGTABLE AND CFFT_F16_4096)
  123. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  124. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_4096)
  125. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_4096)
  126. endif()
  127. #######################################
  128. #
  129. # CFFT F64
  130. #
  131. if (CONFIGTABLE AND CFFT_F64_16)
  132. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_16)
  133. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_16)
  134. endif()
  135. if (CONFIGTABLE AND CFFT_F64_32)
  136. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_32)
  137. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_64)
  138. endif()
  139. if (CONFIGTABLE AND CFFT_F64_64)
  140. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_64)
  141. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_64)
  142. endif()
  143. if (CONFIGTABLE AND CFFT_F64_128)
  144. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_128)
  145. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_128)
  146. endif()
  147. if (CONFIGTABLE AND CFFT_F64_256)
  148. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_256)
  149. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_256)
  150. endif()
  151. if (CONFIGTABLE AND CFFT_F64_512)
  152. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_512)
  153. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_512)
  154. endif()
  155. if (CONFIGTABLE AND CFFT_F64_1024)
  156. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_1024)
  157. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_1024)
  158. endif()
  159. if (CONFIGTABLE AND CFFT_F64_2048)
  160. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_2048)
  161. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_2048)
  162. endif()
  163. if (CONFIGTABLE AND CFFT_F64_4096)
  164. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_4096)
  165. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_4096)
  166. endif()
  167. #######################################
  168. #
  169. # CFFT Q31
  170. #
  171. if (CONFIGTABLE AND CFFT_Q31_16)
  172. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_16)
  173. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_16)
  174. endif()
  175. if (CONFIGTABLE AND CFFT_Q31_32)
  176. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_32)
  177. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_32)
  178. endif()
  179. if (CONFIGTABLE AND CFFT_Q31_64)
  180. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_64)
  181. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_64)
  182. endif()
  183. if (CONFIGTABLE AND CFFT_Q31_128)
  184. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_128)
  185. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_128)
  186. endif()
  187. if (CONFIGTABLE AND CFFT_Q31_256)
  188. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_256)
  189. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_256)
  190. endif()
  191. if (CONFIGTABLE AND CFFT_Q31_512)
  192. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_512)
  193. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_512)
  194. endif()
  195. if (CONFIGTABLE AND CFFT_Q31_1024)
  196. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_1024)
  197. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_1024)
  198. endif()
  199. if (CONFIGTABLE AND CFFT_Q31_2048)
  200. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_2048)
  201. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_2048)
  202. endif()
  203. if (CONFIGTABLE AND CFFT_Q31_4096)
  204. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_4096)
  205. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_4096)
  206. endif()
  207. #######################################
  208. #
  209. # CFFT Q15
  210. #
  211. if (CONFIGTABLE AND CFFT_Q15_16)
  212. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_16)
  213. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_16)
  214. endif()
  215. if (CONFIGTABLE AND CFFT_Q15_32)
  216. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_32)
  217. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_32)
  218. endif()
  219. if (CONFIGTABLE AND CFFT_Q15_64)
  220. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_64)
  221. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_64)
  222. endif()
  223. if (CONFIGTABLE AND CFFT_Q15_128)
  224. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_128)
  225. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_128)
  226. endif()
  227. if (CONFIGTABLE AND CFFT_Q15_256)
  228. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_256)
  229. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_256)
  230. endif()
  231. if (CONFIGTABLE AND CFFT_Q15_512)
  232. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_512)
  233. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_512)
  234. endif()
  235. if (CONFIGTABLE AND CFFT_Q15_1024)
  236. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_1024)
  237. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_1024)
  238. endif()
  239. if (CONFIGTABLE AND CFFT_Q15_2048)
  240. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_2048)
  241. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_2048)
  242. endif()
  243. if (CONFIGTABLE AND CFFT_Q15_4096)
  244. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_4096)
  245. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_4096)
  246. endif()
  247. #######################################
  248. #
  249. # RFFT FAST F64
  250. #
  251. if (CONFIGTABLE AND RFFT_FAST_F64_32)
  252. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_16)
  253. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_16)
  254. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_32)
  255. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_16)
  256. endif()
  257. if (CONFIGTABLE AND RFFT_FAST_F64_64)
  258. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_32)
  259. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_32)
  260. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_64)
  261. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_32)
  262. endif()
  263. if (CONFIGTABLE AND RFFT_FAST_F64_128)
  264. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_64)
  265. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_64)
  266. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_128)
  267. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_64)
  268. endif()
  269. if (CONFIGTABLE AND RFFT_FAST_F64_256)
  270. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_128)
  271. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_128)
  272. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_256)
  273. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_128)
  274. endif()
  275. if (CONFIGTABLE AND RFFT_FAST_F64_512)
  276. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_256)
  277. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_256)
  278. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_512)
  279. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_256)
  280. endif()
  281. if (CONFIGTABLE AND RFFT_FAST_F64_1024)
  282. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_512)
  283. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_512)
  284. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_1024)
  285. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_512)
  286. endif()
  287. if (CONFIGTABLE AND RFFT_FAST_F64_2048)
  288. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_1024)
  289. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_1024)
  290. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_2048)
  291. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_1024)
  292. endif()
  293. if (CONFIGTABLE AND RFFT_FAST_F64_4096)
  294. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_2048)
  295. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT64_2048)
  296. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F64_4096)
  297. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F64_2048)
  298. endif()
  299. #######################################
  300. #
  301. # RFFT FAST F32
  302. #
  303. if (CONFIGTABLE AND RFFT_FAST_F32_32)
  304. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_16)
  305. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_16)
  306. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_32)
  307. endif()
  308. if (CONFIGTABLE AND RFFT_FAST_F32_64)
  309. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_32)
  310. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_32)
  311. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_64)
  312. endif()
  313. if (CONFIGTABLE AND RFFT_FAST_F32_128)
  314. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_64)
  315. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_64)
  316. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_128)
  317. endif()
  318. if (CONFIGTABLE AND RFFT_FAST_F32_256)
  319. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_128)
  320. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_128)
  321. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_256)
  322. endif()
  323. if (CONFIGTABLE AND RFFT_FAST_F32_512)
  324. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_256)
  325. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_256)
  326. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_512)
  327. endif()
  328. if (CONFIGTABLE AND RFFT_FAST_F32_1024)
  329. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_512)
  330. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_512)
  331. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_1024)
  332. endif()
  333. if (CONFIGTABLE AND RFFT_FAST_F32_2048)
  334. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_1024)
  335. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_1024)
  336. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_2048)
  337. endif()
  338. if (CONFIGTABLE AND RFFT_FAST_F32_4096)
  339. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_2048)
  340. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_2048)
  341. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F32_4096)
  342. endif()
  343. #######################################
  344. #
  345. # RFFT FAST F16
  346. #
  347. if (CONFIGTABLE AND RFFT_FAST_F16_32)
  348. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_16)
  349. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_16)
  350. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_16)
  351. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_32)
  352. endif()
  353. if (CONFIGTABLE AND RFFT_FAST_F16_64)
  354. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_32)
  355. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_32)
  356. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_32)
  357. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_64)
  358. endif()
  359. if (CONFIGTABLE AND RFFT_FAST_F16_128)
  360. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_64)
  361. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_64)
  362. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_64)
  363. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_128)
  364. endif()
  365. if (CONFIGTABLE AND RFFT_FAST_F16_256)
  366. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_128)
  367. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_128)
  368. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_128)
  369. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_256)
  370. endif()
  371. if (CONFIGTABLE AND RFFT_FAST_F16_512)
  372. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_256)
  373. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_256)
  374. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_256)
  375. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_512)
  376. endif()
  377. if (CONFIGTABLE AND RFFT_FAST_F16_1024)
  378. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_512)
  379. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_512)
  380. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_512)
  381. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_1024)
  382. endif()
  383. if (CONFIGTABLE AND RFFT_FAST_F16_2048)
  384. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_1024)
  385. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_1024)
  386. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_1024)
  387. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_2048)
  388. endif()
  389. if (CONFIGTABLE AND RFFT_FAST_F16_4096)
  390. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_2048)
  391. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FLT_2048)
  392. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_2048)
  393. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_RFFT_F16_4096)
  394. endif()
  395. #######################################
  396. #
  397. # RFFT F32
  398. #
  399. if (CONFIGTABLE AND RFFT_F32_32)
  400. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  401. # For cfft_radix4_init
  402. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  403. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  404. endif()
  405. if (CONFIGTABLE AND RFFT_F32_64)
  406. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  407. # For cfft_radix4_init
  408. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  409. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  410. endif()
  411. if (CONFIGTABLE AND RFFT_F32_128)
  412. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  413. # For cfft_radix4_init
  414. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  415. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  416. endif()
  417. if (CONFIGTABLE AND RFFT_F32_256)
  418. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  419. # For cfft_radix4_init
  420. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  421. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  422. endif()
  423. if (CONFIGTABLE AND RFFT_F32_512)
  424. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  425. # For cfft_radix4_init
  426. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  427. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  428. endif()
  429. if (CONFIGTABLE AND RFFT_F32_1024)
  430. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  431. # For cfft_radix4_init
  432. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  433. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  434. endif()
  435. if (CONFIGTABLE AND RFFT_F32_2048)
  436. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  437. # For cfft_radix4_init
  438. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  439. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  440. endif()
  441. if (CONFIGTABLE AND RFFT_F32_4096)
  442. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  443. # For cfft_radix4_init
  444. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  445. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  446. endif()
  447. if (CONFIGTABLE AND RFFT_F32_8192)
  448. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  449. # For cfft_radix4_init
  450. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  451. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  452. endif()
  453. #######################################
  454. #
  455. # RFFT F16 (for radix4 and radix2)
  456. #
  457. if (CONFIGTABLE AND RFFT_F16_32)
  458. # For cfft_radix4_init
  459. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  460. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  461. endif()
  462. if (CONFIGTABLE AND RFFT_F16_64)
  463. # For cfft_radix4_init
  464. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  465. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  466. endif()
  467. if (CONFIGTABLE AND RFFT_F16_128)
  468. # For cfft_radix4_init
  469. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  470. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  471. endif()
  472. if (CONFIGTABLE AND RFFT_F16_256)
  473. # For cfft_radix4_init
  474. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  475. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  476. endif()
  477. if (CONFIGTABLE AND RFFT_F16_512)
  478. # For cfft_radix4_init
  479. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  480. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  481. endif()
  482. if (CONFIGTABLE AND RFFT_F16_1024)
  483. # For cfft_radix4_init
  484. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  485. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  486. endif()
  487. if (CONFIGTABLE AND RFFT_F16_2048)
  488. # For cfft_radix4_init
  489. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  490. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  491. endif()
  492. if (CONFIGTABLE AND RFFT_F16_4096)
  493. # For cfft_radix4_init
  494. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  495. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  496. endif()
  497. if (CONFIGTABLE AND RFFT_F16_8192)
  498. # For cfft_radix4_init
  499. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  500. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F16_4096)
  501. endif()
  502. #######################################
  503. #
  504. # RFFT Q31
  505. #
  506. if (CONFIGTABLE AND RFFT_Q31_32)
  507. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  508. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_16)
  509. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_16)
  510. endif()
  511. if (CONFIGTABLE AND RFFT_Q31_64)
  512. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  513. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_32)
  514. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_32)
  515. endif()
  516. if (CONFIGTABLE AND RFFT_Q31_128)
  517. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  518. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_64)
  519. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_64)
  520. endif()
  521. if (CONFIGTABLE AND RFFT_Q31_256)
  522. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  523. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_128)
  524. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_128)
  525. endif()
  526. if (CONFIGTABLE AND RFFT_Q31_512)
  527. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  528. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_256)
  529. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_256)
  530. endif()
  531. if (CONFIGTABLE AND RFFT_Q31_1024)
  532. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  533. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_512)
  534. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_512)
  535. endif()
  536. if (CONFIGTABLE AND RFFT_Q31_2048)
  537. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  538. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_1024)
  539. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_1024)
  540. endif()
  541. if (CONFIGTABLE AND RFFT_Q31_4096)
  542. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  543. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_2048)
  544. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_2048)
  545. endif()
  546. if (CONFIGTABLE AND RFFT_Q31_8192)
  547. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  548. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_4096)
  549. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_4096)
  550. endif()
  551. #######################################
  552. #
  553. # RFFT FAST Q15
  554. #
  555. if (CONFIGTABLE AND RFFT_Q15_32)
  556. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  557. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_16)
  558. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_16)
  559. endif()
  560. if (CONFIGTABLE AND RFFT_Q15_64)
  561. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  562. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_32)
  563. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_32)
  564. endif()
  565. if (CONFIGTABLE AND RFFT_Q15_128)
  566. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  567. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_64)
  568. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_64)
  569. endif()
  570. if (CONFIGTABLE AND RFFT_Q15_256)
  571. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  572. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_128)
  573. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_128)
  574. endif()
  575. if (CONFIGTABLE AND RFFT_Q15_512)
  576. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  577. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_256)
  578. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_256)
  579. endif()
  580. if (CONFIGTABLE AND RFFT_Q15_1024)
  581. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  582. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_512)
  583. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_512)
  584. endif()
  585. if (CONFIGTABLE AND RFFT_Q15_2048)
  586. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  587. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_1024)
  588. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_1024)
  589. endif()
  590. if (CONFIGTABLE AND RFFT_Q15_4096)
  591. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  592. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_2048)
  593. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_2048)
  594. endif()
  595. if (CONFIGTABLE AND RFFT_Q15_8192)
  596. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  597. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_4096)
  598. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREVIDX_FXT_4096)
  599. endif()
  600. #######################################
  601. #
  602. # DCT4 F32
  603. #
  604. if (CONFIGTABLE AND DCT4_F32_128)
  605. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_F32_128)
  606. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  607. # For cfft_radix4_init
  608. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  609. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  610. endif()
  611. if (CONFIGTABLE AND DCT4_F32_512)
  612. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_F32_512)
  613. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  614. # For cfft_radix4_init
  615. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  616. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  617. endif()
  618. if (CONFIGTABLE AND DCT4_F32_2048)
  619. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_F32_2048)
  620. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  621. # For cfft_radix4_init
  622. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  623. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  624. endif()
  625. if (CONFIGTABLE AND DCT4_F32_8192)
  626. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_F32_8192)
  627. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_F32)
  628. # For cfft_radix4_init
  629. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  630. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_F32_4096)
  631. endif()
  632. #######################################
  633. #
  634. # DCT4 Q31
  635. #
  636. if (CONFIGTABLE AND DCT4_Q31_128)
  637. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q31_128)
  638. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  639. # For cfft_radix4_init
  640. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  641. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_4096)
  642. endif()
  643. if (CONFIGTABLE AND DCT4_Q31_512)
  644. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q31_512)
  645. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  646. # For cfft_radix4_init
  647. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  648. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_4096)
  649. endif()
  650. if (CONFIGTABLE AND DCT4_Q31_2048)
  651. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q31_2048)
  652. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  653. # For cfft_radix4_init
  654. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  655. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_4096)
  656. endif()
  657. if (CONFIGTABLE AND DCT4_Q31_8192)
  658. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q31_8192)
  659. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q31)
  660. # For cfft_radix4_init
  661. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  662. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_4096)
  663. endif()
  664. #######################################
  665. #
  666. # DCT4 Q15
  667. #
  668. if (CONFIGTABLE AND DCT4_Q15_128)
  669. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q15_128)
  670. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  671. # For cfft_radix4_init
  672. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  673. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_4096)
  674. endif()
  675. if (CONFIGTABLE AND DCT4_Q15_512)
  676. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q15_512)
  677. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  678. # For cfft_radix4_init
  679. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  680. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_4096)
  681. endif()
  682. if (CONFIGTABLE AND DCT4_Q15_2048)
  683. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q15_2048)
  684. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  685. # For cfft_radix4_init
  686. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  687. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_4096)
  688. endif()
  689. if (CONFIGTABLE AND DCT4_Q15_8192)
  690. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_DCT4_Q15_8192)
  691. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_REALCOEF_Q15)
  692. # For cfft_radix4_init
  693. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  694. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_4096)
  695. endif()
  696. #######################################
  697. #
  698. # Deprecated radix2 and radix4 cfft
  699. #
  700. if (CONFIGTABLE AND (ARM_CFFT_RADIX2_Q15 OR ARM_CFFT_RADIX4_Q15))
  701. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q15_4096)
  702. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  703. endif()
  704. if (CONFIGTABLE AND (ARM_CFFT_RADIX2_Q31 OR ARM_CFFT_RADIX4_Q31))
  705. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_TWIDDLECOEF_Q31_4096)
  706. target_compile_definitions(${PROJECT} PUBLIC ARM_TABLE_BITREV_1024)
  707. endif()
  708. endfunction()