[Freeswitch-users] Problems with wait_for_silence API call
Matthew
matthew at brightfire.net
Fri Jun 10 01:14:26 MSD 2016
Hello All,
After poking around a bit more I realized is that wait_for_silence was
never actually waiting for silence. It needs to detect non-silence
before it will ever try to detect silence. That makes it quite useless
if you call the function from a point where you can't guarantee that
audio is being received :/ What I did was broke up the function into two
smaller functions ...
detect_audio <threshold> <audio_hits> <timeout_ms> [<file>]
detect_silence <threshold> <silence_hits> <timeout_ms> [<file>]
This allowed me the flexibility I needed to build an outbound dial
solution the way I wanted to. For example, I can now do ...
amd_detect = "person"
dialout_session:execute( "voice_start" )
-- wait up to 3 seconds for 5 frames of audio above threshold 300
dialout_session:execute( "detect_audio", "300 5 3000" )
detect_audio_timeout = dialout_session:getVariable(
"detect_audio_timeout" )
dialout_session:consoleLog( "INFO", "dialout: detect_audio_timeout =
" .. detect_audio_timeout )
-- if audio was detected, wait up to 30 seconds for 30 frames of
silence below threshold 300
if detect_audio_timeout == "false" then
dialout_session:execute( "detect_silence", "300 30 30000" )
end
dialout_session:execute( "voice_stop" )
if( dialout_session:getVariable( "amd_status" ) ~= nil ) then
amd_detect = dialout_session:getVariable( "amd_status" )
end
dialout_session:consoleLog( "INFO", "dialout: amd_detect = " ..
amd_detect )
if amd_detect == "machine" then
...
else
...
end
I have patches based on a current git repo. Should I submit those
somewhere for inclusion upstream for other people to use or should I
just maintain these locally?
Thanks,
-Matthew
On 6/8/2016 4:05 PM, Matthew wrote:
> Hello All,
>
> I've having a problem with the wait_for_silence API call in lua. When I
> attempt to orginate a call and then check for silence on the line, I'm
> getting unpredictable results. Sometimes it seems to work, but more
> times than not it times out ( switch_ivr_wait_for_silence: TIMEOUT 0 ).
> To test this, I answer the call, speak a short greeting and then mute
> the handset. In other words, I know the script should be detecting
> silence on the other end of the call. Here is a good portion of the test
> script I'm using ...
>
> local cid_name = argv[1]
> local cid_number = argv[2]
> local gw_string = argv[3]
> local queue_ext = argv[4]
>
> dialout_string =
> "{origination_caller_id_name='" .. cid_name .. "'," ..
> "origination_caller_id_number=" .. cid_number .. "," ..
> "ignore_early_media=true}" .. gw_string
>
> dialout_session = freeswitch.Session( dialout_string )
>
> while dialout_session:ready() and not dialout_session:answered() do
> freeswitch.msleep( 250 )
> end
>
> if dialout_session:ready() and dialout_session:answered() then
>
> dialout_session:consoleLog( "INFO", "dialout: connected to " ..
> gw_string ) )
>
> dialout_session:execute( "voice_start" )
> dialout_session:sleep( 2000 )
> dialout_session:execute( "wait_for_silence", "300 30 15 15000" )
> dialout_session:execute( "voice_stop" )
>
> dialout_session:consoleLog( "INFO", "dialout: amd_detect = " ..
> amd_detect )
>
> end
>
> And here is an example of how I would invoke the script ...
>
> luarun dialout.lua TEST 1234567890 sofia/gateway/twilio/+1234567890 7000
>
> Any ideas why the wait_for_silence API call would be misbehaving? Any
> suggestions on how I could debug this problem further?
>
> Thanks,
>
> -Matthew
>
> _________________________________________________________________________
> Professional FreeSWITCH Consulting Services:
> consulting at freeswitch.org
> http://www.freeswitchsolutions.com
>
> Official FreeSWITCH Sites
> http://www.freeswitch.org
> http://confluence.freeswitch.org
> http://www.cluecon.com
>
> FreeSWITCH-users mailing list
> FreeSWITCH-users at lists.freeswitch.org
> http://lists.freeswitch.org/mailman/listinfo/freeswitch-users
> UNSUBSCRIBE:http://lists.freeswitch.org/mailman/options/freeswitch-users
> http://www.freeswitch.org
Join us at ClueCon 2016 Aug 8-12, 2016
More information about the FreeSWITCH-users
mailing list