i just realized that this formula doesn't work with negative numbers.
for example:  shifting a pitch down one octave over a duration from
0.0 to -0.5, or panning a source with a duration from center at 0.0 to
the left -1.0.

any advice?

On Thu, Jan 7, 2010 at 7:48 PM, Chunk 1978 <chunk1...@gmail.com> wrote:
> graham, thanks for your patients and for the detailed response!  i was
> able to immediately solve my broken logic after reading it.
>
> thanks again.
>
> On Thu, Jan 7, 2010 at 7:19 PM, Graham Cox <graham....@bigpond.com> wrote:
>>
>> On 08/01/2010, at 6:17 AM, Chunk 1978 wrote:
>>
>>> ok i'll use NSTimer instead of performSelector:withObject:afterDelay,
>>> it should be easier to track this way.  however, i'm still having an
>>> issue with executing logic for the callback method:
>>>
>>> so i set the timer to fire ever 0.15 seconds with this:
>>>
>>> currentVolume =+ targetVolume / (fadeDuration / 0.15);
>>>
>>> this makes sense to me but it doesn't work.
>>>
>>> i see in your example you have callback which you said is used for
>>> both fading in and fading out
>>>
>>> float vol = [fi level1] + ([fi delta] * ( t / [fi time]));
>>>
>>> in comparing the two, i believe i'm missing the entire end of the
>>> logic: * ( t / [fi time])), but i can't really figure out what [fi
>>> time] is...
>>>
>>> ughhh...
>>
>>
>> Well, maybe it'll help to just review linear scaling-over-time arithmetic.
>>
>> You want to take a quantity from a value v0 to a new value v1 in a period of 
>> time d. To do this, the time d is broken down into a series of discrete 
>> steps. We are not concerned with precisely how many steps, as long as there 
>> are enough to make the transition smooth. That's why the timer, which is 
>> what is doing the breaking up of d into steps, is simply set to run at some 
>> sufficiently fast constant rate. However, this rate does need to be 
>> considerably faster than d so that there are at least several steps - if 
>> it's too slow the result will be that the value changes abruptly to the end 
>> value as soon as it runs. My code uses 1/30th of a second as the timer rate, 
>> which is a reasonable starting point. If you want more smoothness, go 
>> faster. I think you are setting your timer to the value d; that won't work.
>>
>> At any point in time t between the start time, t0 and the end time, t1, we 
>> need to know the value of v(t). At t0, v(t) = v0. At t1, v(t) = v1.
>>
>> If we arrange the value t to scale linearly from 0 to 1, it's easy to map 
>> that to a second quantity that goes from v0 to v1.
>>
>> v = v0 + (( v1 - v0 ) * t )
>>
>> So now all we need to do is to arrange for our desired timespan to be 
>> normalised to the range 0..1
>>
>> To do that, we must know the start time, t0. So at the start of the run we 
>> make a note of it - it's simply the current time.
>>
>> To scale the actual elapsed time into the range 0..1, is simply:
>>
>> t = ( tc - t0 ) / d
>>
>> where tc is the current time and d is the desired total run time.
>>
>> Substitute this into the first equation:
>>
>> v = v0 + (( v1 - v0 ) * (( tc - t0 ) / d ))
>>
>> The value v is the instantaneous value of (whatever). In your case it's the 
>> desired volume. Note that this works no matter what rate you set the timer 
>> to, and whether v0 is greater or less than v1. Does it work? Let's try some 
>> numbers. If our desired fade time is 5 seconds, and we are going from full 
>> volume (1.0 ) to silence (0.0), and the callback is called at the halfway 
>> point (here the actual timestamp values are just made up):
>>
>> v = 1.0 + (( 0.0 - 1.0 ) * (( 125.5 - 123 ) / 5.0 )) = 1.0 + -1.0 * ( 2.5 / 
>> 5.0 ) = 1.0 - 0.5  = 0.5
>>
>> Yes it does - at the halfway mark in time, the volume is half of what it was.
>>
>> We also know when to stop - as soon as t >= 1.0, we're done.
>>
>> My code doesn't quite appear to implement this equation, because it 
>> precalculates some of the terms, such as v1 - v0, but in fact this saves no 
>> useful time which is why I wouldn't bother doing it that way now - just keep 
>> it direct and simple.
>>
>> If you want a non-linear ramp, the best place to do that is after 
>> calculating the value t in the range 0..1. You can convert that into a new 
>> range 0..1 that is not linear. Because you've normalised the range to 0..1 
>> regardless of the value of d or anything else, this can be a simple 
>> conversion function of the form t' = f(t).
>>
>> hope this helps,
>>
>> --Graham
>>
>>
>>
>
_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
http://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to arch...@mail-archive.com

Reply via email to