US6604144B1 - Data format for multimedia object storage, retrieval and transfer - Google Patents

Data format for multimedia object storage, retrieval and transfer Download PDF

Info

Publication number
US6604144B1
US6604144B1 US08/885,672 US88567297A US6604144B1 US 6604144 B1 US6604144 B1 US 6604144B1 US 88567297 A US88567297 A US 88567297A US 6604144 B1 US6604144 B1 US 6604144B1
Authority
US
United States
Prior art keywords
data
stream
browser
computer
server
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
US08/885,672
Inventor
Mark Anders
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Technology Licensing LLC
Original Assignee
Microsoft Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Corp filed Critical Microsoft Corp
Priority to US08/885,672 priority Critical patent/US6604144B1/en
Assigned to MICROSOFT CORPORATION reassignment MICROSOFT CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ANDERS, MARK
Application granted granted Critical
Publication of US6604144B1 publication Critical patent/US6604144B1/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MICROSOFT CORPORATION
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1097Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]

Definitions

  • the present invention relates to multimedia systems, and more particularly, to a storage and delivery system for multimedia objects in a computer environment, such as the World Wide Web.
  • the World Wide Web is part of a global computer network known as the Internet.
  • the Web functions as an object based multimedia system. It allows for the creation, storage and delivery of multimedia objects.
  • on-line service providers such as Microsoft Network, CompuServe, Prodigy and America Online, have linked to the Web. This enables their customers to access a variety of information and communication services available from independent content providers and other Web users. For example, a typical customer can access electronic mail, news services, weather services, bulletin board services and travel services on the Web.
  • Independent content providers typically create pages to communicate information and services they provide for their Web customers.
  • a customer views a page on a computer screen using a Web browser, such as Microsoft Explorer or Netscape Navigator, installed on the computer.
  • the structure and appearance of a Web page are defined using HyperText Markup Language (HTML).
  • HTML HyperText Markup Language
  • the browser retrieves and interprets the HTML defining a page to display it on a user's computer screen.
  • a typical Web page may have multiple objects including HTML text, a background image, icons, audio and bitmaps for several images.
  • a Web browser accesses a page when a user enters a Universal Resource Locator (URL) or selects a link to a page's URL using a pointing device such as a mouse or glide pad.
  • the browser retrieves the page by first checking its cache of previously retrieved objects.
  • a cache is a collection of previously requested objects that a browser maintains in local storage on the user's computer. If the requested object data exists in cache, the browser fetches the object from the cache. Otherwise, the browser must retrieve the object from a remote computer over the Web. Data transfer over the Web is a very slow process when compared to retrieving the same object from a cache on the local disk of the user's computer.
  • Data transfer speed is basically the result of the bandwidth and latency of a connection.
  • Bandwidth is the speed with which data moves over a connection. Improved bandwidth results by increased carrier capacity and/or increased transmission speed over the carrier.
  • a user can increase the bandwidth of a Web connection over an analog phone line carrier by increasing the modem transmission speed from 14,400 bits per second to 28,800 bits per second.
  • a user may similarly increase the bandwidth of a Web connection by using a digital phone line carrier, such as an Integrated Services Digital Network (ISDN) line, capable of carrying two data channels each at 64,000 bits per second.
  • ISDN Integrated Services Digital Network
  • Latency refers to the delay between the time a request for data is made and the time that the data is received. It results from the logistics of establishing and maintaining a connection over a carrier involving various types of handshakes needed to initiate and complete data transfer. Thus, latency is usually independent of the size of the data being sent over the carrier.
  • HTTP HyperText Transfer Protocol
  • a transport layer is a mechanism for the transfer of data between clients and servers that ensures delivery of in sequence, error-free data with no losses or duplications.
  • TCP establishes connections using a three-part handshake as follows: the client sends a connection request, the server responds and the client acknowledges the response, at which time the client can also send data.
  • TCP uses a mechanism called slow start to negotiate the data transfer speed over a connection.
  • slow start initiates transfer at a low data transfer rate and progressively increases the data transfer rate as more chunks of data are received successfully.
  • the impact of slow start and connection latency are minimal.
  • the impact of slow start and latency from multiple connections is devastating.
  • the transmission speed from a server to a client, the “downstream” connection is substantially higher than the transmission speed from client to server, the “upstream” connection.
  • wireless satellite links and cable modems are capable of transmitting data “downstream” at 10,000,000 bits/second rate while transmission of “upstream” browser requests often occurs at a rate of 768,000 bits/second (a “fractional” T 1 connection, about 13 times slower).
  • the slow speed “upstream” request connection limits data transfer performance due to the response latency of multiple HTTP requests for these objects.
  • the present invention addresses these performance limitations by improving the efficiency of object retrieval and transfer in multimedia computer environments.
  • the present invention reduces the number of transactions to retrieve a set of n objects from n to 1, thereby substantially reducing the latency due to slow start and cascaded round trip delays from opening multiple server connections. This increases delivery performance and improves the user experience by substantially reducing the delays in the transfer and rendering of images on the user's display.
  • the present invention includes data for multiple objects in a single data stream in an optimized interleaved format.
  • Object data is interleaved with data definition entries identifying respective object data into a data format comprising a single stream for storage and delivery.
  • the data format eliminates the need for multiple, asynchronous transactions.
  • the data format enables one to customize and optimize how the object data is prioritized and interleaved to achieve a desired effect on the viewer upon delivery of the multimedia data.
  • One aspect of the present invention includes a data format for storing, transferring and retrieving, in a computer environment having a storage, a stream of objects comprising object data packets stored within the storage for each object in the stream and at least one data definition entry corresponding to each object in the stream, wherein said at least one data definition entry is interleaved with said object data packets such that a data definition entry corresponding to one of the objects in the stream precedes any object data packets of said one object in the stream.
  • Another aspect of the present invention includes a system for transmitting a page comprising a data repository for a stream representing the page, wherein said stream comprises object data packets interleaved with data definition entries, a browser assembling said object data packets with reference to said data definition entries so as to display the page represented by said stream and a network communicating said stream between said data repository and said browser.
  • another aspect of the present invention includes a system for transmitting a page comprising a data repository for a stream representing the page, wherein said stream comprises object data packets interleaved with data definition entries, a browser assembling said object data packets with reference to said data definition entries so as to display the page represented by said stream and a computer communicating said stream between said data repository and said browser.
  • FIG. 1 a is an example of a computer environment for displaying a typical Web page design of the present invention.
  • FIG. 1 b is a typical Web page design as viewed on the visual display of a client computer.
  • FIG. 2 is an HTTP Get command for retrieving a file from a server.
  • FIG. 3 is an HTTP response header resulting from the HTTP Get command of FIG. 2 .
  • FIG. 4 is the HTML code defining the Web page design of FIG. 1 b.
  • FIGS. 5A-5E comprise a sequence of displays for the Web page design of FIG. 1 b as it undergoes progressive rendering.
  • FIG. 6 illustrates a sequence of browser requests and server responses for a progressively rendered Web page, such as shown in FIG. 1 b.
  • FIG. 7 is a block diagram of a serial data stream created from multiple, overlapping object requests serviced by a multitasking server.
  • FIG. 8 is a data diagram showing the structure of a serial data stream prepared in the data format of the present invention.
  • FIG. 9 is an example of a data definition entry of the present invention.
  • FIG. 10 is an example of a data packet of the present invention.
  • FIG. 11 is a block diagram of a publisher supporting the data format of the present invention.
  • FIG. 12 is a flowchart illustrating the process flow of a publisher of the present invention.
  • FIG. 13 is a block diagram of a browser supporting the data format of the present invention.
  • FIG. 14 is a flowchart illustrating the process flow of a browser unpacking a data stream encoded in the data format of the present invention.
  • the description comprises four sections: Object Retrieval Overview; the Jammer Data Format; Data Storage, Retrieval and Transfer Systems; and Summary.
  • the first section provides an overview of object retrieval in the current Web environment, the following two sections describe the Jammer data format and preferred embodiments for practicing the Jammer data format of the present invention, and the remaining section summarizes advantageous features of the present invention.
  • FIG. 1 a is an example of a computer environment for practicing the present invention.
  • a client 102 communicates with a server 106 by means of a network 104 , such as the World Wide Web.
  • the server 106 may include a gateway to a Wide Area Network (WAN) 108 having a plurality of Local Area Networks (LANs) 109 .
  • WAN Wide Area Network
  • LANs Local Area Networks
  • a browser 103 residing on a client 102 , displays a page design for a Jammer home page 100 (FIG. 1 b ) on the World Wide Web.
  • a user can view this page by entering, or selecting a link to, the URL 101 “http://jammer/jamhome.htm” in a browser, such as Microsoft Explorer or Netscape Navigator, executing on the user's computer.
  • the URL 101 (FIG. 1 b ) for the Jammer home page informs the browser to obtain the file jamhome.htm from the jammer server.
  • the file jamhome.htm is the base object defining the Jammer home page.
  • a browser 103 hierarchically retrieves objects comprising the page. The browser 103 first retrieves a base object having HTML defining the page. To obtain the base object, the browser 103 first opens a network connection to an HTTP server named jammer. Referring now to FIG. 2, the browser then sends an HTTP Get command 110 to the jammer server for a document named jamhome.htm. In response, the jammer server locates and sends the jamhome.htm document to the client 102 using the HTTP response format shown in FIG. 3 .
  • the HTTP response format includes a header 130 followed by object data 140 of the requested document.
  • the header 130 comprises items designed to provide the browser with information regarding the server, its capabilities, the status of the response and properties of the data returned.
  • the first header item 132 identifies the protocol version and status code. For example, data returned for jamhome.htm is in HTTP version 1.0 format and a “200 OK” return code indicates that the server carried out this request successfully.
  • the second header item 134 notifies the browser of the server type and identifies the data encoding used.
  • the jammer server is Microsoft-PWS95/2.0 compatible and transfers data encoded using Multipurpose Internet Mail Extensions (MIME) version 1.0.
  • the next header items 136 inform the browser of the content data type and the last modification date for the data. For example, jamhome.htm is HTML text and the last modification to the text occurred on Sunday, February 11.
  • the remaining header item 138 notifies the browser of the amount of data transferred.
  • the jamhome.htm file contains 1463 bytes of data.
  • the browser checks the HTTP header 130 to determine if its request was successful and to identify the received document type and the amount of object data The browser then removes the HTTP header 130 and places the object data 140 in a cache for quick access at a later time. The browser then identifies the object data type and begins to process the data. For example, the HTTP header 130 indicates that the object data 140 is of the type HTML. The browser thus invokes its HTML handler to display the text and to parse through the HTML object data 140 to find references to other objects on the page.
  • the HTML base object 141 for the Jammer home page 100 contains references to three embedded image objects stored on the jammer server: a background image 142 , an under construction image 144 and an Internet Studio image 146 . To assemble and display a page such as the Jammer home page 100 of FIG. 1, the browser must retrieve all objects referenced within the retrieved HTML base object.
  • the browser parses through the HTML base object 141 to locate references to embedded objects, it proceeds through the same steps to retrieve the embedded object data. For each reference to an embedded object, the browser first checks its cache to determine if the object data resides in cache. If so, the browser retrieves the object data from cache. Otherwise, the browser opens a connection to the server having the object data and transmits an HTTP Get command to retrieve the object data. The server in turn responds with an HTTP response header with information regarding the server, its capabilities, the status of the response and properties of the object data returned. Note that the embedded objects 142 , 144 , 146 referenced in FIG. 4 are of the GIF data type so the browser must invoke its GIF handler to process the object data.
  • the browser may also request multiple objects simultaneously. To do this, the browser issues multiple requests to the server, each request requiring a separate connection to the server. The browser then processes the data for each object as it arrives from the server. Using a technique called progressive rendering, the browser draws partial objects on the display as data for each of the multiple objects arrives from the server. The result is that a user views the page as the browser progressively assembles it. This is important since a progressive rendering browser maintains a user's interest despite delays caused by moving large objects over a low-bandwidth connection. Furthermore, the user can interact with those portions of the page already displayed without having to wait for the remaining portions to arrive.
  • FIGS. 5A-5E illustrate a sequence of displays 150 (FIG. 5 A), 152 (FIG.
  • the browser interprets HTML commands from the base object as it arrives from the server.
  • the browser Upon locating a reference to an embedded object such as image object 142 of FIG. 4, the browser dispatches a request for its object data.
  • HTML commands from the base object as it arrives from the server.
  • the browser Upon locating a reference to an embedded object such as image object 142 of FIG. 4, the browser dispatches a request for its object data.
  • FIG. 6 illustrates a sequence of overlapping transactions needed to progressively render the Jammer home page 100 of FIG. 1 .
  • the first transaction 160 a get request, initiates transfer of the base object, jamhome.htm, from the server 169 to the browser 168 .
  • the server 169 responds by serially transmitting HTML from the jamhome.htm file.
  • the browser 168 interprets the HTML, it finds a reference to the background image object 142 and initiates the next transaction 162 , a corresponding get request for the watermark.gif file.
  • the server 169 continues to serially transmit HTML from the jamhome.htm file while it locates and prepares the watermark.gif file for transfer.
  • the browser 168 finds a reference to the under construction image object 144 and initiates another transaction 163 , a get request for the underconstruction.gif file.
  • the server 169 continues to serially transmit HTML from the jamhome.htm file while it now locates and prepares both the watermark.gif and underconstruction.gif files for transfer.
  • the browser 168 now locates a reference to the Internet Studio image object 146 and initiates transaction 164 , a get request for the istudio.gif file.
  • the server 169 then transfers object data for watermark.gif 165 , underconstruction.gif 166 and istudio.gif 167 .
  • An HTTP server such as server 169 of FIG. 6, can receive multiple requests from a single browser, such as browser 168 , as well as multiple requests from multiple browsers.
  • the server 169 can handle multiple transactions simultaneously using the multitasking services provided by its operating system. These multitasking services allow a server to create and coordinate the execution of objects, or tasks.
  • the operating system allocates a small time slice for each task to run. Because these time slices are very small, the operating system switches between them rapidly to create the impression that multiple tasks are executing simultaneously. However, in reality, the operating system executes small portions of each task sequentially. Although the operating system executes the instructions for each task in the correct order, the actual instructions executed by the operating system across all of its tasks includes small portions of each task interleaved in an essentially random order.
  • Multitasking facilities differ between operating systems. For example, in the Unix operating system, a server spawns multiple processes (i.e., tasks), each to handle a single transaction. Under Windows 95 and Windows NT, both licensed by Microsoft, a server uses multiple threads, with each thread handling a transaction. For Unix, Windows 95 or Windows NT, each thread or process is responsible for retrieving the requested data from a disk, database, executable code or other process, formatting the data for transmission over the network, encoding the data according to the selected method, and sending it to a client's browser by writing the formatted, encoded data to the network connection opened by the client.
  • each thread or process is responsible for retrieving the requested data from a disk, database, executable code or other process, formatting the data for transmission over the network, encoding the data according to the selected method, and sending it to a client's browser by writing the formatted, encoded data to the network connection opened by the client.
  • a multitasking server transfers a serial data stream 179 over the Web for progressive rendering on a client.
  • the server creates a task to handle the transaction.
  • a HTML thread 171 retrieves, formats and transmits HTML data 172 while a background image thread 173 retrieves object data for a background image 174 , a first image thread 175 retrieves object data for a first image 176 and a second image thread 177 retrieves object data for a second image 178 .
  • these threads 171 , 173 , 175 , 177 executes during its time slice, it retrieves, formats and transmits a data fragment to the client.
  • the formatting operation includes insertion of an HTTP header in each of the data fragments resulting from execution of the thread 171 , 173 , 175 , 177 .
  • data fragments having small portions of the object data for each of these four objects are interspersed to form the serial data stream 179 .
  • the interspersed stream enables a progressively rendering browser to display the data fragments as they arrive.
  • a single thread such as the HTML thread 171
  • the order of the data packets in the serial data stream 179 is essentially random.
  • This is a result of multitasking as the initiation and completion of tasks to request data, allocate threads and return data from each thread is also essentially random.
  • the browser Upon receipt of the data stream 179 , the browser removes HTTP header information and progressively renders images from the data fragments of the respective object data transferred.
  • a preferred embodiment of the present invention is a flexible data format that enables the combination of object data from multiple objects comprising a set of related objects, such as a HTML page having embedded images, into a single data stream.
  • a browser can retrieve all of the objects in a single request by receiving and processing the data stream as if multiple requests had been made.
  • This flexible data format is advantageous because, unlike an HTTP extension or other protocol, it does not require changing existing HTTP infrastructure or protocols, such as firewalls and proxies. Likewise, the data format does not require changing how the browser works.
  • one can implement the data format by publishing data in the Jammer format on the server and unpacking a Jammer data stream using a proxy that understands the Jammer data format, and how to unpack it, on the client.
  • the data stream 190 includes a general purpose Stream Header 180 followed by a series of interleaved records of two types: Data Definition Entries and Data Packets.
  • the Stream Header 180 provides information about how the server packed the data into the data stream 190 . This includes the version number used to prepare the data stream 190 , as well as optional entries to define the number of objects in the data stream 190 and the total size of the data stream 190 .
  • the Stream Header 180 is extensible and includes ASCII text with one header per line, similar in format to an HTTP header.
  • a data definition entry 192 provides information about a single object that is present in the data stream 190 .
  • the data definition entry 192 is the first reference to an object having object data within the data stream 190 .
  • the data definition entry 192 includes information about the object, but no object data.
  • the information typically includes an object identifier 194 , such as its URL, a stream identifier number (SID) 196 to identify data packets belonging to the stream and other previously described HTTP header information 198 , such as language encoding, content length of data and the date of last modification.
  • a data packet 200 comprises a SID 202 , the number of bytes in the data packet 204 and object data 206 . Note that a data packet does not have to include all of the object data for an object. Thus, in the Jammer data format, the contents of an object may be distributed among a plurality of data packets.
  • data stream 190 includes data packets for an HTML base object 183 , 186 , a background image object 184 , a first image object 188 and a second image object 189 .
  • a data definition entry for an object must precede the first data packet for that object in the data stream 190 .
  • the data definition entry for an object must precede any references to that object in the data packets for any other objects in the stream.
  • data definition entries such as 181 , 182 , 185 , 187 (FIG. 8) for embedded images ( 142 , 144 , 146 ) in the stream must precede references to those embedded images in the HTML base object (FIG. 4 ).
  • the data definition entries facilitate unpacking of the data stream 190 because they define which objects are present in the data stream 190 and provide information about those objects. In this manner, data definition entries in the data stream 190 serve to notify a browser that unpacks the data stream of all objects present in the data stream. Moreover, the process of interleaving object data and data definition entries into a data stream 190 can occur either prior to or at the time the server sends data to the browser. Thus, for Web pages including a static set of objects, the server may create and store a data stream 190 prior to the time a browser requests the page.
  • the server creates and transmits a data stream 190 at the time of the browser request.
  • the data format of the present invention permits optimization of the sequence of object data records.
  • By modifying the sequence of object data records in the data stream 190 it is possible to control how a page is displayed on a client's browser.
  • a prior art browser waits for the data from the server and displays the data as it is received.
  • a browser of the present invention knows at the time an object is requested whether it is present in the data stream 190 because data definition entries for all objects present in the data stream 190 precede references to those objects.
  • the browser displays the data packets of the object as they are received instead of initiating a get request for the object from the server.
  • the present invention allows configuration of a data stream to have object data prioritized, so that the author of the page may control the order in which the browser actually receives object data. For example, the author of a page may desire that the browser display a particular advertising image first to ensure that a viewer sees the advertising before anything else. Similarly, the author may desire that a viewer sees all the embedded images on a page prior to the background image.
  • the Jammer data format permits the author to select the sequence of delivery and display of object data to create a desired effect on the viewer.
  • the process of unpacking the data stream 190 shown in FIG. 8 occurs as follows.
  • the server Upon request for the base object, the server returns the data stream 190 .
  • the browser receives the data stream 190 , it interprets the stream header 180 , recognizes that the data to follow is in the Jammer data format and then begins to unpack the data stream 190 .
  • a first data definition entry 181 follows the stream header 180 and provides the browser with information about the base object.
  • a second data definition entry 182 having information on a background image follows the first data definition entry 181 .
  • the browser then reads the first data record 183 and recognizes HTML data.
  • the browser invokes its HTML handler to parse and display data from the first data record 183 .
  • a second data record 184 follows in the data stream 190 . Using information from the second data definition entry 182 , the browser determines that data in the second data record 184 corresponds to the background image and reads this data into a cache 234 (FIG. 13 ).
  • the following record in the data stream 190 is a third data definition entry 185 .
  • the third data definition entry 185 provides the browser with information on a first image object for later use.
  • the next record in the data stream 190 is additional HTML data 186 from the base object.
  • the HTML handler finds a reference to the background image and issues a request for it.
  • the browser's cache manager receives the request for the background image data and returns the data for the background image it holds in cache for the second data record 184 .
  • the HTML handler finds a reference to the first image object while interpreting the additional HTML data 186 .
  • the browser dispatches a request for the first image object.
  • the remainder of the data stream 190 includes a data definition entry for a second image object 187 as well as object data for the first image 188 and the second 189 image.
  • Unpacking of the remaining records in data stream 190 proceeds by continuation of the method described above. Unpacking of the stream 190 terminates upon detection of an end of stream indicator 191 .
  • a publisher stores object data in a data repository in various formats including the Jammer data format.
  • a publisher 210 includes a stream configurator 212 , a template 214 , an interleavor 216 and a data definition generator 218 .
  • the stream configurator 212 parses through a page stored in a content storage 213 to identify references to objects and their locations within the page.
  • Content storage 213 includes objects having a variety of object data types, such as HTML, JPEG, WAV, GIF and BMP data.
  • the stream configurator 212 also receives information about the objects, such as the sequence in which the objects comprising the page are to be displayed, and produces a stream configuration template 214 .
  • the following pseudo-code illustrates an implementation of a template 214 of the present invention:
  • the InputFileName is the name of the HTML or other file that contains references to the other files.
  • This routine creates the Stream Configuration Template.
  • Each record has the following data:
  • ObjName the name of the object
  • ObjNum the object number (the first object is 1, the second 2, etc.)
  • ObjParent the object number of the object that references this object.
  • ObjOffset the number of bytes from the start of the parent object at which the reference occurred.
  • This first record is for the main object (i.e. the HTML file) that includes references to the other objects.
  • a skilled artisan may modify the template 214 pseudo-code to accommodate nested objects.
  • objects referenced by another object a parent object
  • the ObjParent field of the referenced object is set to the object number of the parent object.
  • the ObjOffset field of the referenced object is then set to the value of the offset in the parent object for which the reference was found.
  • a data definition generator 216 interprets the stream configuration template 214 to create a data definition entry for each object included in the data stream 190 .
  • An interleavor 218 also interprets the stream configuration template 214 to produce a data stream 190 by interleaving data definition entries provided by the data definition generator 216 with object data provided by content storage 219 .
  • the interleavor 218 uses the display sequence information to determine how to interleave the object data in the data stream 190 so as to ensure that the data definition entry for each object precedes any of its object data packets in the data stream 190 .
  • the interleavor 218 writes object data into the data stream 190 for those objects having a lower sequence number prior to the object data for those objects having a higher sequence number.
  • the following pseudo-code illustrates an implementation of a publisher 210 of the present invention:
  • This function takes as input a Stream Configuration Template. It reads in the various data files that template references (HTML, GIF, etc.) and produces the Jammed interleaved file.
  • template references HTTP, GIF, etc.
  • This routine reads records from the Stream Configuration Template.
  • Each record has the following data:
  • ObjName the name of the object
  • ObjNum the object number (the first object is 1, the second 2, etc.)
  • ObjParent the object number of the object that references this object.
  • ObjOffset the number of bytes from the start of the parent object at which the reference occurred.
  • the countOfBytesWritten is the counter of how many bytes of the HTML file have been written to the Jammed File.
  • the reason that we need this, is that we must write a data definition entry for a referenced object before we write the reference to that object in the HTML file. Since each record in the configuration template has the offset in the file of where the reference appears, and the records are in the order that they appeared in the HTML file, as we read each record, we can compare the offset with how much of the parent has been written. In this way, we can optimize when we write the data definition entries to the stream. Note that to support nested objects, that is objects whose ObjParent is greater than 1, we would need to maintain counters of how much of each of the parent objects had been written.
  • the activeObjectsList is the list of objects for which data definition entries have already been written to the stream, and for which we are currently writing data packets.
  • FIGS. 8, 11 and 12 illustrate the process flow of the publisher 210 (FIG. 11) of the present invention.
  • the publisher 210 prepares a stream header 180 to indicate that the data to follow is prepared using the data format of the present invention.
  • the publisher 210 proceeds to state 222 where it generates a stream configuration template 214 including information regarding objects defined by a page, their locations on the page and their sequence of display.
  • the publisher 210 prepares data definition entries 192 (FIG. 9) for each object defined by the page. Note that the publisher 210 may generate the template 214 and prepare the data definition entries 192 (FIG. 9) concurrently.
  • the publisher 210 interleaves object data packets 200 (FIG. 10) with data definition entries 192 (FIG. 9) according to the sequence defined by the stream configuration template 214 so as to form a data stream 190 . Lastly, the publisher 210 appends an end of stream indicator 191 to indicate the end of the data stream 190 .
  • FIG. 13 illustrates the structure of a browser 230 of one embodiment of the present invention.
  • the browser 230 of the present invention supports data transfer using the data format of the present invention as well as those of standard TCP and HTTP protocols.
  • the browser 230 includes an unpacker 232 to receive an incoming data stream, such as the data stream 190 (FIG. 8 ), from a server 106 (FIG. 1 a ).
  • the unpacker 232 communicates with an unpacked object cache (UOC) 234 to store object data received in the Janmuer data format.
  • UOC unpacked object cache
  • the unpacker 232 may communicate with a browser cache 235 to store received object data that is not encoded in the Jammer data format.
  • the browser cache 235 operates in the conventional manner of prior art browsers, such as Microsoft Internet Explorer and Netscape Navigator, which is well known.
  • the unpacker 232 identifies the data type of an object in the data stream 190 and invokes a data handler 236 to interpret the object data.
  • the data handler 236 is capable of interpreting a wide variety of data types, such as HTML, GIF, JPEG, WAV, ActiveX and Java applets.
  • the data handler 236 passes the interpreted object data to an object renderer 238 to render on a display 239 for viewing.
  • FIG. 14 illustrates the process by which a browser 230 (FIG. 13) unpacks a data stream 190 (FIG. 8) encoded in the data format of the present invention.
  • the unpacker 232 of the browser 230 processes a request for an object. For example, when the user points and clicks on a hyperlinked object on a Web page, the browser 230 issues a request, such as a URL, for the object.
  • the unpacker 232 may determine if the requested object data is in the Jammer format. If not, then the unpacker 232 issues a request to the server 106 (FIG. 1 a ) at state 244 to return the object data in the conventional format of the prior art.
  • the unpacker 232 checks the UOC 234 to determine if the requested object is present. If the object is not present in the UOC 234 , the unpacker 232 proceeds to state 248 to issue a request to the server 106 (FIG. 1 a ) to return the requested object data in the Jammer format. Otherwise, the UOC 234 returns the requested object. The unpacker 232 proceeds to state 250 to determine if the returned data is a data definition entry 192 (FIG. 9 ). If a data definition entry 192 (FIG. 9) is found, the unpacker 232 proceeds to state 252 to create an entry in the UOC 234 for the object corresponding to the data definition entry 192 (FIG. 9 ).
  • an object data packet 200 (FIG. 10) is encountered and the unpacker 232 proceeds to state 254 where it appends data from the data packet 200 (FIG. 10) to the entry in the UOC 234 corresponding to the object and forwards the data to the browser if it has been previously requested.
  • the browser 230 proceeds to state 256 where it checks for the end of stream indicator 191 (FIG. 8 ). If the indicator is found, the process terminates at state 258 . Otherwise, the process continues at state 240 .
  • the unpacker 232 when it receives a data stream 190 (FIG. 8 ), it examines the stream header 180 (FIG. 8) to determine if the data is encoded in the Jammer data format. If the data is encoded in the Jammer data format, the unpacker 232 proceeds to the first data definition entry, which identifies the base object. Since the base object is the object that the browser 230 initially requested, an entry is created for this object in the UOC 234 and data packets for this object will be sent to the browser. When the browser 230 encounters a reference to another object, it makes a request to the unpacker 232 for the object.
  • This funtion is what the Browser calls when it wants to get a particular URL. It is implemented by the Unpacker. It returns the data for the object specified by the URL objName.
  • record.type is a data definition entry
  • record.type is a data packet
  • the unpacker resides on a web server proxy in communication with the browser 168 (FIG. 6) and with the server 169 (FIG. 6 ).
  • the web server proxy intercepts communications between the browser 168 and the server 169 .
  • the web server proxy includes an unpacker and an unpacker object cache.
  • the unpacker examines the stream header 180 (FIG. 8) to determine if the data stream 190 (FIG. 8) from the server 169 is encoded in the Jammer data format. If so, the unpacker of the web server proxy unpacks the data stream 190 (FIG. 8) as described above and forwards the unpacked data to the browser 168 .
  • the data format of the present invention may be used with a conventional browser 168 of the prior art.
  • the data repository comprises a server 106 linked to the World Wide Web 104 portion of the Internet.
  • the server 106 communicates with storage devices for holding object data. These storage devices may communicate directly or indirectly with the server and may reside separately, on the server computer itself, within other servers communicating with the server or among a plurality of computers linked to the Internet. Storage devices include magnetic disk drives, electronic memory, optical disk drives, magnetic tape and other devices used to stored data.
  • the browser comprises a client 102 having a viewing device and the browser communicates with the server 106 through the World Wide Web 104 . Viewing devices for the client 102 include CRT monitors, flat panel displays, projection displays and other display devices.
  • a server 106 is any device capable of locating, storing, retrieving and transferring object data and a client 102 is any device capable of requesting, receiving and displaying object data.
  • Servers and clients can be stationary or mobile and may communicate using conventional land lines or wireless technologies, such as satellite, cellular or infrared.
  • the data repository comprises a server 106 linked to an intranet 104 .
  • the intranet 104 functions in a manner similar to that of the World Wide Web. However, for security reasons, the intranet 104 is not connected to the Internet.
  • the server 106 communicates with storage devices for holding object data. These storage devices may communicate directly or indirectly with the server and may reside separately, on the server itself, within other servers communicating with the server or among a plurality of computers linked to the intranet. Storage devices include magnetic disk drives, electronic memory, optical disk drives, magnetic tape and other devices used to store data.
  • the browser comprises a client 102 having a viewing device and the browser communicates with the server 106 through the intranet 104 .
  • Viewing devices for the client 102 include CRT monitors, flat panel displays, projection displays and other display devices.
  • a server 106 is any device capable of locating, storing, retrieving and transferring object data and a client 102 is any device capable of requesting, receiving and displaying object data.
  • Servers and clients can be stationary or mobile and may communicate using conventional land lines or wireless technologies, such as satellite, cellular or infrared.
  • the data repository comprises a network server 107 linked to a wide area network 108 or to a local area network 109 .
  • the network server 107 communicates with storage devices for holding object data. These storage devices may communicate directly or indirectly with the network server and may reside separately, on the network server itself, within other network servers communicating with the network server or among a plurality of computers linked to the wide or local area network. Storage devices include magnetic disk drives, electronic memory, optical disk drives, magnetic tape and other devices used to store data.
  • the browser comprises a network client 103 having a viewing device and the browser communicates with the network server 107 through the wide area 108 or the local area network 109 . Viewing devices for the network client 103 include CRT monitors, flat panel displays, projection displays and other display devices.
  • network servers 107 and clients 103 are typically computing devices linked into a network using specialized software for communication and data transfer, such as Microsoft Windows NT or Novell Netware.
  • Network servers 107 and clients 103 can be stationary or mobile and may communicate using conventional land lines or wireless technologies, such as satellite, cellular or infrared.
  • the data repository comprises a storage device 105 (FIG. 1 a ) communicating with a user computer 102 .
  • Storage devices may reside separately or within the user computer.
  • Storage devices include magnetic disk drives, electronic memory, optical disk drives such as CD-ROMs, magnetic tape and other devices used to store data.
  • the browser resides on the user computer 102 having a viewing device and the browser communicates with the storage device 105 through the user computer's processor. Viewing devices for the user computer 102 include CRT monitors, flat panel displays, projection displays and other display devices.
  • the data format of the present invention advantageously overcomes important limitations of available and anticipated alternatives.
  • the present invention substantially reduces the impact of latency on object retrieval by reducing the number of get and retrieve transactions to one.
  • planned HTTP improvements enable multiple transactions per connection
  • the protocol extension does not reduce the number of transactions required to get multiple objects needed to display a multimedia page.
  • server push a technique of enabling a server to interpret the HTML base object to find embedded objects, may reduce latency, but again does not reduce the number of transactions needed to transfer and display the page. Instead, server push merely transfers the burden of multiple object retrieval from the browser to the server.
  • server push does not permit an author to optimize the sequence of object data transfers.
  • Another proposed alternative, multi-part MIME permits assembly of multiple objects into a single data stream. However, in contrast to the present invention, multi-part MIME does not permit interleaving of object data, nor does it permit optimization of how objects and object parts are delivered, in a predetermined order.
  • the data format of the present invention advantageously reduces server loading by eliminating the need for superfluous transactions. For example, a page having 15 objects currently requires 15 transactions to transfer. Thus, a server capable of handling 150 transactions/second can only deliver 10 pages/sec. In contrast, the present invention typically results in the transfer of a single larger data stream and this may degrade server performance slightly. Thus, even if the server is only capable of handling 100 transactions/second using the data format of the present invention, it can still deliver 100 pages/sec. Hence, a user practicing the present invention realizes a tenfold improvement over existing techniques.

Abstract

In a computer environment, a new storage and delivery data format for multimedia object sets increases performance and improves the user experience by reducing the transactions needed to retrieve a set of n objects from n to 1. The object data is interleaved with data definition entries identifying respective object data into a data format comprising a single stream for storage and/or delivery. The data format eliminates the need for multiple, asynchronous transactions thus reducing latency in the data transfer process. Moreover, the data format allows for optimization of how the object data is prioritized and interleaved to achieve desired performance objectives upon delivery of the multimedia objects.

Description

BACKGRUOND OF THE INVENTION
1. Field of the Invention
The present invention relates to multimedia systems, and more particularly, to a storage and delivery system for multimedia objects in a computer environment, such as the World Wide Web.
2. Description of Related Technology
The World Wide Web (Web) is part of a global computer network known as the Internet. Scientists and academicians initially developed and used the Internet to share information and collaborate. The Web functions as an object based multimedia system. It allows for the creation, storage and delivery of multimedia objects. Recently, on-line service providers, such as Microsoft Network, CompuServe, Prodigy and America Online, have linked to the Web. This enables their customers to access a variety of information and communication services available from independent content providers and other Web users. For example, a typical customer can access electronic mail, news services, weather services, bulletin board services and travel services on the Web.
Independent content providers typically create pages to communicate information and services they provide for their Web customers. A customer views a page on a computer screen using a Web browser, such as Microsoft Explorer or Netscape Navigator, installed on the computer. The structure and appearance of a Web page are defined using HyperText Markup Language (HTML). The browser retrieves and interprets the HTML defining a page to display it on a user's computer screen. A typical Web page may have multiple objects including HTML text, a background image, icons, audio and bitmaps for several images.
A Web browser accesses a page when a user enters a Universal Resource Locator (URL) or selects a link to a page's URL using a pointing device such as a mouse or glide pad. The browser retrieves the page by first checking its cache of previously retrieved objects. In this context, a cache is a collection of previously requested objects that a browser maintains in local storage on the user's computer. If the requested object data exists in cache, the browser fetches the object from the cache. Otherwise, the browser must retrieve the object from a remote computer over the Web. Data transfer over the Web is a very slow process when compared to retrieving the same object from a cache on the local disk of the user's computer.
Data transfer speed is basically the result of the bandwidth and latency of a connection. Bandwidth is the speed with which data moves over a connection. Improved bandwidth results by increased carrier capacity and/or increased transmission speed over the carrier. For example, a user can increase the bandwidth of a Web connection over an analog phone line carrier by increasing the modem transmission speed from 14,400 bits per second to 28,800 bits per second. A user may similarly increase the bandwidth of a Web connection by using a digital phone line carrier, such as an Integrated Services Digital Network (ISDN) line, capable of carrying two data channels each at 64,000 bits per second. Latency refers to the delay between the time a request for data is made and the time that the data is received. It results from the logistics of establishing and maintaining a connection over a carrier involving various types of handshakes needed to initiate and complete data transfer. Thus, latency is usually independent of the size of the data being sent over the carrier.
Data transfers over the Web conform to the HyperText Transfer Protocol (HTTP). HTTP manages connections between those who request information, clients, and those who provide information, servers. In the HTTP model, a client establishes a connection to a remote server and then issues a request. The server processes the request, returns a response and closes the connection. Importantly, the HTTP model only permits a single transaction per connection. In addition, HTTP uses the Transmission Control Protocol (TCP) as a transport layer. A transport layer is a mechanism for the transfer of data between clients and servers that ensures delivery of in sequence, error-free data with no losses or duplications. TCP establishes connections using a three-part handshake as follows: the client sends a connection request, the server responds and the client acknowledges the response, at which time the client can also send data.
Certain design features of HTTP interact poorly with TCP causing problems with data transfer performance. Opening a connection to a server creates a latency of at least two round trips over the network because a client must wait for a server to send its connection response. Similarly, TCP uses a mechanism called slow start to negotiate the data transfer speed over a connection. To prevent overrunning a receiving computer, slow start initiates transfer at a low data transfer rate and progressively increases the data transfer rate as more chunks of data are received successfully. When transferring large amounts of data over a single connection, the impact of slow start and connection latency are minimal. However, when transferring small amounts of data over a large number of connections, the impact of slow start and latency from multiple connections is devastating.
In the early days of the Web, cumulative delays from slow start and connection latency were tolerable because early Web pages included a single HTML page with one or two images. However, the complexity of Web pages is increasing. Modern Web page designs include more objects, such as bitmaps, audio, ActiveX controls and Java Applets, and thus HTTP requires numerous transactions to transfer each page over the Web. Thus, the cumulative latency due to TCP handshaking and slow start becomes a substantial performance limitation. Moreover, a HTML page includes the names of referenced objects and a browser cannot request these referenced objects until it has retrieved and interpreted the HTML defining the page. Thus, the latency of retrieving the HTML defining a page can create a cascade of delays in requesting embedded objects. Cascaded round trip delays from opening multiple server connections to retrieve embedded objects and subsequent slow start delays often result in situations where users can do no useful work because the system is waiting instead of transmitting data.
Lastly, numerous HTTP transactions severely impact the data transfer performance of high-speed satellite and cable modem systems. In these systems, the transmission speed from a server to a client, the “downstream” connection, is substantially higher than the transmission speed from client to server, the “upstream” connection. For example, wireless satellite links and cable modems are capable of transmitting data “downstream” at 10,000,000 bits/second rate while transmission of “upstream” browser requests often occurs at a rate of 768,000 bits/second (a “fractional” T1 connection, about 13 times slower). For a Web page having numerous objects, the slow speed “upstream” request connection limits data transfer performance due to the response latency of multiple HTTP requests for these objects.
SUMMARY OF THE INVENTION
The present invention addresses these performance limitations by improving the efficiency of object retrieval and transfer in multimedia computer environments. In contrast to the multiple transactions currently required to retrieve multiple objects in HTTP, the present invention reduces the number of transactions to retrieve a set of n objects from n to 1, thereby substantially reducing the latency due to slow start and cascaded round trip delays from opening multiple server connections. This increases delivery performance and improves the user experience by substantially reducing the delays in the transfer and rendering of images on the user's display.
The present invention includes data for multiple objects in a single data stream in an optimized interleaved format. Object data is interleaved with data definition entries identifying respective object data into a data format comprising a single stream for storage and delivery. The data format eliminates the need for multiple, asynchronous transactions. Moreover, the data format enables one to customize and optimize how the object data is prioritized and interleaved to achieve a desired effect on the viewer upon delivery of the multimedia data.
One aspect of the present invention includes a data format for storing, transferring and retrieving, in a computer environment having a storage, a stream of objects comprising object data packets stored within the storage for each object in the stream and at least one data definition entry corresponding to each object in the stream, wherein said at least one data definition entry is interleaved with said object data packets such that a data definition entry corresponding to one of the objects in the stream precedes any object data packets of said one object in the stream.
Another aspect of the present invention includes a system for transmitting a page comprising a data repository for a stream representing the page, wherein said stream comprises object data packets interleaved with data definition entries, a browser assembling said object data packets with reference to said data definition entries so as to display the page represented by said stream and a network communicating said stream between said data repository and said browser.
Lastly, another aspect of the present invention includes a system for transmitting a page comprising a data repository for a stream representing the page, wherein said stream comprises object data packets interleaved with data definition entries, a browser assembling said object data packets with reference to said data definition entries so as to display the page represented by said stream and a computer communicating said stream between said data repository and said browser.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1a is an example of a computer environment for displaying a typical Web page design of the present invention.
FIG. 1b is a typical Web page design as viewed on the visual display of a client computer.
FIG. 2 is an HTTP Get command for retrieving a file from a server.
FIG. 3 is an HTTP response header resulting from the HTTP Get command of FIG. 2.
FIG. 4 is the HTML code defining the Web page design of FIG. 1b.
FIGS. 5A-5E comprise a sequence of displays for the Web page design of FIG. 1b as it undergoes progressive rendering.
FIG. 6 illustrates a sequence of browser requests and server responses for a progressively rendered Web page, such as shown in FIG. 1b.
FIG. 7 is a block diagram of a serial data stream created from multiple, overlapping object requests serviced by a multitasking server.
FIG. 8 is a data diagram showing the structure of a serial data stream prepared in the data format of the present invention.
FIG. 9 is an example of a data definition entry of the present invention.
FIG. 10 is an example of a data packet of the present invention.
FIG. 11 is a block diagram of a publisher supporting the data format of the present invention.
FIG. 12 is a flowchart illustrating the process flow of a publisher of the present invention.
FIG. 13 is a block diagram of a browser supporting the data format of the present invention.
FIG. 14 is a flowchart illustrating the process flow of a browser unpacking a data stream encoded in the data format of the present invention.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
The following detailed description of the preferred embodiments presents a description of certain specific embodiments to assist in understanding the claims. However, one may practice the present invention in a multitude of different embodiments as defined and covered by the claims.
For convenience, the description comprises four sections: Object Retrieval Overview; the Jammer Data Format; Data Storage, Retrieval and Transfer Systems; and Summary. The first section provides an overview of object retrieval in the current Web environment, the following two sections describe the Jammer data format and preferred embodiments for practicing the Jammer data format of the present invention, and the remaining section summarizes advantageous features of the present invention.
I. Object Retrieval Overview
FIG. 1a is an example of a computer environment for practicing the present invention. A client 102 communicates with a server 106 by means of a network 104, such as the World Wide Web. The server 106 may include a gateway to a Wide Area Network (WAN) 108 having a plurality of Local Area Networks (LANs) 109. A browser 103, residing on a client 102, displays a page design for a Jammer home page 100 (FIG. 1b) on the World Wide Web. A user can view this page by entering, or selecting a link to, the URL 101 “http://jammer/jamhome.htm” in a browser, such as Microsoft Explorer or Netscape Navigator, executing on the user's computer. The URL 101 (FIG. 1b) for the Jammer home page informs the browser to obtain the file jamhome.htm from the jammer server. The file jamhome.htm is the base object defining the Jammer home page. To display this page, a browser 103 hierarchically retrieves objects comprising the page. The browser 103 first retrieves a base object having HTML defining the page. To obtain the base object, the browser 103 first opens a network connection to an HTTP server named jammer. Referring now to FIG. 2, the browser then sends an HTTP Get command 110 to the jammer server for a document named jamhome.htm. In response, the jammer server locates and sends the jamhome.htm document to the client 102 using the HTTP response format shown in FIG. 3. The HTTP response format includes a header 130 followed by object data 140 of the requested document.
Referring to FIG. 3, the header 130 comprises items designed to provide the browser with information regarding the server, its capabilities, the status of the response and properties of the data returned. The first header item 132 identifies the protocol version and status code. For example, data returned for jamhome.htm is in HTTP version 1.0 format and a “200 OK” return code indicates that the server carried out this request successfully. The second header item 134 notifies the browser of the server type and identifies the data encoding used. For example, the jammer server is Microsoft-PWS95/2.0 compatible and transfers data encoded using Multipurpose Internet Mail Extensions (MIME) version 1.0. The next header items 136 inform the browser of the content data type and the last modification date for the data. For example, jamhome.htm is HTML text and the last modification to the text occurred on Sunday, February 11. Finally, the remaining header item 138 notifies the browser of the amount of data transferred. For example, the jamhome.htm file contains 1463 bytes of data.
The browser checks the HTTP header 130 to determine if its request was successful and to identify the received document type and the amount of object data The browser then removes the HTTP header 130 and places the object data 140 in a cache for quick access at a later time. The browser then identifies the object data type and begins to process the data. For example, the HTTP header 130 indicates that the object data 140 is of the type HTML. The browser thus invokes its HTML handler to display the text and to parse through the HTML object data 140 to find references to other objects on the page. Referring now to FIG. 4, the HTML base object 141 for the Jammer home page 100 contains references to three embedded image objects stored on the jammer server: a background image 142, an under construction image 144 and an Internet Studio image 146. To assemble and display a page such as the Jammer home page 100 of FIG. 1, the browser must retrieve all objects referenced within the retrieved HTML base object.
As the browser parses through the HTML base object 141 to locate references to embedded objects, it proceeds through the same steps to retrieve the embedded object data. For each reference to an embedded object, the browser first checks its cache to determine if the object data resides in cache. If so, the browser retrieves the object data from cache. Otherwise, the browser opens a connection to the server having the object data and transmits an HTTP Get command to retrieve the object data. The server in turn responds with an HTTP response header with information regarding the server, its capabilities, the status of the response and properties of the object data returned. Note that the embedded objects 142, 144, 146 referenced in FIG. 4 are of the GIF data type so the browser must invoke its GIF handler to process the object data.
The browser may also request multiple objects simultaneously. To do this, the browser issues multiple requests to the server, each request requiring a separate connection to the server. The browser then processes the data for each object as it arrives from the server. Using a technique called progressive rendering, the browser draws partial objects on the display as data for each of the multiple objects arrives from the server. The result is that a user views the page as the browser progressively assembles it. This is important since a progressive rendering browser maintains a user's interest despite delays caused by moving large objects over a low-bandwidth connection. Furthermore, the user can interact with those portions of the page already displayed without having to wait for the remaining portions to arrive. FIGS. 5A-5E illustrate a sequence of displays 150 (FIG. 5A), 152 (FIG. 5B), 154 (FIG. 5C), 156 (FIG. 5D), 158 (FIG. 5E) for the Jammer home page 100 of FIG. 1 as it undergoes progressive rendering. To support progressive rendering, the browser interprets HTML commands from the base object as it arrives from the server. Upon locating a reference to an embedded object such as image object 142 of FIG. 4, the browser dispatches a request for its object data. Thus, it is possible to have multiple overlapping object data transfers from the server to the browser while the browser is still parsing and interpreting HTML from the base object defining the page.
FIG. 6 illustrates a sequence of overlapping transactions needed to progressively render the Jammer home page 100 of FIG. 1. The first transaction 160, a get request, initiates transfer of the base object, jamhome.htm, from the server 169 to the browser 168. In the next transaction 161, the server 169 responds by serially transmitting HTML from the jamhome.htm file. As the browser 168 interprets the HTML, it finds a reference to the background image object 142 and initiates the next transaction 162, a corresponding get request for the watermark.gif file. The server 169 continues to serially transmit HTML from the jamhome.htm file while it locates and prepares the watermark.gif file for transfer. The browser 168 then finds a reference to the under construction image object 144 and initiates another transaction 163, a get request for the underconstruction.gif file. The server 169 continues to serially transmit HTML from the jamhome.htm file while it now locates and prepares both the watermark.gif and underconstruction.gif files for transfer. The browser 168 now locates a reference to the Internet Studio image object 146 and initiates transaction 164, a get request for the istudio.gif file. The server 169 then transfers object data for watermark.gif 165, underconstruction.gif 166 and istudio.gif 167.
An HTTP server, such as server 169 of FIG. 6, can receive multiple requests from a single browser, such as browser 168, as well as multiple requests from multiple browsers. The server 169 can handle multiple transactions simultaneously using the multitasking services provided by its operating system. These multitasking services allow a server to create and coordinate the execution of objects, or tasks. The operating system allocates a small time slice for each task to run. Because these time slices are very small, the operating system switches between them rapidly to create the impression that multiple tasks are executing simultaneously. However, in reality, the operating system executes small portions of each task sequentially. Although the operating system executes the instructions for each task in the correct order, the actual instructions executed by the operating system across all of its tasks includes small portions of each task interleaved in an essentially random order. Multitasking facilities differ between operating systems. For example, in the Unix operating system, a server spawns multiple processes (i.e., tasks), each to handle a single transaction. Under Windows 95 and Windows NT, both licensed by Microsoft, a server uses multiple threads, with each thread handling a transaction. For Unix, Windows 95 or Windows NT, each thread or process is responsible for retrieving the requested data from a disk, database, executable code or other process, formatting the data for transmission over the network, encoding the data according to the selected method, and sending it to a client's browser by writing the formatted, encoded data to the network connection opened by the client.
Referring now to FIG. 7, a multitasking server transfers a serial data stream 179 over the Web for progressive rendering on a client. Each time the browser issues a request to the server to retrieve an object, the server creates a task to handle the transaction. As shown in FIG. 7, a HTML thread 171 retrieves, formats and transmits HTML data 172 while a background image thread 173 retrieves object data for a background image 174, a first image thread 175 retrieves object data for a first image 176 and a second image thread 177 retrieves object data for a second image 178. As each of these threads 171, 173, 175, 177 executes during its time slice, it retrieves, formats and transmits a data fragment to the client. Note that the formatting operation includes insertion of an HTTP header in each of the data fragments resulting from execution of the thread 171, 173, 175, 177. Due to time sliced multitasking, data fragments having small portions of the object data for each of these four objects are interspersed to form the serial data stream 179. The interspersed stream enables a progressively rendering browser to display the data fragments as they arrive. Thus, although a single thread, such as the HTML thread 171, transmits data packets in the correct order, the order of the data packets in the serial data stream 179 is essentially random. This is a result of multitasking as the initiation and completion of tasks to request data, allocate threads and return data from each thread is also essentially random. Moreover, it is not possible to arrange delivery of data fragments in a selected order in these multitasking systems. Upon receipt of the data stream 179, the browser removes HTTP header information and progressively renders images from the data fragments of the respective object data transferred.
II. Jammer Data Format
A preferred embodiment of the present invention is a flexible data format that enables the combination of object data from multiple objects comprising a set of related objects, such as a HTML page having embedded images, into a single data stream. In this manner, a browser can retrieve all of the objects in a single request by receiving and processing the data stream as if multiple requests had been made. This flexible data format is advantageous because, unlike an HTTP extension or other protocol, it does not require changing existing HTTP infrastructure or protocols, such as firewalls and proxies. Likewise, the data format does not require changing how the browser works. Thus, one can implement the data format by publishing data in the Jammer format on the server and unpacking a Jammer data stream using a proxy that understands the Jammer data format, and how to unpack it, on the client.
Referring now to FIG. 8, a data stream 190 prepared according to an embodiment of the present invention is illustrated. The data stream 190 includes a general purpose Stream Header 180 followed by a series of interleaved records of two types: Data Definition Entries and Data Packets. The Stream Header 180 provides information about how the server packed the data into the data stream 190. This includes the version number used to prepare the data stream 190, as well as optional entries to define the number of objects in the data stream 190 and the total size of the data stream 190. The Stream Header 180 is extensible and includes ASCII text with one header per line, similar in format to an HTTP header.
As shown in FIG. 9, a data definition entry 192 provides information about a single object that is present in the data stream 190. The data definition entry 192 is the first reference to an object having object data within the data stream 190. The data definition entry 192 includes information about the object, but no object data. The information typically includes an object identifier 194, such as its URL, a stream identifier number (SID) 196 to identify data packets belonging to the stream and other previously described HTTP header information 198, such as language encoding, content length of data and the date of last modification. As shown in FIG. 10, a data packet 200 comprises a SID 202, the number of bytes in the data packet 204 and object data 206. Note that a data packet does not have to include all of the object data for an object. Thus, in the Jammer data format, the contents of an object may be distributed among a plurality of data packets.
Referring back to FIG. 8, data stream 190 includes data packets for an HTML base object 183, 186, a background image object 184, a first image object 188 and a second image object 189. A data definition entry for an object must precede the first data packet for that object in the data stream 190. Additionally, the data definition entry for an object must precede any references to that object in the data packets for any other objects in the stream. For example, data definition entries, such as 181, 182, 185, 187 (FIG. 8) for embedded images (142, 144, 146) in the stream must precede references to those embedded images in the HTML base object (FIG. 4). The data definition entries facilitate unpacking of the data stream 190 because they define which objects are present in the data stream 190 and provide information about those objects. In this manner, data definition entries in the data stream 190 serve to notify a browser that unpacks the data stream of all objects present in the data stream. Moreover, the process of interleaving object data and data definition entries into a data stream 190 can occur either prior to or at the time the server sends data to the browser. Thus, for Web pages including a static set of objects, the server may create and store a data stream 190 prior to the time a browser requests the page. Similarly, for Web pages including objects having frequently changing data, such as an object having the results of a database query, or for which an object set is dynamically created at the time of a browser request, the server creates and transmits a data stream 190 at the time of the browser request.
Furthermore, the data format of the present invention permits optimization of the sequence of object data records. By modifying the sequence of object data records in the data stream 190, it is possible to control how a page is displayed on a client's browser. As discussed previously, there is no particular order to the display of data fragments in current browsers supporting progressive rendering. When a request is made for an image, for example, a prior art browser waits for the data from the server and displays the data as it is received. In contrast, a browser of the present invention knows at the time an object is requested whether it is present in the data stream 190 because data definition entries for all objects present in the data stream 190 precede references to those objects. Thus, when an object is being requested, if a browser of the present invention has already determined from the data definition entries that the object is present in the stream, the browser displays the data packets of the object as they are received instead of initiating a get request for the object from the server. The present invention allows configuration of a data stream to have object data prioritized, so that the author of the page may control the order in which the browser actually receives object data. For example, the author of a page may desire that the browser display a particular advertising image first to ensure that a viewer sees the advertising before anything else. Similarly, the author may desire that a viewer sees all the embedded images on a page prior to the background image. The Jammer data format permits the author to select the sequence of delivery and display of object data to create a desired effect on the viewer.
The process of unpacking the data stream 190 shown in FIG. 8 occurs as follows. Upon request for the base object, the server returns the data stream 190. As the browser receives the data stream 190, it interprets the stream header 180, recognizes that the data to follow is in the Jammer data format and then begins to unpack the data stream 190. A first data definition entry 181 follows the stream header 180 and provides the browser with information about the base object. A second data definition entry 182 having information on a background image follows the first data definition entry 181. The browser then reads the first data record 183 and recognizes HTML data. The browser invokes its HTML handler to parse and display data from the first data record 183. A second data record 184 follows in the data stream 190. Using information from the second data definition entry 182, the browser determines that data in the second data record 184 corresponds to the background image and reads this data into a cache 234 (FIG. 13).
Referring again to FIG. 8, the following record in the data stream 190 is a third data definition entry 185. The third data definition entry 185 provides the browser with information on a first image object for later use. The next record in the data stream 190 is additional HTML data 186 from the base object. In parsing this additional HTML data 186, the HTML handler finds a reference to the background image and issues a request for it. The browser's cache manager receives the request for the background image data and returns the data for the background image it holds in cache for the second data record 184. In addition, the HTML handler finds a reference to the first image object while interpreting the additional HTML data 186. As no object data for the first image object exists in the data stream 190 up to this point, the browser dispatches a request for the first image object. The remainder of the data stream 190 includes a data definition entry for a second image object 187 as well as object data for the first image 188 and the second 189 image. Unpacking of the remaining records in data stream 190 proceeds by continuation of the method described above. Unpacking of the stream 190 terminates upon detection of an end of stream indicator 191.
III. Data Storage, Retrieval and Transfer Systems
The Jammer data format is useful in a variety of computer environments having data storage. In a preferred embodiment, a publisher stores object data in a data repository in various formats including the Jammer data format. As shown in FIG. 11, a publisher 210 includes a stream configurator 212, a template 214, an interleavor 216 and a data definition generator 218. The stream configurator 212 parses through a page stored in a content storage 213 to identify references to objects and their locations within the page. Content storage 213 includes objects having a variety of object data types, such as HTML, JPEG, WAV, GIF and BMP data. The stream configurator 212 also receives information about the objects, such as the sequence in which the objects comprising the page are to be displayed, and produces a stream configuration template 214. The following pseudo-code illustrates an implementation of a template 214 of the present invention:
Function MakeStreamConfigurationTemplate (InputFileName)
The InputFileName is the name of the HTML or other file that contains references to the other files.
This routine creates the Stream Configuration Template. Each record has the following data:
ObjName—the name of the object
ObjNum—the object number (the first object is 1, the second 2, etc.)
ObjParent—the object number of the object that references this object.
ObjOffset—the number of bytes from the start of the parent object at which the reference occurred.
User supplied display sequence information. This provides information to the Interleavor for the order in which to display the objects.
Write a record for the Input File to the template file.
Set ObjName to InputFile,
Set ObjNum to 1,
Set ObjParent to 0 (since this is the root object),
Set ObjOffset to 0.
This first record is for the main object (i.e. the HTML file) that includes references to the other objects.
Set ObjectCount to 2
Read the HTML file, and find all of the references to objects, such as gifs, Java Applets,
ActiveX controls that it contains.
For each object that you find
Write a record for the object to the template file.
Set ObjName to URL of the object,
Set ObjNum to ObjectCount,
Set ObjParent to 1,
Set ObjOffset to the offset in bytes that the reference was found in the HTML file.
Write Display ordering information
Set ObjectCount=ObjectCount+1
End
A skilled artisan may modify the template 214 pseudo-code to accommodate nested objects. For example, in the template 214, objects referenced by another object, a parent object, appear after the parent object. The ObjParent field of the referenced object is set to the object number of the parent object. In addition, the ObjOffset field of the referenced object is then set to the value of the offset in the parent object for which the reference was found.
A data definition generator 216 interprets the stream configuration template 214 to create a data definition entry for each object included in the data stream 190. An interleavor 218 also interprets the stream configuration template 214 to produce a data stream 190 by interleaving data definition entries provided by the data definition generator 216 with object data provided by content storage 219. The interleavor 218 uses the display sequence information to determine how to interleave the object data in the data stream 190 so as to ensure that the data definition entry for each object precedes any of its object data packets in the data stream 190. Thus, the interleavor 218 writes object data into the data stream 190 for those objects having a lower sequence number prior to the object data for those objects having a higher sequence number. The following pseudo-code illustrates an implementation of a publisher 210 of the present invention:
Function MakeJammedStream(StreamConfigurationTemplate)
This function takes as input a Stream Configuration Template. It reads in the various data files that template references (HTML, GIF, etc.) and produces the Jammed interleaved file.
This routine reads records from the Stream Configuration Template.
Each record has the following data:
ObjName—the name of the object
ObjNum—the object number (the first object is 1, the second 2, etc.)
ObjParent—the object number of the object that references this object.
ObjOffset—the number of bytes from the start of the parent object at which the reference occurred.
User supplied display sequence information. This provides information to the Interleavor for the order in which to display the objects.
Set countOfBytesWritten to 0
The countOfBytesWritten is the counter of how many bytes of the HTML file have been written to the Jammed File. The reason that we need this, is that we must write a data definition entry for a referenced object before we write the reference to that object in the HTML file. Since each record in the configuration template has the offset in the file of where the reference appears, and the records are in the order that they appeared in the HTML file, as we read each record, we can compare the offset with how much of the parent has been written. In this way, we can optimize when we write the data definition entries to the stream. Note that to support nested objects, that is objects whose ObjParent is greater than 1, we would need to maintain counters of how much of each of the parent objects had been written.
Read the first record from the StreamConfigurationTemplate Call the DataDefinitionGenerator to create a data definition entry for the first record.
Add the first record to the activeObjectsList
the activeObjectsList is the list of objects for which data definition entries have already been written to the stream, and for which we are currently writing data packets.
While there are still records in the StreamConfigurationTemplate
Read a record from the template, and set it to currentRecord.
If countOfBytesWritten is less than currentRecord.ObjOffset
While countOfBytesWritten is less than currentRecord.ObjOffset
Write out data packets for each object in the activeObjectsList.
If we write out data from the first object, add the bytes written to countOfBytesWritten
if we finish writing data for any of the objects, remove them from the activeObjectsList
end While
end if
Call the DataDefinitionGenerator to create a data definition entry for currentRecord.
Add currentRecord to the activeObjectsList before all objects with a lower priority as determined by the user supplied ordering information.
end While
While activeObjectsList contains 1 or more objects
Write out data packets for each object in the activeObjectsList.
if we finish writing data for any of the objects, remove them from the activeObjectsList
end While
End
Reference is now principally made to FIGS. 8, 11 and 12 which illustrate the process flow of the publisher 210 (FIG. 11) of the present invention. At state 220, the publisher 210 prepares a stream header 180 to indicate that the data to follow is prepared using the data format of the present invention. The publisher 210 proceeds to state 222 where it generates a stream configuration template 214 including information regarding objects defined by a page, their locations on the page and their sequence of display. At state 224, the publisher 210 prepares data definition entries 192 (FIG. 9) for each object defined by the page. Note that the publisher 210 may generate the template 214 and prepare the data definition entries 192 (FIG. 9) concurrently. At state 226, the publisher 210 interleaves object data packets 200 (FIG. 10) with data definition entries 192 (FIG. 9) according to the sequence defined by the stream configuration template 214 so as to form a data stream 190. Lastly, the publisher 210 appends an end of stream indicator 191 to indicate the end of the data stream 190.
FIG. 13 illustrates the structure of a browser 230 of one embodiment of the present invention. In contrast to prior art browsers, the browser 230 of the present invention supports data transfer using the data format of the present invention as well as those of standard TCP and HTTP protocols. The browser 230 includes an unpacker 232 to receive an incoming data stream, such as the data stream 190 (FIG. 8), from a server 106 (FIG. 1a). The unpacker 232 communicates with an unpacked object cache (UOC) 234 to store object data received in the Janmuer data format. In addition, the unpacker 232 may communicate with a browser cache 235 to store received object data that is not encoded in the Jammer data format. The browser cache 235 operates in the conventional manner of prior art browsers, such as Microsoft Internet Explorer and Netscape Navigator, which is well known. The unpacker 232 identifies the data type of an object in the data stream 190 and invokes a data handler 236 to interpret the object data. The data handler 236 is capable of interpreting a wide variety of data types, such as HTML, GIF, JPEG, WAV, ActiveX and Java applets. The data handler 236 in turn passes the interpreted object data to an object renderer 238 to render on a display 239 for viewing.
In conjunction with FIG. 13, FIG. 14 illustrates the process by which a browser 230 (FIG. 13) unpacks a data stream 190 (FIG. 8) encoded in the data format of the present invention. At state 240, the unpacker 232 of the browser 230 processes a request for an object. For example, when the user points and clicks on a hyperlinked object on a Web page, the browser 230 issues a request, such as a URL, for the object. At state 242, the unpacker 232 may determine if the requested object data is in the Jammer format. If not, then the unpacker 232 issues a request to the server 106 (FIG. 1a) at state 244 to return the object data in the conventional format of the prior art. Otherwise, at state 246, the unpacker 232 checks the UOC 234 to determine if the requested object is present. If the object is not present in the UOC 234, the unpacker 232 proceeds to state 248 to issue a request to the server 106 (FIG. 1a) to return the requested object data in the Jammer format. Otherwise, the UOC 234 returns the requested object. The unpacker 232 proceeds to state 250 to determine if the returned data is a data definition entry 192 (FIG. 9). If a data definition entry 192 (FIG. 9) is found, the unpacker 232 proceeds to state 252 to create an entry in the UOC 234 for the object corresponding to the data definition entry 192 (FIG. 9). Otherwise, an object data packet 200 (FIG. 10) is encountered and the unpacker 232 proceeds to state 254 where it appends data from the data packet 200 (FIG. 10) to the entry in the UOC 234 corresponding to the object and forwards the data to the browser if it has been previously requested. Lastly, the browser 230 proceeds to state 256 where it checks for the end of stream indicator 191 (FIG. 8). If the indicator is found, the process terminates at state 258. Otherwise, the process continues at state 240.
Now referring principally to FIG. 13, when the unpacker 232 receives a data stream 190 (FIG. 8), it examines the stream header 180 (FIG. 8) to determine if the data is encoded in the Jammer data format. If the data is encoded in the Jammer data format, the unpacker 232 proceeds to the first data definition entry, which identifies the base object. Since the base object is the object that the browser 230 initially requested, an entry is created for this object in the UOC 234 and data packets for this object will be sent to the browser. When the browser 230 encounters a reference to another object, it makes a request to the unpacker 232 for the object. Because a data definition entry for an object must precede any references to the object in the data stream 190 (FIG. 8), when the unpacker 232 searches the UOC 234, the object has an entry in the UOC 234, which returns the found object to the browser 230 immediately. Otherwise, the unpacker 232 searches the browser cache 235 to locate the requested object. If the unpacker 232 is unable to locate the requested object within the UOC 234 or the browser cache 235, the unpacker 232 requests the object from the server. The following pseudo-code illustrates an implementation of an unpacker 232 of the present invention:
Function GetObject(URL objName)
This funtion is what the Browser calls when it wants to get a particular URL. It is implemented by the Unpacker. It returns the data for the object specified by the URL objName.
Check the UOC to see if an entry already exists for this URL.
If URL is present in UOC
return the object from the UOC
else if cacheManager has URL
return the object from the cache
else
contact remote host specified in URL, and request object.
if host reports error
return error code
else if object is not jammer encoded format
return object to browser
else
At this point, we have obtained the object from the server, and it is encoded in the Jammer Encoded Format.
Get first record from stream
if record.type is not data definition entry
end connection to server
return error code
else
create, new entry for object in UOC
While GetNextRecordFromStream returns success
if record.type is a data definition entry
add to UOC
if record.type is a data packet
find the corresponding entry in the UOC, and append the data to the object.
if object is currently being read from the UOC by the browser
send this data to browser
end if
end While
end else
end Function GetObject
In another embodiment of the present invention, the unpacker resides on a web server proxy in communication with the browser 168 (FIG. 6) and with the server 169 (FIG. 6). In this embodiment, the web server proxy intercepts communications between the browser 168 and the server 169. The web server proxy includes an unpacker and an unpacker object cache. In a similar fashion, the unpacker examines the stream header 180 (FIG. 8) to determine if the data stream 190 (FIG. 8) from the server 169 is encoded in the Jammer data format. If so, the unpacker of the web server proxy unpacks the data stream 190 (FIG. 8) as described above and forwards the unpacked data to the browser 168. In this manner, the data format of the present invention may be used with a conventional browser 168 of the prior art.
Referring back to FIG. 1a, in another preferred embodiment, the data repository comprises a server 106 linked to the World Wide Web 104 portion of the Internet. The server 106 communicates with storage devices for holding object data. These storage devices may communicate directly or indirectly with the server and may reside separately, on the server computer itself, within other servers communicating with the server or among a plurality of computers linked to the Internet. Storage devices include magnetic disk drives, electronic memory, optical disk drives, magnetic tape and other devices used to stored data. The browser comprises a client 102 having a viewing device and the browser communicates with the server 106 through the World Wide Web 104. Viewing devices for the client 102 include CRT monitors, flat panel displays, projection displays and other display devices. In one sense, a server 106 is any device capable of locating, storing, retrieving and transferring object data and a client 102 is any device capable of requesting, receiving and displaying object data. Servers and clients can be stationary or mobile and may communicate using conventional land lines or wireless technologies, such as satellite, cellular or infrared.
In yet another preferred embodiment, the data repository comprises a server 106 linked to an intranet 104. The intranet 104 functions in a manner similar to that of the World Wide Web. However, for security reasons, the intranet 104 is not connected to the Internet. The server 106 communicates with storage devices for holding object data. These storage devices may communicate directly or indirectly with the server and may reside separately, on the server itself, within other servers communicating with the server or among a plurality of computers linked to the intranet. Storage devices include magnetic disk drives, electronic memory, optical disk drives, magnetic tape and other devices used to store data. The browser comprises a client 102 having a viewing device and the browser communicates with the server 106 through the intranet 104. Viewing devices for the client 102 include CRT monitors, flat panel displays, projection displays and other display devices. In one sense, a server 106 is any device capable of locating, storing, retrieving and transferring object data and a client 102 is any device capable of requesting, receiving and displaying object data. Servers and clients can be stationary or mobile and may communicate using conventional land lines or wireless technologies, such as satellite, cellular or infrared.
In yet another preferred embodiment, the data repository comprises a network server 107 linked to a wide area network 108 or to a local area network 109. The network server 107 communicates with storage devices for holding object data. These storage devices may communicate directly or indirectly with the network server and may reside separately, on the network server itself, within other network servers communicating with the network server or among a plurality of computers linked to the wide or local area network. Storage devices include magnetic disk drives, electronic memory, optical disk drives, magnetic tape and other devices used to store data. The browser comprises a network client 103 having a viewing device and the browser communicates with the network server 107 through the wide area 108 or the local area network 109. Viewing devices for the network client 103 include CRT monitors, flat panel displays, projection displays and other display devices. As is well known in the art, network servers 107 and clients 103 are typically computing devices linked into a network using specialized software for communication and data transfer, such as Microsoft Windows NT or Novell Netware. Network servers 107 and clients 103 can be stationary or mobile and may communicate using conventional land lines or wireless technologies, such as satellite, cellular or infrared.
In yet another preferred embodiment, the data repository comprises a storage device 105 (FIG. 1a) communicating with a user computer 102. These storage devices may reside separately or within the user computer. Storage devices include magnetic disk drives, electronic memory, optical disk drives such as CD-ROMs, magnetic tape and other devices used to store data. The browser resides on the user computer 102 having a viewing device and the browser communicates with the storage device 105 through the user computer's processor. Viewing devices for the user computer 102 include CRT monitors, flat panel displays, projection displays and other display devices.
IV. Summary
The data format of the present invention advantageously overcomes important limitations of available and anticipated alternatives. The present invention substantially reduces the impact of latency on object retrieval by reducing the number of get and retrieve transactions to one. Although planned HTTP improvements enable multiple transactions per connection, the protocol extension does not reduce the number of transactions required to get multiple objects needed to display a multimedia page. Similarly, server push, a technique of enabling a server to interpret the HTML base object to find embedded objects, may reduce latency, but again does not reduce the number of transactions needed to transfer and display the page. Instead, server push merely transfers the burden of multiple object retrieval from the browser to the server. Moreover, server push does not permit an author to optimize the sequence of object data transfers. Another proposed alternative, multi-part MIME, permits assembly of multiple objects into a single data stream. However, in contrast to the present invention, multi-part MIME does not permit interleaving of object data, nor does it permit optimization of how objects and object parts are delivered, in a predetermined order.
Moreover, the data format of the present invention advantageously reduces server loading by eliminating the need for superfluous transactions. For example, a page having 15 objects currently requires 15 transactions to transfer. Thus, a server capable of handling 150 transactions/second can only deliver 10 pages/sec. In contrast, the present invention typically results in the transfer of a single larger data stream and this may degrade server performance slightly. Thus, even if the server is only capable of handling 100 transactions/second using the data format of the present invention, it can still deliver 100 pages/sec. Hence, a user practicing the present invention realizes a tenfold improvement over existing techniques.
Those skilled in the art may practice the principles of the present invention in other specific forms without departing from its spirit or essential characteristics. Accordingly, the disclosed embodiments of the invention are merely illustrative and do not serve to limit the scope of the invention set forth in the following claims.

Claims (34)

What is claimed is:
1. A computer-readable medium having stored thereon a data structure, comprising:
object data packets stored within the storage for each object in the stream; and
at least one data definition entry corresponding to each object in the stream, wherein said at least one data definition entry is interleaved with said object data packets such that a data definition entry corresponding to one of the objects in the stream precedes any object data packets of said one object in the stream.
2. The computer-readable medium of claim 1, wherein said data definition entry corresponding to said one object in the stream precedes any reference to said one object from any other object in the stream.
3. The computer-readable medium of claim 1, wherein said object data packets are interleaved with said data definition entries so as to display objects in the stream in a selected order.
4. The computer-readable medium of claim 1, wherein said data definition entry comprises:
an object identifier to identify an object in the stream corresponding to said data definition entry; and
a stream identifier to identify object data packets belonging to the stream.
5. The computer-readable medium of claim 1, wherein said object data packet comprises:
object data;
a size indicator indicative of the amount of said object data packet; and
a stream identifier number to identify object data packets belonging to the stream.
6. The computer-readable medium of claim 5, wherein said object data comprises text.
7. The computer-readable medium of claim 5, wherein said object data comprises image data.
8. The computer-readable medium of claim 5, wherein said object data comprises audio data.
9. A system for transmitting a page, comprising:
a data repository for a stream representing the page, wherein said stream comprises object data packets interleaved with data definition entries;
a browser assembling said object data packets with reference to said data definition entries so as to display the page represented by said stream; and
a network communicating said stream between said data repository and said browser.
10. The system of claim 9, wherein said data repository comprises a server in communication with a storage device.
11. The system of claim 10, wherein said server comprises a computing device.
12. The system of claim 10, wherein said storage device comprises at least one storage device in direct communication with said server.
13. The system of claim 10, wherein said storage device comprises a plurality of storage devices distributed within said network.
14. The system of claim 9, wherein said browser comprises a client having a viewing device.
15. The system of claim 14, wherein said client comprises a computing device.
16. The system of claim 9, wherein said network comprises the World Wide Web portion of the Internet.
17. The system of claim 9, wherein said network comprises an intranet.
18. The system of claim 9, wherein said network comprises a wide area network.
19. The system of claim 9, wherein said network comprises a local area network.
20. A system for transmitting a page, comprising:
a data repository for a stream representing the page, wherein said stream comprises object data packets interleaved with data definition entries;
a browser assembling said object data packets with reference to said data definition entries so as to display the page represented by said stream; and
a computer communicating said stream between said data repository and said browser.
21. The system of claim 20, wherein said data repository comprises at least one storage device.
22. The system of claim 21, wherein said at least one storage device comprises a CD-ROM.
23. The system of claim 20, wherein said browser comprises a viewing device in communication with said at least one storage device.
24. A computer-readable medium having computer-executable instructions for performing the steps comprising:
preparing a header for indicating the data structure of a data stream;
generating a stream configuration template for indicating the presence of embedded object data packets in the data stream wherein each embedded object data packet corresponds to an embedded object;
preparing data definition entries for each embedded object data packet;
interleaving embedded object data packets with data definition entries; and
appending end of stream indicator for marking the end of the data stream.
25. The computer-executable instructions of claim 24, wherein the step of generating a stream configuration template includes determining the number of embedded object data packets, the location of embedded objects, and the order of display of embedded objects.
26. The computer-executable instructions of claim 24, wherein the step of preparing data definition entries includes identifying the embedded object data packet, generating data representative of the size of said embedded object data packet, and generating data representative of the identity of the data stream.
27. The computer-executable instructions of claim 24, wherein the step of interleaving embedded object data packets with data definition entries includes arranging the data definition entry preceding the corresponding embedded object data packet.
28. A computer-readable medium having stored thereon a data structure comprising:
a first data field including data representing an object data packet;
a second data field including data representing data definition for the object data packet, and stored preceding said first data field; and
a third data field functioning as an end marker for the data structure and stored after said first and second data fields.
29. The data structure of claim 28 wherein the second data field precedes any reference to the first data field in the data structure.
30. The data structure of claim 28 including a plurality of first data fields and a plurality of second data fields and further wherein the number of first data fields is equal to the number of second data fields.
31. The data structure of claim 28 including a plurality of first data fields and an equal plurality of second data fields and further wherein the first data fields are interleaved with the second data fields.
32. The data structure of claim 28 wherein the second data field includes data representative of the identity of an object and data representative of the identity of the data structure.
33. The data structure of claim 28 wherein the first data field includes object data, and data representative of the size of said object data, and data representative of the identity of the data structure.
34. The data structure of claim 28 wherein the contents of the first data field is data selected from the group consisting of text data, image data and audio data.
US08/885,672 1997-06-30 1997-06-30 Data format for multimedia object storage, retrieval and transfer Expired - Lifetime US6604144B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US08/885,672 US6604144B1 (en) 1997-06-30 1997-06-30 Data format for multimedia object storage, retrieval and transfer

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US08/885,672 US6604144B1 (en) 1997-06-30 1997-06-30 Data format for multimedia object storage, retrieval and transfer

Publications (1)

Publication Number Publication Date
US6604144B1 true US6604144B1 (en) 2003-08-05

Family

ID=27623450

Family Applications (1)

Application Number Title Priority Date Filing Date
US08/885,672 Expired - Lifetime US6604144B1 (en) 1997-06-30 1997-06-30 Data format for multimedia object storage, retrieval and transfer

Country Status (1)

Country Link
US (1) US6604144B1 (en)

Cited By (68)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20010056351A1 (en) * 2000-06-26 2001-12-27 Byobroadcast, Inc. Networked audio posting method and system
US20030028598A1 (en) * 1999-09-23 2003-02-06 Rocket Network, Inc. Method and system for archiving and forwarding multimedia production data
US20030041265A1 (en) * 2001-08-21 2003-02-27 Todd Lagimonier System for efficiently handling cryptographic messages containing nonce values in a wireless connectionless environment without compromising security
US20030126196A1 (en) * 2001-12-27 2003-07-03 Todd Lagimonier System for optimizing the invocation of computer-based services deployed in a distributed computing environment
US20030128219A1 (en) * 2002-01-07 2003-07-10 Xerox Corporation Pixel color map operator interface
US20030140160A1 (en) * 1998-07-22 2003-07-24 Uri Raz Method and apparatus for determining the order of streaming modules
US20030195924A1 (en) * 2002-04-15 2003-10-16 Franke Michael Martin Methods and system using a local proxy server to process media data for local area users
US20030200336A1 (en) * 2002-02-15 2003-10-23 Suparna Pal Apparatus and method for the delivery of multiple sources of media content
US20050120132A1 (en) * 2003-11-14 2005-06-02 Ingo Hutter Method for discontinuous transmission, in sections, of data in a network of distributed stations, as well as a network subscriber station as a requesting appliance for carrying out a method such as this, and a network subscriber station as a source appliance for carrying out a method such as this
US20050198302A1 (en) * 2003-12-29 2005-09-08 Microsoft Corporation Multi-client support
US20050234961A1 (en) * 2004-04-16 2005-10-20 Pinnacle Systems, Inc. Systems and Methods for providing a proxy for a shared file system
US20050246710A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Sharing of downloaded resources
US20050246724A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Systems and methods for support of various processing capabilities
US20050243346A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Planar mapping of graphical elements
US20050243345A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Systems and methods for handling a file with complex elements
US20050243355A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Systems and methods for support of various processing capabilities
US20050248790A1 (en) * 2004-04-30 2005-11-10 David Ornstein Method and apparatus for interleaving parts of a document
US20050262134A1 (en) * 2004-05-03 2005-11-24 Microsoft Corporation Spooling strategies using structured job information
US20050278272A1 (en) * 2004-04-30 2005-12-15 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US6985932B1 (en) * 1994-11-30 2006-01-10 Realnetworks, Inc. Multimedia communications system and method for providing audio on demand to subscribers
US20060116917A1 (en) * 2004-11-19 2006-06-01 Microsoft Corporation Time polynomial arrow-debreu market equilibrium
US20060190815A1 (en) * 2004-12-20 2006-08-24 Microsoft Corporation Structuring data for word processing documents
US20070112833A1 (en) * 2005-11-17 2007-05-17 International Business Machines Corporation System and method for annotating patents with MeSH data
US20070139189A1 (en) * 2005-12-05 2007-06-21 Helmig Kevin S Multi-platform monitoring system and method
US20070162843A1 (en) * 2006-01-10 2007-07-12 International Business Machines Corporation System and method for serving multiple data objects and formatting functions in a single request
US20070214169A1 (en) * 2001-10-15 2007-09-13 Mathieu Audet Multi-dimensional locating system and method
US20070216694A1 (en) * 2001-10-15 2007-09-20 Mathieu Audet Multi-Dimensional Locating System and Method
US7318088B1 (en) * 2001-03-30 2008-01-08 Western Digital Ventures, Inc. Receiving data at a client computer and performing an operation on the data at the client computer based on information in the key file
US20080016153A1 (en) * 1996-06-12 2008-01-17 Mount Hamilton Partners, Llc System and Method for Generating a Modified Web Page by Inline Code Insertion in Response to an Information Request From a Client Computer
US7349976B1 (en) 1994-11-30 2008-03-25 Realnetworks, Inc. Audio-on-demand communication system
US7366982B2 (en) 2004-04-30 2008-04-29 Microsoft Corporation Packages that contain pre-paginated documents
US20080104203A1 (en) * 2006-10-31 2008-05-01 Microsoft Corporation Viewing Digital Information Over a Network
US20080141115A1 (en) * 2001-10-15 2008-06-12 Mathieu Audet Multi-dimensional document locating system and method
US7464330B2 (en) 2003-12-09 2008-12-09 Microsoft Corporation Context-free document portions with alternate formats
US7487448B2 (en) 2004-04-30 2009-02-03 Microsoft Corporation Document mark up methods and systems
US7512878B2 (en) 2004-04-30 2009-03-31 Microsoft Corporation Modular document format
US7549118B2 (en) 2004-04-30 2009-06-16 Microsoft Corporation Methods and systems for defining documents with selectable and/or sequenceable parts
US7584415B2 (en) 2004-09-15 2009-09-01 Microsoft Corporation Common charting using shapes
US7614000B2 (en) 2004-12-20 2009-11-03 Microsoft Corporation File formats, methods, and computer program products for representing presentations
US7617444B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation File formats, methods, and computer program products for representing workbooks
US7617450B2 (en) 2004-09-30 2009-11-10 Microsoft Corporation Method, system, and computer-readable medium for creating, inserting, and reusing document parts in an electronic document
US7617229B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation Management and use of data in a computer-generated document
US7617447B1 (en) 2003-12-09 2009-11-10 Microsoft Corporation Context free document portions
US7620889B2 (en) 2004-12-20 2009-11-17 Microsoft Corporation Method and system for linking data ranges of a computer-generated document with associated extensible markup language elements
US7716312B2 (en) 2002-11-13 2010-05-11 Avid Technology, Inc. Method and system for transferring large data files over parallel connections
US7752632B2 (en) 2004-12-21 2010-07-06 Microsoft Corporation Method and system for exposing nested data in a computer-generated document in a transparent manner
US7770180B2 (en) 2004-12-21 2010-08-03 Microsoft Corporation Exposing embedded data in a computer-generated document
US8069404B2 (en) 2007-08-22 2011-11-29 Maya-Systems Inc. Method of managing expected documents and system providing same
US8243317B2 (en) 2004-05-03 2012-08-14 Microsoft Corporation Hierarchical arrangement for spooling job data
US20120216235A1 (en) * 1998-08-14 2012-08-23 International Business Machines Corporation Wireless Information Transfer and Interactive Television System
US8316306B2 (en) 2001-10-15 2012-11-20 Maya-Systems Inc. Method and system for sequentially navigating axes of elements
US8363232B2 (en) 2004-05-03 2013-01-29 Microsoft Corporation Strategies for simultaneous peripheral operations on-line using hierarchically structured job information
US8607155B2 (en) 2008-09-12 2013-12-10 9224-5489 Quebec Inc. Method of managing groups of arrays of documents
US20130346554A1 (en) * 2011-03-15 2013-12-26 Haoyu Ren Transmission processing method and apparatus, electronic device
US8661332B2 (en) 2004-04-30 2014-02-25 Microsoft Corporation Method and apparatus for document processing
US20140059150A1 (en) * 2006-03-31 2014-02-27 Blackberry Limited Method for presenting an attachment within an email message
US8826123B2 (en) 2007-05-25 2014-09-02 9224-5489 Quebec Inc. Timescale for presenting information
US8924395B2 (en) 2010-10-06 2014-12-30 Planet Data Solutions System and method for indexing electronic discovery data
US9058093B2 (en) 2011-02-01 2015-06-16 9224-5489 Quebec Inc. Active element
US9098516B2 (en) * 2012-07-18 2015-08-04 DS Zodiac, Inc. Multi-dimensional file system
US9130765B1 (en) * 1996-06-12 2015-09-08 Michael Carringer System and method for generating a modified web page by inline code insertion in response to an information request from a client computer
US9262381B2 (en) 2007-08-22 2016-02-16 9224-5489 Quebec Inc. Array of documents with past, present and future portions thereof
US9519693B2 (en) 2012-06-11 2016-12-13 9224-5489 Quebec Inc. Method and apparatus for displaying data element axes
US9613167B2 (en) 2011-09-25 2017-04-04 9224-5489 Quebec Inc. Method of inserting and removing information elements in ordered information element arrays
US9646080B2 (en) 2012-06-12 2017-05-09 9224-5489 Quebec Inc. Multi-functions axis-based interface
US9652438B2 (en) 2008-03-07 2017-05-16 9224-5489 Quebec Inc. Method of distinguishing documents
US10671266B2 (en) 2017-06-05 2020-06-02 9224-5489 Quebec Inc. Method and apparatus of aligning information element axes
US11704356B2 (en) * 2019-09-06 2023-07-18 Dropbox, Inc. Restoring integrity of a social media thread from a social network export

Citations (47)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4498079A (en) * 1981-08-20 1985-02-05 Bally Manufacturing Corporation Prioritized overlay of foreground objects line buffer system for a video display system
US5303302A (en) * 1992-06-18 1994-04-12 Digital Equipment Corporation Network packet receiver with buffer logic for reassembling interleaved data packets
US5327559A (en) * 1990-10-23 1994-07-05 International Business Machines Corporation Remote and batch processing in an object oriented programming system
US5421012A (en) * 1987-08-21 1995-05-30 Wang Laboratories, Inc. Multitasking computer system for integrating the operation of different application programs which manipulate data objects of different types
US5481543A (en) * 1993-03-16 1996-01-02 Sony Corporation Rational input buffer arrangements for auxiliary information in video and audio signal processing systems
US5487167A (en) 1991-12-31 1996-01-23 International Business Machines Corporation Personal computer with generalized data streaming apparatus for multimedia devices
US5513305A (en) * 1994-03-01 1996-04-30 Apple Computer, Inc. System and method for documenting and displaying computer program code
US5577258A (en) 1994-07-13 1996-11-19 Bell Communications Research, Inc. Apparatus and method for preprocessing multimedia presentations to generate a delivery schedule
US5594911A (en) 1994-07-13 1997-01-14 Bell Communications Research, Inc. System and method for preprocessing and delivering multimedia presentations
US5598566A (en) 1990-01-30 1997-01-28 Johnson Service Company Networked facilities management system having a node configured with distributed load management software to manipulate loads controlled by other nodes
US5613057A (en) * 1994-01-14 1997-03-18 International Business Machines Corporation Method for creating a multimedia application using multimedia files stored in directories that are characteristics of display surface areas
US5632009A (en) * 1993-09-17 1997-05-20 Xerox Corporation Method and system for producing a table image showing indirect data representations
US5642478A (en) * 1994-12-29 1997-06-24 International Business Machines Corporation Distributed trace data acquisition system
US5657096A (en) 1995-05-03 1997-08-12 Lukacs; Michael Edward Real time video conferencing system and method with multilayer keying of multiple video images
US5666137A (en) * 1993-08-06 1997-09-09 Intel Corporation Packed YUV9 format for interleaved storage and efficient processing of digital video data
US5701368A (en) * 1995-03-20 1997-12-23 Daewoo Electronics Co., Ltd. Apparatus for encoding an image signal having a still object
US5706502A (en) 1996-03-25 1998-01-06 Sun Microsystems, Inc. Internet-enabled portfolio manager system and method
US5748960A (en) * 1993-08-10 1998-05-05 Fischer; Addison M. Method and apparatus for validating travelling object-oriented programs with digital signatures
US5754242A (en) 1995-01-06 1998-05-19 Mitsubishi Electric Information Technology Center America, Inc. Data formatting system for processing multiple independent input data streams for high resolution screen displays
US5754566A (en) 1996-09-06 1998-05-19 Intel Corporation Method and apparatus for correcting a multilevel cell memory by using interleaving
US5757416A (en) * 1993-12-03 1998-05-26 Scientific-Atlanta, Inc. System and method for transmitting a plurality of digital services including imaging services
US5764241A (en) 1995-11-30 1998-06-09 Microsoft Corporation Method and system for modeling and presenting integrated media with a declarative modeling language for representing reactive behavior
US5768510A (en) * 1996-07-01 1998-06-16 Sun Microsystems, Inc. Object-oriented system, method and article of manufacture for a client-server application enabler system
US5778372A (en) * 1996-04-18 1998-07-07 Microsoft Corporation Remote retrieval and display management of electronic document with incorporated images
US5781739A (en) * 1996-12-31 1998-07-14 International Business Machines Corp. IMS/WWW mapping system
US5784056A (en) * 1995-12-29 1998-07-21 Sun Microsystems, Inc. System and method for temporally varying pointer icons
US5787454A (en) 1995-12-27 1998-07-28 Intel Corporation Recorder buffer with interleaving mechanism for accessing a multi-parted circular memory array
US5813014A (en) * 1996-07-10 1998-09-22 Survivors Of The Shoah Visual History Foundation Method and apparatus for management of multimedia assets
US5818935A (en) * 1997-03-10 1998-10-06 Maa; Chia-Yiu Internet enhanced video system
US5818832A (en) * 1995-10-10 1998-10-06 Sicom, Inc. Rapid synchronization for communication systems
US5841819A (en) * 1996-04-09 1998-11-24 Thomson Multimedia, S.A. Viterbi decoder for digital packet signals
US5860073A (en) * 1995-07-17 1999-01-12 Microsoft Corporation Style sheets for publishing system
US5877966A (en) 1994-05-31 1999-03-02 Pantheon Solutions, Inc. System and method for creating configurations using templates
US5884014A (en) * 1996-05-23 1999-03-16 Xerox Corporation Fontless structured document image representations for efficient rendering
US5892512A (en) * 1996-07-06 1999-04-06 International Business Machines Corporation Selection of operations in a computer system
US5892909A (en) * 1996-09-27 1999-04-06 Diffusion, Inc. Intranet-based system with methods for co-active delivery of information to multiple users
US5907837A (en) * 1995-07-17 1999-05-25 Microsoft Corporation Information retrieval system in an on-line network including separate content and layout of published titles
US5933435A (en) * 1990-12-04 1999-08-03 International Business Machines Corporation Optimized method of data communication and system employing same
US5956716A (en) * 1995-06-07 1999-09-21 Intervu, Inc. System and method for delivery of video data over a computer network
US5968119A (en) 1996-12-09 1999-10-19 Wall Data Incorporated Method of accessing information of an SNA host computer from a client computer using a specific terminal emulation
US5995554A (en) * 1996-06-03 1999-11-30 Vtech Communications, Ltd. Data framing format for digital radio communications and method of forming same
US6006332A (en) * 1996-10-21 1999-12-21 Case Western Reserve University Rights management system for digital media
US6016158A (en) 1993-09-15 2000-01-18 Pelmorex Media Inc. Object oriented communication network
US6065058A (en) 1997-05-09 2000-05-16 International Business Machines Corp. Dynamic push filtering based on information exchanged among nodes in a proxy hierarchy
US6173327B1 (en) * 1996-07-11 2001-01-09 Jeroen De Borst Object-oriented method and apparatus for information delivery
US6189048B1 (en) * 1996-06-26 2001-02-13 Sun Microsystems, Inc. Mechanism for dispatching requests in a distributed object system
US6269403B1 (en) * 1997-06-30 2001-07-31 Microsoft Corporation Browser and publisher for multimedia object storage, retrieval and transfer

Patent Citations (48)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4498079A (en) * 1981-08-20 1985-02-05 Bally Manufacturing Corporation Prioritized overlay of foreground objects line buffer system for a video display system
US5421012A (en) * 1987-08-21 1995-05-30 Wang Laboratories, Inc. Multitasking computer system for integrating the operation of different application programs which manipulate data objects of different types
US5598566A (en) 1990-01-30 1997-01-28 Johnson Service Company Networked facilities management system having a node configured with distributed load management software to manipulate loads controlled by other nodes
US5327559A (en) * 1990-10-23 1994-07-05 International Business Machines Corporation Remote and batch processing in an object oriented programming system
US5933435A (en) * 1990-12-04 1999-08-03 International Business Machines Corporation Optimized method of data communication and system employing same
US5487167A (en) 1991-12-31 1996-01-23 International Business Machines Corporation Personal computer with generalized data streaming apparatus for multimedia devices
US5303302A (en) * 1992-06-18 1994-04-12 Digital Equipment Corporation Network packet receiver with buffer logic for reassembling interleaved data packets
US5481543A (en) * 1993-03-16 1996-01-02 Sony Corporation Rational input buffer arrangements for auxiliary information in video and audio signal processing systems
US5666137A (en) * 1993-08-06 1997-09-09 Intel Corporation Packed YUV9 format for interleaved storage and efficient processing of digital video data
US5748960A (en) * 1993-08-10 1998-05-05 Fischer; Addison M. Method and apparatus for validating travelling object-oriented programs with digital signatures
US6016158A (en) 1993-09-15 2000-01-18 Pelmorex Media Inc. Object oriented communication network
US5632009A (en) * 1993-09-17 1997-05-20 Xerox Corporation Method and system for producing a table image showing indirect data representations
US5757416A (en) * 1993-12-03 1998-05-26 Scientific-Atlanta, Inc. System and method for transmitting a plurality of digital services including imaging services
US5613057A (en) * 1994-01-14 1997-03-18 International Business Machines Corporation Method for creating a multimedia application using multimedia files stored in directories that are characteristics of display surface areas
US5513305A (en) * 1994-03-01 1996-04-30 Apple Computer, Inc. System and method for documenting and displaying computer program code
US5877966A (en) 1994-05-31 1999-03-02 Pantheon Solutions, Inc. System and method for creating configurations using templates
US5594911A (en) 1994-07-13 1997-01-14 Bell Communications Research, Inc. System and method for preprocessing and delivering multimedia presentations
US5577258A (en) 1994-07-13 1996-11-19 Bell Communications Research, Inc. Apparatus and method for preprocessing multimedia presentations to generate a delivery schedule
US5642478A (en) * 1994-12-29 1997-06-24 International Business Machines Corporation Distributed trace data acquisition system
US5754242A (en) 1995-01-06 1998-05-19 Mitsubishi Electric Information Technology Center America, Inc. Data formatting system for processing multiple independent input data streams for high resolution screen displays
US5701368A (en) * 1995-03-20 1997-12-23 Daewoo Electronics Co., Ltd. Apparatus for encoding an image signal having a still object
US5657096A (en) 1995-05-03 1997-08-12 Lukacs; Michael Edward Real time video conferencing system and method with multilayer keying of multiple video images
US5956716A (en) * 1995-06-07 1999-09-21 Intervu, Inc. System and method for delivery of video data over a computer network
US5907837A (en) * 1995-07-17 1999-05-25 Microsoft Corporation Information retrieval system in an on-line network including separate content and layout of published titles
US5860073A (en) * 1995-07-17 1999-01-12 Microsoft Corporation Style sheets for publishing system
US5818832A (en) * 1995-10-10 1998-10-06 Sicom, Inc. Rapid synchronization for communication systems
US5764241A (en) 1995-11-30 1998-06-09 Microsoft Corporation Method and system for modeling and presenting integrated media with a declarative modeling language for representing reactive behavior
US5787454A (en) 1995-12-27 1998-07-28 Intel Corporation Recorder buffer with interleaving mechanism for accessing a multi-parted circular memory array
US5784056A (en) * 1995-12-29 1998-07-21 Sun Microsystems, Inc. System and method for temporally varying pointer icons
US5706502A (en) 1996-03-25 1998-01-06 Sun Microsystems, Inc. Internet-enabled portfolio manager system and method
US5841819A (en) * 1996-04-09 1998-11-24 Thomson Multimedia, S.A. Viterbi decoder for digital packet signals
US5841478A (en) * 1996-04-09 1998-11-24 Thomson Multimedia, S.A. Code sequence detection in a trellis decoder
US5778372A (en) * 1996-04-18 1998-07-07 Microsoft Corporation Remote retrieval and display management of electronic document with incorporated images
US5884014A (en) * 1996-05-23 1999-03-16 Xerox Corporation Fontless structured document image representations for efficient rendering
US5995554A (en) * 1996-06-03 1999-11-30 Vtech Communications, Ltd. Data framing format for digital radio communications and method of forming same
US6189048B1 (en) * 1996-06-26 2001-02-13 Sun Microsystems, Inc. Mechanism for dispatching requests in a distributed object system
US5768510A (en) * 1996-07-01 1998-06-16 Sun Microsystems, Inc. Object-oriented system, method and article of manufacture for a client-server application enabler system
US5892512A (en) * 1996-07-06 1999-04-06 International Business Machines Corporation Selection of operations in a computer system
US5813014A (en) * 1996-07-10 1998-09-22 Survivors Of The Shoah Visual History Foundation Method and apparatus for management of multimedia assets
US6173327B1 (en) * 1996-07-11 2001-01-09 Jeroen De Borst Object-oriented method and apparatus for information delivery
US5754566A (en) 1996-09-06 1998-05-19 Intel Corporation Method and apparatus for correcting a multilevel cell memory by using interleaving
US5892909A (en) * 1996-09-27 1999-04-06 Diffusion, Inc. Intranet-based system with methods for co-active delivery of information to multiple users
US6006332A (en) * 1996-10-21 1999-12-21 Case Western Reserve University Rights management system for digital media
US5968119A (en) 1996-12-09 1999-10-19 Wall Data Incorporated Method of accessing information of an SNA host computer from a client computer using a specific terminal emulation
US5781739A (en) * 1996-12-31 1998-07-14 International Business Machines Corp. IMS/WWW mapping system
US5818935A (en) * 1997-03-10 1998-10-06 Maa; Chia-Yiu Internet enhanced video system
US6065058A (en) 1997-05-09 2000-05-16 International Business Machines Corp. Dynamic push filtering based on information exchanged among nodes in a proxy hierarchy
US6269403B1 (en) * 1997-06-30 2001-07-31 Microsoft Corporation Browser and publisher for multimedia object storage, retrieval and transfer

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
Brown, M.R., et al., Special Edition Using Netscape 3, pp. 254, 263-265, 268-270, 428 (1996).
DeFazio et al, Database Extensions for Complex Domains IEEE 1996.* *
Lemay, Teach Yourself Web Publishing with HTML 3.2, 1996.* *
McGowan, J.F., "AVI Overview", http://think.atr.net/mirror/faq/rt . . . /AVI_Graphics_Format_Overview.html, pp. 1-25, (1997).
Nittel et al, Geo POM: A Heterogeneous Geoscientific Persistent Object System. IEEE Feb. 1997.* *
Zellweger, P.T., et al., "Fluid Links for Informed and Incremental Link Transitions", Proceedings of Hypertext '98, , Pittsburgh, PA, pp. 1-8, (1998).

Cited By (148)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7500011B2 (en) 1994-11-30 2009-03-03 Realnetworks, Inc. Audio-on-demand communication system
US7349976B1 (en) 1994-11-30 2008-03-25 Realnetworks, Inc. Audio-on-demand communication system
US6985932B1 (en) * 1994-11-30 2006-01-10 Realnetworks, Inc. Multimedia communications system and method for providing audio on demand to subscribers
US20060271989A1 (en) * 1994-11-30 2006-11-30 Realnetworks, Inc. Audio-on-demand communication system
US20090144781A1 (en) * 1994-11-30 2009-06-04 Realnetworks, Inc. Audio-on-demand communication system
US7464175B1 (en) 1994-11-30 2008-12-09 Realnetworks, Inc. Audio-on demand communication system
US8131869B2 (en) 1994-11-30 2012-03-06 Realnetworks, Inc. Audio-on-demand communication system
US8706903B2 (en) 1994-11-30 2014-04-22 Intel Corporation Audio on-demand communication system
US9130765B1 (en) * 1996-06-12 2015-09-08 Michael Carringer System and method for generating a modified web page by inline code insertion in response to an information request from a client computer
US8601050B2 (en) 1996-06-12 2013-12-03 Michael Carringer System and method for generating a modified web page by inline code insertion in response to an information request from a client computer
US9021023B2 (en) 1996-06-12 2015-04-28 Smooth Ride, Series 53 Of Allied Security Trust I System and method for generating a modified web page by inline code insertion in response to an information request from a client computer
US20080016153A1 (en) * 1996-06-12 2008-01-17 Mount Hamilton Partners, Llc System and Method for Generating a Modified Web Page by Inline Code Insertion in Response to an Information Request From a Client Computer
US20030140160A1 (en) * 1998-07-22 2003-07-24 Uri Raz Method and apparatus for determining the order of streaming modules
US7606924B2 (en) * 1998-07-22 2009-10-20 Symantec Corporation Method and apparatus for determining the order of streaming modules
US20120216235A1 (en) * 1998-08-14 2012-08-23 International Business Machines Corporation Wireless Information Transfer and Interactive Television System
US8756643B2 (en) * 1998-08-14 2014-06-17 International Business Machines Corporation Wireless information transfer and interactive television system
US7069296B2 (en) * 1999-09-23 2006-06-27 Avid Technology, Inc. Method and system for archiving and forwarding multimedia production data
US20030028598A1 (en) * 1999-09-23 2003-02-06 Rocket Network, Inc. Method and system for archiving and forwarding multimedia production data
US20010056351A1 (en) * 2000-06-26 2001-12-27 Byobroadcast, Inc. Networked audio posting method and system
US7318088B1 (en) * 2001-03-30 2008-01-08 Western Digital Ventures, Inc. Receiving data at a client computer and performing an operation on the data at the client computer based on information in the key file
US7856660B2 (en) 2001-08-21 2010-12-21 Telecommunication Systems, Inc. System for efficiently handling cryptographic messages containing nonce values
US8453240B2 (en) 2001-08-21 2013-05-28 Telecommunication Systems, Inc. System for efficiently handling cryptographic messages containing nonce values in a wireless connectionless environment without comprising security
US9071438B2 (en) 2001-08-21 2015-06-30 Telecommunication Systems, Inc. System for efficiently handling cryptographic messages containing nonce values in a wireless connectionless environment
US20160021063A1 (en) * 2001-08-21 2016-01-21 Telecommunication Systems, Inc. System for Efficiently Handling Cryptographic Messages Containing Nonce Values in a Wireless Connectionless Environment
US8161553B2 (en) 2001-08-21 2012-04-17 Telecommunication Systems, Inc. System for efficiently handling cryptographic messages containing nonce values in a wireless connectionless environment without comprising security
US20110088094A1 (en) * 2001-08-21 2011-04-14 Todd Lagimonier System for efficiently handling cryptographic messages containing nonce values in a wireless connectionless environment without comprising security
US20030041265A1 (en) * 2001-08-21 2003-02-27 Todd Lagimonier System for efficiently handling cryptographic messages containing nonce values in a wireless connectionless environment without compromising security
US20070214169A1 (en) * 2001-10-15 2007-09-13 Mathieu Audet Multi-dimensional locating system and method
US8151185B2 (en) 2001-10-15 2012-04-03 Maya-Systems Inc. Multimedia interface
US20070216694A1 (en) * 2001-10-15 2007-09-20 Mathieu Audet Multi-Dimensional Locating System and Method
US8645826B2 (en) 2001-10-15 2014-02-04 Apple Inc. Graphical multidimensional file management system and method
US8893046B2 (en) 2001-10-15 2014-11-18 Apple Inc. Method of managing user-selectable elements in a plurality of directions
US20080071822A1 (en) * 2001-10-15 2008-03-20 Mathieu Audet Browser for managing documents
US8904281B2 (en) 2001-10-15 2014-12-02 Apple Inc. Method and system for managing multi-user user-selectable elements
US8954847B2 (en) 2001-10-15 2015-02-10 Apple Inc. Displays of user select icons with an axes-based multimedia interface
US20080092038A1 (en) * 2001-10-15 2008-04-17 Mahieu Audet Document vectors
US8316306B2 (en) 2001-10-15 2012-11-20 Maya-Systems Inc. Method and system for sequentially navigating axes of elements
US9251643B2 (en) 2001-10-15 2016-02-02 Apple Inc. Multimedia interface progression bar
US9454529B2 (en) 2001-10-15 2016-09-27 Apple Inc. Method of improving a search
US7680817B2 (en) 2001-10-15 2010-03-16 Maya-Systems Inc. Multi-dimensional locating system and method
US20080141115A1 (en) * 2001-10-15 2008-06-12 Mathieu Audet Multi-dimensional document locating system and method
US8078966B2 (en) 2001-10-15 2011-12-13 Maya-Systems Inc. Method and system for managing musical files
US7606819B2 (en) 2001-10-15 2009-10-20 Maya-Systems Inc. Multi-dimensional locating system and method
US8136030B2 (en) 2001-10-15 2012-03-13 Maya-Systems Inc. Method and system for managing music files
US20030126196A1 (en) * 2001-12-27 2003-07-03 Todd Lagimonier System for optimizing the invocation of computer-based services deployed in a distributed computing environment
US20030128219A1 (en) * 2002-01-07 2003-07-10 Xerox Corporation Pixel color map operator interface
US20030200336A1 (en) * 2002-02-15 2003-10-23 Suparna Pal Apparatus and method for the delivery of multiple sources of media content
US20030195924A1 (en) * 2002-04-15 2003-10-16 Franke Michael Martin Methods and system using a local proxy server to process media data for local area users
US7668901B2 (en) 2002-04-15 2010-02-23 Avid Technology, Inc. Methods and system using a local proxy server to process media data for local area users
US7716312B2 (en) 2002-11-13 2010-05-11 Avid Technology, Inc. Method and system for transferring large data files over parallel connections
US20050120132A1 (en) * 2003-11-14 2005-06-02 Ingo Hutter Method for discontinuous transmission, in sections, of data in a network of distributed stations, as well as a network subscriber station as a requesting appliance for carrying out a method such as this, and a network subscriber station as a source appliance for carrying out a method such as this
US8195828B2 (en) * 2003-11-14 2012-06-05 Thomson Licensing Method for discontinuous transmission, in sections, of data in a network of distributed stations, as well as a network subscriber station as a requesting appliance for carrying out a method such as this, and a network subscriber station as a source appliance for carrying out a method such as this
DE10353564A1 (en) * 2003-11-14 2005-06-16 Deutsche Thomson-Brandt Gmbh Method for the intermittent, discontinuous transmission of data in a network of distributed stations and network subscriber station as a request device in the implementation of such a method as well as network subscriber station as a source device in the implementation of such a method
US7464330B2 (en) 2003-12-09 2008-12-09 Microsoft Corporation Context-free document portions with alternate formats
US7617447B1 (en) 2003-12-09 2009-11-10 Microsoft Corporation Context free document portions
US20050198302A1 (en) * 2003-12-29 2005-09-08 Microsoft Corporation Multi-client support
US20050234961A1 (en) * 2004-04-16 2005-10-20 Pinnacle Systems, Inc. Systems and Methods for providing a proxy for a shared file system
US7383500B2 (en) 2004-04-30 2008-06-03 Microsoft Corporation Methods and systems for building packages that contain pre-paginated documents
US7752235B2 (en) 2004-04-30 2010-07-06 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US20050278272A1 (en) * 2004-04-30 2005-12-15 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US8661332B2 (en) 2004-04-30 2014-02-25 Microsoft Corporation Method and apparatus for document processing
US20050248790A1 (en) * 2004-04-30 2005-11-10 David Ornstein Method and apparatus for interleaving parts of a document
US7359902B2 (en) 2004-04-30 2008-04-15 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US7366982B2 (en) 2004-04-30 2008-04-29 Microsoft Corporation Packages that contain pre-paginated documents
US7383502B2 (en) 2004-04-30 2008-06-03 Microsoft Corporation Packages that contain pre-paginated documents
US7418652B2 (en) 2004-04-30 2008-08-26 Microsoft Corporation Method and apparatus for interleaving parts of a document
US7620650B2 (en) 2004-04-30 2009-11-17 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US7451156B2 (en) 2004-04-30 2008-11-11 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US7487448B2 (en) 2004-04-30 2009-02-03 Microsoft Corporation Document mark up methods and systems
US8122350B2 (en) 2004-04-30 2012-02-21 Microsoft Corporation Packages that contain pre-paginated documents
US7512878B2 (en) 2004-04-30 2009-03-31 Microsoft Corporation Modular document format
US7549118B2 (en) 2004-04-30 2009-06-16 Microsoft Corporation Methods and systems for defining documents with selectable and/or sequenceable parts
US7836094B2 (en) 2004-04-30 2010-11-16 Microsoft Corporation Method and apparatus for maintaining relationships between parts in a package
US20050246710A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Sharing of downloaded resources
US8243317B2 (en) 2004-05-03 2012-08-14 Microsoft Corporation Hierarchical arrangement for spooling job data
US7607141B2 (en) 2004-05-03 2009-10-20 Microsoft Corporation Systems and methods for support of various processing capabilities
US20050262134A1 (en) * 2004-05-03 2005-11-24 Microsoft Corporation Spooling strategies using structured job information
US7526504B2 (en) 2004-05-03 2009-04-28 Microsoft Corporation Spooling strategies using structured job information
US7519899B2 (en) 2004-05-03 2009-04-14 Microsoft Corporation Planar mapping of graphical elements
US8024648B2 (en) 2004-05-03 2011-09-20 Microsoft Corporation Planar mapping of graphical elements
US8639723B2 (en) 2004-05-03 2014-01-28 Microsoft Corporation Spooling strategies using structured job information
US7580948B2 (en) 2004-05-03 2009-08-25 Microsoft Corporation Spooling strategies using structured job information
US20050243355A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Systems and methods for support of various processing capabilities
US20050243345A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Systems and methods for handling a file with complex elements
US7634775B2 (en) 2004-05-03 2009-12-15 Microsoft Corporation Sharing of downloaded resources
US7440132B2 (en) 2004-05-03 2008-10-21 Microsoft Corporation Systems and methods for handling a file with complex elements
US8363232B2 (en) 2004-05-03 2013-01-29 Microsoft Corporation Strategies for simultaneous peripheral operations on-line using hierarchically structured job information
US20050243346A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Planar mapping of graphical elements
US7755786B2 (en) 2004-05-03 2010-07-13 Microsoft Corporation Systems and methods for support of various processing capabilities
US20050246724A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Systems and methods for support of various processing capabilities
US7584415B2 (en) 2004-09-15 2009-09-01 Microsoft Corporation Common charting using shapes
US7673235B2 (en) 2004-09-30 2010-03-02 Microsoft Corporation Method and apparatus for utilizing an object model to manage document parts for use in an electronic document
US7617450B2 (en) 2004-09-30 2009-11-10 Microsoft Corporation Method, system, and computer-readable medium for creating, inserting, and reusing document parts in an electronic document
US20060116917A1 (en) * 2004-11-19 2006-06-01 Microsoft Corporation Time polynomial arrow-debreu market equilibrium
US7584111B2 (en) 2004-11-19 2009-09-01 Microsoft Corporation Time polynomial Arrow-Debreu market equilibrium
US7617229B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation Management and use of data in a computer-generated document
US7620889B2 (en) 2004-12-20 2009-11-17 Microsoft Corporation Method and system for linking data ranges of a computer-generated document with associated extensible markup language elements
US7617451B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation Structuring data for word processing documents
US7617444B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation File formats, methods, and computer program products for representing workbooks
US7614000B2 (en) 2004-12-20 2009-11-03 Microsoft Corporation File formats, methods, and computer program products for representing presentations
US20060190815A1 (en) * 2004-12-20 2006-08-24 Microsoft Corporation Structuring data for word processing documents
US7752632B2 (en) 2004-12-21 2010-07-06 Microsoft Corporation Method and system for exposing nested data in a computer-generated document in a transparent manner
US7770180B2 (en) 2004-12-21 2010-08-03 Microsoft Corporation Exposing embedded data in a computer-generated document
US20070112833A1 (en) * 2005-11-17 2007-05-17 International Business Machines Corporation System and method for annotating patents with MeSH data
US20070139189A1 (en) * 2005-12-05 2007-06-21 Helmig Kevin S Multi-platform monitoring system and method
US20070162843A1 (en) * 2006-01-10 2007-07-12 International Business Machines Corporation System and method for serving multiple data objects and formatting functions in a single request
US11029925B2 (en) 2006-01-10 2021-06-08 International Business Machines Corporation System and method for serving multiple data objects and formatting functions in a single request
US10241758B2 (en) 2006-01-10 2019-03-26 International Business Machines Corporation System and method for serving multiple data objects and formatting functions in a single request
US9361276B2 (en) 2006-01-10 2016-06-07 International Business Machines Corporation System and method for serving multiple data objects and formatting functions in a single request
US8301997B2 (en) * 2006-01-10 2012-10-30 International Business Machines Corporation System and method for serving multiple data objects and formatting functions in a single request
US9608948B2 (en) * 2006-03-31 2017-03-28 Blackberry Limited Method for presenting an attachment within an email message
US20140059150A1 (en) * 2006-03-31 2014-02-27 Blackberry Limited Method for presenting an attachment within an email message
US20080104203A1 (en) * 2006-10-31 2008-05-01 Microsoft Corporation Viewing Digital Information Over a Network
US8826123B2 (en) 2007-05-25 2014-09-02 9224-5489 Quebec Inc. Timescale for presenting information
US11550987B2 (en) 2007-08-22 2023-01-10 9224-5489 Quebec Inc. Timeline for presenting information
US8788937B2 (en) 2007-08-22 2014-07-22 9224-5489 Quebec Inc. Method and tool for classifying documents to allow a multi-dimensional graphical representation
US10719658B2 (en) 2007-08-22 2020-07-21 9224-5489 Quebec Inc. Method of displaying axes of documents with time-spaces
US10430495B2 (en) 2007-08-22 2019-10-01 9224-5489 Quebec Inc. Timescales for axis of user-selectable elements
US10282072B2 (en) 2007-08-22 2019-05-07 9224-5489 Quebec Inc. Method and apparatus for identifying user-selectable elements having a commonality thereof
US9262381B2 (en) 2007-08-22 2016-02-16 9224-5489 Quebec Inc. Array of documents with past, present and future portions thereof
US9348800B2 (en) 2007-08-22 2016-05-24 9224-5489 Quebec Inc. Method of managing arrays of documents
US9690460B2 (en) 2007-08-22 2017-06-27 9224-5489 Quebec Inc. Method and apparatus for identifying user-selectable elements having a commonality thereof
US8069404B2 (en) 2007-08-22 2011-11-29 Maya-Systems Inc. Method of managing expected documents and system providing same
US9652438B2 (en) 2008-03-07 2017-05-16 9224-5489 Quebec Inc. Method of distinguishing documents
US8607155B2 (en) 2008-09-12 2013-12-10 9224-5489 Quebec Inc. Method of managing groups of arrays of documents
US8984417B2 (en) 2008-09-12 2015-03-17 9224-5489 Quebec Inc. Method of associating attributes with documents
US8924395B2 (en) 2010-10-06 2014-12-30 Planet Data Solutions System and method for indexing electronic discovery data
US9733801B2 (en) 2011-01-27 2017-08-15 9224-5489 Quebec Inc. Expandable and collapsible arrays of aligned documents
US9189129B2 (en) 2011-02-01 2015-11-17 9224-5489 Quebec Inc. Non-homogeneous objects magnification and reduction
US9588646B2 (en) 2011-02-01 2017-03-07 9224-5489 Quebec Inc. Selection and operations on axes of computer-readable files and groups of axes thereof
US9122374B2 (en) 2011-02-01 2015-09-01 9224-5489 Quebec Inc. Expandable and collapsible arrays of documents
US9058093B2 (en) 2011-02-01 2015-06-16 9224-5489 Quebec Inc. Active element
US10067638B2 (en) 2011-02-01 2018-09-04 9224-5489 Quebec Inc. Method of navigating axes of information elements
US9529495B2 (en) 2011-02-01 2016-12-27 9224-5489 Quebec Inc. Static and dynamic information elements selection
US20130346554A1 (en) * 2011-03-15 2013-12-26 Haoyu Ren Transmission processing method and apparatus, electronic device
US10289657B2 (en) 2011-09-25 2019-05-14 9224-5489 Quebec Inc. Method of retrieving information elements on an undisplayed portion of an axis of information elements
US10558733B2 (en) 2011-09-25 2020-02-11 9224-5489 Quebec Inc. Method of managing elements in an information element array collating unit
US9613167B2 (en) 2011-09-25 2017-04-04 9224-5489 Quebec Inc. Method of inserting and removing information elements in ordered information element arrays
US11080465B2 (en) 2011-09-25 2021-08-03 9224-5489 Quebec Inc. Method of expanding stacked elements
US11281843B2 (en) 2011-09-25 2022-03-22 9224-5489 Quebec Inc. Method of displaying axis of user-selectable elements over years, months, and days
US10845952B2 (en) 2012-06-11 2020-11-24 9224-5489 Quebec Inc. Method of abutting multiple sets of elements along an axis thereof
US11513660B2 (en) 2012-06-11 2022-11-29 9224-5489 Quebec Inc. Method of selecting a time-based subset of information elements
US9519693B2 (en) 2012-06-11 2016-12-13 9224-5489 Quebec Inc. Method and apparatus for displaying data element axes
US10180773B2 (en) 2012-06-12 2019-01-15 9224-5489 Quebec Inc. Method of displaying axes in an axis-based interface
US9646080B2 (en) 2012-06-12 2017-05-09 9224-5489 Quebec Inc. Multi-functions axis-based interface
US9098516B2 (en) * 2012-07-18 2015-08-04 DS Zodiac, Inc. Multi-dimensional file system
US10671266B2 (en) 2017-06-05 2020-06-02 9224-5489 Quebec Inc. Method and apparatus of aligning information element axes
US11704356B2 (en) * 2019-09-06 2023-07-18 Dropbox, Inc. Restoring integrity of a social media thread from a social network export

Similar Documents

Publication Publication Date Title
US6604144B1 (en) Data format for multimedia object storage, retrieval and transfer
US6269403B1 (en) Browser and publisher for multimedia object storage, retrieval and transfer
US5778372A (en) Remote retrieval and display management of electronic document with incorporated images
US6877007B1 (en) Method and apparatus for tracking a user's interaction with a resource supplied by a server computer
US5870767A (en) Method and system for rendering hyper-link information in a printable medium from a graphical user interface
US6035324A (en) Client-side asynchronous form management
US6657647B1 (en) Controlling the order in which content is displayed in a browser
US6505242B2 (en) Accessing page bundles on a portable client having intermittent network connectivity
US6304909B1 (en) Client-controlled link processing in computer network
US6427149B1 (en) Remote access of archived compressed data files
US6477529B1 (en) Apparatus and method for dynamically limiting information sent to a viewing device
US6571245B2 (en) Virtual desktop in a computer network
US7421515B2 (en) Method and system for communications network
US6344851B1 (en) Method and system for website overview
US20040133848A1 (en) System and method for providing and displaying information content
US7143181B2 (en) System and method of sending chunks of data over wireless devices
WO2004040481A1 (en) A system and method for providing and displaying information content
KR20000010691A (en) Providing communications links in a computer network
US20010047397A1 (en) Method and system for using pervasive device to access webpages
US20020116500A1 (en) Protocol for wireless devices
US7447738B1 (en) Component download selection mechanism for web browsers
US20050235036A1 (en) Intelligent URL redirector
EP1159663A2 (en) A system and method for content analysis and minimization
US6754700B1 (en) Method and apparatus for monitoring and adjusting bandwidth usage in a browser
US6721786B1 (en) Method and apparatus for balancing bandwidth usage in a browser

Legal Events

Date Code Title Description
AS Assignment

Owner name: MICROSOFT CORPORATION, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ANDERS, MARK;REEL/FRAME:014170/0319

Effective date: 19971008

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034541/0001

Effective date: 20141014

FPAY Fee payment

Year of fee payment: 12