System and method for handling media streams

Information

  • Patent Application
  • 20080031231
  • Publication Number
    20080031231
  • Date Filed
    August 02, 2007
    17 years ago
  • Date Published
    February 07, 2008
    16 years ago
Abstract
A mechanism for managing and enhancing communication streams in a VOIP service using SIP is discussed. SIP is used to manage and enhance a communication stream at a centralized switching element in the VoIP environment rather than at the communication stream endpoints. The communication stream set up by SIP is directed through a central switching element under administrative control rather than traveling directly between the stream endpoints. As a result, the media stream may be conditioned with treatments and may be provided with enhanced services at the central switching element without the specific treatments and services being supported at both stream endpoints. The use of the centralized switching element allows full administrative control of the VoIP environment.
Description

BRIEF DESCRIPTION OF THE DRAWINGS

The invention is pointed out with particularity in the appended claims. The advantages of the invention described above, as well as further advantages of the invention, may be better understood by reference to the following description taken in conjunction with the accompanying drawings, in which:



FIG. 1 (prior art) depicts a conventional VOIP environment;



FIG. 2 depicts an environment suitable for practicing the illustrative embodiment of the present invention;



FIG. 3 depicts an alternate environment that is also suitable for practicing the illustrative embodiment of the present invention; and



FIG. 4 is a flowchart of the sequence of steps followed by the illustrative embodiment to manage and enhance communication streams.





DETAILED DESCRIPTION

The illustrative embodiment of the present invention allows a communication stream in a VoIP environment to be managed and enhanced from a single intermediate point in the communication stream. A communication session is established by a control module and the resulting communication stream is directed and connected through a software relay module. The control module uses SIP to communicate with the relay module and manage the communication stream. More specifically, the control module uses SIP to send directives to the relay module to create communication streams and apply optional treatments. Because both the control module and the relay module support SIP, the communication stream may be conditioned and enhanced using SIP services even though one or both endpoints do not support an identical set of media related features such as recording, voice and video transcoding, lawful intercept and statistics gathering and communication stream enhancements such as packet loss concealment.


In order to better explain the present invention, a conventional VoIP environment will first be discussed. FIG. 1 depicts an exemplary conventional VoIP environment. A first computing device 2 interfaced with a network 4 includes or is accessible by a calling unit 3. The calling unit 3 may be a physical device such as a phone or alternatively may be a software process providing communication features. It will be appreciated that the phone itself may be equipped with a processor and capable of directly accessing and sending digital communications over the network 4. Alternatively the calling unit may be a conventional analog phone that is connected to the first computing device via an analog telephone adapter that converts the analog signal of the phone into a digital signal before transmitting the signal over the network 4. In the exemplary VoIP environment, the calling unit 3 sends a call or communication request to a control module 7 that is executing on a server 6 in the network 4. The control module 7 is a control agent that has access to registrar and location databases. The control module 7 checks the database to determine the location of the called unit 9 on a second computing device 8 interfaced with the network 4. A connection request is sent to the called unit 9 by the control module 7. If the called unit 9 is available, an acknowledgement is sent back to the control module 7 and forwarded to the calling unit 7. The control module also passes on information to both the calling unit 3 and the called unit 9 enabling the formation of a session utilizing a communication stream 20 that is bi-directionally transmitted between the calling unit 3 and the called unit 9. The communication stream 20 may use RTP (Real Time Transport Protocol) or a similar transport protocol to transport the voice, video or other data over the network 4.


If both the calling unit 3 and the called unit 9 support the SIP protocol, the control module 7 may use the Session Initiation Protocol (SIP) to establish and tear down call sessions. With SIP, the calling unit 3 sends an initial invitation identifying the called unit 9 to the control module 7. The invitation includes the Session Description Protocol (SDP) for the calling unit 3. The SDP describes the media content of the desired session. For example, the SDP describes what IP ports to use in the session and the desired codecs. The control module 7 may authenticate the user of the calling unit 3 that is initiating the invitation before taking additional action. An invitation message which includes the SDP of the calling unit 3 is then sent by the control module 7 to the called unit 9. If the called unit 9 is able to take the call, an acknowledgement is sent back to the control module 7 with the SDP of the called unit 9. The control module 7 forwards the acknowledgement to the calling unit along with the SDP of the called unit 9 that contains the necessary codec and port information so that the calling unit 3 and the called unit 9 can thereafter communicate directly. If both the calling unit and the called unit support the same SIP features, those features may be implemented in the established communication session. In the conventional VoIP environment, if either the calling unit 3 or called unit 9 fail to support a particular SIP feature, that particular feature may not be used in the communication session.


