This application is related to U.S. patent application Ser. No. 13/417,915, entitled MULTIMEDIA MESSAGING AND SYSTEM, filed 12 Mar. 2012, U.S. patent application Ser. No. 09/707,140, entitled METHOD FOR IMPLEMENTING A MULTIMEDIA MESSAGING SERVICE, A MULTIMEDIA MESSAGING SYSTEM, A SERVER OF A MULTIMEDIA MESSAGING SYSTEM AND A MULTIMEDIA TERMINAL, filed 6 Nov. 2000, issued as U.S. Pat. No. 7,653,734, and U.S. patent application Ser. No. 10/149,639, entitled MULTIMEDIA MESSAGING METHOD AND SYSTEM, filed 14 Jun. 2002, issued as U.S. Pat. No. 8,150,989.
This invention relates to communication services. It is related particularly, but not exclusively, to streaming in a Multimedia Messaging Service (MMS).
Electronic mail, or e-mail is a messaging service, which allows quick and economical communication in electronic form. Using the Internet, e-mail messages can be sent all over the world, in many cases practically free of charge. Furthermore, the same e-mail message can be sent to a plurality of recipients. This technique is called multicasting. As the relaying of e-mail messages is entirely automated, the e-mail messages can arrive very shortly after they are sent. E-mail messages can carry computer files such as documents, program files, and different media files like audio- or video clips.
Ordinary home users having Personal Computers (PCs) prefer not to have a permanent connection to their e-mail system (for example to the Internet) but rather to set up a temporary and remote connection to an e-mail server that stores messages received since a previous e-mail message reading session. Using this kind of connection and an e-mail message reading program, new e-mail messages can be transferred from the e-mail server to the memory or a hard disk of a PC and then be read either while the connection is still extant, or alternatively after the connection has been closed. The transmission of data between the PC and the e-mail server is typically carried out using a modem attached to the PC.
In the following, the term “sender” refers to a device that sends data intended for a receiver and “receiver” refers to a device that receives the data and to which the data was intended.
In the Internet, e-mail messages are sent using certain well-known protocols. Simply speaking, an e-mail message, once composed, is packaged into a single unit, stamped with an address of the receiver and is sent to the sender's e-mail server. The sender's e-mail server forwards the message through the Internet to the receiver's e-mail server. The next time the receiver forms a connection to the receiver's e-mail server via the Internet and checks whether new e-mail messages have been received using an e-mail reading program, the receiver can download any newly received e-mail message over the connection (e.g. modem link). When the e-mail message has been received completely, it can be presented to the user. It should be noted that during the various stages of its transmission, the e-mail message is typically split into numerous smaller packets according to the data transfer protocol(s) used. On reception, the receiver gathers together all of the packets, assembles them into the correct order (if necessary) and reconstructs the e-mail message into its original form, before presenting the e-mail message to a user of the receiver.
An e-mail transmission system described above is convenient and provides the possibility for multicasting, but it is best suited, and originally intended, for receiving e-mail messages and then presenting them at the convenience of the user. Thus, the content of a given e-mail message can only be accessed after completion of the e-mail message transmission to the receiver. This is not a real problem with plain text form e-mail messages, but in the case of a large media or multimedia content (clip) it is a drawback that the user of the receiver cannot start presentation of the clip while it is still being downloaded. Another drawback is that in order to receive an e-mail message, the receiver must have a sufficiently large memory to accommodate the entire message. Particularly in mobile communications networks, or any other network in which part of the communications link is formed by a radio connection, it is also problematic to receive a long e-mail message without interruptions or errors, for example due to a temporary loss of or deterioration in radio coverage. Mobile terminals also tend to have limited memory available for the storage of received e-mail messages, which further exacerbates the problem associated with the accommodation of messages in the receiver. These problems are at least partly mitigated by the Multimedia Messaging Service (MMS).
The MMS is a new end-to-end messaging approach for one-way transmission of multimedia messages having text and/or multimedia content. MMS provides the possibility of sending multimedia messages between mobile users and between a mobile user and the Internet. There is already an agreed solution for implementation of MMS in 3rd Generation mobile communication networks. The currently specified features of the proposed MMS are described in 3rd Generation Partnership Project (3GPP) technical specification 23.140 V.3.0.1. “Multimedia Messaging Service (MMS), Functional Description, Stage 2 (Release 1999)”. The MMS proposed in 3GPP 23.140 employs a store-and-forward approach to multimedia message delivery. Multimedia messages are constructed in such a way that the media content, information necessary to describe the media content and addressing information, identifying the intended receiver of the multimedia message, are encapsulated together. The multimedia message is then sent to an MMS Centre MMSC, which in turn notifies the receiver about the multimedia message. The multimedia message is downloaded by the receiving terminal as a whole and only presented to the user once downloaded and stored in the receiving terminal.
It should be appreciated that although the term “multimedia message” is used generally to describe a message that contains more than one type of content, in this application, the term extends to cover messages that contain only one media type.
As currently specified, the MMS has a drawback: the receiving terminal must store the multimedia message before it can be presented to the user. Therefore the size of the memory of the receiving terminal sets an upper limit on the size of multimedia messages that can be downloaded. WO 99/166746 solves this problem by dividing a message into sub-messages (segments) if the entire message would not fit into the memory of the receiving terminal. These sub-messages are small enough so that the receiving terminal can individually download each of them as a whole. In that case, the receiving terminal initially downloads a first sub-message. After the first sub-message has been fully downloaded, the receiving terminal can present it. After presentation of the first sub-message, the receiving terminal can download a second sub-message and then present it. Each sub-message is downloaded and then presented by itself. The size of the sub-messages depends on the memory size of the receiving terminal and must be small enough to fit into the memory.
Apart from MMS, there are streaming-techniques used in the Internet for transmission over fixed lines. “Streaming” is a term used generally to describe the presentation of a media stream, for example an audio or video stream, or a combination of different streams, in a continuous way while this stream or those streams are being transmitted to a client over a data network. A “stream” is a flow of data typically enabling the receiver to present some continuous data such as a motion picture, voice or music. In a typical video stream, some 10 to 20 video frames are transmitted per second. In practice, streaming can be either live (real-time) or performed in an on-demand fashion. As its name suggests, “live streaming” describes the creation of a media stream from a live source, for example a stream of digital images produced by a video camera, while “on-demand streaming” describes the creation of a media stream from, for example, a file stored on a server. Streaming also involves establishing a streaming session, during which the stream or streams is or are transmitted to the client.
Within streaming there are two very important functionalities, namely streaming control and media transport. Streaming control takes care of establishing, managing and terminating a streaming session using a negotiated or pre-configured set of parameter values. Media transport concerns the transportation of media during the established session using an agreed or negotiated transport protocol. For example, there are widely agreed protocols in the Internet to provide both streaming control and media transport functionalities and these can be used as transport protocols in streaming applications.
Whilst streaming is widely used in the Internet, it has still to be adapted for use in mobile communication networks. It should be appreciated that the use of streaming is desirable in mobile networks, since mobile terminals typically have limited storage capacity (memory). However, present mobile communication networks do not support streaming for reasons described in the following.
The encapsulation of media content, message description and addressing information in a single entity as proposed in current MMS specifications is incompatible with the streaming of media content. In order to establish a streaming session, it is necessary for the receiving terminal to be aware, in advance, of certain information relating to the media content. Such information includes, but is not limited to, the type of media contained in the multimedia message, the way that media is encoded and a suitable transport protocol that can be used to download the media content. Because present MMS specifications require information describing the media content to be encapsulated with the multimedia message itself, the receiving terminal cannot obtain prior knowledge about the properties of the media content and therefore cannot establish any form of streaming session. Thus, according to the present MMS specification, the entire multimedia message must be downloaded to the receiving terminal in order for the details of the media content to be extracted. Only then can any media content, such as video and/or audio clips be played back to the user of the receiving terminal. This limits the usability of the present MMS because multimedia clips are usually bulky in terms of bits and therefore a receiving terminal, for example a mobile station, would require a comparatively large memory to completely receive the clips. The need to download an entire multimedia message before it can be presented may also give rise to significant delays in certain conditions, for example if the multimedia message is very large, or the data transmission rate of the connection is low.
It should further be emphasised that the addressing scheme suggested by current MMS specifications does not facilitate the implementation of streaming in such a system. The current MMS can be viewed as a “sender orientated” system. In other words, the sender decides what media content to send to the receiver, encapsulates that in the multimedia message and addresses the multimedia message to the intended receiver. Streaming, on the other hand, is more “receiver orientated”. To establish a streaming session, it is generally necessary for a streaming connection to be formed between the receiver and the sender, for example a network-based server, the content being streamed from the server once the necessary connection has been established. Thus, establishment of a streaming session requires the recipient to have knowledge of the location of the media content, but it does not necessarily require the media content to be directly addressed to the recipient.
Now a new solution has been invented where the problems of the prior art can be avoided or at least mitigated.
According to a first aspect of the invention there is provided a communication method comprising the steps of:
receiving by a communication server content and information describing the content from a first terminal; and
sending a notification message from the communication server to a second terminal, the notification message notifying about availability of the content;
characterised by the method further comprising:
forming a streaming session between the communication server and the second terminal, using the information describing the content; and
transmitting the content in sequential sub-parts from the communication server to the second terminal, during the streaming session.
The transmission of the content to the second terminal as a stream allows rapid access to the content as a recipient using the second terminal need not wait for the content to be received completely.
Preferably, the content and the information describing the content are sent from the first terminal to the communication server in separate messages. This allows, for example, separate sending of the content to one entity of the communication server and sending of a notification message to the recipients.
Preferably, the information describing the content is sent from the communication server to the second terminal within the notification message.
Preferably, the method further comprises sending by the communication server to the second terminal the information describing the content as a media component of a multimedia message.
The sending of the description of the streamable component as a media component allows utilizing of existing multimedia messaging systems with minor changes. It further allows embedding in the same multimedia message more than one media component, wherein some or all of the media components may be descriptions of streamable components.
Preferably, the multimedia message comprises at least one non-streamable component and at least one description of a streamable component.
Preferably, the communication method further comprises the step of presenting at the second terminal the received content as a stream during the streaming session. The second terminal can start presenting the content immediately and possibly take certain measures (for example, pausing or aborting the data transmission) during the transmission.
Preferably, the method further comprises the step of deciding at the second terminal to receive or not to receive the content, at a certain time, and the streaming session is only formed if the decision is to receive the content.
Preferably, the communication server comprises a content server for storing and transmitting the content and a notification server for receiving and transmitting notifications, wherein the content server and the notification server have a physical relationship selected from the group consisting of the following: a single unit, separate units, and separate units distributed at different geographic locations.
Preferably, the communication method further comprises the step of generating the content at the first terminal. Preferably, content generated at the first terminal is streamed to the content server and the sending of the content occurs during the generation of the content. By doing so the content can be made available to the user earlier than if content was generated wholly or to a large extent in the first terminal and only then streamed to the content server.
Preferably, when using streamed content generation, the information describing the content is sent before content generation is complete, so that the second terminal can start receiving the content before its generation is complete.
Preferably, during the streaming session between the communication server and the second terminal, the receiver can issue an abort command to abort the session. Preferably, the streaming session is aborted in response to the abort command.
Preferably, the notification message comprises information required by the second terminal in order to form a streaming session with the content server.
Preferably, the method is implemented as part of the Multimedia Messaging Service (MMS).
Preferably, the method further comprises the step of multicasting the content to at least one other terminal in addition to the second terminal in at least one other streaming session.
In an embodiment in which there are a plurality of streaming sessions, each of the streaming sessions may be formed independently of any other, so that the sessions may start and end at different times or at the same time. Preferably, each of the sessions can be aborted independently of any other, responsive to each of the respective terminals.
According to a second aspect of the invention there is provided a communications system comprising:
a plurality of terminals including a first terminal and a second terminal;
a communication server accessible to the plurality of terminals;
means for sending the content and information describing the content from the first terminal to the communication server; and
means for sending a notification message from the communication server to the second terminal;
characterised by the system further comprising
means for forming a streaming session between the communication server and the second terminal, using the information describing the content; and
means for transmitting the content in sequential sub-parts from the communication server to the second terminal, during the streaming session.
Preferably, the system further comprises means for generating the content at a first terminal.
Preferably, the system further comprises means for presenting at the second terminal the received content as a stream, during the streaming session.
According to a third aspect of the invention there is provided a communication server for serving a plurality of terminals, the communication server comprising:
means for receiving content and information describing the content from a first terminal; and
means for sending a notification message to a second terminal, the notification message notifying the second terminal about availability of the content;
characterised by the server further comprising:
means for forming a streaming session with the second terminal, using the information describing the content; and
means for transmitting the content in sequential sub-parts to the second terminal, during the streaming session.
According to a fourth aspect of the invention there is provided a computer program product comprising:
computer program code for causing a communication server to receive content and information describing the content from a first terminal to a communication server; and
computer program code for causing the communication server to send a notification message from the communication server to a second terminal, the notification message notifying the second terminal about availability of the content;
characterised by the computer program product further comprising:
computer program code for causing the communication server to form a streaming session between the communication server and the second terminal, using the information describing the content; and
computer program code for causing the communication server to transmit the content in sequential sub-parts from the communication server to the second terminal, during the streaming session.
According to a fifth aspect of the invention there is provided a communication device comprising:
means for receiving from a communication server information describing a message intended for the communication device;
characterised by
the message comprising a streamable component;
the information describing the message comprising information describing the streamable component; and
the communication device further comprising:
means for forming a streaming session with the communication server for receiving the streamable component, using the information describing the streamable component; and
means for receiving the content in sequential sub-parts from the communication server.
According to a sixth aspect of the invention there is provided a computer program product comprising:
computer program code for causing a communication device to receive from a communication server information describing a message intended for the communication device;
characterised by
the message comprising a streamable component;
the information describing the message comprising information describing the streamable component; and
the computer program product further comprising:
computer program code for causing the communication device to form, using the information describing the streamable component, a streaming session with the communication server for receiving the streamable component; and
computer program code for causing the communication device to receive the content in sequential sub-parts from the communication server.
Preferably, the communication device is a wireless communication device. Even more preferably, the communication device is a mobile telephone. In an alternative embodiment, the wireless communication device is a wireless communication adapter adapted for providing wireless communication functionality to an external device such as a laptop PC.
According to a seventh aspect there is provided a method in a communication device, the method comprising the steps of:
receiving from a communication server information describing a message intended for the communication device;
characterised by
the message comprising a streamable component;
the information describing the message comprising information describing the streamable component; and
the method further comprising:
forming a streaming session with the communication server for receiving the streamable component, by using the information describing the streamable component; and
presenting the streamable component during the streaming session.
The embodiments of one aspect also apply to various other aspects of the invention. In sake of brevity, all the embodiments have not been repeated in connection with every aspect of the invention. A skilled reader will appreciate the advantages of the various aspects and embodiments based on the advantages of the first aspect and its embodiments.
The invention will now be described, by way of example only, with reference to the accompanying drawings, in which:
Next, a preferred embodiment of the invention is briefly summarised and then fully disclosed with reference to
According to a preferred embodiment of the invention, streaming is incorporated within the Multimedia Messaging Service (MMS). A three-phase approach is taken in this regard. In a first phase (phase 1), a sender (sending terminal) transfers a multimedia message, or more accurately, media content, to a media (streaming) server. In a second phase (phase 2), one or more receivers (receiving terminals) is or are notified that media content is available for delivery. In a third phase (phase 3), the media content is transferred to the receiver or receivers. Advantageously, the notification performed in phase 2, takes place by means of a notification message sent from the sender via a Multimedia Messaging Server (MMS) to the receiver. Typically, the MMS server stores the notification message and then tries to forward it to the receiver. If it fails in the forwarding, it tries to re-send the stored notification message at a later time.
Advantageously, streaming is performed in the first and third phases, namely while uploading the media content to the media (streaming) server and while downloading the media content from the media (streaming) server. It should be noted that streaming during the uploading phase (phase 1) is not an essential feature of the method according to the invention. However, the use of streaming in both phases 1 and 3 can reduce the delay between starting transmission of the media content from the sender and the commencement of streaming at the receiver. It may also have the effect of reducing storage requirements in the media (streaming) server and can effectively enable implementation of real-time or near real-time streaming in the MMS.
Phase 2 of the method can be regarded as a message control phase, which takes care of forwarding a multimedia message and streaming-related information to a recipient (a target receiver of a multimedia message) via the MMS server. Phases 1 and 2 may be performed sequentially or substantially simultaneously, while phase 3 can be performed automatically on receipt of the notification message at the receiver, or at some later time at the discretion of a user of the receiver. Thus, the invention provides the flexibility to play the streamed media content at the receiver at any time. The preferred embodiment does not impose any limitation on the size of the media content or the number of recipients in the case of multicasting. The preferred embodiment is based on a store-and-forward approach and it is thus in-line with other MMS solutions. This enables any media content that is not to be streamed or is not of a type suitable for streaming to be downloaded to the receiver in a conventional manner that is as specified in current MMS specifications.
It is an advantage of the present invention that the implementation of streaming functionality can enhance the proposed MMS in many ways, particularly when the media content is large or it is to be multicast. The store-and-forward approach to streaming in MMS is effective and desirable, since it provides the receiver with complete flexibility to decide whether and when to receive and play back the media content within a multimedia message. The invention also provides streaming functionality within the framework of the proposed MMS and is thus fully compatible with the existing MMS standards.
The embodiments of the invention described hereafter outline the main steps for streaming under MMS.
In this example of a multimedia message streaming method, the sender 21 is a mobile terminal equipped with a video-camera 25 and a microphone (not shown) which creates media content (an audio/video clip) to be sent to the receiver 24. The receiver 24 is a mobile terminal equipped with appropriate presentation software and equipment to enable presentation of the media content (the audio/video clip). Typically, the sender 21 and the receiver 24 are similar devices, one of them being the sender 21 and another of the being the receiver 24 just because of their roles as sending and receiving parties (sender and recipient). The three phases of the method are described in detail in the following.
In the phase 1, the sender 21 establishes a streaming session with the media (streaming) server 22 which starts storing the media content in a predetermined location. This phase can be considered as a media upload phase.
In the phase 2, the sender 21 sends a notification via the MMS server 23 to the receiver 24 about the media content being stored. The notification includes presentation description information required to establish another streaming session between the receiver 24 and the media server 22. The presentation description information includes, but is not limited to, the following data: the network address of the media server, details of an access mechanism by use of which media content can be retrieved from the media server 22, the type of media to be streamed, the encoding method(s) used to encode the media content and an indication of the transport protocol(s) to be used for media downloading.
In the phase 3, the receiver 24 establishes a streaming session with the media server 22, based on the information received in the notification message and the receiver 24 starts to download and play the media. This phase can be considered as a media download phase. The media content is downloaded as a sequence of content sub-parts, each representing one time period of the streaming session. The content sub-parts may be separate data packets, or one sub-part may be comprised by more than one data packet, depending the type of coding of the media content and payload size of the data packets.
The media server 22 and the MMS server 23 can be merged together or maintained as different entities in the network depending on the implementation chosen by the service provider, which controls them. The media server 22 can be located, for example, in a mobile communications network or can reside in the Internet, possibly under the control of a service provider other than that responsible for provision of services in the mobile communications network.
When streaming is used both in the phase 1 and in the phase 3, the (notification) phase 2 is performed during the (media upload) phase 1 and the (media download) phase 3 can also be started during the phase 1. The sender 21 continues to send the media content to the media server 22 while the media server 22 simultaneously sends those parts of the media content received earlier to the receiver 24. The receiver 24 starts (and continues) playing back the media content with a total delay that depends on the streaming process, data transmission delays, and the time at which the phase 3 was initiated. If the phase 3 is not started automatically, but only after prompting and receiving permission from the user of the receiver 24, the total delay is typically longer than if the phase 3 were to be initiated immediately on notification being received at the receiver 24.
In an alternative embodiment the media content is already stored in the media server 22 and the sender 21 knows the presentation description information of the media content. In this case the phase 1 can be omitted. As stated above, streaming of media content is not essential to phase 1. For example, a non-streaming approach to phase 1 can be used in connection with the provision of media content from a commercial content provider, such as a provider of news content, located in a communications network, such as the Internet. The content provider updates the media content stored on the media server 22 using non-streaming transmission over an IP connection and notifies potential recipients of media content about new clips of interest, using notification messages according to phase 2 of the invention. The recipients of notification messages would be, for example, users having a subscription with the particular content provider. Based on the notification message, at individually convenient times, each recipient can decide whether to form a streaming session with the media server 22 in order to retrieve new media content made available by the particular content provider. This also represents an example of a multicasting approach to streaming using the multimedia messaging system according to the invention.
According to an alternative embodiment of the invention, the presentation description information can be stored in a server other than the MMS server 23 or the media server 22, for example in an e-mail or Web-server. In this embodiment, the notification message sent to the receiver 24 identifies the particular server on which the presentation description information is stored and an access mechanism (HTTP GET, WSP GET, IMAP4, POP3, RTSP DESCRIBE) can be used to retrieve the presentation description information from that location. Then the receiver 24 retrieves the presentation description information from the server identified in the notification message using the specified access mechanism. The presentation description information thus retrieved then guides the receiver 24 to invoke phase 3 of the method for retrieving and playing the stored media content. If the server used to store presentation description information is the MMS server 23, the existing MMS solution can be used directly to retrieve the presentation description information. In this situation, the MMS notification from the sender 21 to the MMS server 23 carries presentation description information and the presentation description information is stored in the MMS server 23. The notification from the server storing the presentation description to the receiver 24 then carries the location of the stored presentation description, the server address and other required information. Finally, the receiver 24 follows the MMS to retrieve the presentation description from the MMS server 23.
It should thus be noted that, in certain situations, the information content of the notification message sent from the sender 21 to the MMS server 23 may be different from that sent from the MMS server 23 to the receiver 24.
According to a preferred embodiment of the invention, if the senders 21 and receivers 24 are under the authority of different mutually linked MMS servers (that is they have different “serving” multimedia servers), the notification message is carried over the link between the MMS servers. The number of servers that may be linked together between serving MMS servers is not limited for any end-to-end notification.
There are existing protocols for both streaming control and media transport in the Internet domain. Phases 1 and 3 can thus be implemented based on these existing protocols. In this way, the solution provided by the present invention also ensures interworking with the Internet, which is also an important objective of current MMS standard. Phase 2 conforms to existing MMS standards and thus provides backward compatibility with previously proposed mechanisms for non-streamed media content download.
Some practical approaches to accomplish the different phases of the preferred embodiment of the present invention are outlined below as examples.
The Real Time Streaming Protocol (RTSP) is a client-server streaming control protocol that enables controlled delivery of streamed multimedia data over an IP network. It is an application-level protocol and can work in conjunction with either the Transmission Control Protocol (TCP) or User Datagram Protocol (UDP). RTSP provides scope to use RTP (Real-time Transport Protocol)/UDP or any other lower level protocol for media transport. RTSP comprises a set of methods/instructions to control streamed audio and/or video. In this regard, the most useful methods/instructions are OPTIONS, DESCRIBE, ANNOUNCE, SETUP, PLAY, PAUSE, TEARDOWN, REDIRECT and RECORD. The media upload and download can be implemented using SETUP, PLAY, RECORD, PAUSE and TEARDOWN.
The Hypertext Transport Protocol (HTTP) can also be used to enable and control the uploading and downloading of media content according to the invention, using TCP as a transport protocol. HTTP has methods/instructions PUT and GET, corresponding to RECORD and PLAY in RTSP, which can be used for media uploading (phase 1) and downloading (phase 3).
UDP is a connectionless lightweight transport protocol providing communication with comparatively low latency. RTP is purposely designed for real-time communication and is implemented in such a way that it provides time-stamps and sequence numbers for data packets on top of UDP. Multicasting is possible using RTP. RTP is further designed to work in conjunction with the auxiliary control protocol RTCP (Real-time Control Protocol) to obtain feedback on the quality of data transmission and information about participants in an on-going session. Together, RTP and RTCP provide functionality and control mechanisms necessary for carrying real-time content and hence to enable streaming of media content and can thus be used in conjunction with the present invention.
TCP is a connection-orientated transport protocol. It ensures guaranteed and sequential reception of data packets at the cost of increased latency and larger overhead compared with UDP. Multicasting is not possible with TCP, but TCP can be used in streaming applications, if initial buffering time is not critical and the media clips to be streamed are comparatively short.
Message control functionality is required on top of streaming control and media transport layers in order to incorporate streaming in the MMS.
A streaming control layer 32 is controlled by the message control layer 31. It is responsible for forming a streaming session for each type of media content to be streamed, according to information provided by the message control layer 31, or according to predefined rules for each media type. It is also responsible for controlling/regulating the streaming of media content once a streaming session is established. In the sender 21, the streaming control layer 32 is responsible for streamed uploading of media content to a media server 22 and conversely, in the receiver 24, it is responsible for controlling the streamed downloading of media content from the media server 22. Alternatively, streaming control functionality may be provided in the media server 22 in a situation, for example, in which streaming is performed in phase 1 and 3 in such a way as to provide real-time or near real-time streaming of media content between senders 21 and receivers 24. A media transport layer 33 handles the actual transportation of data using an appropriate transport protocol. The choice of protocol may be predefined for different media types or may be indicated to the media transport layer 33 via the message control and streaming control layers 31,32 in accordance with information provided in the notification message. In a preferred embodiment, the media streaming control adapts the streaming in accordance with the data transmission channel condition as notified by the media transport layer 33.
The receiver 24 requests for the media content it has been notified about in phase 2. The receiver 24 sends to the MMSC an RTSP setup message (41) for setting up a streaming session, and receives a corresponding acknowledgement (41_ACK). The receiver 24 next sends an RTSP play instruction message (42) to the MMSC, and receives a corresponding acknowledgement (42_ACK). In response to the play instruction, the MMSC starts sending RTP audio (43) and RTP video (44) content to the receiver 24, according to the multimedia message being sent. The receiver 24 may control the MMSC's sending of the media content by an RTCP message (45). Once the user of the receiver 24 desires to pause the streaming downloading of content, he or she requests for pausing the streaming and, responsively, the receiver 24 sends an RTSP pause message (46) to the MMSC, and receives a corresponding acknowledgement (46_ACK). Responsive to the RTSP pause message, the MMSC pauses the sending of the media content (RTP audio and RTP video). Next, an RTSP teardown message (47) is sent from the receiver 24 to the MMSC to end the RTP session, allowing the streaming be continued on a later occasion. A corresponding acknowledgement message (47_ACK) is returned by the MMSC to the receiver 24.
By replacing the PLAY instruction with RECORD, a similar session suitable for media uploading in phase 1 of the invention can be implemented, wherein in place of the receiver 24 there is the sender 21.
End-to-end notification is required for message control functionality because, as explained previously, the receiver 24 requires certain information concerning the media content to be streamed in order to take part in a streaming session. According to current MMS specifications, information describing media content is encapsulated together with the media content itself and thus cannot be sent independently to the receiver 24. In the absence of such information, the receiver 24 is unable to download the media content by streaming. By providing separate end-to-end communication of media presentation information, the method according to the invention supplies the receiver 24 with the information it requires in order to download media content by streaming. Furthermore, the existing non-streaming MMS protocol has scope to allow communication of media presentation information using end-to-end messaging via an MMS server, rendering the method according to the invention compatible with current MMS standards.
RTSP is believed to represent a best mode for enabling and controlling streaming in phases 1 and 3. A certain degree of compromise in performance is required if RTP/UDP or TCP is used as a media transport protocol. Specifically, implementations using TCP do not provide multicasting functionality, as TCP is a connection orientated protocol. Nevertheless, TCP represents a viable alternative media transport protocol that can be used in connection with the present invention. Indeed, its connection-orientated nature may provide advantages in certain situations, particularly if a more secure streaming connection is desired. According to the preferred embodiment of the invention, the existing MMS protocol is used to provide end-to-end notification of presentation description information from the sender 21 to the receiver 24 via the MMSC in phase 2.
While the invention has been described in relation to its implementation in a communications network in which at least part of the network comprises a radio communication link, it should be emphasised that its use is not in any way limited to this kind of network. The invention may equally well be implemented in networks where the physical connections between the various elements of the network (sender 21, receiver 24 and network servers) are implemented partially or entirely by means of fixed line connections.
The operation of the servers and terminals involved with different embodiments of the invention, such as the MMSC, the sender 21 and the receiver 24, is preferably controlled by computer program products causing these entities to operate according to the invention.
Particular implementations and embodiments of the invention have been described. It is clear to a person skilled in the art that the invention is not restricted to details of the embodiments presented above, but that it can be implemented in other embodiments using equivalent means without deviating from the characteristics of the invention. The scope of the invention is only restricted by the attached patent claims.
Number | Date | Country | Kind |
---|---|---|---|
20001741 | Aug 2000 | FI | national |
Number | Name | Date | Kind |
---|---|---|---|
5224648 | Simon et al. | Jul 1993 | A |
5513126 | Harkins et al. | Apr 1996 | A |
5530917 | Andersson et al. | Jun 1996 | A |
5544321 | Theimer et al. | Aug 1996 | A |
5557724 | Sampat et al. | Sep 1996 | A |
5584025 | Keithley et al. | Dec 1996 | A |
5592469 | Szabo | Jan 1997 | A |
5617539 | Ludwig et al. | Apr 1997 | A |
5642171 | Baumgartner et al. | Jun 1997 | A |
5694334 | Donahue et al. | Dec 1997 | A |
5717955 | Swinehart | Feb 1998 | A |
5737011 | Lukacs | Apr 1998 | A |
5740384 | Asthana et al. | Apr 1998 | A |
5745782 | Conway | Apr 1998 | A |
5751704 | Kostic et al. | May 1998 | A |
5778187 | Monteiro et al. | Jul 1998 | A |
5848415 | Guck | Dec 1998 | A |
5854898 | Riddle | Dec 1998 | A |
5901287 | Bull et al. | May 1999 | A |
5918002 | Klemets et al. | Jun 1999 | A |
5996022 | Krueger | Nov 1999 | A |
6006227 | Freeman et al. | Dec 1999 | A |
6014706 | Cannon et al. | Jan 2000 | A |
6029195 | Herz | Feb 2000 | A |
6047051 | Ginzboorg et al. | Apr 2000 | A |
6052735 | Ulrich et al. | Apr 2000 | A |
6085222 | Fujino et al. | Jul 2000 | A |
6094661 | Salomaki | Jul 2000 | A |
6105036 | Henckel | Aug 2000 | A |
6134235 | Goldman et al. | Oct 2000 | A |
6134313 | Dorfman et al. | Oct 2000 | A |
6163809 | Buckley | Dec 2000 | A |
6167040 | Haeggstrom | Dec 2000 | A |
6167261 | Amin | Dec 2000 | A |
6172673 | Lehtinen et al. | Jan 2001 | B1 |
6173328 | Sato | Jan 2001 | B1 |
6181714 | Isaksson et al. | Jan 2001 | B1 |
6199099 | Gershman et al. | Mar 2001 | B1 |
6200216 | Peppel | Mar 2001 | B1 |
6211869 | Loveman et al. | Apr 2001 | B1 |
6216013 | Moore et al. | Apr 2001 | B1 |
6233318 | Picard et al. | May 2001 | B1 |
6236909 | Colson et al. | May 2001 | B1 |
6249844 | Schloss et al. | Jun 2001 | B1 |
6260050 | Yost et al. | Jul 2001 | B1 |
6263371 | Geagan et al. | Jul 2001 | B1 |
6269483 | Broussard | Jul 2001 | B1 |
6301482 | Shohara | Oct 2001 | B1 |
6308171 | De La Huerga | Oct 2001 | B1 |
6314094 | Boys | Nov 2001 | B1 |
6314302 | Haferbeck et al. | Nov 2001 | B1 |
6314457 | Schena et al. | Nov 2001 | B1 |
6317584 | Abu-Amara et al. | Nov 2001 | B1 |
6317795 | Malkin et al. | Nov 2001 | B1 |
6330244 | Swartz et al. | Dec 2001 | B1 |
6341288 | Yach et al. | Jan 2002 | B1 |
6356529 | Zarom | Mar 2002 | B1 |
6363411 | Dugan et al. | Mar 2002 | B1 |
6366554 | Isaksson et al. | Apr 2002 | B1 |
6377996 | Lumelsky et al. | Apr 2002 | B1 |
6385451 | Kalliokulju et al. | May 2002 | B1 |
6389473 | Carmel et al. | May 2002 | B1 |
6411807 | Amin et al. | Jun 2002 | B1 |
6415439 | Randell et al. | Jul 2002 | B1 |
6421707 | Miller et al. | Jul 2002 | B1 |
6430177 | Luzeski et al. | Aug 2002 | B1 |
6446130 | Grapes | Sep 2002 | B1 |
6456594 | Kaplan et al. | Sep 2002 | B1 |
6466971 | Humpleman et al. | Oct 2002 | B1 |
6469714 | Buxton et al. | Oct 2002 | B2 |
6469998 | Burgaleta Salinas et al. | Oct 2002 | B1 |
6498865 | Brailean et al. | Dec 2002 | B1 |
6501741 | Mikkonen et al. | Dec 2002 | B1 |
6510153 | Inoue et al. | Jan 2003 | B1 |
6522638 | Haugli et al. | Feb 2003 | B1 |
6522875 | Dowling et al. | Feb 2003 | B1 |
6526580 | Shimomura et al. | Feb 2003 | B2 |
6538623 | Parnian et al. | Mar 2003 | B1 |
6539118 | Murray et al. | Mar 2003 | B1 |
6542819 | Kovacs et al. | Apr 2003 | B1 |
6546005 | Berkley et al. | Apr 2003 | B1 |
6549612 | Gifford et al. | Apr 2003 | B2 |
6553412 | Kloba et al. | Apr 2003 | B1 |
6557001 | Dvir et al. | Apr 2003 | B1 |
6567667 | Gupta et al. | May 2003 | B1 |
6584146 | Bose et al. | Jun 2003 | B2 |
6587457 | Mikkonen | Jul 2003 | B1 |
6594238 | Wallentin et al. | Jul 2003 | B1 |
6600917 | Maupin | Jul 2003 | B1 |
6606479 | Cook et al. | Aug 2003 | B2 |
6608832 | Forslow | Aug 2003 | B2 |
6611674 | Jokimies et al. | Aug 2003 | B1 |
6625274 | Hoffpauir et al. | Sep 2003 | B1 |
6629130 | Mertama et al. | Sep 2003 | B2 |
6633906 | Callaway et al. | Oct 2003 | B1 |
6636256 | Passman et al. | Oct 2003 | B1 |
6636733 | Helferich | Oct 2003 | B1 |
6643284 | Inoue et al. | Nov 2003 | B1 |
6647535 | Bozdagi et al. | Nov 2003 | B1 |
6654601 | Picoult et al. | Nov 2003 | B2 |
6658254 | Purdy et al. | Dec 2003 | B1 |
6658485 | Baber et al. | Dec 2003 | B1 |
6674733 | Huusko | Jan 2004 | B1 |
6677858 | Faris et al. | Jan 2004 | B1 |
6678361 | Rooke et al. | Jan 2004 | B2 |
6693915 | Lappetelainen et al. | Feb 2004 | B1 |
6714778 | Nykanen et al. | Mar 2004 | B2 |
6718551 | Swix et al. | Apr 2004 | B1 |
6725038 | Subbiah | Apr 2004 | B1 |
6728753 | Parasnis et al. | Apr 2004 | B1 |
6731940 | Nagendran | May 2004 | B1 |
6738800 | Aquilon et al. | May 2004 | B1 |
6744761 | Neumann et al. | Jun 2004 | B1 |
6760324 | Scott et al. | Jul 2004 | B1 |
6763388 | Tsimelzon | Jul 2004 | B1 |
6771964 | Einola et al. | Aug 2004 | B1 |
6772212 | Lau et al. | Aug 2004 | B1 |
6784899 | Barrus et al. | Aug 2004 | B1 |
6792273 | Tellinger et al. | Sep 2004 | B1 |
6795711 | Sivula | Sep 2004 | B1 |
6850614 | Collins | Feb 2005 | B1 |
6859882 | Fung | Feb 2005 | B2 |
6898207 | Boasson et al. | May 2005 | B2 |
6917965 | Gupta et al. | Jul 2005 | B2 |
6938268 | Hodge | Aug 2005 | B1 |
6963783 | Bi et al. | Nov 2005 | B1 |
6968366 | Zhang et al. | Nov 2005 | B1 |
6976082 | Ostermann et al. | Dec 2005 | B1 |
7000107 | Hewett et al. | Feb 2006 | B2 |
7028264 | Santoro et al. | Apr 2006 | B2 |
7047305 | Brooks et al. | May 2006 | B1 |
7062765 | Pitzel et al. | Jun 2006 | B1 |
7065553 | Chesley et al. | Jun 2006 | B1 |
7069573 | Brooks et al. | Jun 2006 | B1 |
7073191 | Srikantan et al. | Jul 2006 | B2 |
7113780 | McKenna et al. | Sep 2006 | B2 |
7152092 | Beams et al. | Dec 2006 | B2 |
7190681 | Wu | Mar 2007 | B1 |
7200385 | Wallenius et al. | Apr 2007 | B1 |
7209949 | Mousseau et al. | Apr 2007 | B2 |
7249344 | Zeanah et al. | Jul 2007 | B1 |
7284187 | Corboy | Oct 2007 | B1 |
8150989 | Mostafa | Apr 2012 | B2 |
20010003191 | Kovacs et al. | Jun 2001 | A1 |
20020016818 | Kirani et al. | Feb 2002 | A1 |
20020045808 | Ford et al. | Apr 2002 | A1 |
20020049852 | Lee | Apr 2002 | A1 |
20020054090 | Silva et al. | May 2002 | A1 |
20020073172 | Armstrong et al. | Jun 2002 | A1 |
20020111907 | Ling | Aug 2002 | A1 |
20020120939 | Wall et al. | Aug 2002 | A1 |
20020126708 | Skog et al. | Sep 2002 | A1 |
20020194130 | Maegawa et al. | Dec 2002 | A1 |
20020196127 | Benson | Dec 2002 | A1 |
20030195976 | Shiigi | Oct 2003 | A1 |
20030219030 | Gubbi | Nov 2003 | A1 |
20040162125 | Tarlie | Aug 2004 | A1 |
20050033632 | Wu et al. | Feb 2005 | A1 |
20050120082 | Hesselink et al. | Jun 2005 | A1 |
20050246624 | Humpleman et al. | Nov 2005 | A1 |
20050246752 | Liwerant et al. | Nov 2005 | A1 |
20060031237 | DeAnna et al. | Feb 2006 | A1 |
20060045030 | Bieselin | Mar 2006 | A1 |
20080146272 | Rao et al. | Jun 2008 | A1 |
20090070485 | Barger et al. | Mar 2009 | A1 |
20130117394 | Salmi et al. | May 2013 | A1 |
Number | Date | Country |
---|---|---|
0662763 | Jul 1995 | EP |
0748121 | Dec 1996 | EP |
0845894 | Sep 1999 | EP |
0984584 | Mar 2000 | EP |
0993148 | Apr 2000 | EP |
08097854 | Apr 1996 | JP |
9-311831 | Dec 1997 | JP |
10040188 | Feb 1998 | JP |
10240463 | Sep 1998 | JP |
10240643 | Sep 1998 | JP |
10313338 | Nov 1998 | JP |
411274993 | Oct 1999 | JP |
11328063 | Nov 1999 | JP |
2000222302 | Aug 2000 | JP |
2000232530 | Aug 2000 | JP |
2002-34014 | Sep 2000 | JP |
2001005751 | Dec 2001 | JP |
2002-034014 | Jan 2002 | JP |
9411858 | May 1994 | WO |
9411981 | May 1994 | WO |
9714244 | Apr 1997 | WO |
9826592 | Nov 1997 | WO |
9803005 | Jan 1998 | WO |
9815091 | Apr 1998 | WO |
9819438 | May 1998 | WO |
WO 9854637 | Dec 1998 | WO |
9956431 | Nov 1999 | WO |
9962258 | Dec 1999 | WO |
9966746 | Dec 1999 | WO |
WO 9966746 | Dec 1999 | WO |
0016541 | Mar 2000 | WO |
WO 0011847 | Mar 2000 | WO |
WO 0040007 | Jul 2000 | WO |
WO 0042755 | Jul 2000 | WO |
WO 0056088 | Sep 2000 | WO |
0064110 | Oct 2000 | WO |
0211398 | Feb 2002 | WO |
Entry |
---|
Handley et al. SDP: Session Description Protocol. RFC 2327. http://tools.ietf.org/pdf/rfc2327. Apr. 1998. |
Singh et al. “Unified Messaging using SIP and RTSP”. IPTS 200. Atlanta, GA. Sep. 11, 2000. pp. 1-7. |
Schulzrinne et al. RFC 2326. “Real Time Streaming Protocol (RTSP)”. Apr. 1998. pp. 1-92. |
3G TS 23.140 version 3.0.1 Release 1999. Universal Mobile Telecommunications System (UMTS); Multimedia Messaging Service (MMS), Functional description; Stage 2. pp. 1-26. Mar. 2000. |
3rd Generation Partnership Project (3GPP) technical specification 23.140, V.3.0.1, “Multimedia Messaging Service (MMS) Functional Description, Stage 2”, 1999. |
EPO Communication dated Nov. 11, 2004. |
JP Decision Rejection dated Oct. 21, 2004. |
3GPP TS 23.140, V 4.2.0 (Mar. 2001), 3rd Generation Partnership Project; Technical Specification Group Terminals' Multimedia Messaging Service (MMS); Functional description; Stage 2 (Release 4); Section 6.1.7, p. 23. |
Sevanto, J. “Multimedia Messaging Service for GPRS and UMTS”, Wireless Communications and Networking Conference, 1999. WCNC. 1999 IEEE, vol. 3, pp. 1422-1426, Sep. 24, 1999. |
Ekudden, Erik et al: ‘On-demand mobile media—a rich service experience for mobile users’ Ericsson Review No. 4, 2001, pp. 168-177. |
Miraj-E-Mostafa: ‘Circuit-switched mobile multimedia telephony—terminal requirements and call control’ Third International Symposium on Wireless Personal Multimedia Communications, WPMC'00. Proceedings vol. 2, Nov. 12, 2000-Nov. 15, 2000, Bangkok, Thailand, pp. 994-999. |
Seiji Okumura et al., “The Method of the QoS control on a MPEG-4 over RTP Delivery System”, Multimedia, Distributed, Cooperative and Mobile (DICOMO 2000) Symposium, vol. 2000, No. 7, Information Processing Society of Japan, pp. 433-438, Jun. 28, 2000. |
Meggers et al., “A multimedia communication architecture for handheld devices,” Personal, Indoor, and Mobile Radio Communication, 1998, 9th IEEE Int'l Symposium, Sep. 8-11, 1998, vol. 3, pp. 1245-1249. |
3rd Generation Technical Specification Group Terminals; Multimedia Messaging Service Partnership Project (MMS); Functional Description; Stage 2 (Release 4) 3GPP TS 23.140 V4.1.0 (Dec. 2000). |
3rd Generation Technical Specification Group Services and System Aspects; Packet-switched Partnership Project Streaming Services (PSS); General Description (Release 4) 3GPP TS 26.233 V1.0.0 (Dec. 2000). |
3rd Generation Technical Specification Group Services and System Aspects; Packet-switched Partnership Project Streaming Services (PSS); Protocols and Codecs (Release 4) 3GPP TS 26.234 V1.0.0 (Dec. 2000). |
WAP-209 MMSEncapsulation—WAP MMS Message Encapsulation—Proposed Version 17—Feb. 2000—Wireless Application Protocol forum Ltd. 2000. |
Journal of the Audio Engineering Society, vol. 48, Jul.-Aug. 2000, USA, Xu et al., “Real-Time Streaming of Multichannel Audio Data over Internet”, s. 627-641. |
International Search Report for PCT/IB2002/001431, dated Jul. 5, 2002, 3 pp. |
International Search Report, PCT/FI00/00965,dated Feb. 13, 2001, 4pp. |
Perkowitz et al., Adaptive Web Sites: Automatically Synthesizing Web Pages, AAAI '98, Proceedings of the Fifteenth National Conference on Artificial Intelligence, Jul. 26-30, 1998, pp. 727-732, Madison, WI (http://www.aaai.org/Library/AAAI/1998/aaai98-103.php). |
Karmouch et al., Agent Based Multimedia Communication On Internet, IEEE Canadian Conference on Electrical and Computer Engineering, May 25-28, 1998, pp. 734-737, Waterloo, Ont. |
Betti et al., A Burst Level Error Generation Model for 2GHZ Personal Radio Communications, IEEE Vehicular Technology Conference, Sep. 19-22, 1999, pp. 102-106, Amsterdam, NL. |
Perkins et al., Handling Multimedia Data for Mobile Computers, COMPSAC '96., Proceedings of 20th International Computer Software and Applications Conference, Aug. 21-23, 1996, pp. 147-148, Seoul, KR. |
Voruganti et al., Intelligent Decision Aids for 21st C4I Architectures, MILCOM 97 Proceedings, Nov. 3-5, 1997, pp. 618-622, Monterey, CA. |
Bacon et al., Location-Oriented Multimedia, IEEE Personal Communications, Oct. 1997, pp. 48-57, vol. 4, Issue 5. |
Liao, W., Mobile Internet Telephony Protocol: An Application Layer Protocol for Mobile Internet Telephony Services, ICC '99., 1999 IEEE International Conference on Communications, Jun. 6-10, 1999, pp. 339-343, Vancouver, BC. |
Angin et al., The Mobileware Toolkit: Programmable Support for Adaptive Mobile Networking, IEEE Personal Communications, Aug. 1998, pp. 32-43, vol. 5, No. 4. |
Ducey, R. V., Multimedia Broadcasting And The Internet, INET'96, The 6th Annual Conference of the Internet Society, Jun. 25-28, 1996, pp. 1-10, Montreal, CA. |
Meggers et al., A Multimedia Communication Architecture for Handheld Devices, The Ninth IEEE International Symposium on Personal, Indoor and Mobile Radio Communications, Sep. 8-11, 1998, pp. 1245-1249, Boston, MA. |
Friedman et al, Navigational Plans For Data Integration, AAAI '99, Proceedings of the Sixteenth National Conference on Artificial intelligence, Jul. 18-22, 1999, pp. 67-73, Orlando FL (http://www.aaai.org/Libraiy/AAAI/1999/aaai99-010.php). |
Simeonov, P. L., On Using Nomadic Services for Distributed Intelligence, The Eight IEEE International Conference on Computer Communications and Networks, Oct. 11-13, 1999, pp. 228-231, Boston, MA. |
Wu et al., Personal Mobile Multimedia Communications In A Wireless WAN Environment, IEEE First Workshop on Multimedia Signal Processing, Jun. 23-25, 1997, pp. 389-394, Princeton, NJ. |
Kornegay et al., Quality Of Service And System Design, IEEE Computer Society Workshop On VLSI, Apr. 8-9, 1999, pp. 112-117, Orlando, FL. |
Lassila et al., Resource Description Framework (RDF) Model and Syntax Specification, W3C Recommendation Feb. 22, 1999, (http://www.w3.org/TR/1999/REC-rdf-syntax-19990222). |
Tennenhouse et al., The SpectrumWare Approach To Wireless Signal Processing, Wireless Networks Journal, Jan. 1966, pp. 1-12, vol. 2, Issue 1, Kluwer Academic Publishers, Hingham, MA. |
Kraver, T., Summary Report of Research Task Group Reports, Arizona Learning Technology Partnership, Nov. 23, 1997 (http://www.altp.org/SSP/SummaryofResearchTaskForceReports.htm). |
Oono et al., The Proposal Of Wireless Multimedia Communication System With Integration Of Packet-Switched And Circuit-Switched Channels, GLOBECOM 1998, The Bridge to Global Integration, IEEE Global Telecommunications Conference, Nov. 8-12, 1998, pp. 120-125, Sydney, NSW. |
Hjelm et al., WAP Forum-W3 Cooperation While Paper, W3C Note Oct. 30, 1998, (http://www.w3.org/TR/1998/NOTE-WAP-19981030). |
Jokela, P., Wireless Internet Access Using Anonymous Access Methods, MoMuC '99, IEEE International Workshop on Mobile Multimedia Communications, Nov. 15-17, 1999, pp. 194-197, San Diego, CA. |
Number | Date | Country | |
---|---|---|---|
20020073205 A1 | Jun 2002 | US |