[Clam-devel] Re: [CLAM] Question regarding CLAM::Audio::GetEndTime()
Pau Arumi
parumi at iua.upf.edu
Wed Feb 7 11:52:37 PST 2007
Fixed in svn as David said in clam-devel with more details.
Xavier Amatriain wrote:
> So that is definitely a bug... BeginTime is being incremented in
> seconds while EndTime is output
> in milliseconds and expects BeginTime to be also in milliseconds.
>
> The error is in line 128 in MultichannelAudioFileReader:
>
> mDeltaTime = TData
> <http://www.clam.iua.upf.edu/doc/CLAM-doxygen/namespaceCLAM.html#b9c6321b061069797fcc173f61e8111a>(sizeTmp)
> / mConfig.GetSourceFile().GetHeader().GetSampleRate();
>
> There is a *1000. missing.
>
> Actually I am seeing that the same error repeats in different
> places... so I guess the
> issue would be easier to fix in the Audio getter. I'll push the
> discussion to the clam-devel list.
>
>
>
> Bad Data wrote:
>> This is what I'm doing for every chunk:
>> std::cout << "EndTime: " <<
>> incomingAudioChannels[0].GetEndTime()
>> << " Size: " <<
>> incomingAudioChannels[0].GetSize()
>> << " BeginTime " <<
>> incomingAudioChannels[0].GetBeginTime()
>> << "\n";
>>
>>
>> And this is what it is outputing:
>>
>> audioMixer examples # ./FilePlayback_example blue_serge.wav
>> EndTime: 23.22 Size: 1024 BeginTime 0
>> EndTime: 23.2432 Size: 1024 BeginTime 0.02322
>> EndTime: 23.2664 Size: 1024 BeginTime 0.0464399
>> EndTime: 23.2896 Size: 1024 BeginTime 0.0696599
>>
>>
>> James
>>
>>
>> */Xavier Amatriain <xamat at iua.upf.edu>/* wrote:
>>
>> That is weird indeed but I can't see the bug by looking at the
>> code. It
>> is clear that BeginTime is set incorrectly for the first audio.
>> Can you
>> print both GetSize() and GetBeginTime() for all chunks?
>>
>> Bad Data wrote:
>> > I've starting to work with CLAM and have come across something
>> that I
>> > don't understand. I started with the FilePlayback_example.cxx to
>> get a
>> > basic idea how Audio is worked with. I changed the main loop of
>> the
>> > program around to see what can be done with the Audio class,
>> during
>> > one such test I did the following:
>> >
>> > while( reader.Do( incomingAudioChannels ) )
>> > {
>> > count += incomingAudioChannels[0].GetSize();
>> > time += incomingAudioChannels[0].GetDuration();
>> >
>> > for ( int i = 0; i < audioOutputs.Size(); i++ ){
>> > audioOutputs[i].Do( incomingAudioChannels[i] );
>> > }
>> > std::cout << "Durr: " <<
>> > incomingAudioChannels[0].GetEndTime() << "\n"; // I added this
>> line.
>> > }
>> >
>> >
>> > when I compile and run this program the first few lines output to
>> > stdout are:
>> > audioMixer examples # ./FilePlayback_example blue_serge.wav
>> > Durr: 23.22
>> > Durr: 23.2432
>> > Durr: 23.2664
>> > Durr: 23.2896
>> > Durr: 23.3128
>> > Durr: 23.3361
>> > Durr: 23.3593
>> >
>> >
>> > Shouldn't the first line be 0.002322 and aren't the subsequent
>> lines
>> > off by 23.22?
>> > It's my understanding that GetEndTime() returns the end time of
>> the
>> > audio in ms, and that the first chunk is only 1024 samples long.
>> Am I
>> > misunderstanding the correct use?
>> >
>> >
>> > James
>> >
>> >
>> >
>> >
>> >
>>
>> ------------------------------------------------------------------------
>> > Get your own web address.
>> >
>> > Have a HUGE year through Yahoo! Small Business.
>> >
>> >
>> >
>>
>> ------------------------------------------------------------------------
>> >
>> > _______________________________________________
>> > CLAM mailing list
>> > CLAM at iua.upf.es
>> > http://www.iua.upf.es/mtg/clam
>>
>>
>> ------------------------------------------------------------------------
>> TV dinner still cooling?
>> Check out "Tonight's Picks"
>> <http://us.rd.yahoo.com/evt=49979/*http://tv.yahoo.com/> on Yahoo! TV.
>> ------------------------------------------------------------------------
>>
>> _______________________________________________
>> CLAM mailing list
>> CLAM at iua.upf.es
>> http://www.iua.upf.es/mtg/clam
>
>
> _______________________________________________
> CLAM mailing list
> CLAM at iua.upf.es
> http://www.iua.upf.es/mtg/clam
More information about the clam-devel
mailing list