The present invention removes the requirement that the calling endpoints both support a particular SIP feature in order to utilize that feature in a communication session. FIGS. 2 and 3 depict exemplary environments suitable for practicing the illustrative embodiment of the present invention. With regard to FIG. 2, a calling unit 33 executing on or in communication with a first computing device 32 sends a communication invitation (hereafter referred to herein as a “call invitation”) identifying a called unit 39 executing on or in communication with a second computing device 38. The call invitation is sent over a network 34 to a control module 40. The first and second computing devices 32 and 38 may be a workstation, server, laptop, PDA, IP-enabled phone or other computing device equipped with a processor and able to establish a communication session over the network 34. The calling unit 33 and called unit 39 may be analog phones, digital phones or software processes providing communication features. The network 34 may be the Internet, a Local Area Network (LAN), a Wide Area Network (WAN), a wireless network, or some other type of network over which the first computing device 32, second computing device 38 and server 36 can communicate. For illustration purposes, the control module 40 is depicted as executing on a server 36 although it should be appreciated that the control module may also operate on other types of computing devices. The control module 40 establishes the communication session between the first computing device and second device as requested by the invitation. Upon receiving the invitation request from the calling unit 33, the control module 40 determines whether the called unit 39 is available. In the event the called unit 39 is available for the requested communication session, the control module provides port and codec information of a software relay module 42 through which the communication stream 50 for the session will bi-directionally pass. Both the control module 40 and the relay module 42 support the use of SIP. It should be appreciated that while the relay module 42 is depicted for ease of illustration as being executed on the same server 36 as the control module 40, the relay module 42 may also be located on a different computing device in the network 34.


Because both the control module 40 and relay module 42 support identical SIP features, the communication stream 50 may be conditioned and enhanced with both well-known and/or new features even when particular features are not supported by a one or both of the call endpoints for the communication stream 50. For example, the communication stream 50 may be conditioned so that transcoding is applied to the communication stream to change the data from one format to another as it passes through the relay module 42 so that it will be compatible with the receiving calling unit or called unit. Exemplary enhanced services which may be applied to the communication stream 50 at the relay module 42 include call recording (by storing the packets passing through the relay module), the application of global policy information for the stream so as to provide consistent packet marking and handling, and the application of enhanced speech processing technologies such as packet loss concealment. Lawful intercepts may also occur at the relay module 42 and statistics may be gathered. It will be appreciated that many other features may similarly be applied to the communication stream 50 at the relay module 42. As a result of the communication between the control module 40 and the relay module 42, the control module has access to a single point (the relay module) from which to manage and enhance the communication stream.



FIG. 3 depicts an additional environment in which the illustrative embodiment of the present invention may be practiced. A second server (or other computing device) 56 is added to the network 34 discussed in FIG. 2 and is in communication with the first server 36 executing the control module 40. The second server 56 includes a second control module 60 and second relay module 62. The second control module 60 may be used in both the establishment of the communication session between the calling unit 33 and the called unit 39 and in management of the communication stream 50. The communication stream 50 may be directed to pass between one or both of the relay modules 42 and 62. It should be appreciated that alternate environments with additional control modules and relay modules are also within the scope of the present invention.



FIG. 4 is a flowchart of a sequence of steps that may be followed by the illustrative embodiment of the present invention in order to enhance and manage a communication stream. The sequence begins when the control module receives a connection request from the calling unit (step 80). When the called unit accepts the connection (step 82) a session is established with the communication stream being directed through the relay module (step 84). The control module is in communication with the relay module through which the communication stream passes and may monitor the stream (step 86). The control module uses SIP to send directives to the relay module to condition and/or enhance the communication stream at the relay module (step 88).


