Re: realtime altivec fft -- checking & performance
Re: realtime altivec fft -- checking & performance
- Subject: Re: realtime altivec fft -- checking & performance
- From: Shaun Wexler <email@hidden>
- Date: Mon, 13 Jan 2003 08:58:36 -0800
- Resent-date: Mon, 13 Jan 2003 08:59:15 -0800
- Resent-from: Shaun Wexler <email@hidden>
- Resent-message-id: <email@hidden>
- Resent-to: CoreAudio API <email@hidden>
On Monday, January 13, 2003, at 08:39 AM, Brian Whitman wrote:
Thanks to the v2 hint yesterday, I'm off and running with our vst
conversions. I'd be interested in hearing from anyone with a fft/ifft
loop in their AudioUnit about cpu usage in the realtime case. I was
getting 33% with old c code and now 20% with what I think is
Altivec-enhanced code on a Powerbook 1GHZ / 1GB. I say 'what I think
is' because I am not positive that the fft is being vectorized thanks
to doubts that our input data structure is 16-byte aligned. (We have to
interface with lapack/blas with our own vector class, but I've added
the __attribute__ ((aligned (16))) parameter to try to fix it.)
1) Is 20% "OK" for this sort of machine in realtime? My pIII 800 on VST
would get about this, so I'm wondering, especially since the g4 altivec
fft is highly touted.
2) Is there a way to make sure that the fft code is being vectorized?
The vDSP docs say that it will fall back to scalar if certain
parameters aren't met but don't suggest a way to check.
Look at the address of the pointers to your data structure. If (addr
== addr & 0xfffffff0) then it is 16-byte aligned in memory. If all
other parameters meet fft_zropt() vector requirements, etc, and you're
running on a G4, it should be using the vectorized code. Wrap a usec
timer around the routine, then add +1 to one of the data structure
addresses and run it again; note the time to execute.
I'm sure there's a more robust way to check, but the above method works.
--
Shaun Wexler
MacFOH
http://www.macfoh.com
_______________________________________________
coreaudio-api mailing list | email@hidden
Help/Unsubscribe/Archives:
http://www.lists.apple.com/mailman/listinfo/coreaudio-api
Do not post admin requests to the list. They will be ignored.