The invention is related to Internet Protocol (IP) telephony systems. More specifically, the invention is related to systems and methods for controlling the data rate used to conduct an IP telephony communication.
When an audio or video IP telephony communication is conducted between first and second parties, via data communications, an encoding/decoding scheme is used by the first party's telephony device to convert an audio or video signal received from or generated by the first party into a stream of data packets. Those data packets are sent to the second party's telephony device via a data network. The second party's telephony device uses a similar encoding/decoding scheme to convert the received data packets back into an audio or video signal, which is then used to play the audio or video to the second party. In a typical audio or video telephony communication, the same thing is simultaneously happening in reverse. In other words, the second party's telephony device encodes an audio or video signal received from or generated by the second party into data packets, and sends the data packets to the first party's telephony device. The first party's telephony device converts the received data packets back into an audio or video signal, and the audio or video signal is used to play audio or video to the first party.
The encoding and decoding schemes used to convert an audio or video signal into data packets, and to convert the data packets back into an audio or video signal, are commonly referred to as CODECs. Although a CODEC can be embodied in a physical electrical circuit structure, CODECs are typically computer algorithms or computer programs running on a processor.
Different CODECs can be used to convert the same audio or video stream into varying amounts of digital data. Thus, a first CODEC could convert an input audio/video signal into a first digital data stream having a first bit rate, while a second CODEC converts the same input audio/video stream into a second digital data stream having a second, lower bit rate. In addition, some CODECs are multi-rate, meaning they can generate output digital data are a plurality of different bit rates. In most cases, the higher the bit rate, the better the quality of the communication. Thus, in the absence of other constraining factors, it is desirable to use a CODEC that creates a digital data stream having the largest possible bit rate, as that is likely to result in the highest quality communication.
Unfortunately, there are several factors that constrain the bit rates that can be used for IP telephony communications. One factor is the bandwidth available for data communications passing between a first party's telephony device and a second party's telephony device. The CODEC that is used must be capable of generating a digital data stream with a low enough bit rate to send the digital data stream through all links that extend between the first and second party's telephony devices.
It is common for the link between one party's telephony device and the data network to have a smaller bandwidth than the link between the other party's telephony device and the data network. The link with the lowest bandwidth will determine the maximum data bit rate that can be used for a telephony communication. In some instances, a link within the data network itself may be the constraining factor that determines the maximum bit rate that can be used. In still other instances, one party's telephony device may be the constraining factor in determining the maximum bit rate that can be used.
In some situations, a first party's telephony device will use a first CODEC that communicates at a first bit rate, and the second party's telephony device will use a second CODEC that communicates at a second, higher bit rate. In these circumstances, one of the devices in communications path between the first and second telephony devices converts the lower bit rate data stream generated by the first CODEC on the first telephony device into a higher bit rate data stream that can be used by the second CODEC on the second telephony device. Likewise, the same device in the communications path converts the higher bit rate data stream generated by the second CODEC on the second telephony device into a lower bit rate stream that can be used by the first CODEC on the first telephony device. This type of a bit rate or CODEC conversion operation is commonly referred to as a transcoding operation. In this sort of a situation, although the second telephony device is using a higher bit rate than the first telephony device, the quality of the telephony communication is determined by the lower bit rate being used by the first telephony device.
Most systems and methods for setting the bit rate that is to be used for an IP telephony communication focus on the capabilities of the first and second party's telephony devices, and/or the present capability of the data communications channel between the first and second parties' telephony devices. The maximum possible bit rate of the telephony device with the lower capability is taken into account. Also the present capabilities of the data network communications channel is taken into account. The present capability of the data communications channel can be established by testing the speed and reliability of the communications channel with test data communications. Once these factors are determined, a bit rate is established for the telephony communication. Typically, based on the available bandwidth, the telephony devices for each party states its preferred CODEC and bit rate during call setup, and the two telephony devices then negotiate the CODEC to be used for the communication. The first and second parties' telephony devices are informed of that bit rate. The first and second parties' telephony devices then agree on a CODEC to be used for the telephony communication. As noted above, in some instances, the first and second telephony devices may end up using different CODECs that communicate at different bit rates, and an element in the communication path between the telephony devices may perform a transcoding operation. In yet other instances, where the first and second telephony devices are both capable of communicating with two or more CODECS, the first telephony device may send data using a first CODEC and the second telephony device may send data using a second CODEC, but no transcoding occurs at an interim element. Instead, because each telephony device is capable of receiving and using the CODEC being used by the other telephony device, it is possible for the telephony devices to use different CODECs.
Although known techniques for selecting a bit rate for IP telephony communications take into account the capabilities of the first and second telephony devices, and existing data network conditions, it would be desirable to take other factors into account in setting and controlling the bit rate that is used. For example, if one of the telephony devices that is to engage in an IP telephony communication is a mobile device that is communicating over a cellular telephony system, the user of the telephony device may have to pay a per/unit charge for data communications. For example, the user may have to pay a certain amount per megabyte or gigabyte of data. Similarly, the user may have a monthly allowance for data communications, and the user may have to pay extra for any data usage in excess of the monthly allowance. Under these circumstances, it would be desirable to take these factors into account when setting up an IP telephony communication for the user, so that the user can minimize the cost of conducting IP telephony communications.
In other instances, the data communications channel that is established between first and second telephony devices may have a data communications capability that varies over time. If that is the case, an IP telephony communication between the first and second telephony devices might begin at a point in time when the bit rate capability of the communications channel is high, and the bit rate capability of the communications channel might deteriorate as the IP telephony communication continues. If the first and second telephony devices attempt to continue the communication at a first, relatively high bit rate that is established at the beginning of the communication, the communication channel could deteriorate to the point where the communications channel can no longer support the initial bit rate. The result would increasingly poor communications quality, potentially leading to a dropped call.
Under these circumstances, where the communications channel established between first and second telephony devices is known to vary over time, it would be desirable to take the time varying nature of the communications channel into account when establishing the initial bit rate to be used for the communications channel. It may also be desirable to vary the bit rate, and thus the CODEC(s) that are used, as the telephony communication continues, to accommodate the known time varying nature of the communications channel. In instances where a CODEC capable of multiple bit rates is being used, the bit rate may change during a communication, while the CODEC remains the same.
The following detailed description of preferred embodiments refers to the accompanying drawings, which illustrate specific embodiments of the invention. Other embodiments having different structures and operations do not depart from the scope of the present invention.
In the following description, the terms VOIP system, VOIP telephony system, IP system and IP telephony system are all intended to refer to a system that connects callers and that delivers data, text or video communications using Internet protocol data communications.
As illustrated in
The gateway 122 allows users and devices that are connected to the PSTN 140 and cellular network 130 to connect with users and devices that are reachable through the IP telephony system 120, and vice versa. In some instances, the gateway 122 would be a part of the IP telephony system 120. In other instances, the gateway 122 could be maintained by a third party.
Customers of the IP telephony system 120 can place and receive telephone calls using an IP telephony device 108 that is connected to the Internet 110 via an interface 109. Such an IP telephony device 108 could be connected to an Internet service provider via a wired connection or via a wireless router.
Alternatively, a customer could utilize a normal analog telephone 102 which is connected to the Internet 110 via a terminal adapter 104 and the interface 109. The terminal adapter 104 converts analog signals from the telephone 102 into digital data signals that pass over the Internet 110, and vice versa. Analog telephony devices include, but are not limited to, standard telephones and document imaging devices such as facsimile machines.
In addition, a customer could utilize a soft-phone client running on a computer 106 to place and receive IP based telephone calls, and to access other IP telephony systems (not shown). In some instances, the soft-phone client could be assigned its own telephone number. In other instances, the soft-phone client could be associated with a telephone number that is also assigned to an IP telephone 108, or to a terminal adaptor 104 that is connected to one or more analog telephones 102.
Likewise, a mobile computing device 137 may be used to send and receive telephony communications via the IP telephony system 120. The mobile computing device 137 could establish a data connection to the Internet 110 via a wireless interface 119, such as a WiFi router. IP telephony software on the mobile computing device 137 could then be used to conduct telephony communications through the IP telephony system 120.
A third party using an analog telephone 132 which is connected to the PSTN 140 may call a customer of the IP telephony system 120. In this instance, the call is initially connected from the analog telephone 132 to the PSTN 140, and then from the PSTN 140, through the gateway 122 to the IP telephony system 120. The IP telephony system 120 then routes the call to the customer's IP telephony device. Likewise, a third party using a cellular telephone 136 could also place a call to an IP telephony system customer, and the connection would be established in a similar manner, although the first link would involve communications between the cellular telephone 136 and a cellular telephony network 130.
In addition, a smartphone 138 that includes both mobile computing capabilities and cellular telephony capabilities can connect to the cellular network 130 using its cellular telephone capabilities. However, the smartphone 138 also may establish a data connection to the IP telephony system 120 via a wireless interface 119 and the Internet 110. In this instance, communications between the smartphone 138 and other parties could be entirely carried by data communications. Of course, alternate embodiments could utilize any other form of wired or wireless communications path to enable communications.
Users of the first IP telephony system 120 are able to access the service from virtually any location where they can connect to the Internet 110. Thus, a customer could register with an IP telephony system provider in the U.S., and that customer could then use an IP telephony device 108 located in a country outside the U.S. to access the services. Likewise, the customer could also utilize a computer with IP telephony software 106 or a mobile computing device with IP telephony software 137 outside the U.S. to access the IP telephony system 120. Further, in some instances a user could place a telephone call with the analog telephone 132 or the cellular telephone 136 that is routed through the PSTN 140 or cellular network 130, respectively, to the IP telephony system 120 via the gateway 122. This would typically be accomplished by the user calling a local telephone number that is routed to the IP telephony system 120 via the gateway 122. Once connected to the IP telephony system 120, the user may then place an outgoing long distance call to anywhere in the world using the IP telephony system's network. Thus, the user is able place a long distance call using lower cost IP telephony service provided by the IP telephony system 120, rather than a higher cost service provided by the PSTN 140 or cellular network 130.
The processor 250 shown in
The memory 254 is coupled to the CPU 252. The memory 254, or computer-readable medium, may be one or more of readily available memory such as random access memory (RAM), read only memory (ROM), floppy disk, hard disk, flash memory or any other form of digital storage, local or remote, and is preferably of non-volatile nature. The support circuits 256 are coupled to the CPU 252 for supporting the processor in a conventional manner. These circuits include cache, power supplies, clock circuits, input/output circuitry and subsystems, and the like.
A software routine 262, when executed by the CPU 252, causes the processor 250 to perform processes of the disclosed embodiments, and is generally stored in the memory 254. The software routine 262 may also be stored and/or executed by a second CPU (not shown) that is remotely located from the hardware being controlled by the CPU 252. Also, the software routines could also be stored remotely from the CPU. For example, the software could be resident on servers and memory devices that are located remotely from the CPU, but which are accessible to the CPU via a data network connection.
The software routine 262, when executed by the CPU 252, transforms the general purpose computer into a specific purpose computer that performs one or more functions of the IP telephony system 120, a data rate control unit 400, and/or a user's telephony device. Although the processes of the disclosed embodiments may be discussed as being implemented as a software routine, some of the method steps that are disclosed therein may be performed in hardware as well as by a processor running software. As such, the embodiments may be implemented in software as executed upon a computer system, in hardware as an application specific integrated circuit or other type of hardware implementation, or a combination of software and hardware. The software routine 262 of the disclosed embodiments is capable of being executed on any computer operating system, and is capable of being performed using any CPU architecture.
In the following description, references will be made to an “IP telephony device.” This term is used to refer to any type of device which is capable of interacting with an IP telephony system to conduct or participate in an IP telephony communication. An IP telephony device could be an IP telephone, a computer running IP telephony software, a telephone adaptor which is connected to an analog telephone, or some other type of device capable of communicating via data packets. An IP telephony device could also be a cellular telephone, a smartphone, or a portable or tablet computing device that runs a software client that enables the device to act as an IP telephony device. Thus, a single device might be capable of operating as both a cellular telephone and an IP telephony device.
Moreover, certain devices that are not traditionally used as telephony devices may act as telephony devices once they are configured with appropriate client software. Thus, some devices that would not normally be considered telephony devices may become telephony devices or IP telephony devices once they are running appropriate software. One example would be a desktop or a laptop computer that is running software that can interact with an IP telephony system over a data network to conduct telephone calls. Another example would be a portable computing device, such as an Apple iPod touch™, which includes a speaker and a microphone. A software application loaded onto an Apple iPod touch™ can be run so that the Apple iPod touch can interact with an IP telephony system to conduct a telephone call. Similarly, an IP telephony software application could be run on a smart TV.
The following description will also refer to telephony communications and telephony activity. These terms are intended to encompass all types of telephony communications, regardless of whether all or a portion of the communications are carried in an analog or digital format. Telephony communications could include audio or video telephone calls, facsimile transmissions, text messages, SMS messages, MMS messages, video messages, and all other types of telephony and data communications sent by or received by a user. These terms are also intended to encompass data communications that are conveyed through a PSTN or VOIP telephony system. In other words, these terms are intended to encompass any communications whatsoever, in any format, which traverse all or a portion of a communications network or telephony network.
In the following description, multiple different systems and methods for controlling the data rate of IP telephony communications are discussed. In some of these methods, historical data network conditions are used to set and selectively vary the data rate at which IP telephony communications are conducted. In other methods, a user's monthly data allowance with a cellular telephony system is taken into account in setting and adjusting the data rate at which that user conducts IP telephony communications. In some of the systems and methods disclosed below, the factors which are taken into account are used to constrain or reduce the data rate at which IP telephony communications are conducted. In other instances, such as where historical data network conditions are taken into account, the maximum allowable data rate is used, whenever possible, to ensure the highest quality communications.
The data rate control unit 400 includes a network conditions database 402, which stores historical information about the conditions that existed in the past in various portions of a data network that is used to conduct IP telephony communications. The information can includes the data rates at which reliable data communications were conducted at various different times in the past over various different portions of the data network. This can include the data rates at which reliable IP communications were conducted between two nodes in the Internet or a private data network. This can also include the data rates that were provided at various different times by individual cell towers of a cellular telephony service provider.
As is well known to those of ordinary skill in the art, the data rate at which data packet communications can be conducted across different portions of a data network can vary depending upon the location within the data network. In addition, the data rate at which reliable communications can be conducted through any given portion of a data network can vary depending upon the time of day, the day of the week, or even the week within a month. Information about the maximum reliable data rates of various different portions of a data network, and how those reliable data rates vary as function of time, are stored in the network conditions database 402.
For example, the network conditions database 402 could include information that indicates, for a specific cell tower (base station) of a cellular telephony service provider, the data rates at which the cell tower was capable of communicating with individual cellular telephones at various different times of the day, for various different days of the week, and for various different portions of a month. This same information can be tracked for multiple different cell towers. If this historical information is tracked over time for multiple months, the information can be used to predict the data rates at which an individual the cell tower is likely to be able to communicate at any given time of day and day of the week.
The data rate control unit 400 also includes a telephony devices database 404. The telephony devices database 404 can include various different items of information about individual user telephony devices. This can include information about calls or other telephony communications that have been conducted by various user telephony devices. This can also include information about the amount of data communicated by a user telephony device.
For example, if a given user's telephony device has a monthly data budget, information about that data budget, and information about how much of the data budget has been used in any given month, could also be stored in the telephony devices database 404. A monthly data budget refers to a data plan that the user may have with a telephony services provider, such as a cellular telephony services provider. It is common for a user to purchase a communications plan which allows the user to make use of up to a maximum amount of data in any given month without additional charges. However, if the user's data usage exceeds the monthly budget in any given month, the user will be charged additional amounts per unit of data used in excess of the monthly budget. Information about a particular telephony device's actual data usage over the course of a month could be periodically obtained from the cellular telephony service provider, and stored in the telephony devices database 404.
The data rate control unit 400 also includes a location unit 406, which determines the location at which a telephony device will initiate a new IP telephony communication. The location of a telephony device could be determined by GPS coordinate data reported from the telephony device, or possibly by the IP address being used by the telephony device. Information reported from a cellular telephony service provider might also be used to determine the location of a telephony device. The location unit 406 may also identify or determine the portion or portions of a data network which will be used to communicate with the user's telephony device once a new IP telephony communication begins. For example, if the user telephony device will communicate over a cell tower (base station) of a cellular telephony service provider, the location unit could identify the specific cellular tower that will be used. How this location unit 406 is then used to control the data rates for IP telephony communications is discussed in detail below.
The data rate control unit 400 also includes a network testing unit 408. The network testing unit 408 is used to test various portions of a data network to determine the maximum data rate at which reliable communications can be conducted. The network testing unit 408 could operate to send test data packets through a particular path through the data network in order to check data packet communication conditions. The testing would be done to determine various statistical measures of data packet communications which can be indicative of the quality of an IP telephony communication. Common examples are the data transfer rate, the frequency of dropped or lost data packets, latency, or the delay time for the delivery of packets, and jitter, which is a measure of the variable nature of the time taken to deliver data packets. Other data packet statistical measures could also be tested by the network testing unit 408.
The data rate control unit 400 further includes a usage rate unit 410. The usage rate unit 410 calculates the rate at which a user is using data under a monthly data budget. For example, the usage rate unit 410 could total the amount of data which has already been used by a user during the first 10 days of a month. The usage rate unit 410 could then calculate the average amount of data used per day. The average daily data usage rate could then be used to estimate the total amount of data that a user is likely to use during the month if the current usage rate continues to the end of the month.
The data rate control unit 400 further includes a call frequency unit 412. The call frequency unit 412 determines the typical number of calls made by a user on a daily basis. For example, if the user has made a total of fifty IP telephony communications during the first 10 days of a month, the call frequency unit 412 would calculate that the user is making IP telephony communications at a rate of approximately 5 per day. This information can then be used to help control or set the data rate at which future IP telephony communications are conducted. Note, the usage rate unit 410 and the call frequency unit 412 may both consult the telephony devices database 404 for data regarding an individual user's actual and/or typical usage patterns.
The data rate control unit 400 also includes a rate setting unit 414. The rate setting unit 414 includes an initial rate setting unit 416 and an adjustment range setting unit 418. The initial rate setting unit 416 uses various items of information to determine an initial data rate at which a user's IP telephony device will begin to conduct IP telephony communications. The adjustment range setting unit 418 determines a maximum allowable adjustment range for an IP telephony communication. This means how much the data rate can be adjusted upward or downward during the course of the IP telephony communication.
The data rate control unit can also include a signal strength unit 420. The signal strength unit 420 can determine the wireless signal strength that a user telephony device has when communicating with a cell tower or a wireless access point. This information could be determined or reported in various different ways. For example, and with reference to
Although
The IP telephony system 120 may optionally include a network conditions database 504 and a telephony devices database 506 that are similar to and that store the same types of information as the corresponding units discussed above in connection with the data rate control unit 400.
The IP telephony system 120 also includes a data rate control unit 508. The data rate control unit 508 is essentially the same as the data rate control unit 400 discussed above in connection with
The IP telephony system also includes a call data record (CDR) unit. The CDR unit receives call data records which are generated by various elements of the communications environment and which include information about individual telephony communications handled by the IP telephony system 120. Those call data records are then stored in a database. In some instances, the CDR unit 510 may mediate information received from multiple elements of the communications environment, and then create one or more comprehensive call detail records relating to an IP telephony communication.
The IP telephony system 120 also includes a billing unit 512 which is responsible for generating bills or invoices for its own clients, and for other telephony systems which are terminating telephony communications through the IP telephony system 120. The billing unit 512 will make use of information stored in the call detail records created and stored by the CDR unit 510.
Although
Assuming that a first IP telephony device 302 would like to conduct an IP telephony communication with a second IP telephony device 308 as illustrated in
When the first IP telephony device 302 requests the setup of a new IP telephony communication with the second IP telephony device 308, elements of the IP telephony system 120, such as a communication setup unit 502, help to establish the IP telephony communication. A data rate control unit 400, which could be resident on the first IP telephony device 302, or the second IP telephony device 308, or the IP telephony system 120, performs the method illustrated in
Turning to
In some instances, the location unit may identify other portions of the data network that will be used to conduct the IP telephony communication. For example, the location unit may also identify portions of the data network corresponding to communications channel C, which passes from the Internet 110 through the second wireless access point 306 to the second IP telephony device 308.
Next, in step S606, an initial rate setting unit 416 of a rate setting unit 414 sets an initial data rate for the IP telephony communication. This initial data rate is set based upon information about historical data network conditions through the portions of the data network identified in step S604. The initial rate setting unit 416 makes use of the data stored in the network conditions database 402, which provides historical information about the typical or maximum data transfer rates which can be used to achieve reliable communications through those portions of the data network that are to be used, given the time of day determined in step S602. While historical data about data transfer conditions may not be a 100% accurate prediction for what will occur at the present time, the historical conditions will usually be relatively accurate in predicting how the data network will perform at the determined present time.
For example, the information in the network conditions database 402 may indicate that the portions of the data network provided along pathway A between the first IP telephony device 302 and the Internet 110 can provide a first relatively high data rate with good reliability. The network conditions database 402 may also indicate that pathway C between the second IP telephony device 308 and the Internet 110 only supports a second lower data rate with good reliability. Under those conditions, the initial rate setting unit 416 select the lower data rate for the IP telephony communication, in recognition of the fact that pathway C will likely only support this lower data rate.
The method may also include an optional step S608 where an adjustment range setting unit 418 sets an adjustment range for the data rate for the IP telephony communication. The adjustment range setting unit 418 could determine a maximum upper boundary for the data rate, and a minimum lower boundary for the data rate for the IP telephony communication. As the IP telephony communication continues, it may be possible to adjust the data rate upward or downward, depending upon actual network conditions, in order to ensure that the IP telephony communication proceeds with good or high quality.
As mentioned above in the Background section, various different CODECs can be used by the individual IP telephony devices to conduct the IP telephony communication. The data rate which is determined for the IP telephony communication can in turn determine the CODEC(s) that will be used for the IP telephony communication. In the case of a CODEC capable of multiple bit rates, the determined bit rate will set the bit rate at which the CODEC begins to operate. For example, if the initial rate setting unit 416 sets the initial data rate for an IP telephony communication between the first IP telephony device 302 and the second IP telephony device 308 to be a relatively low data rate, then both the first IP telephony device 302 and the second IP telephony device 308 can use a same or similar CODEC which operates at this relatively low data rate.
Once the initial data rate for the IP telephony communication has been determined, the method illustrated in
In any event, by checking the historical network conditions prior to beginning a new IP telephony communication, one can help to set an initial data rate that is likely to be useful in conducting a reliable IP telephony communication with relatively high quality. Operating in this fashion also prevents a situation in which the IP telephony communication begins at a data rate which is too high to be supported by actual network conditions.
In addition, if the check of historical data network conditions which is performed in step S606 indicates that the network conditions will likely support a relatively high data rate at the present time, but that the data network conditions are likely to deteriorate over the next ten to twenty minutes, then the initial rate setting unit 416 may set the initial data rate for the IP telephony communication to a relatively low data rate. Although this would result in the IP telephony communication beginning at a lower data rate than actual network conditions currently will support, as time proceeds, and the IP telephony communication continues, and as the data network conditions begin to deteriorate, the lower initial data rate will not have to be changed as the IP telephony communication is ongoing. Thus, selecting a lower data rate at the beginning of the IP telephony communication obviates the need to change the data rate, and to switch to a different CODEC, in the middle of the IP telephony communication.
If the method also includes an optional step S608 of setting an adjustment range for the data rate, the historical network conditions can also be used to determine that adjustment range. For example, in the situation described above, where network conditions are likely to deteriorate during the course of an IP telephony communication, step S608 could involve setting an upper limit for the data rate which is no higher than the data rate which the network is likely to support over the course of the IP telephony communication.
In several of the examples described above, attempts are made to predict the network conditions which will occur as an IP telephony communication continues. The predicted network conditions are then used to set the initial data rate, and possibly also an adjustment range. In both instances, the likely length or duration of the IP telephony communication will affect the decision. If the IP telephony communication is likely to be relatively short, then it is less necessary to take probable future network conditions into account. If the IP telephony communication is likely to be quite lengthy, then future network conditions, as predicted from the historical database, can be quite helpful in setting the initial data rate and/or the adjustment range. For these reasons, a predicted length of an IP telephony communication may be taken into account in making these decisions.
For example, if the user of the first IP telephony device 302 typically engages in relatively short communications, this information can be used in making a decision about the initial data rate and/or the adjustment range. Conversely, if the user of the first IP telephony device 302 typically engages in quite lengthy communications, this information could also be taken into account. This type of historical information could be present in the telephony devices database 404, which tracks the telephony communications conducted by individual user telephony devices.
Another factor which may be taken into account in setting the initial data rate for a telephony communication is the signal strength of wireless data communications. For example, and with reference to
For example, if the first IP telephony device 302 is communicating with a cell tower of the cellular telephony system 130, and the signal strength is gradually increasing, then the initial rate setting unit 416 could select an initial rate which is supported by current network conditions, and set an adjustment range which allows for increasing the data rate. Conversely, if the signal strength information indicates the signal strength is gradually decreasing, then the initial data rate set for the IP telephony communication may be set to a rate which is lower than is currently supported by network conditions. As a result, if the signal strength continues to deteriorate, IP telephony communication can proceed at the lower data rate, even after the signal strength continues to deteriorate.
In the methods discussed above, historical data network conditions and information about the current data network conditions can both be taken into account in determining an initial data rate for an IP telephony communication, as well as an allowable adjustment range. In any given embodiment, only one piece of this information could be used, or multiple pieces of this information can be used together to set an initial data rate, or an adjustment range. Moreover, additional factors which are not discussed above could also be taken into account in determining the initial data rate, or an adjustment range.
As mentioned above, if a user makes use of a cellular telephony system to conduct IP telephony communications, the data being transferred in order to conduct the IP telephony communication will count as part of the user's monthly data budget. For example, and with reference to
For purposes of the following explanation, we will assume that the user of the first IP telephony device 302 can use up to a maximum of 4 gigabytes of data, with 1GB budgeted for voice communications, and the other 3GB dedicated to streaming video, data and other similar uses, in any given month as part of his monthly service charge. However, if the user exceeds the 4 gigabyte data budget in any given month, the user will pay additional amounts for each additional gigabyte of data used that month. Under these circumstances, it would be desirable for the user to ensure that his data usage in any given month does not exceed the 4 gigabyte monthly data budget. The method illustrated in
The method illustrated in
In the descriptions which follow, they are references to a “nominal data rate.” A nominal data rate is a default data rate that will be used for IP telephony communications in the absence of other constraints. The nominal data rate would typically provide good quality for the IP telephony communication. However, it would be possible to conduct the IP telephony communications at lower data rates, and still maintain a reasonable level of quality.
The method 700 illustrated in
To provide one concrete example, assume it is the 10th day of a 30-day month, and that the user has a monthly data budget of 1GB for voice communications. Assume also that the user is currently averaging 0.025 gigabytes of data usage per day while conducting IP telephony communications at the nominal data rate. Because it is the 10th day of the month, the user will have already used 0.25 gigabytes. Projecting this average daily usage rate forward to the end of the month, would predict that the user will use a total of 0.75 gigabytes of data, if he continues to conduct IP telephony communications at the same daily usage rate, using the nominal data rate. Because this would not cause the user to exceed his monthly data budget of 1GB, the user could continue to use the nominal data rate for the present time, without fear of exceeding his monthly data budget.
Alternatively, if the user has been averaging 0.05GB of data usage per day, and it is the 10th day of the month, the user will have already used 0.5GB of data by the 10th day of the month. Projecting this data usage rate forward to the end of the month, would predict that the user will make use of 1.5GB of data by the end of the month, far exceeding his monthly data budget of 1GB. Under those circumstances, it makes sense to lower the data rate for IP telephony communications going forward, in an attempt to prevent the user from exceeding his monthly data budget.
Returning to the method illustrated in
Once an initial data rate is set, and perhaps an adjustment range, the method illustrated in
Another factor that may be taken into account in setting the initial data rate is the user's historical data usage patterns over previous months. For example, if a user frequently exceeds his monthly data budget, then the initial data rate might be lowered farther below the nominal data rate earlier in the month than would otherwise occur to help prevent the user from exceeding his data budget in the present month. Similarly, if an analysis of previous months indicates that the user tends to use a large amount of data during the last few days of each month, then the initial data rate set during days early in the present month may be set lower than would otherwise occur, in recognition of the fact that the user is likely to consume a large amount of data later in the month. Individual user usage patterns can thus be taken into account in setting the initial data rate for IP telephony communications, in addition to the other factors discussed above.
In the foregoing examples, a monthly data budget was contemplated. In other embodiments, a different total time period could be considered in performing similar methods. The selection of a month as the time period for a particular data budget is somewhat arbitrary, and only reflects the fact that current cellular data plans tend to use a one month time period for a data budget.
Information about a user's data usage could be drawn from a telephony services database 404, as illustrated for the data rate control unit 400 in
As illustrated in
As the IP telephony communication continues, a network testing unit 408 tests actual network conditions while the IP telephony communication is ongoing. If the current network conditions would support a higher data rate, and the higher data rate is likely to result in a higher quality communication, then in step S810, the data rate for the IP telephony communication could be adjusted upward. Of course, this upward adjustment would only occur if doing so is not likely to cause the user to exceed his monthly data budget, given the information gathered in step S802.
Alternatively, the network conditions measured in step S808 could indicate that the data network is no longer capable of reliably communicating data packets at the initial data rate set in step S804. Under these conditions, the data rate could be adjusted downward to ensure that the IP telephony communication continues with relatively high quality. Although this would force the user's telephony devices to switch to a different CODEC, or to vary the bit rate being used by a CODEC capable of communicating at multiple bit rates, to utilizes a lower data rate, doing so could help to preserve the quality of the communication, as opposed to using a CODEC which requires a higher data rate which can no longer reliably be supported by the data network. Once the adjustment has been made in step S808, the method ends. In some embodiments, steps S808 and S810 may be re-performed on a periodic basis as an IP telephony communication continues to ensure that the IP telephony communication has an acceptable quality.
The method then proceeds to step S906 where an initial data rate for IP communications is set based on the information gathered in steps S902 and S904. The information gathered in step S902 is taken into account in the ways discussed above in connection with
As illustrated in
A method as illustrated in
This situation basically wastes bandwidth, because it is unnecessary to communicate at the higher data rate. The quality of the IP telephony communication is determined by the lowest data rate in the communications channel. Thus, the second IP telephony device can be switched to a lower data rate which matches the data rate being used by the first IP telephony device without impairing or impacting the quality of the IP telephony communication. Doing so, in turn, reduces the bandwidth being used by the second IP telephony device, and it eliminates the need for any transcoding operation to be performed by an element located between the two IP telephony devices.
In most instances, when a new IP telephony communication is being setup, neither telephony device is aware of the data rate capabilities of the other IP telephony device. However, if this information is encoded in the typical IP communication setup messaging which passes between the two devices, then both devices can be made aware of the capabilities of the other device, and a suitable data rate can be selected for the IP telephony communication. As mentioned above, a convenient way of exchanging this information is to include the data rate information in a header of a typical IP telephony communication setup request.
In many of the foregoing descriptions, a software application running on a telephony device performs various functions. In alternate embodiments, a browser running on the telephony device may access a software application that is running on some other device via a data network connection. For example, the software application could be running on a remote server that is accessible via a data network connection. The software application running elsewhere, and accessible via a browser on the telephony device may provide all of the same functionality as an application running on the telephony device itself. Thus, any references in the foregoing description and the following claims to an application running on a telephony device are intended to also encompass embodiments and implementations where a browser running on a telephony device accesses a software application running elsewhere via a data network.
Also, although many of the examples provided about related to telephony communications, those telephony communications could be audio or video calls, or other forms of telephony communications. The methods and techniques described above could be used to enable many different types of communications. Thus, the foregoing references to calls or telephony communications should in no way be considered limiting.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
While the invention has been described in connection with what is presently considered to be the most practical and preferred embodiment, it is to be understood that the invention is not to be limited to the disclosed embodiment, but on the contrary, is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims.
Number | Date | Country | |
---|---|---|---|
62151028 | Apr 2015 | US |