The present invention may be provided as one or more computer-readable programs embodied on or in one or more mediums. The mediums may be a floppy disk, a hard disk, a compact disc, a digital versatile disc, a flash memory card, a PROM, a RAM, a ROM, or a magnetic tape. In general, the computer-readable programs may be implemented in any programming language. Some examples of languages that can be used include FORTRAN, C, C++, C#, or JAVA. The software programs may be stored on or in one or more mediums as object code. Hardware acceleration may be used and all or a portion of the code may run on a FPGA or an ASIC. The code may run in a virtualized environment such as in a virtual machine. Multiple virtual machines running the code may be resident on a single processor.


Since certain changes may be made without departing from the scope of the present invention, it is intended that all matter contained in the above description or shown in the accompanying drawings be interpreted as illustrative and not in a literal sense. Practitioners of the art will realize that the sequence of steps and architectures depicted in the figures may be altered without departing from the scope of the present invention and that the illustrations contained herein are singular examples of a multitude of possible depictions of the present invention.

Claims
  • 1. A computer-implemented method for managing and enhancing communication streams in a VoIP environment, the method comprising the steps of: establishing, with a control module, a communication stream between a calling unit and a called unit;providing at least one relay module, the control module directing the communication stream through the at least one relay module; andmanaging, from the control module, the communication stream passing through the at least one relay module, the managing of the communication stream using SIP (Session Initiation Protocol).
  • 2. The method of claim 1, further comprising: conditioning the communication stream at the at least one relay module using SIP.
  • 3. The method of claim 2 wherein the communication stream is transcoded.
  • 4. The method of claim 1, further comprising: providing an enhanced service to the communication stream at the at least one relay module using SIP.
  • 5. The method of claim 4 wherein the enhanced service is at least one of a call recording, an application of global policy information, and an application of an enhanced speech processing technology.
  • 6. The method of claim 5 wherein the application of global policy information affects packet marking and handling.
  • 7. The method of claim 5 wherein the application of an enhanced speech processing technology provides packet loss concealment for the communication stream.
  • 8. A computer-implemented system for managing and enhancing communication streams in a VoIP environment, comprising: a calling unit on a first computing device;a called unit on a second computing device, the second computing device accessible over a network by the first computing device;a control module, the control module establishing a communication stream between the calling unit and the called unit; andat least one relay module, the communication stream directed through the at least one relay module by the control module, the communication stream being managed at the relay module by the control module, the managing of the communication stream using SIP (Session Initiation Protocol).
  • 9. The system of claim 8 wherein the communication stream is conditioned at the relay module using SIP.
  • 10. The system of claim 8 wherein the control module provides an enhanced service to the communication stream at the relay module using SIP.
  • 11. The system of claim 8 wherein statistics are compiled about the communication stream by monitoring the communication stream at the relay module.
  • 12. The system of claim 8 wherein the statistics track packet loss in the communication stream.
  • 13. The system of claim 8 wherein the statistics track jitter in the communication stream.
  • 14. The system of claim 8 wherein the system includes at least two relay modules.
  • 15. A physical medium for use with a computing device, the medium holding computer-executable instructions for managing and enhancing communication streams in a VoIP environment, the instructions comprising: instructions for establishing, with a control module, a communication stream between a calling unit and a called unit;instructions for providing at least one relay module, the control module directing the communication stream through the at least one relay module; andinstructions for managing, from the control module, the communication stream passing through the at least one relay module, the managing of the communication stream using SIP (Session Initiation Protocol).
  • 16. The medium of claim 15, the instructions further comprising: instructions for conditioning the communication stream at the at least one relay module using SIP.
  • 17. The medium of claim 16 wherein the communication stream is transcoded.
  • 18. The medium of claim 15, wherein the instructions further comprise: instructions for providing an enhanced service to the communication stream at the at least one relay module using SIP.
  • 19. The medium of claim 18 wherein the enhanced service is at least one of a call recording, an application of global policy information, and an application of an enhanced speech processing technology.
  • 20. The medium of claim 19 wherein the application of global policy information affects packet marking and handling.
  • 21. The medium of claim 19 wherein the application of an enhanced speech processing technology provides packet loss concealment for the communication stream.
RELATED APPLICATION

This application claims priority to U.S. Provisional Patent Application Ser. No. 60/835,374, filed Aug. 3, 2006, the contents of which are hereby incorporated by reference.

Provisional Applications (1)
Number Date Country
60835374 Aug 2006 US