amd
property in a dial verb.
In this example, the Answering Machine Detection feature is activated as soon as the call is answered, and later sends a webhook to amd
to determine if a human or a machine has answered the call.
Configuration
The full set of configuration parameters:Parameter | Description | Required |
---|---|---|
actionHook | A webhook to receive an HTTP POST for AMD events. Default is amd | Yes |
thresholdWordCount | The number of spoken words in a greeting that result in an amd_machine_detected result. The default value is 9 . | No |
recognizer | Speech recognition parameters, used as per the gather and transcribe functions. The default value is application . | No |
timers | An object containing various timeouts. | No |
timers.noSpeechTimeoutMs | The time in milliseconds to wait for speech before returning amd_no_speech_detected . The default value is 5000 . | No |
timers.decisionTimeoutMs | The time in milliseconds to wait before returning amd_decision_timeout . The default value is 15000 . | No |
timers.toneTimeoutMs | The time in milliseconds to wait to hear a tone. The default value is 20000 . | No |
timers.greetingCompletionTimeoutMs | The silence in milliseconds to wait for during greeting before returning amd_machine_stopped_speaking . The default value is 2000 . | No |
Events
The payload included in theactionHook
always contains a type property describing the event type.
Some event types may include additional properties.
Event | Description | Additional Properties |
---|---|---|
amd_human_detected | A human is speaking. | {reason, greeting, language} , where: - reason — a short greeting, - greeting — a recognized greeting. - language — a recognized language. |
amd_machine_detected | A machine is speaking. | {reason, hint, transcript, language} , where: - reason — a hint or long greeting. - hint — a recognized hint. - transcript — a recognized greeting. - language — a recognized language. |
amd_no_speech_detected | No speech was detected. | - |
amd_decision_timeout | No decision was able to be made in the time given. | - |
amd_machine_stopped_speaking | Machine has completed the greeting. | - |
amd_tone_detected | A beep was detected. | - |
amd_error | An error has occurred. | An error message. |
amd_stopped | Answering Machine Detection was stopped. | - |
amd_machine_detected
amd_tone_detected
amd_machine_stopped_speaking
Inbound calls
You can use Answering Machine Detection for incoming calls by adding anamd
property in a config
verb. It can be useful in situations where Voice Gateway is located behind a dialer. In these cases, the dialer initiates the outbound call and then links it to Voice Gateway via an INVITE
request.