The present invention relates in general to enterprise information systems. More particularly, the present invention relates to methods and apparatus for optimizing the delivery of data to a device.
Timely intelligence is critical to proper business decision making. Collecting and quickly analyzing information, however, is often difficult. In a dynamic marketplace, delayed delivery of intelligence can reduce both its reliability and relevancy. Substantial delays can even make the information, often acquired at considerable cost, completely worthless.
Intelligence is often extracted from OLTP applications and from specialized databases, called operational data stores. OLTP (online transaction processing) applications are those enterprise systems that manage a company's basic transactions, such as order entry and billing systems. Since they are commonly optimized for reading and writing, and not for querying, extracting information from an OLTP application can be sufficiently complex to require additional user training. Furthermore, while operational data stores generally archive OLTP information in a format for querying, they also generally do not maintain important historical information. For instance, an operational data store may store a current checking account balance, but not the individual daily balances over the previous month.
In addition, the queries themselves often take substantial time to execute, producing only static snapshots of the information. Observing the dynamic aspect of changing information is therefore difficult. A possible solution may be to sequentially execute and aggregate a series of queries. However, this solution can be both inefficient and ineffective, since manual manipulation still often delays the information delivery. That is, these queries must be first manually aggregated and summarized, before intelligence reports can be generated and delivered.
ETL (extraction, transformation, and loading) systems help by extracting, transforming, and aggregating the information. But latency inherently found in most distributed networks, coupled with considerable manual intervention that ETL systems often require, mean that critical information can still be received late.
Automatic notification is a possible solution. Many analytical products such as business intelligence (BI) and online analytical processing (OLAP) systems are capable of monitoring, scheduling, and broadcasting alerts via email or pager. These systems, however, cannot generally assure that the intended recipient promptly receives and reads the message. This presents a significant problem for time-sensitive information, where minutes or even seconds can make a difference.
To facilitate discussion,
OLTP (online transaction processing) applications 152 are commonly coupled to each other, as well as to other enterprise applications, through a dedicated messaging and queuing application (MQ), such as IBM's MQSeries. MQ provides an efficient communication channel for these applications, by storing and forwarding data messages, in a manner that is similar to email.
Commonly coupled to each OLTP application 152 is operational data store 154, such as an Oracle database. Through an API (application programming interface), transactional data can be transferred between the OLTP application and the database. Operational data store 154 consolidates that data from multiple sources and provides a near real-time, integrated view of volatile, current data. Since its purpose is to provide integrated data for operational purposes, operational data store 154 primarily has add, change, and delete functionality.
In order to conduct meaningful analysis, this information is often further placed in a more stable environment, optimized for random querying. ETL system 155 extracts the information from the appropriate data store 154, transforms and combines the data based on pre-defined constraints, and subsequently loads the data into data warehouse 156. A popular ETL technique, developed by Sagent, is the use of data flows.
Data flows are a series of rule-enabled transformations that are connected in data pipelines. They handle the tasks of joining, merging, comparing and splitting data and permit the separation of data into different logic paths, each of which can be further combined and split off to create more complex transformation sequences.
ETL data extractions often occur by either a bulk or a trickle method. In the bulk method, periodic snap shots of data in operational data store 154 are extracted and uploaded into data warehouse 156. This commonly occurs as a large batch file scheduled during a low system utilization period. In the trickle method, changes in operational data store 154 are continuously uploaded, or “trickled” into data warehouse 156. These updates are therefore frequent, smaller, and more current than in the bulk method. As in the case of OLTP 152 systems, ETL 155 can also use the MQ for data extraction.
Once the data is in data warehouse 156, it is available for OLAP 158 (online analytical processing). OLAP enables trained users to perform ad hoc analysis of data in multiple dimensions, such as with an OLAP cube. OLAP cubes provide multi-dimensional views of data, querying, and analytical capabilities. Furthermore, many OLAP products can schedule, run, publish, and broadcast reports, alerts and responses over the network, email, or personal digital assistant. Users often access OLAP 158 by thin client 162. Thin clients are applications that generally are integrated into the underlying client device, and generally require minimal modification. For instance, a thin client can be browser with a Macromedia Flash module installed.
Although OLAP analysis can provide valuable insight about business operations, critical information is often received late, even with automated reporting. Automated OLAP reporting often only has access to the information within data warehouse 156, which can be several processing stages behind OLTP 152. This delay can be substantial, reducing the information's value. Furthermore, these reports are often only static snapshots of information in data warehouse 156.
For example, a NASDAQ, broker places an order into an OLTP 152 application called an electronic communications network, or ECN. The ECN matches customer buy and sell orders directly through the computer. In this case, an order to buy 100 shares of ABC at $18.75 was entered. This open order is stored in the ECN operational data store 154, subsequently extracted by ETL 155, and analyzed by OLAP 158. If the buy order amount is the then highest in the ECN, OLAP 158 forwards the information to thin client 164, NASDAQ quote montage, where it is immediately displayed on the familiar stock market ticker tape. And although this system delivers stock information to individual brokers with reasonably small latency, it is also not easily modified. The NASDAQ application is custom designed for the specific purpose of enabling stock trading. As such, it would be difficult to display additional data on the stock ticker, such as non-financial information, without substantial additional programming.
In view of the foregoing, there is desired a method and apparatus for optimizing the delivery of data to a device, in which relevant information is received in a timely manner, and in which that data is rendered in a dynamic format.
The invention relates, in one embodiment, to a method of optimizing a first set of graphical display elements on a client device. The method also includes coupling a first server to the client device by a first connection; coupling a second server to the client device by a second connection; and generating the first set of graphical display elements on a first server, wherein the first set of graphical display elements further comprises a first graphical display element and a second graphical display element. The method further includes generating a second set of graphical display elements on a second server; transmitting the first set of graphical display elements from the first server to the client device; and transmitting the second set of graphical display elements from the second server to the client device, wherein a third set of graphical display elements is created in a first window comprising the first set of graphical display elements and the second set of graphical display elements. The method also includes generating a set of data stream elements on the first server, and further comprising a first data stream element and a second data stream element, wherein the first data stream element is associated with the first graphical display element, and the second data stream element is associated with the second graphical display element; and creating a second window on the client device, wherein the first set of graphical display elements is coupled to the second window, and the second server is coupled to the second window; and wherein the first graphical display element retrieves and renders the first data stream; and, the second graphical display element retrieves and renders the second data stream.
The invention relates, in another embodiment, to an apparatus for optimizing a first set of graphical display elements on a client device. The apparatus also includes a means of coupling a first server to the client device by a first connection; a means of coupling a second server to the client device by a second connection; and a means of generating the first set of graphical display elements on a first server, wherein the first set of graphical display elements further comprises a first graphical display element and a second graphical display element. The apparatus further includes a means of generating a second set of graphical display elements on a second server; a means of transmitting the first set of graphical display elements from the first server to the client device; and a means of transmitting the second set of graphical display elements from the second server to the client device, wherein a third set of graphical display elements is created in a first window comprising the first set of graphical display elements and the second set of graphical display elements. The apparatus further includes a means of generating a set of data stream elements on the first server, and further comprising a first data stream element and a second data stream element, wherein the first data stream element is associated with the first graphical display element, and the second data stream element is associated with the second graphical display element; a means of creating a second window on the client device, wherein the first set of graphical display elements is coupled to the second window, and the second server is also coupled to the second window; wherein the first graphical display element retrieves and renders the first data stream; and, the second graphical display element retrieves and renders the second data stream.
These and other features of the present invention will be described in more detail below in the detailed description of the invention and in conjunction with the following figures.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
The present invention will now be described in detail with reference to a few preferred embodiments thereof as illustrated in the accompanying drawings. In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art, that the present invention may be practiced without some or all of these specific details. In other instances, well known process steps and/or structures have not been described in detail in order to not unnecessarily obscure the present invention. The features and advantages of the present invention may be better understood with reference to the drawings and discussions that follow.
In accordance with one embodiment of the present invention, an active data architecture is advantageously employed to facilitate the presence-aware delivery of timely data. That is, determining the type of device available to the user, and delivering the information in a format within the device's capabilities. In accordance with another embodiment of the present invention, information can be continuously extracted from data sources without the need for manual queries, or additional user training. In accordance with another embodiment of the present invention, information may be dynamically delivered in order to render streaming real-time or near real-time data and/or analytical results, whether graphically, textually, audibly, or otherwise.
Referring now to
As in
Through the use of browser technology, such as DHTML, thin client 114 and a rich client 282 provide the user with enhanced visualization functionality, such as the capability to graphically render streaming data. Thin client 114, in one embodiment, is called active viewer, and comprises a browser. Rich client 282, in another embodiment, is called active viewer pro, and comprises a browser with additionally installed software. DHTML is a combination of HTML, style sheets, and scripts, and allows web-pages to be animated. In addition, rich client 282 further allows for enhanced functionality, such as pen-based user input, secure instant messaging, robust printing capability, and the use of skins. Skins are configuration files that allow modification of the browser appearance. Messaging client 115, such as a SMS cell phone, or an instant messaging program, such as Yahoo Messenger or Windows Messenger, provides alert capability. These alerts, as well as static reports, can also be received through thin client 114, such as a browser. Other 280 represents those enterprise applications that have been programmatically coupled to active data platform 210, as a client.
In one embodiment, client applications in client layer 142 can reside on a Tablet PC. The Tablet PC represents the evolution of the business notebook personal computer. It marks a new direction for notebook PCs, adding pen-based technologies to existing notebook functionality and enabling Windows XP-compatible applications to take advantage of various input modes, such as pen and voice-based data. The Table PC will be among the most versatile PCs ever made, with high-powered and efficient processors, lightweight designs, and, for man, built-in wireless capability. All Tablet PCs will have keyboards, some permanently attached and others detachable. But the Tablet PC is more than just a great notebook. The real value of the Table PC is that it makes it possible for information workers to bring he power of their business PC into more places than ever before, and they can do it with the same software they use on their office PC or notebook today.
For example, betting transactions would be normally stored in a casino's game transaction system. Wanting to be extra-attentive to high-rollers, a casino would configure the active data platform to observe for any customer whose betting exceeds a specified threshold, upon which an alert would be sent to the closest pit boss. The pit boss would locate these customers and personally oversee that exceptional customer service was provided.
Active data cache 256 is the core repository for the active data platform. Unlike traditional databases, such as operational data store 104 and data warehouse 106, active data cache 256 stores data in a de-normalized format. Normalization is the practice of optimizing the database structure into multiple tables, eliminating data redundancy and improving scalability and maintainability.
Since active data cache 256 is primarily focused on automatic reporting, and not on querying, it generates substantially de-normalized tables representing each report or data stream. By logically placing these de-normalized tables near client layer 142, in a non-obvious fashion, fewer processing stages are required and latency is substantially reduced.
Database tables are not commonly de-normalized, since data is duplicated. In general, duplicated data tends to increase the likelihood of data corruption during updates. That is, multiple separate entries no longer match each other. Furthermore, de-normalized tables tend to be more difficult to query than normalized tables, since each individual data record may be substantially larger, and hence take longer to search. This is even more so if the table is not properly indexed. However, since ad-hoc querying is not a substantial requirement, and table joins are not necessary, normalization enables database tables within active data cache 256 to be optimized for the efficient creation of pre-defined reports and alerts. In one embodiment, a single de-normalized table is the source for each report.
Active design process 290 is powerful, intuitive suite of applications that allow a user to create rules, map onto message queues, manage security, define data objects, and configure enterprise link 254 processes and sources, based on simple drag-and-drop operations for the data streams, reports, and alerts. In addition to active design process 290 in active data layer 241, there is a corresponding active design process client in client layer 142, such as a web browser. In one embodiment, active design process 290 comprises an application entitled architect. Unlike traditional real time business intelligence applications, active design process 290 allows a user to dynamically add new data sources, or create new transformations and reports, without changing the system as a whole. That is, unlike the NASDAQ stock trading example previously shown, which is not easily modified, active design process 290 can easily tailor the active data platform to new applications and changing corporate infrastructures.
Active report engine 274 converts the raw information in active data cache 256 into charts, tables, and graphs for display on a device in the client layer 142. Active studio 291 is a presentation editor that allows a user to easily create and format specific graphical and textual active views of data, based on pre-defined templates. Common views are tables, pie graphs, bar graphs, line graphs, scatter graphs, columnar reports, form reports, geographic (map) views, crosstabs, and Excel integration. For instance, a user can create an hourly report in which gambling customers are aggregated into different groups based on the value of their accumulated betting that day. The user selects a bar graph for the report, and changes the fill color and font type to the user's preference. These views can be substantially active, changing in near real time as the underlying data changes, or the can be static, like a printed report.
Event engine 257 monitors the information in active data cache 256 for pre-determined changes, or events. Once an event occurs, such as a rising temperature in a chemical processing plant, message center 272 is notified, subsequently forwarding the appropriate message to messaging client 115, thin client 114, or rich client 282.
In one embodiment, message center 272 tracks the presence of client devices, as well as the status of users themselves, in order to substantially assure message delivery. This is in contrast to traditional messaging systems that cannot determine if messages are, in fact, delivered to intended recipients. Presence determines if the device is available on the network. Status determines if the intended recipient is available to read and respond to the instant message. Common status categories include descriptive information, such as “out to lunch”, “busy”, “away from desk”, “important meeting”, etc. For instance, the device may be turned on and available, but the intended recipient is in an important meeting and does not wish to be disturbed. The intended recipient sets the status to “important meeting” in order to notify message center 272, as well as any other subscribed user, that he will probably not respond to the alert until after the meeting. Message center 272 would then choose an alternative available recipient, based on an established notification rule.
For example, a casino's active data platform attempts to notify the nearest pit boss of a particularly prolific gaming customer. However, since the pit boss has a “busy” status, the casino manager is alerted instead, and subsequently walks over to greet the customer.
Enterprise security system 258 represents a company's existing security infrastructure, such as Steel-Belted Radius by Funk Software. Since operational information may be sensitive, active data cache 256 can be integrated into enterprise security system 258. In this way users are authenticated before information is transmitted to client layer 142 devices.
Event engine 257 is further comprised of four logical components: event generator manager 428, rules manager 408, accountability manager 410, and actions manager 412. Event generator manager 428 maintains the state information of monitored events 402 for rules manager 408. Rules manager 408 is the primary event handler for the active data platform. Accountability manager 410 monitors the delivery status of all reports and alerts. And, actions manager 412 initiates actions based on input from the actions module 434 of the rules manager 408.
Event generator manager 428 maintains state information of monitored events 402 for rules manager 408. Constraint module 426 specifies the parameters that must be satisfied before evaluating an event and/or a condition and/or before applying the rule. Conditions module 424 maintains information for the corresponding conditions module 432 in rules manager 408. It further specifies attributes relevant to the specific event, other than constraints, which must be satisfied before the action associated with the rule may be taken. Events module 425 maintains event information for the corresponding events module 430 in rules manager 408.
Rules manager 408 further includes three components in order to manage active data: an events module 430, a conditions module 432, and an actions module 434. Events module 430 monitors all generated events 402 within the active data platform. Conditions module 432 filters out non-relevant events, and forwards the information to actions module 434, which in turn, initiates new system events based on criteria within rule sets 256. For example, all betting transactions are sent as events to event generator manager 428, which in turn sends the information to the events module 430 of rules manager 408. The conditions module 432 is configured to subsequently filter out all but the blackjack events. The actions module, based on rules 256, then creates an internal system event to instruct the active reports engine 274, as shown in
Accountability manager 410 monitors the delivery status of all reports and alerts. It further includes an unaccounted notifies module 438, and a report engine tie module 436. The unaccounted notifies module 438 maintains the status of undelivered alerts and reports. That is, unaccounted notifies module 438 determines if a recipient cannot be reached, subsequently forwards a delivery-incomplete message to rules manager 408. Report engine tie 436 monitors for successfully received reports and alerts, and subsequently forwards a delivery-complete message to rules manager 408. For example, a receipt notification status message is received in accountability manager 410, which is subsequently processed. If the receipt notification status message comprises an acknowledgment, report engine tie module 436 further processes the message and forwards the information to rules manager 408. However, if an acknowledgment is not received, unaccounted notifies module 438 processes the message and forwards the information to rules manager 408, which in turn allows active data cache to escalate alerts and reports to alternate recipients, based on status and presence, should the original recipient be unavailable.
Actions manager 412 initiates events and actions based upon input from the actions module 434. It further includes a notification module 416, a generate event module 414, a run a plan module 418, a web service/MQ module 420, and an others module 422. Notification module 416 forwards any report and alert non-delivery messages to unaccounted notifies module 438. Generate event module 414 generates system events initiated by actions module 434 in rules manager 408. Run a plan module 418 executes script based on rules 256. Web service/MQ module 420 provides an interface to third-party web-services based on WSDL (web-service description language), as well as message queue applications. Others module 422 is an API that allows additional modules to be later added.
Rich client 282 is comprised of a main application 536, a rendered reports 540 component, and a re-notify applet 506 component. Main application 536 provides the core environment for client interface to the active data cache 256. It comprises several functional components that can dynamically render incoming data streams from active data cache 256, and locally create reports, such as report builder 538. Rendered reports 540 functions as a viewer to display reports from active data cache 256 which already have been assembled. Re-notify applet 506 displays notification messages to the user.
In a non-obvious fashion, rich client 282 substantially maintains an open TCP-IP connection to active data cache 256, through the execution of blocking HTTP request in a second open browser window. Internet browsers normally implement HTTP, an asynchronous protocol that uses multiple short-lived synchronous TCP-IP connections to render the objects on a web page. For instance, a connection is opened, a picture is rendered, and the connection is closed. However, in the current invention, a web server periodically sends keep-alive messages to the second open browser window, in order to prevent a TCP-IP connection timeout. Through the use of this code, a TCP-IP connection is kept open, allowing data to be sent in a substantially continuous way to rich client 282, without having first to refresh the browser window. Thus, the dynamic rendering process in the primary browser window is more readily controlled. For example, the following JavaScript code may be executed by the second browser window:
Line 1: <script id=‘s1’>
Line 2: parent.ProcessActiveData(‘“+viewsetID+”’, ‘“+strXML”’);
Line 3: s1.removeNode(true);
Line 4: </script>
viewsetID indicates the viewset to which the active data applies, whereas strXML refers to an XML document describing new data. Line 1 indicates to the browser that the following section need not be rendered since it is a script section. The execution of line 2 causes the report in the main application (active studio or active viewer) browser to change. The execution of line 3 removes the script from the page. And line 4 indicates to the browser that the script section has ended.
Active data cache further comprises functional components that facilitate the generation of a report. These are: a report execution component 522, a view execution component 524, a report builder component 528, a rule builder component 530, a modifier builder component 532, data object builder component 534, a structured data supplier component 526, and a message center gateway 536.
Report execution 522 creates, caches, and then forwards specific reports based on configuration, to either rendered reports 540 for report builder 538. View execution 524 likewise creates and forwards views to report builder 538. Views are data objects that may be filtered. Report builder 528 pre-processes extracted information from multiple sources, and transforms the aggregated data into a format optimized for use in multiple reports. Rule builder 530 pre-processes stored rules from multiple rule caches for use in the generation of multiple reports. Modifier builder 532 pre-processes intermediate information transformations, such as additional metrics that the user wishes calculated and reported. Data object builder 534 pre-processes data objects into optimized formats for report execution component 522. Structured data supplier 526 forwards external pre-processed data to report builder 528.
API layer 605 provides a uniform application interface for system generated events, such as notification request 608, administration request 606, and presence request 604. Presence and notify component 612 provides the main messaging infrastructure for the active data platform. It insures that the reports and alerts are properly routed to intended recipients. Local user information 626 maintains a local cache of user profile information, such as names, passwords, and delivery preferences.
Rich client interface 614 is further coupled to rich client 282, which provides the user with enhanced visualization functionality, such as the capability to graphically render streaming data. Thin client interface 616 is coupled to thin client 112, which further comprises agent application 660. Since thin client 114 is commonly a browser without presence functionality, agent 660 notifies presence and notify component 612 that a given report or alert is being viewed. Agent 660 is commonly an Active X component or a java applet. Email interface 618 is further coupled to email server 632, such as an SMTP server, which forwards messages to email client 115a. IM interface is further coupled to IM client manager 628 which sends a notification request 630 to IM client 115b. Instant messaging (IM) is a means for sending small, simple messages that are delivered immediately to online users. It differs from email primarily in that its primary focus is immediate end-user delivery. Through an IM client application, a user can discover and immediately begin a text conversation, or chat session. Common public instant message systems include AOL Instant Messenger, MSN Messenger, Yahoo! Messenger, Microsoft Exchange 2000 IM, and Lotus Sametime.
For example, a casino's active data cache identifies particularly prolific gaming customer. The active data cache forwards a notification request 608 to message center 272. The presence & notify module 626 then determines if the intended user's device is present, and the user is available. If so, message center 272 forwards an alert through IM interface 620 to IM server 630, and finally to IM client 657.
Unlike like the prior art, the active data platform is general purpose, and is substantially customizable by entering new parameters in active design process 290 and the active studio 291, as shown is
Referring now to
The display is divided into three sections, a tab pane 701, a function pane 714, and a display pane 715. Tab pane 701 further allows the user to select one of various functional displays within active studio 304, such as: home 705, my reports 706, shared reports 707, personalize 708, and alerts 709. Home 705 comprises a summarized view of the user's most recent activities. My reports 706 comprises a summarized list of the user's created reports. Shared reports 707 comprises a summarized list of third-party reports to which the user has subscribed. Personalize 708 comprises administrative components that can allow the user to modify report delivery and display parameters. And alerts 709 comprises a summarized list of a user's active alerts.
Function pane 714 displays several functional list boxes within home 705 tab, such as: recent list box 710, new list box 711, list toolbox 712, and actions list box 713. Recent list box 710 displays the user's most recently accessed reports. The new list box 711 displays the user's new reports. The alerts list box 712 displays the user's currently active alerts. And the actions list box 713 allows the user to create and edit reports. Display pane 715 displays the corresponding result of the chose function of function pane 714. In this case, a dynamic financial report comprising a cost bar graph and a percentage change line graph. For example, if a user where to select intraday sales by region in the new list box 711, the corresponding dynamic intraday sales report would be displayed in display pane 715. As sales are booked through out the day, the sales chart would dynamically change as well.
Referring now to
Referring now to
Referring now to
Referring now to
In another aspect of the invention, an Iteration instant messaging & collaboration server is advantageously employed to enable rich secure graphical collaboration in an instant messaging environment. Instant messaging systems commonly monitor the presence of devices, and availability state of users. Presence determines if the IM device is coupled to the given IM network, or at least reachable from the client. Status determines if the intended recipient is available to read and respond to the instant message. Common status categories also include descriptive information, such as “out to lunch”, “busy”, “away from desk”, “important meeting”, etc. For instance, the IM device may be turned on and available, but the user is in an important meeting and does not wish to be disturbed. The user would set the status to “important meeting,” in order to notify other subscribed IM users that he will probably not respond to a text message until after the meeting.
These IM systems, however, commonly lack the capability for graphical peer-to-peer or multi-party collaboration. That is, while short text messages can be sent back and forth in an online chat meeting, there is no comparable means for sharing a graph or report. This would normally have to be compressed and transmitted ahead of time to each recipient, who would each then download, de-compress, and locally store the file. In situations where the underlying data is continuously changing, as temperatures would be in a chemical plant, and impromptu collaboration is desired, pre-mailing a graph would be very impractical, inefficient, and of marginal use to the problem at hand.
Furthermore, public IM systems are not particularly secure. They were originally designed for rapid information text conversations, called chat. IM protocols emerged and were established primarily without supervision from any standard bodies, such as the Internet Engineering Task Force. Subsequently, security was never originally considered and common instant messaging traffic is essentially unencrypted. Just about anyone on the network can secretly monitor a chat conversation.
User manager 811 manages user profile information. Users create profiles based on rules, in which they describe events of which they want to be notified. Should such an event occur, user manager 811 notifies message center 272, which in turn contacts the user. Furthermore, user manager 811 selects alternative recipients, if the primary recipient is unavailable, based on user preference and availability status. For instance, user #1 has configured user manger 811 for notification of a specific event, for example a temperature change beyond a certain range. Furthermore, user #1 also wants user #2 to be notified should user #1 be unavailable. Once the event occurs, if user #1 is unavailable, message center 272 attempts to notify user #2. Presence manager 813 monitors for the availability of user devices on the network. For instance, in the previous example, user #1 has a wireless PDA and a SMS phone. If the event occurs, and the PDA is turned-off, an alert is sent to the SMS phone instead.
IIM (Iteration instant messenger) interface 806 provides an interface to the IIM client 819-823, an enhanced IM application that allows secure concurrent graphical collaboration and pen-based user input. In general, it is sometimes desirable to implement private instant messaging systems having enhanced capability (including different protocols, encryption capabilities, graphical processing/display capabilities, I/O capabilities, and/or the like) compared to public messaging systems (such as those available from Yahoo™, AOL™, and the like). DM client is an example of a client in such a private instant messaging system.
IIM client 819-823 commonly connect through active collaboration server 817, which marshals collaboration request from multiple IIM clients, and combines connections whenever possible to improve overall system performance and scalability. Furthermore, active collaboration server 817 synchronizes the text and graphical portions of the IIM session to insure that all users view the same information at substantially the same time.
Active collaboration server 817 further enforces security protocols as implemented by the IIM client, in order to prevent unauthorized interception of the collaboration session. In one embodiment, IIM client 819-823 implements a Triple DES security protocol to protect the collaboration session and insure message integrity. Triple DES is an encryption algorithm whose security is based on a single secret key. Each key is generated (selected at random from all possible keys) for each particular collaboration session.
In another embodiment, only one user in an IIM collaboration session needs authorization to access a given alert or report. By virtue of being authenticated to the session, all other users will receive the alert or report with the security privileges of authorized user, for as long as these users participate in the session.
In addition to IIM interface 806, there is SMTP interface 807 and other IM interface 809. SMTP, or simple mail transfer protocol, is the most common protocol for sending email message on the internet. Through SMTP interface 807, message center 272 can forward email notifications with the event information to email server 815. Unlike IIM client 819-823, however, notification is not automatic. The user must first log onto mail server 815 with a SMTP client 827, such as MS Outlook and download the messages. Likewise, other IM interface 809 represents traditional IM interfaces to currently available IM systems 831, such as AOL Instant Messenger, MSN Messenger, Yahoo! Messenger, Microsoft Exchange 2000 IM, and Lotus Sametime. In contrast to SMTP, notification can be automatic, although communication is generally insecure. Furthermore, graphical collaboration is difficult.
For example, user #1 is a chemical engineer at a petroleum processing plant. He created a profile in user manager 811, in which he wants to be notified of specific event, such as a change in a process temperature beyond a certain range. The event occurs. Message center 272 forwards the notification to active collaboration server 817, through TIM interface 806. Seeing the temperature dynamically change on his device, user #1 realizes that he wants additional advice from user #2, his manager. Through his IIM device, he instructs message center 272 to initiate a request for collaboration with user #2. Receiving a collaboration request from his subordinate, user #2 accepts the connection. User #1's display is immediately rendered on User 2's device, upon which they collaborate on the matter at hand.
Referring to
For example, user #1 is a network systems engineer monitoring traffic at a company's e-commerce web site. When network congestion reaches a certain point, active report engine 274 generates a report and forwards it to user #1. Realizing that customers are starting to have difficulty placing online orders, user #1 initiates a connection with user #2, the web site manager, and user #3, the customer service manager. Once both accept, user #1's display is immediately rendered on the other devices, upon which all can collaborate on the mater at hand.
In another embodiment, an instant messaging manager is advantageously employed to rapidly alert intended recipients of data events. Referring to
Rules-based monitoring engine 916 monitors the applications in enterprise systems 902 for pre-defined events. A rule is s pre-defined procedure comprising the event(s) to be monitored, and the subsequent action or transformation that is required. For example, the event can be a specific transaction, a change in a file size, the publishing of a report, etc. Rules U/I 920 is typically graphical application that allows a user to create sophisticated and complex rules, as well as store the rules in the rules db 918 for use by rules based monitoring engine 916. In this case, the subsequent action is an alert.
When a specific event occurs, rules-based monitoring engine 916 forwards an alert to notification engine 924a, which properly formats the alert and transmits it via email system 915a, pager system 915b, or another system through proprietary API 915c. Alerts sent to email system 915a can further contain an embedded link to a report generated by active reports engine 274, as shown if
For example, betting transactions would be normally stored in a casino's game transaction system. Wanting to be extra-attentive to high-rollers, a casino would configure the rules based monitoring engine 916 to observe for any customer whose betting exceeds a specified threshold, upon which an alert would be sent to the closest pit boss with an embedded link to the customer record.
As in
Instant messaging manager 924b properly formats the alert as an instant message and transmits to the intended recipient through on of the various instant message systems 915d-f. Unlike notification engine 924a, however, instant messaging manager 924b also monitors the various instant message systems 915d-f for changes in state for any subscribed users. State is comprises of presence and status. Presence determines if the IM device is coupled to the given IM network, or at least reachable from the client. The given instant message system 915d-f normally determines the presence of individual IM clients, and broadcast the information to interested parties, such as the instant messaging manager 924b. Status determines if the intended recipient is able to read and respond to the instant message. Normally whether a recipient is available or not is a true or false question. However, it is common for recipients to customize the unavailable status with further descriptive information, such as “out to lunch”, “busy”, “away from desk”, “important meeting”, etc.
For instance, the IM device can be turned on and available, but the user is in an important meeting and does not wish to be disturbed. The user can set the status to “important meeting” notifying any other subscribed users that he will probably not be able to respond to the instant message until after the meeting. The rules-based monitoring engine 916, realizing that the user will not immediately read the instant message, will choose an alternative present and available user based on a pre-determined notification rule. Rules-based monitoring engine 916 can forward an alert to instant messaging manager 924b for immediate delivery to the intended recipient.
Referring now to
In another embodiment, an event engine is advantageously employed to substantially assure the examination of a report by a user. Many analytical products such as business intelligence (BI) and online analytical processing (OLAP) systems are capable of monitoring, scheduling, and broadcasting alerts via email or pager. These systems, however, cannot generally assure that the intended recipient promptly receives and reads the message. This presents a significant problem for time-sensitive information, where minutes or even seconds can make a difference.
In the current invention, the event engine monitors the state of transmitted alerts in an escalation table. Upon receipt of an alert, the user reviews the received report. This is commonly done by manually browsing for the report, or by clicking an embedded URL contained within the alert. If the user does not review the report within a specified time, the escalation table can further escalate the alert to another user based upon predefined rules. For instance, the alert is transmitted to the user's manager.
Referring to
Enterprise data 140 comprises those enterprise systems that manage a company's basic transactions, such as order entry and billing systems. Active data cache 256 monitors transaction data packets 1104 generated by enterprise data 140. Active data cache 256 further comprises user data manager 1108, which describes user event interest, and monitoring rule manager 1111, that analyzes data packet 1104 for specific events.
Should an event of interest occur, monitoring rule manager 111 forwards a rule fired message 1116 to the rules list manager 1120 of event engine 257. Rules list manager 1120 further comprises the subsequent actions required for the fired rule, such as the transmission of a notification message to a user, the execution of a subsequent rule, or the generation of an accountability escalation event. In this case, notification message 1130 is forwarded to message center 272. Rules list manager 1120 also places an entry into escalation table 1120, describing notification message 1130, the intended recipient, and the time the message was sent. If a report viewed message 1176 is not received within a pre-determined amount of time, a timeout occurs, and escalation table 1122 notifies escalation manager 1138, which in turn executes pre-configured escalation rules, such as notification of a different person or entity, or the calling of a web service.
Upon receiving notification message 1130, user address manager 1142 attempts to find a device address at which the user is currently available. Message center 272 further embeds a link in notification message 1146, through which the user can review the corresponding report from active reports engine 274.
The user subsequently receives notification message 1146 on his device, in this case, through a browser. If not already viewing the report, the user can either locate the report by manually entering information such as a URL, or can also simply click on an embedded link to the report.
Upon receiving a request, report supplier 1168 of report engine 274, generates the report from information in the active reports table 1170, and forwards it to user device 1150. A report viewed message 1176 is also generated and forwarded to escalation table 1122, which in turn deactivates the previous notification message entry.
For example, a large multi-site manufacturing organization, such as Ford Motor Company, would configure the active data platform to monitor manufacturing processing information, such as increasing part reject rates, or outright machine failures. Should a machine failure actually occur, an alert is forwarded to the appropriate manufacturing process engineer. The alert would contain an embedded link to the specific machine's status report, as generated by active reports engine 274. If the process engineer did not review the report within a few minutes (or any time period specified), a new alert would be immediately forwarded to the local plant manager for immediate action.
Referring to
In accordance with one aspect of the present invention, rule evaluation is advantageously distributed in order to improve efficiency. To further elaborate, a rule often comprises multiple interdependent components (i.e., event, constraint, condition, and action) that must be evaluated and acted upon.
The first component of a rule is the event, which specifies the event of interest. An example of an event is when the sales volume exceeds 5,000 units. If the sales volume exceeds 5,000 units, the event component is satisfied.
The second component of a rule is the constraint, which specifies the parameters that must be satisfied before evaluating an event and/or a condition and/or before applying the rule. A constraint is usually provided for efficiency reason and commonly comprises dates, times, and/or frequencies. For instance, if the specific event described in the event clause (e.g., sales volume in the previous example) does not need to be monitored over the weekend or between certain times or more often than a given frequency, then the constraint clause would instruct the event engine to that effect. Typically a constraint is evaluated to be either true or false. In one embodiment, if the constraint is evaluated to be false by the event engine, the satellite evaluation engine is informed accordingly and does not even need to spend its resources evaluating the event. Advantageously, efficiency is improved.
The third component of a rule is the condition, which further specifies other attributes relevant to the specific event, which attributes must be satisfied before the action associated with the rule may be taken. In the previous example, the condition may be to take action only if the sales volume that fires the event is achieved without any special promotion in place. Generally speaking, all conditions may be thought of as events but not all events are conditions.
The fourth component of a rule is the action, which determines the course of action taken should the event, constraint and/or condition components are satisfied. For instance, the sending of a notification to a specific person may be an action that needs to be taken if, as in the previous example, during a weekday (constraint satisfied), the sales volume exceeds 5,000 units (event satisfied) and the sales volume is achieved without any special promotion in place (condition satisfied).
It should be noted that a rule typically includes an action but a rule does not require all three other components, i.e., event, condition, and constraint. A rule may have one, two, or three of these components as desired by the rule designer. Furthermore, each of the event, condition, constraint, and action components may be a complex Boolean operation comprising multiple sub-components. A preferred embodiment, however, is a single event component per rule.
For example, an event may be satisfied if sales volume is greater than 5,000 and the total revenue is greater than $10,000 (a Boolean operation of two sub-events).
In order to reduce design complexity, a common solution has been to evaluate and execute these rules in a centralized event engine. It is found, however, that the information that needs to be monitored and evaluated can be found anywhere on the enterprise network. It is often the case that the information that must be monitored and evaluated (e.g., the event or condition) may be distributed in one or more machines (such as servers) remote from the computer executing the centralized event engine. In some cases, only 5% of the information may be relevant to a particular rule. Yet when the rule evaluation is centralized, all the data that needs to be monitored and evaluated must be transmitted across machine and/or process boundaries for the centralized event engine to perform its rule evaluation task. In a networked environment, the remaining 95% of the information that is needlessly sent represents an inefficient use of scarce network resources and bandwidth, as well as a detriment to performance.
In accordance with one embodiment of the invention, rule evaluation is distributed in one or more satellite evaluation engines local to or closer to the origin of the monitored information. The evaluation is distributed in satellite evaluation engines that are in communication with an event engine. Distributed rule evaluation allows the evaluation of a rule to take place with reduced bandwidth usage and delay. Since active data and the timely report/notification responsive to active data are important aspects of the active data platform, minimizing delay is an important consideration, and the distributed evaluation mechanism substantially furthers that goal.
To facilitate the implementation of distributed rule evaluation, it is highly preferable that a universal rule syntax be developed that allows the event engine to analyze any given rule and decides which portion of the rule should be distributed and which portion of the rule should be processed by the centralized event engine.
In accordance with one embodiment of the invention, a rule syntax is developed in which the four components of a rule (event, constraint, condition, action) are specified as clauses in a specific order to facilitate parsing.
For example, the following is a simplified example of a rule that may be executed:
Clause 1: ON viewset.changed(“QTD Sales”)
Clause 2: WITH OnlyDayWeek(“MON-FRI”)
Clause 3: IF Time.Between(9,17) AND Date.Endottuarter( )
Clause 4: DO notify.send(“Joe”, “email”)
Clause 1 describes the event to be executed by the satellite evaluation engine, in this case, the viewset application. The event is a change to QTD Sales information. Clause 2 comprises the constraint clause. It describes that the event will only be monitored from Monday to Friday. Clause 3 comprises the condition, further qualifying the situation that occasions the firing of the action. In this case, if the time was between 9:00 a.m. and 5:00 p.m. (i.e., 1700 hrs), and if the date corresponds to the end of the quarter. Clause 4 describes the action. In this case, the action is to send an email to user named Joe if the event, constraint, and condition are satisfied. Of course, these four components may be ordered in a different order if another syntax construct so dictates.
In accordance with one embodiment of the present invention, a rule is parsed to one or more core events, which are then distributed to one or more appropriate satellite evaluation engines to facilitate evaluation of the distributed event(s). In the previous example, the rule may be parsed and the event pertaining to the sales volume may be distributed to, for example, the satellite evaluation engine associated with the active data cache. The satellite evaluation engine then evaluates the monitored data (sales volume in this example) and communicates the result (which may be simply true/false or may include pertinent sales volume data) back to the event engine. Meanwhile, the event engine is offloaded from the task of handling that rule until the event is satisfied.
To further improve efficiency, the centralized event engine may not even parse all components of a rule until the event is satisfied. Thus, if an event is never satisfied, no resource has been wasted parsing the entire rule and preparing the centralized event engine and/or the satellite evaluation engine(s) to handle the other components (which may never need to be handled if the event is never satisfied). Further, the satellite evaluation engine may only send information back to the event engine if the event evaluates to be true. Thus, if the sales volume is below 5,000 in the previous example, no message is sent from the satellite evaluation engine to advantageously avoid wasting bandwidth. Of course, as mentioned earlier, the evaluation of an event may be held off by the satellite evaluation engine to further avoid wasting resource unless the constraint is evaluated to be true by the centralized event monitor.
If the event is evaluated to be true at the satellite evaluation engine (and assuming any applicable constraint is also evaluated to be true), the satellite evaluation engine informs the centralized event engine, which may then evaluate the condition using either the same or another satellite evaluation engine or using the centralized resource. If the same or a different satellite evaluation engine is also used to evaluate a condition, the event monitor may send out the parsed condition and ask for the result of the evaluation of the condition. As the exemplary syntax above indicates, each of the event, constraint, condition, and action may be (but not required in all cases) implemented as a function. Distributing rule evaluation thus may comprise using the appropriate satellite evaluation engine to make the required function call.
Referring to
Satellite evaluation engines 1036a-1036h are some exemplary satellite evaluation engines employed by the active data platform of
Other satellite evaluation engine 1306i represents additional events that can be programmatically monitored by event engine 257.
In accordance with another embodiment of the present invention, there is provided a universal function call syntax to facilitate the task of distributing certain aspects of rule evaluation to one or more satellite evaluation engines. As discussed above, the rule syntax allows an event, a constraint, a condition, or an action to be specified as a function. Thus, the function call syntax may have the following construct:
By creating a universal function call syntax, the invention substantially simplifies the task of specifying that a particular satellite evaluation engine should handle a particular event or condition. Furthermore, the function syntax improves scalability in that when a new satellite evaluation engine is added to the system, only the satellite evaluation engine name needs to be changed and the remainder of the syntax may be reused. Also, if a new event or condition is specified vis-à-vis an existing satellite evaluation engine, only the function name needs to be changed.
In one embodiment, a rule template library may be provided to allow users to leverage on work done by others. A rule template is simply a rule with certain argument(s) not completely specified. For example, a rule template may specify that if the sales volume exceeds 5,000 on a weekday and no special promotion is involved then notify person X. In this case, person X represents the argument that remains to be filled out to turn the rule template into a rule instance. In this example, the filling out of the person may be automatically accomplished by filling in the missing argument with the identity of the user accessing the rule template. In other cases, the missing arguments may be filled out by the user wishing to employ the rule template.
Of course the user can always edit existing rules (i.e., complete rule instances) to fit his needs. For example, the user can access an existing report and edit the rules therein to modify the arguments related to the event, condition, constraint, and/or action so that the newly created report would contain the information needed. The universal rule syntax renders it simple to implement rule templates and makes it easy for users to convert a rule template to a rule instance or to modify an existing rule to fit his needs.
In another aspect of the current invention, an active data architecture is advantageously employed to maintain application execution over an intermittent network connection. In one embodiment, the intermittent network connection is a wireless network, such as 802.11b. In another embodiment, the intermittent network connection is a wired network, such as Ethernet. In another embodiment, the data transmitted on the intermittent network connection is XML. In another embodiment, the data transmitted on the intermittent network connection is DHTML.
Modern data networks, such as the Internet, allow packets to arrive at their destination by multiple paths. However, since different portions of the network may be congested to different degrees, transmitted packets can sporadically arrive. Should the arrival delay between successive packets become sufficiently long, an intermittent connection results. Furthermore, in wireless networks, an intermittent network connection may also be caused by ambient radio interference, or by dead pockets, caused by multi-path. Multi-path is interference caused when signals bounce around between obstructions, creating multiple reflections of the same signal. Small changes in the spatial relationship between the transmitter and the receiver (i.e., by walking around) can substantially alter the extent of multi-path interference, and the subsequent degree of network connection intermittence.
For many applications, such as static web pages, an intermittent network connection is tolerable. Though potentially bothersome to a user, the utility of the web page is generally not diminished by the waiting a few minutes. For others, such as streaming applications, an intermittent network connection is problematic. These applications may require a continuous supply of packets in order to properly function, since they are generally designed to receive, buffer, render, and discard packets over a period of time. And although buffering a surplus of packets may improve perceived latency, upon depletion, the streaming application can freeze and even drop the connection altogether. Since this often requires the connection to be actively reestablished, should a user be subsequently preoccupied, reestablishment of the connection could be substantially delayed. Furthermore, in situations where the streaming information may be both urgent and dynamic, such as with active data, an opportunity for the user to react may be entirely lost.
A more optimum solution may be to provide functionality that allows the streaming application to temporarily pause and passively re-establish the connection for the user. In one embodiment, the streaming application comprises a communications browser window coupled to a rendering browser window, wherein the communications browser window maintains the connection, and the rendering browser window renders the received data stream. In yet another embodiment, this coupling is established through Microsoft JScript. In yet another embodiment, this coupling is established through Javascript. In yet another embodiment, the data stream is comprised of a set of event notifications. In yet another embodiment, the last rendered display is statically maintained during the reconnection period. In yet another embodiment, the user is notified that the connecting was lost.
Active studio 291 is further comprised of communications browser window coupled to a rendering browser window, wherein the communications browser window maintains the connection, and the rendering browser window renders the received data stream. In one embodiment of the present invention, a first rendering browser window establishes the connection by rendering an initial web page. The rendering browser window, in turn, instantiates a second communications browser window to receive and then forward updates to the rendering browser window. However, unlike in a common web page, the communications browser window maintains an open connection, never fully receiving the web page from the web server (e.g. since periodic active data updates are being received). Should the connection be interrupted (generating a JScript offload event), the communications browser may automatically attempt to reestablish the connection, and reload the web page again.
The functional components shown in
The process would again be repeated for the next chunk of data. That is, active studio 291 requests the next segment of data, or a chunk, from active reports server 274 at step 1520 (GetChangeList (Viewset ID, chunk_index=1)). Active reports server 274, in turn, forwards the request at step 1522 to report cache 1404. Report cache 1404 then determines if it contains the requested chunk of data at step 1524 (Check if cache (1)). Chunk 1 is not available in the cache, since it is the first time that the chunk has been requested. Report cache 1404, in turn, forwards the request at step 1526 to active data cache 256. Active data cache 256 generates the chunk and forwards it back to report cache 1404 at step 1528 (Active Data XML Chunk (1)). Report cache 1404 forwards the chunk to active reports server 274 at step 1530, as well as maintaining a local cached copy at step 1529 (Persist (1)). Active Reports server 274, in turn, forwards the chunk to active studio 291 at step 1532. The process would again be repeated for the next chunk of data.
At this point, however, the connection is interrupted and subsequently reestablished at step 1519. The last chunk that was received is once again requested at step 1540, (GetChangeList (Viewset ID, chunk_index=0)). Active reports server 274, in turn, forwards the request at step 1542 to report cache 1404. Report cache 1404 then determines if it contains the requested segment of data at step 1544 (Check if cache (0)). In this instance, since the chunk bad previously been requested, a copy has been cached. Report cache 1404, in turn, resends the chunk to active reports server 274 at step 1546. Active Reports server 274, in turn, forwards the chunk to active studio 291 at step 1548, passively completing the request.
In another aspect of the current invention, a browser can natively print a report in a substantially WSYIWIG format. The pervasiveness of browser technology has simplified the deployment enterprise software applications. Instead of mandating the installation of proprietary clients, which often can be costly to implement and frustrating to use, users can access the same enterprise applications through common Internet browsers, such as Netscape Navigator or Microsoft Internet Explorer. And in the case of Explorer, the browser is further integrated into the underlying operating system, requiring no additional installation.
Web page functionality was further enhanced with the introduction of embedded scripting languages, such as Microsoft JScript and Netscape Javascript. These scripting language instructions, embedded in the HTML page, can be subsequently interpreted and executed on the client browser, producing results that the user sees (i.e., drop down boxes, enhanced menus, popup windows, etc.).
Traditionally, web pages were designed to be viewed on many different platforms, from text-only terminals, to Macintoshes, to handheld computers. Since there was no way to know how the web page would be displayed (i.e., availability of fonts, ability to render images, etc.) the browser was designed to optimize the web page structure into a format that its host computer is equipped to display. In practice, it was therefore entirely possible for the web page to render differently on the screen of its reader than it did on the screen of its author. Furthermore, since the browser was primarily concerned with rendering the web page, and not in printing it, browser printed output was often problematic. For simple or small web pages, this was not necessarily a problem, since the entire rendered web page could be printed on a single printed page. However, the columnar or tabular reports generated by enterprise applications often would often span multiple printed pages.
Unlike modern word-processors, such as Microsoft Word, browsers do not generally print WYSIWYG (“What You See Is What You Get”). That is, web pages may be rendered without respect to the selected printer. Printing a web page generally causes the appropriate printer driver to map the rendered web page display to each printed page. However, the appearance of the printed page is generally dependent on client configuration (i.e., screen resolution, margin settings, paper size, paper orientation, type of printer, etc.). Since the web page was not originally rendered with the printer limitations in mind, as would be the case with a word processor, portions of the web page may be unexpectedly chopped off.
Furthermore, since printer drivers generally understand only the displayed screen pixels and not data objects, such as text or figures, portions of the rendered web page will either be lost (if they exceed the page's printable width), or printed on the following page (if they exceed the page's printable length). The result is text or figures that are split across a printed page boundary. And, unlike a word processor, navigation bars and sidebars will be printed as well. Any page breaks and frame boundaries, created by the web page designer, will also cause the print driver to forward subsequent pixels to the following page.
A possible solution is to copy the rendered data into a WYSIWYG application, like Microsoft Word, and then print. Simply copying, however, is problematic since it can be both time-consuming and error-prone. In the process of pasting data from the browser into the application, original formatting may be lost. And although text in paragraph form will simply wrap, remaining readable, tables and columns may transfer misaligned, causing information from one column or cell to appear to be in another. Careful error checking may therefore be required to insure data integrity. For particularly large reports, this may require several hours of work, creating a printing disincentive, and hence reducing the effectiveness of the enterprise application as a whole.
Another possible solution is for the web server to generate the web-page in a proprietary WYSIWYG format, such as in Microsoft Word or Adobe Acrobat. This, too, can be problematic since it requires the installation of a third party application which may further increase cost and complexity, or may not be available for a given client device. The browser, in essence, again becomes a proprietary client. Furthermore, the use of a proprietary format may also produce large documents, substantially increasing download latency.
Yet a third solution may be for the web server to provide a link for a separate printer friendly web page. Such a page would leave out navigation bars and sidebar information. A single web page, however, can be very large, again increasing download latency. Furthermore, printer friendly usually refers to the web page's printable width, and not its printable length. Since there is generally no way for the web server to discover the local client's configuration settings, figures and text may still be split across two printed page boundaries.
A more optimum solution may be to provide functionality that allows the browser to natively print active reports in a substantially WSYIWIG format. The active data architecture comprises two general types of reports: continuous columnar and tiled. Continuous columnar reports are comparable to common accounting spreadsheets in that they usually have column and report titles, as well as aggregate cells (i.e., subtotals, sums, etc.). These reports generally summarize or analyze some aspect of the underlying data, and are generally intended to be printed out in total. Tiled reports, by comparison, are more comparable to Microsoft PowerPoint slides. They can simultaneously comprise both lists (i.e., a sequential list of text and numbers without aggregates) and graphical display objects (i.e., charts, graphs, office web components, etc.). Furthermore, the tiled reports are optimized to allow the user to select and print just the relevant portion of the list.
Referring now to
Since transferring large web pages can be slow, the current invention transmits the continuous columnar report to the client browser in a series of smaller frames, each optimized to reduce latency. These frames are then rendered in separate independent browser windows, which are contiguously positioned without frame borders, to give the impression of a single large web page. The first frame, slightly larger than the display window, would generally render relatively quickly, creating the perception that the entire web page has arrived (since the hourglass is no longer visible), although subsequent frames may still be rendering. However, once the user manually scrolls down from the first frame, subsequent frames should have substantially rendered.
In this example, two frames are displayed, a first frame 1612 and a second frame 1616. The first frame 1612 has thirty lines (F1-L1 to F1-L30), while the second frame 1616 also has thirty lines, although only two lines (beginning at F2-L1) are displayed for purposes of illustration. The each line is further comprised of cells which may further include display elements (i.e., active data elements, aggregate elements, report titles, header text, footer text, etc.) contiguously arranged. Since the first frame 1612 is larger than display pane 1606, both vertically and horizontally, a user would subsequently need to use the scroll bars to see the hidden portions of the frame.
Active reports, unlike normally rendered web pages, can further be manipulated and customized by the users when in edit or print preview mode. For instance, columns can be re-sized (both width and height), re-positioned (swapping one column with another), and re-formatted (font type, font size, line borders, background color, etc). Function pane 714 further displays several functional list boxes within home 705 tab, such as actions list box 1609 which further comprises a print function 1611 (which allows the user to print the rendered report) and a print boundaries function 1610.
In traditional browser printing, printer output can be previewed by using the browser's print preview function. This function takes computer and printer configuration information (i.e., such as page size, orientation, margins, etc.), calculates the total amount of screen pixels that can fit on a printed page, and renders a static picture of that page in a new print preview window. As previous discussed, portions of the web page beyond the print boundaries will be chopped off. Any portion of the web page exceeding the printed page width will be completely lost, while any portion exceeding the printed height will be printed on the next page, potentially splitting text and figures between two contiguous pages. Furthermore, since the print preview window is essentially a static snapshot, the user is generally unable to manipulate elements on the page to fit within the displayed print boundaries.
In a non-obvious fashion, print boundaries function 1610 superimposes a set of non-printable guides 1608 identifying the printable areas of the columnar report, as rendered in display pane 715. Vertical row positioning can be further optimized to insuring that a page break does not occur in the middle of a row. Furthermore, unlike the traditional static print preview window, the user can manipulate the rendered report to fit within the displayed guides, allowing the active report to be printed in a substantially WYSIWYG manner. That is, users can both re-sized and re-positioned columns, as well as re-formatted font types and sizes.
Referring now to
Referring to
Depending on the set of rows selected, there are four possible situations that must be addressed. The first test determines if the FVR and the LVR are both within the parent frame at step 1764. If so, the rows above the FVR and below the LVR in the parent frame are hidden, at step 1772. If not, a second test determines if the FVR is in the parent frame and the LVR is in a child frame, step 1766. If so, the rows above the FVR in the parent frame, and the rows below the LVR in the child frame, are hidden at step 1774. If not, a third test determines if the FVR and the LVR are in the same child frame at step 1768. If so, the rows above the FVR and below the LVR are hidden in the child frame at step 1776. If not, a final test determines if the FVR is in a first child frame and the LVR is in a second child frame, at step 1770. If so, the rows above the FVR in the first child frame, and the rows below the LVR in the second child frame, are hidden at step 1778. At this stage, the remaining frames are hidden, at step 1780. Since the remaining visible rows fit within the printed page, the vertical scroll bar also disappears. The titled report is forwarded to the printer, at step 1780. At this point, all rows that were previously hidden are made visible, returning the vertical scroll bar, at step 1782.
Referring now to
Referring now to
In another aspect of the current invention, a user's rich client interface can automatically be optimized according to a set of characteristics. In one embodiment, the set of characteristics includes screen resolution. In another embodiment, the set of characteristics includes orientation. In yet another embodiment, the set of characteristics includes a specific open window. In yet another embodiment, the set of characteristics includes a specific task.
Client devices are becoming smaller, faster, mobile, and more ubiquitous. Mobile, handheld computers, computing appliances, and smart telephones allow computer support to be built into task situations. Such situations include new physical environments, where computers have been impractical up to now, and also new social environments, where, previously, computers imposed a formidable barrier to social interaction.
Many of these devices include displays that are substantially similar to traditional computer monitors. It is not uncommon for these devices to have both a portrait mode and landscape mode, depending on user preferences and application context. For instance, in a smart phone with a relatively small display, a contact list may be shown in a portrait mode to maximize the number of viewable entries, while a web browser would be displayed in a landscape mode, to maximize the display width.
Many devices also have sophisticated graphical operating systems that can simultaneously run multiple applications. These applications often allow users to customize their working environment, often called a workspace, in order to work more efficiently. A workspace configuration commonly comprises a set of customized application and display settings. Common application settings include printing preferences, visual style, mouse interaction, and keyboard shortcuts. Whereas display settings include rearranging, relocating, and resizing movable elements, such as toolbars and windows. These settings can often be saved and displayed again in subsequent sessions. In some applications, such as Adobe Illustrator, the settings are saved upon exiting the application. In others, such as Netscape Navigator, the settings must be saved by the user.
However, applications generally do not automatically optimize the user's workspace based on a change between portrait mode and landscape mode. Some applications simply relocate windows that would otherwise be outside the display boundary. The result may be a workspace that appears overly cluttered with overlapping windows. Other applications both relocate and proportionately resize windows. Although reducing clutter, the result also minimizes the effective work area. That is, if the change is from portrait to landscape mode, the display areas on the sides are not used. And if the change is from landscape to portrait mode, display areas at the top and bottom are not used. Still others do nothing, allowing windows to fall outside the display area. The result is that in many of these applications, the user must manually rearrange, resize, and relocate workspace elements in order to effectively user the application in the changed mode.
In a non-obvious fashion, the current invention allows an application to select a workspace configuration, from a set of default or user-defined workspace configurations, based on a set of characteristics. In one embodiment, the set of characteristics includes resolution. In another embodiment, the set of characteristics includes orientation. In yet another embodiment, the set of characteristics includes a current user task. In yet another embodiment, the set of characteristics includes time. In yet another embodiment, the workspace configuration is stored on a device other than the client device (i.e. the active data cache). In yet another embodiment, the workspace configuration can be retrieved to an alternate client device.
Referring now to
The characteristics are then checked at step 2006. For example, has the screen resolution changed from 800×600 to 1024×768, or has the orientation changed from portrait to landscape. At step 2008, if at least one characteristic has changed, the application determines if a saved workspace configuration exists which comprises the changed characteristics at step 2014. If at step 2008, no characteristics have changed, the characteristics are then again checked at step 2006.
If at step 2014, a saved configuration is found which comprises the changed characteristic, it is used at step 2016. The characteristics are then again checked at step 2006. If at step 2014, a saved configuration is not found, a default workspace configuration is used at step 2012. This default configuration is not optimized for any specific user, but rather includes generally accepted user preference. For instance, if possible, windows should not overlap. The characteristics are then again checked at step 2006.
Referring now to
Referring now to
In accordance with another aspect of the present invention, there are provided innovative methods and arrangements for efficiently displaying cross-tab data. As the term is employed herein, cross-tab data refers to aggregate data displayed in a cell of a table, which aggregate data is a mathematical function of other data items associated with other cells in the same table,
Da=f(D1,D2,D3 . . . Dn) (Equation 1)
Depending on the type of cross-tab analysis desired, the mathematical function f in Equation 1 above may represent any desired mathematical and/or statistical function. Da represents the aggregate data displayed in an aggregate data cell in the table, and D1-Dn represent data items displayed in other cells of the same table.
Generally speaking, the cells that contain values D1-Dn are cells that are disposed in the same row or in the same column with the aggregate data cell. With reference to
With reference to
A situation arises when the column function differs from the row function. Suppose, for example, that the column function is a sum function while the row function is an average function. In this case, the value in the aggregate data cell 2302 differs depending on whether the row function or the column function is employed to calculate the value in data cell 2302. The difficulty lies in deciding which value to display in aggregate data cell 2302.
One possible solution is to furnish an extra cell to facilitate the display of the aggregate data for both the column function and the row function, i.e., showing both the sum of the three cells above aggregate data cell 2302 and the average of the four cells to the left of aggregate data cell 2302. However, this approach doubles the space requirement for displaying aggregate data, thereby disadvantageously reducing the space available to display other data. Further, the simultaneous display of two aggregate data cells, one for each of the column function and the row function, may confuse users who are already familiar with the paradigm of viewing a single aggregate data cell at each intersection of a row and a column.
In accordance with one aspect of the present invention, there is provided a user-selectable function selector for determining whether the aggregate data cell disposed at the intersection of a row and a column would display the result calculated in accordance with the row function or with the column function.
In the example of
Note that it is not required that the value in the aggregate data cell must represent an aggregate of the values in the cells immediately adjacent to the aggregate data cell in the same row or the same column. For example, aggregate data cell 2510 is an aggregate of other aggregate data cells 2504, 2506, and 2508, which are not adjacent in the same column. As mentioned, the column function is employed since the user has selected in user-selectable function selector 2500 that the column function be employed to calculate the aggregate data value. It should be kept in mind that although the sum function is employed as an exemplary aggregate function in
As can be appreciated from the foregoing, the provision of the user-selectable function selector advantageously allows the user to select whether the row function or the column function will be employed to calculate the aggregate value displayed in an aggregate data cell at the intersection of a row and a column of a cross-tab table. Furthermore, the provision of the user-selectable function selector does not require the use of additional aggregate data cells to display aggregate data and/or require user to become familiarized with another way of displaying cross-tab data. With the present invention, only a single aggregate data cell with a single aggregate data value is provided at the intersection of a row and a column, which aggregate data value changes according to the selection made by the user-selectable function selector. Accordingly, efficient space utilization and user-friendliness are preserved while furnishing the user with a way to access both the row function aggregate data and the column function aggregate data.
In another aspect of the current invention, a report cache is advantageously employed in order to optimize network performance and scalability. In one embodiment, the report cache stores sets of data in memory. In another embodiment, the report cache stores sets of data on a hard drive. In yet another embodiment, the report cache stores sets of data as sets of memory mapped files.
Modern enterprise architectures often comprise distributed application elements connected across a data network, and optimized for task and usage. A common reason is scalability, since different portions of the enterprise architecture can be expanded without disruption to other elements. In the current invention, active data cache is coupled to various enterprise data sources, and subsequently offloads the caching of viewsets to a report cache. Active report server, in turn, requests and subsequently formats portions of the cached viewsets for proper rendering in active studio (i.e., transformation from XML to HTML), which may be located on the client device. A single client device can also comprise multiple simultaneously opened viewsets. Hence, the active data cache may scale with the volume of enterprise data, the report cache may scale with the number of opened viewsets, and the active reports server may scale with the number of users.
The active data cache is generally optimized for sequential access. That is, it receives, transforms, forwards, and subsequently discards active data. In one embodiment, this is done through the use of a forward-moving cursor (a variable that runs through a stored database table in one direction). While accessing data through a forward-moving cursor can make the active data cache very fast, is can also make other forms of access very inefficient or practically impossible (i.e., random access).
In a non-obvious fashion, a report cache is advantageously employed in order to optimize network performance and scalability, by offloading the caching of viewsets from the active data cache memory. A viewset (static de-normalized representations of information in active data cache) often comprises an initial large recordset of data, and a series of smaller changelists that represent subsequent changes to the recordset. Since browsers are often incapable of rendering a web page beyond a certain size (e.g. usually several megabytes), the client browser (through active studio) may request a much smaller subset of the recordset. However, since there is no guarantee that subsequent user requests will be sequential, the report cache is optimized for random access. For example, a recordset of over 1 million rows is forwarded from the active data cache to the report cache, along with a steady stream of changelists. Rows 1-100 are, in turn, forwarded to active studio on the user's device. The user then scrolls down, or moves to another page, and wishes to receive rows 1134-1233, followed by 8455-8554, and then 20-119. Without the use of a report cache, the active data cache would have to provide the rows. However, since active data cache is optimized for a forward moving cursor, and not random access, non-sequential row requests would be inefficient or impossible. Instead, the active data cache would have to keep all produced viewsets in memory to allow random access to them, potentially overwhelming the limited storage capability of the active data cache and its ability to process new active data.
The report cache is further optimized through the use of memory-mapped files. In one embodiment, memory-mapped files allow the report cache to map and access smaller portions of the recordset into memory as needed, without having to read the entire file into memory first. That is, when the report cache needs to access a set of rows in a recordset, a specific range of memory addresses are requested from the operating system, similar to accessing a byte array in memory. The operating system, in turn, automatically brings the appropriate pages from the hard drive, and maps them onto its memory space for efficient and rapid access by the report cache.
In another embodiment, asynchronous I/O is used for hard drive access. In common synchronous I/O, a process thread within an application must wait until a hard drive access is completed, in order to be informed of the success or failure of the operation. The execution of the process is blocked while it waits to be notified by the operating system. In a non-obvious fashion, processes within the report cache can initiate transfers to the hard drive using asynchronous I/O and still continue to execute. Instead of being blocked, the operating system notifies report cache once the transfer is complete. Non-blocking operations allow the report cache to continue to process other reads and writes to other memory-mapped files, further optimizing performance. Referring now to
In another embodiment, the file management system, combines read and writes in order to reduce disk access overhead which can be substantial (e.g., a single hard drive access can be over a million times slower than access to memory). In another embodiment, the physical files are of a fixed size. As active data is discarded and replaced, the same physical files are used, subsequently reducing external fragmentation on the hard drive. That is, the data would be stored in a substantially contiguous sequence of bits on the hard drive, instead of a set of non-contiguous linked fragments. Fragmentation can slow data access over time, as each fragment of a file must be accessed for the entire file to be read in.
In another embodiment, a set of active data reports is advantageously multiplexed in a client-server application, providing simultaneous views of multiple sources of active data. In one example, the source of the rendered active data reports is different from the source of the remaining displayed window elements. For instance, a web page would be generated by a web server, but would contain active data reports generated by another web server.
Each active data report further comprises one or more viewsets, as shown in
Referring now to
In a common non-multiplexed implementation of active studio 291, as shown in
In the present multiplexed application, each active data report is also displayed in an individual rendering browser window, within the multiplexed active data window. Without further enhancement, each would also generate and display its own active data window on the client. In addition to creating unnecessary screen clutter, each active data window would attempt to create a separate connection to the active data source. However, in many HTTP implementations, such as in Microsoft Internet Explorer, only two HTTP connections are allowed to a given source. The result would therefore be to limit the total number of rendered active data reports to just two.
In a non-obvious fashion, the multiplexed active data report has been further optimized to consolidate communication requests with other co-located active data reports, through a single instantiated active data window. The first active report to initiate rendering will generate an active data window, and subsequently set a cookie on the client containing a generated active data session ID. This active data session ID is a substantially unique identifier identifying a specific set of active data reports on a specific machine, used by a specific user, and for a specific period of time. In one embodiment, the active data session ID comprises a timestamp. Subsequently, other active data windows will check for the existence of a valid cookie, and if so, will not create an additional active data window, but rather refer to the existing one.
Referring now to
Referring now to
If the active data report is determined to be first at step 2908 (g_bIsFirstReport), it assigns c_strWinDataName as the active data target at step 2910 (formActiveData.Target=c_strWinDataName). c_strWinDataName is a constant string used by the active data window to set itself as the “feeding” active data window to all of the active reports. If the active data report is not first at step 2906, the active target is a hidden frame at step 2906 (formActiveData.target=“reportActiveDataFrame”+_strActiveReportID). All subsequent communication for the set of active data reports will now be channeled thorough the single active data window generated at step 2910.
The active data window is then assigned both the value of the active session ID at step 2912 (formActiveData.strActiveDataSessionID.value=g_strActiveDataSessionID), and the report ID at step 2914 (formActiveData.strActiveReportID.value=gstrActiveReportID). The value of g_bIsFirstReport is then assigned to the active data report at step 2916 (formActiveData.bOsForstReport.value=g_bIsFirstReport). As previously described, the first active report is true, and all others are false.
If the report is first, it is allowed to open the active data window at step 2920 (window..open(“ ”, c_strWinDataName, strFeatures)). At this point, each active data window, whether opened as a new window or a hidden frame, will submit a request for the change lists of its viewsets.
Referring now to
If the interruption exceeds the timeout period established in the active data platform (i.e., 3 minutes), the viewset will expire in the active report cache. The active report server, once notified of the viewset expiration, will cause the active data window to refresh all of the opened reports, close itself, and subsequently remove the cookie. The first active data report to finish refreshing will again generate a new active data window, and subsequently set a new cookie on the client containing a new generated active data session ID, thereby starting the process again.
The reports hash table is then initialized at step 3010. This hash table allows the active data window to quickly discover a reference to target active data report by its name. All active data reports then enable the pause button at step 3008 (EnablePauseActiveDataButton) enables pausing and resuming the active data stream for a given report. The active data is then retrieved at step 3012 (StartActiveData), which submits a form to a hidden frame, within the ActiveData, that subsequently receives the JScript events, and never fully loads.
Referring now to
If the report has already been closed at step 3104 (IsReportClosed (strActiveReportID)), then there is nothing further to do at step 3106 (Do nothing). Else, a reference to the report is obtained using the strActiveReportID at step 3108 (GetReport (strActiveReportID)).
AddReport is then called with this ID at step 3110 (AddReport (strActiveReportID)). If the active report ID is not contained within the hash table at step 3114 (IsReportAddded (strActiveReportID)), the window reference is obtained by asking the browser to open its window. Since the window should already be opened and initialized, its reference is returned in step 3112 (Open window by strActiveReportID name to get a reference to the report's window).
This window reference is then set as the oActiveDataFeed window in the report window at step 3116. The report is then retrieved from the report's window, and added it to the g_oReports hashtable at 3118. All active data windows then return the report from the g_oReports hashtable at 3121. And finally, the report's method to process active data is invoked through the obtained reference at step 3122 (oReport.ProcessActiveData (strViewsetId, iIndex, strXml)).
Referring now to
The first report opens it as a new window that holds an open connection to the client. All of the ActiveDataReaders will get a reference to the first ActiveData object that has the connection to the client, and will use it to stream the JScript event down to their ViewSets. This connection is used to stream the Jscript events down to the browser. WebPage 3212 profiles a reference to the Context.Response Object that is used to send the Jscript events. ActiveDataScripter 3214 creates the scripts to be sent down to the browser. DataFormatter 3218 formats ActiveData, 3216. DataManager 3220 is a singleton that reads ActiveData 3216 from the report cache. ReportCacheClient 3222 is a singleton that connects the report server to the report cache.
While this invention has been described in terms of several preferred embodiments, there are alterations, permutations, and equivalents which fall within the scope of this invention. For example, although reference is given to Sagent Business Intelligence Solutions, it should be understood that the invention can also integrate with other business intelligence and ETL solutions. It should also be noted that there are many alternative ways of implementing the apparatuses of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention.
Advantages of the invention include optimizing the presence-aware delivery of relevant information a device in a timely manner, and rendered in a dynamic format; and the continuous extraction of information from data sources without the need for manual queries, or the need of additional user training. Other advantages include synchronizing and validating a session by the use of cookies, and obtaining a reference to a second browser window from a first browser window using the “window.open” function by name.
Having disclosed exemplary embodiments and the best mode, modifications and variations may be made to the disclosed embodiments while remaining within the subject and spirit of the invention as defined by the following claims.
This application is a continuation of U.S. patent application Ser. No. 10/452,665, filed May 30, 2003, entitled “METHOD AND APPARATUS FOR A MULTIPLEXED ACTIVE DATA WINDOW IN A NEAR REAL-TIME BUSINESS INTELLIGENCE SYSTEM” which claims the benefit under 35 USC 119(e) of U.S. Provisional Application No. 60/410,989, filed Sep. 16, 2002, entitled “Business Intelligent System” by inventors Powers and Gardner, and under 35 USC 120 of a commonly assigned U.S. patent application Ser. No. 10/237,559, filed Sep. 6, 2002 entitled “ENTERPRISE LINK FOR A SOFTWARE DATABASE,” by inventors Powers and Gardner, the disclosures of which are incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
4403286 | Fry et al. | Sep 1983 | A |
5010478 | Deran | Apr 1991 | A |
5033009 | Dubnoff | Jul 1991 | A |
5283894 | Deran | Feb 1994 | A |
5289372 | Guthrie et al. | Feb 1994 | A |
5510980 | Peters | Apr 1996 | A |
5544329 | Engel et al. | Aug 1996 | A |
5550982 | Long et al. | Aug 1996 | A |
5553215 | Kaethler | Sep 1996 | A |
5592608 | Weber et al. | Jan 1997 | A |
5613131 | Moss et al. | Mar 1997 | A |
5615362 | Jensen et al. | Mar 1997 | A |
5654726 | Mima et al. | Aug 1997 | A |
5717895 | Leedom et al. | Feb 1998 | A |
5721847 | Johnson | Feb 1998 | A |
5754774 | Bittinger et al. | May 1998 | A |
5758337 | Hammond | May 1998 | A |
5765164 | Prasad et al. | Jun 1998 | A |
5778372 | Cordell et al. | Jul 1998 | A |
5781911 | Young et al. | Jul 1998 | A |
5784275 | Sojoodi et al. | Jul 1998 | A |
5787409 | Seiffert et al. | Jul 1998 | A |
5802492 | Delorme et al. | Sep 1998 | A |
5809267 | Moran et al. | Sep 1998 | A |
5812840 | Shwartz | Sep 1998 | A |
5831609 | London et al. | Nov 1998 | A |
5831615 | Drews et al. | Nov 1998 | A |
5835721 | Donahue et al. | Nov 1998 | A |
5857201 | Wright, Jr. et al. | Jan 1999 | A |
5862325 | Reed et al. | Jan 1999 | A |
5864669 | Osterman et al. | Jan 1999 | A |
5881239 | Desgrousilliers | Mar 1999 | A |
5890174 | Khanna et al. | Mar 1999 | A |
5893126 | Drews et al. | Apr 1999 | A |
5893150 | Hagersten et al. | Apr 1999 | A |
5898434 | Small et al. | Apr 1999 | A |
5918009 | Gehani et al. | Jun 1999 | A |
5922044 | Banthia | Jul 1999 | A |
5926177 | Hatanaka et al. | Jul 1999 | A |
5928327 | Wang et al. | Jul 1999 | A |
5930794 | Linenbach et al. | Jul 1999 | A |
5943620 | Boltz et al. | Aug 1999 | A |
5956716 | Kenner et al. | Sep 1999 | A |
5974236 | Sherman | Oct 1999 | A |
6023694 | Kouchi et al. | Feb 2000 | A |
6025844 | Parsons | Feb 2000 | A |
6031978 | Cotner et al. | Feb 2000 | A |
6035324 | Chang | Mar 2000 | A |
6038558 | Powers et al. | Mar 2000 | A |
6055548 | Comer et al. | Apr 2000 | A |
6070197 | Cobb et al. | May 2000 | A |
6073242 | Hardy et al. | Jun 2000 | A |
6075530 | Lucas et al. | Jun 2000 | A |
6088481 | Okamoto et al. | Jul 2000 | A |
6092102 | Wagner | Jul 2000 | A |
6094681 | Shaffer et al. | Jul 2000 | A |
6112236 | Dollin et al. | Aug 2000 | A |
6125177 | Whittaker | Sep 2000 | A |
6141659 | Barker et al. | Oct 2000 | A |
6161126 | Wies et al. | Dec 2000 | A |
6170019 | Dresel et al. | Jan 2001 | B1 |
6175859 | Mohler | Jan 2001 | B1 |
6182116 | Namma et al. | Jan 2001 | B1 |
6185582 | Zellweger et al. | Feb 2001 | B1 |
6189069 | Parkes et al. | Feb 2001 | B1 |
6201539 | Miller et al. | Mar 2001 | B1 |
6204846 | Little et al. | Mar 2001 | B1 |
6205474 | Hurley | Mar 2001 | B1 |
6208990 | Suresh et al. | Mar 2001 | B1 |
6219042 | Anderson et al. | Apr 2001 | B1 |
6226750 | Trieger | May 2001 | B1 |
6233578 | Machihara et al. | May 2001 | B1 |
6239797 | Hills et al. | May 2001 | B1 |
6240444 | Fin et al. | May 2001 | B1 |
6243698 | Powers et al. | Jun 2001 | B1 |
6243713 | Nelson et al. | Jun 2001 | B1 |
6256649 | Mackinlay et al. | Jul 2001 | B1 |
6256676 | Taylor et al. | Jul 2001 | B1 |
6260114 | Schug | Jul 2001 | B1 |
6269393 | Yost et al. | Jul 2001 | B1 |
6269403 | Anders | Jul 2001 | B1 |
6272493 | Pasquali | Aug 2001 | B1 |
6292803 | Richardson et al. | Sep 2001 | B1 |
6301601 | Helland et al. | Oct 2001 | B1 |
6301609 | Aravamudan et al. | Oct 2001 | B1 |
6304546 | Natarajan et al. | Oct 2001 | B1 |
6314463 | Abbott et al. | Nov 2001 | B1 |
6317737 | Gorelik et al. | Nov 2001 | B1 |
6324582 | Sridhar et al. | Nov 2001 | B1 |
6327592 | Yoshikawa | Dec 2001 | B1 |
6336135 | Niblett et al. | Jan 2002 | B1 |
6341312 | French et al. | Jan 2002 | B1 |
6348933 | Walls et al. | Feb 2002 | B1 |
6363363 | Haller et al. | Mar 2002 | B1 |
6393421 | Paglin | May 2002 | B1 |
6397217 | Melbin | May 2002 | B1 |
6397228 | Lamburt et al. | May 2002 | B1 |
6430576 | Gates et al. | Aug 2002 | B1 |
6430604 | Ogle et al. | Aug 2002 | B1 |
6449344 | Goldfinger et al. | Sep 2002 | B1 |
6467052 | Kaler et al. | Oct 2002 | B1 |
6480847 | Linenbach et al. | Nov 2002 | B1 |
6493000 | Wynn et al. | Dec 2002 | B1 |
6501956 | Weeren et al. | Dec 2002 | B1 |
6510457 | Ayukawa et al. | Jan 2003 | B1 |
6513047 | Talley | Jan 2003 | B1 |
6519568 | Harvey et al. | Feb 2003 | B1 |
6519601 | Bosch | Feb 2003 | B1 |
6523046 | Liu et al. | Feb 2003 | B2 |
6532465 | Hartley et al. | Mar 2003 | B2 |
6535227 | Fox et al. | Mar 2003 | B1 |
6542165 | Ohkado | Apr 2003 | B1 |
6546425 | Hanson et al. | Apr 2003 | B1 |
6553363 | Hoffman | Apr 2003 | B1 |
6567796 | Yost et al. | May 2003 | B1 |
6567814 | Bankier et al. | May 2003 | B1 |
6574618 | Eylon et al. | Jun 2003 | B2 |
6574639 | Carey et al. | Jun 2003 | B2 |
6591277 | Spence et al. | Jul 2003 | B2 |
6591278 | Ernst | Jul 2003 | B1 |
6598167 | Devine et al. | Jul 2003 | B2 |
6606596 | Zirngibl et al. | Aug 2003 | B1 |
6640234 | Coffen et al. | Oct 2003 | B1 |
6647272 | Asikainen | Nov 2003 | B1 |
6651055 | Kilmer et al. | Nov 2003 | B1 |
6651142 | Gorelik et al. | Nov 2003 | B1 |
6654790 | Ogle et al. | Nov 2003 | B2 |
6664978 | Kekic et al. | Dec 2003 | B1 |
6668173 | Greene | Dec 2003 | B2 |
6678719 | Stimmel | Jan 2004 | B1 |
6687360 | Kung et al. | Feb 2004 | B2 |
6701485 | Igra et al. | Mar 2004 | B1 |
6714982 | McDonough et al. | Mar 2004 | B1 |
6728763 | Chen | Apr 2004 | B1 |
6731314 | Cheng et al. | May 2004 | B1 |
6745193 | Horvitz et al. | Jun 2004 | B1 |
6763384 | Gupta et al. | Jul 2004 | B1 |
6766418 | Alexander et al. | Jul 2004 | B1 |
6775267 | Kung et al. | Aug 2004 | B1 |
6775298 | Aggarwal | Aug 2004 | B1 |
6775703 | Burns et al. | Aug 2004 | B1 |
6782424 | Yodaiken | Aug 2004 | B2 |
6789083 | Thelen | Sep 2004 | B2 |
6789090 | Miyake et al. | Sep 2004 | B1 |
6792456 | Hellerstein et al. | Sep 2004 | B1 |
6807562 | Pennock et al. | Oct 2004 | B1 |
6807583 | Hrischuk et al. | Oct 2004 | B2 |
6832341 | Vijayan | Dec 2004 | B1 |
6839737 | Friskel | Jan 2005 | B1 |
6870830 | Schuster et al. | Mar 2005 | B1 |
6898625 | Henry et al. | May 2005 | B2 |
6901592 | Mar et al. | May 2005 | B2 |
6907422 | Predovic | Jun 2005 | B1 |
6915457 | Miller | Jul 2005 | B1 |
6920607 | Ali et al. | Jul 2005 | B1 |
6937713 | Kung et al. | Aug 2005 | B1 |
6938221 | Nguyen | Aug 2005 | B2 |
6941345 | Kapil et al. | Sep 2005 | B1 |
6941351 | Vetrivelkumaran et al. | Sep 2005 | B2 |
6954757 | Zargham et al. | Oct 2005 | B2 |
6954902 | Noma et al. | Oct 2005 | B2 |
6975710 | Fujino et al. | Dec 2005 | B2 |
6996768 | Elo et al. | Feb 2006 | B1 |
7003568 | Chikada et al. | Feb 2006 | B1 |
7003731 | Rhoads et al. | Feb 2006 | B1 |
7024474 | Clubb et al. | Apr 2006 | B2 |
7028051 | McMullan et al. | Apr 2006 | B1 |
7028092 | MeLampy et al. | Apr 2006 | B2 |
7031314 | Craig et al. | Apr 2006 | B2 |
7032006 | Zhuk | Apr 2006 | B2 |
7035923 | Yoakum et al. | Apr 2006 | B1 |
7058953 | Willard et al. | Jun 2006 | B2 |
7089311 | Devine et al. | Aug 2006 | B2 |
7096432 | Huapaya et al. | Aug 2006 | B2 |
7113934 | Levesque et al. | Sep 2006 | B2 |
7113964 | Bequet et al. | Sep 2006 | B1 |
7120139 | Kung et al. | Oct 2006 | B1 |
7139797 | Yoakum et al. | Nov 2006 | B1 |
7171473 | Eftis et al. | Jan 2007 | B1 |
7174339 | Wucherer et al. | Feb 2007 | B1 |
7177909 | Stark et al. | Feb 2007 | B2 |
7187762 | Celi et al. | Mar 2007 | B2 |
7188160 | Champagne et al. | Mar 2007 | B2 |
7197565 | Abdelaziz et al. | Mar 2007 | B2 |
7221658 | Armstrong et al. | May 2007 | B1 |
7222294 | Coffen et al. | May 2007 | B2 |
7233979 | Dickerman et al. | Jun 2007 | B2 |
7243124 | Gardner et al. | Jul 2007 | B1 |
7243127 | Tabayoyon, Jr. et al. | Jul 2007 | B2 |
7243130 | Horvitz et al. | Jul 2007 | B2 |
7269625 | Willhide et al. | Sep 2007 | B1 |
7269627 | Knauerhase | Sep 2007 | B2 |
7272660 | Powers et al. | Sep 2007 | B1 |
7275215 | Werndorfer et al. | Sep 2007 | B2 |
7283805 | Agrawal | Oct 2007 | B2 |
7284034 | Matsa et al. | Oct 2007 | B2 |
7296217 | Earnshaw et al. | Nov 2007 | B1 |
7299257 | Boyer et al. | Nov 2007 | B2 |
7310532 | Knauerhase et al. | Dec 2007 | B2 |
7313593 | Pulito et al. | Dec 2007 | B1 |
7313617 | Malik et al. | Dec 2007 | B2 |
7349862 | Palmer et al. | Mar 2008 | B2 |
7353455 | Malik | Apr 2008 | B2 |
7359938 | Davies et al. | Apr 2008 | B1 |
7373428 | Armstrong et al. | May 2008 | B1 |
7379963 | Khare et al. | May 2008 | B1 |
7386588 | Mousseau et al. | Jun 2008 | B2 |
7389351 | Horvitz | Jun 2008 | B2 |
7392478 | Aureglia et al. | Jun 2008 | B2 |
7398327 | Lee | Jul 2008 | B2 |
7401158 | Beauchamp et al. | Jul 2008 | B2 |
7406569 | van de Waerdt | Jul 2008 | B2 |
7412438 | Schmitz et al. | Aug 2008 | B2 |
7412481 | Nicholls et al. | Aug 2008 | B2 |
7412486 | Petrack et al. | Aug 2008 | B1 |
7412518 | Duigou et al. | Aug 2008 | B1 |
7412645 | Kotler et al. | Aug 2008 | B2 |
7415502 | Vishik et al. | Aug 2008 | B2 |
7426059 | Broda et al. | Sep 2008 | B2 |
7433922 | Engstrom | Oct 2008 | B2 |
7436939 | Packingham | Oct 2008 | B1 |
7436947 | Ordille et al. | Oct 2008 | B2 |
7454423 | Powers et al. | Nov 2008 | B2 |
7461378 | Beyda | Dec 2008 | B2 |
7464139 | Malik | Dec 2008 | B2 |
7487437 | Aureglia et al. | Feb 2009 | B2 |
7499973 | Couts et al. | Mar 2009 | B2 |
7506243 | Kotler et al. | Mar 2009 | B2 |
7552204 | Bobde et al. | Jun 2009 | B2 |
7554938 | Smith et al. | Jun 2009 | B1 |
7627666 | DeGiulio et al. | Dec 2009 | B1 |
7631047 | Adamczyk | Dec 2009 | B1 |
7657616 | Poling et al. | Feb 2010 | B1 |
7664817 | Watanabe et al. | Feb 2010 | B2 |
7668915 | Couts et al. | Feb 2010 | B2 |
7668917 | Netsch et al. | Feb 2010 | B2 |
7725523 | Bolnick et al. | May 2010 | B2 |
7784275 | Marlett et al. | Aug 2010 | B2 |
7814208 | Stephenson et al. | Oct 2010 | B2 |
7870258 | Sundaresan et al. | Jan 2011 | B2 |
7899879 | Broda | Mar 2011 | B2 |
7904823 | Beauchamp et al. | Mar 2011 | B2 |
7912899 | Beauchamp et al. | Mar 2011 | B2 |
7925771 | Ping et al. | Apr 2011 | B1 |
7936815 | Dankworth et al. | May 2011 | B2 |
7941542 | Broda et al. | May 2011 | B2 |
7945846 | Beauchamp et al. | May 2011 | B2 |
8001185 | Nicholls et al. | Aug 2011 | B2 |
8161193 | Cain | Apr 2012 | B1 |
8165993 | Broda et al. | Apr 2012 | B2 |
8234453 | Sukegawa | Jul 2012 | B2 |
8255454 | Broda | Aug 2012 | B2 |
8266189 | Wagner et al. | Sep 2012 | B2 |
8351994 | Mansikkaniemi et al. | Jan 2013 | B2 |
8402095 | Beauchamp et al. | Mar 2013 | B2 |
8484370 | Coffee et al. | Jul 2013 | B1 |
8566693 | Beauchamp et al. | Oct 2013 | B2 |
8577989 | Broda | Nov 2013 | B2 |
20010034733 | Prompt et al. | Oct 2001 | A1 |
20010039616 | Kumagai et al. | Nov 2001 | A1 |
20010040945 | Fujino et al. | Nov 2001 | A1 |
20010049683 | Yoshikawa | Dec 2001 | A1 |
20010049721 | Blair et al. | Dec 2001 | A1 |
20020013853 | Baber et al. | Jan 2002 | A1 |
20020023143 | Stephenson et al. | Feb 2002 | A1 |
20020032602 | Lanzillo, Jr. et al. | Mar 2002 | A1 |
20020035597 | Khodko et al. | Mar 2002 | A1 |
20020038217 | Young | Mar 2002 | A1 |
20020038362 | Bhatia et al. | Mar 2002 | A1 |
20020056000 | Coussement | May 2002 | A1 |
20020057657 | La Porta et al. | May 2002 | A1 |
20020057678 | Jiang et al. | May 2002 | A1 |
20020059425 | Belfiore et al. | May 2002 | A1 |
20020059472 | Wollrath et al. | May 2002 | A1 |
20020065894 | Dalal et al. | May 2002 | A1 |
20020073236 | Helgeson et al. | Jun 2002 | A1 |
20020075299 | Tobin et al. | Jun 2002 | A1 |
20020075303 | Thompson et al. | Jun 2002 | A1 |
20020078208 | Crump et al. | Jun 2002 | A1 |
20020083067 | Tamayo et al. | Jun 2002 | A1 |
20020083072 | Steuart | Jun 2002 | A1 |
20020083118 | Sim | Jun 2002 | A1 |
20020095465 | Banks et al. | Jul 2002 | A1 |
20020103909 | Devine et al. | Aug 2002 | A1 |
20020107864 | Battas et al. | Aug 2002 | A1 |
20020107905 | Roe et al. | Aug 2002 | A1 |
20020107957 | Zargham et al. | Aug 2002 | A1 |
20020116362 | Li et al. | Aug 2002 | A1 |
20020116461 | Diacakis et al. | Aug 2002 | A1 |
20020120697 | Generous et al. | Aug 2002 | A1 |
20020120765 | Boehmke | Aug 2002 | A1 |
20020138640 | Raz et al. | Sep 2002 | A1 |
20020143710 | Liu | Oct 2002 | A1 |
20020147777 | Hackbarth et al. | Oct 2002 | A1 |
20020152402 | Tov et al. | Oct 2002 | A1 |
20020156901 | Erickson et al. | Oct 2002 | A1 |
20020165849 | Singh et al. | Nov 2002 | A1 |
20020178035 | Lajouanie | Nov 2002 | A1 |
20020178353 | Graham | Nov 2002 | A1 |
20020181506 | Loguinov | Dec 2002 | A1 |
20020184187 | Bakalash et al. | Dec 2002 | A1 |
20020194393 | Hrischuk et al. | Dec 2002 | A1 |
20020198985 | Fraenkel et al. | Dec 2002 | A1 |
20020199203 | Duffy et al. | Dec 2002 | A1 |
20030004742 | Palmer et al. | Jan 2003 | A1 |
20030009603 | Ruths et al. | Jan 2003 | A1 |
20030014513 | Ruths et al. | Jan 2003 | A1 |
20030018719 | Ruths et al. | Jan 2003 | A1 |
20030023691 | Knauerhase | Jan 2003 | A1 |
20030023742 | Allen et al. | Jan 2003 | A1 |
20030028597 | Salmi et al. | Feb 2003 | A1 |
20030028682 | Sutherland | Feb 2003 | A1 |
20030028683 | Yorke et al. | Feb 2003 | A1 |
20030033329 | Bergman et al. | Feb 2003 | A1 |
20030037103 | Salmi et al. | Feb 2003 | A1 |
20030037113 | Petrovykh | Feb 2003 | A1 |
20030041108 | Henrick et al. | Feb 2003 | A1 |
20030071850 | Geidi | Apr 2003 | A1 |
20030074393 | Peart | Apr 2003 | A1 |
20030084161 | Watson et al. | May 2003 | A1 |
20030088633 | Chiu et al. | May 2003 | A1 |
20030093585 | Allan | May 2003 | A1 |
20030101201 | Saylor et al. | May 2003 | A1 |
20030101223 | Pace et al. | May 2003 | A1 |
20030105837 | Kamen et al. | Jun 2003 | A1 |
20030110249 | Buus et al. | Jun 2003 | A1 |
20030112948 | Brown et al. | Jun 2003 | A1 |
20030115186 | Wilkinson et al. | Jun 2003 | A1 |
20030120805 | Couts et al. | Jun 2003 | A1 |
20030126136 | Omoigui | Jul 2003 | A1 |
20030131069 | Lucovsky et al. | Jul 2003 | A1 |
20030131142 | Horvitz et al. | Jul 2003 | A1 |
20030154177 | Holland et al. | Aug 2003 | A1 |
20030158873 | Sawdon et al. | Aug 2003 | A1 |
20030182428 | Li et al. | Sep 2003 | A1 |
20030182461 | Stelting et al. | Sep 2003 | A1 |
20030187971 | Uliano et al. | Oct 2003 | A1 |
20030204741 | Schoen et al. | Oct 2003 | A1 |
20030208543 | Enete et al. | Nov 2003 | A1 |
20030208600 | Cousins | Nov 2003 | A1 |
20030217081 | White et al. | Nov 2003 | A1 |
20030217142 | Bobde et al. | Nov 2003 | A1 |
20030218631 | Malik | Nov 2003 | A1 |
20030220860 | Heytens et al. | Nov 2003 | A1 |
20030220989 | Tsuji et al. | Nov 2003 | A1 |
20030225811 | Ali et al. | Dec 2003 | A1 |
20030229722 | Beyda | Dec 2003 | A1 |
20030235279 | Richomme | Dec 2003 | A1 |
20040002360 | Chun et al. | Jan 2004 | A1 |
20040002958 | Seshadri et al. | Jan 2004 | A1 |
20040003090 | Deeds | Jan 2004 | A1 |
20040010543 | Grobman | Jan 2004 | A1 |
20040019695 | Fellenstein et al. | Jan 2004 | A1 |
20040024822 | Werndorfer et al. | Feb 2004 | A1 |
20040024845 | Fishhaut et al. | Feb 2004 | A1 |
20040030762 | Silverthorne et al. | Feb 2004 | A1 |
20040031054 | Dankworth et al. | Feb 2004 | A1 |
20040039776 | Ballard | Feb 2004 | A1 |
20040039800 | Black et al. | Feb 2004 | A1 |
20040049477 | Powers et al. | Mar 2004 | A1 |
20040054802 | Beauchamp et al. | Mar 2004 | A1 |
20040060001 | Coffen et al. | Mar 2004 | A1 |
20040073596 | Kloninger et al. | Apr 2004 | A1 |
20040080504 | Salesky et al. | Apr 2004 | A1 |
20040087300 | Lewis | May 2004 | A1 |
20040117439 | Levett et al. | Jun 2004 | A1 |
20040146044 | Herkerdorf et al. | Jul 2004 | A1 |
20040152477 | Wu et al. | Aug 2004 | A1 |
20040199603 | Tafla et al. | Oct 2004 | A1 |
20040254998 | Horvitz | Dec 2004 | A1 |
20050004984 | Simpson | Jan 2005 | A1 |
20050055329 | Bakalash et al. | Mar 2005 | A1 |
20050086211 | Mayer | Apr 2005 | A1 |
20050102294 | Coldewey | May 2005 | A1 |
20050102611 | Chen | May 2005 | A1 |
20050114534 | Lee | May 2005 | A1 |
20050125377 | Kotler | Jun 2005 | A1 |
20050144114 | Ruggieri et al. | Jun 2005 | A1 |
20050187982 | Sato | Aug 2005 | A1 |
20060089939 | Broda et al. | Apr 2006 | A1 |
20060161440 | Nakayama et al. | Jul 2006 | A1 |
20060161540 | Schmitz et al. | Jul 2006 | A1 |
20060206589 | Lentini et al. | Sep 2006 | A1 |
20060259626 | Stone-Kaplan et al. | Nov 2006 | A1 |
20070192495 | Marais | Aug 2007 | A1 |
20080004904 | Tran | Jan 2008 | A1 |
20080043256 | Broda et al. | Feb 2008 | A1 |
20080046505 | Netsch et al. | Feb 2008 | A1 |
20080046506 | Broda | Feb 2008 | A1 |
20080046510 | Beauchamp et al. | Feb 2008 | A1 |
20080046536 | Broda | Feb 2008 | A1 |
20080046556 | Nicholls et al. | Feb 2008 | A1 |
20080046568 | Broda et al. | Feb 2008 | A1 |
20080046803 | Beauchamp et al. | Feb 2008 | A1 |
20080046837 | Beauchamp et al. | Feb 2008 | A1 |
20080077656 | Broda | Mar 2008 | A1 |
20080148289 | Nicholls et al. | Jun 2008 | A1 |
20080155020 | Beauchamp et al. | Jun 2008 | A1 |
20080209490 | Dankworth et al. | Aug 2008 | A1 |
20090031205 | Aureglia et al. | Jan 2009 | A1 |
20090037803 | Bauchot | Feb 2009 | A1 |
20110167169 | Ping et al. | Jul 2011 | A1 |
20110219336 | Mansikkaniemi et al. | Sep 2011 | A1 |
20120060078 | Beauchamp et al. | Mar 2012 | A1 |
20120254541 | Beckmann et al. | Oct 2012 | A1 |
20130007388 | Kito et al. | Jan 2013 | A1 |
Number | Date | Country |
---|---|---|
1126663 | Aug 2001 | EP |
0163466 | Aug 2001 | WO |
WO0155848 | Aug 2001 | WO |
Entry |
---|
U.S. Appl. No. 10/289,139, filed Nov. 5, 2002, Notice of Allowance mailed May 1, 2007, 6 pages. |
U.S. Appl. No. 10/289,139, filed Nov. 5, 2002, Office Action mailed Nov. 30, 2006, 14 pages. |
U.S. Appl. No. 10/289,139, filed Nov. 5, 2002, Final Office Action mailed Apr. 11, 2006, 16 pages. |
U.S. Appl. No. 10/289,139, filed Nov. 5, 2002, Office Action mailed Dec. 9, 2005, 14 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Notice of Allowance mailed Nov. 5, 2010, 9 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Office Action mailed Apr. 12, 2010, 12 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Final Office Action mailed Dec. 14, 2009, 9 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002 Office Action mailed Apr. 30, 2009, 10 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Final Office Action mailed Nov. 6, 2008, 10 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Office Action mailed Apr. 15, 2008, 12 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Final Office Action mailed Apr. 16, 2007, 15 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Office Action mailed Nov. 30, 2006, 13 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Final Office Action mailed Apr. 11, 2006, 15 pages. |
U.S. Appl. No. 10/289,231, filed Nov. 5, 2002, Office Action mailed Dec. 9, 2005, 17 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Notice of Allowance mailed Sep. 29, 2009, 7 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Notice of Allowance mailed Jun. 11, 2009, 9 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Final Office Action mailed Jan. 6, 2009, 11 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Office Action mailed Jul. 28, 2008, 12 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Advisory Action mailed Apr. 14, 2008, 3 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Final Office Action mailed Jan. 29, 2008, 14 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Office Action mailed Aug. 6, 2007, 11 pages. |
U.S. Appl. No. 10/289,155, filed Novemeber 5, 2002, Advisory Action mailed May 31, 2007, 3 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Final Office Action mailed Mar. 27, 2007, 12 pages. |
U.S. Appl. No. 10/289,155, filed Nov. 5, 2002, Office Action mailed May 18, 2006, 11 pages. |
U.S. Appl. No. 10/289,142, filed Nov. 5, 2002, Notice of Allowance mailed May 2, 2008, 5 pages. |
U.S. Appl. No. 10/289,142, filed Nov. 5, 2002, Notice of Allowance mailed Jan. 4, 2008, 9 pages. |
U.S. Appl. No. 10/289,142, filed Nov. 5, 2002, Final Office Action mailed May 30, 2007, 10 pages. |
U.S. Appl. No. 10/289,142, filed Nov. 5, 2002, Office Action mailed Dec. 4, 2006, 9 pages. |
U.S. Appl. No. 10/289,142, filed Nov. 5, 2002, Final Office Action mailed Apr. 24, 2006, 12 pages. |
U.S. Appl. No. 10/289,142, filed Nov. 5, 2002, Office Action mailed Dec. 20, 2005, 9 pages. |
U.S. Appl. No. 12/035,376, filed Feb. 21, 2008, Notice of Allowance mailed Mar. 18, 2011, 6 pages. |
U.S. Appl. No. 12/035,376, filed Feb. 21, 2008, Notice of Allowance mailed Jan. 25, 2011, 8 pages. |
U.S. Appl. No. 12/035,376, filed Feb. 21, 2008, Office Action mailed Sep. 15, 2010, 9 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Notice of Allowance mailed Dec. 30, 2010, 3 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Advisory Action mailed Sep. 23, 2010, 3 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Final Office Action mailed Jul. 7, 2010, 25 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Office Action mailed Oct. 27, 2009, 20 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Advisory Action mailed Jul. 20, 2009, 3 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Final Office Action mailed May 13, 2009, 18 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Office Action mailed Oct. 6, 2008, 20 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Advisory Action mailed Jul. 21, 2008, 3 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Final Office Action mailed Mar. 19, 2008, 12 pages. |
U.S. Appl. No. 10/391,128, filed Mar. 17, 2003, Office Action mailed Jul. 20, 2007, 9 pages. |
U.S. Appl. No. 10/390,945, filed Mar. 17, 2003, Notice of Allowance mailed Jun. 9, 2008, 7 pages. |
U.S. Appl. No. 10/390,945, filed Mar. 17, 2003, Notice of Allowance mailed Jan. 9, 2008, 7 pages. |
U.S. Appl. No. 10/390,945, filed Mar. 17, 2003, Final Office Action mailed Jul. 5, 2007, 9 pages. |
U.S. Appl. No. 10/390,945, filed Mar. 17, 2003, Office Action mailed Feb. 9, 2007, 8 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Notice of Allowance mailed Jan. 4, 2011, 14 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Final Office Action mailed Jun. 17, 2010, 28 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Office Action mailed Dec. 14, 2009, 25 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Final Office Action mailed Sep. 4, 2009, 24 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Office Action mailed Mar. 5, 2009, 20 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003ages, Advisory Action mailed Nov. 3, 2008, 3 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Final Office Action mailed Sep. 3, 2008, 17 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Office Action mailed Jan. 9, 2008, 16 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Final Office Action mailed Jun. 25, 2007, 17 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Office Action mailed Feb. 21, 2007, 16 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Final Office Action mailed May 18, 2006, 13 pages. |
U.S. Appl. No. 10/390,978, filed Mar. 17, 2003, Office Action mailed Sep. 1, 2005, 9 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Notice of Allowance mailed Oct. 28, 2010, 5 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Notice of Allowance mailed Aug. 13, 2010, 10 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Notice of Allowance mailed Mar. 25, 2010, 10 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Advisory Action mailed Dec. 11, 2009, 2 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Final Office Action mailed Aug. 28, 2009, 18 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Office Action mailed Feb. 3, 2009, 16 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Advisory Action mailed Dec. 3, 2008, 5 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Final Office Action mailed Sep. 17, 2008, 15 pages. |
U.S. Appl. No. 10/391,544, filed Mar. 17, 2003, Office Action mailed Sep. 8, 2006, 12 pages. |
U.S. Appl. No. 11/763,134, filed Jun. 14, 2007, Office Action mailed Jun. 21, 2012, 31 pages. |
U.S. Appl. No. 11/763,134, filed Jun. 14, 2007, Final Office Action mailed Nov. 24, 2010, 25 pages. |
U.S. Appl. No. 11/763,134, filed Jun. 14, 2007, Office Action mailed Jun. 3, 2010, 21 pages. |
U.S. Appl. No. 10/452,665, filed May 30, 2003, Notice of Allowance mailed May 30, 2012, 8 pages. |
U.S. Appl. No. 10/452,665, filed May 30, 2003, Notice of Allowance mailed Apr. 10, 2012, 3 pages. |
U.S. Appl. No. 10/452,665, filed May 30, 2003, Notice of Allowance mailed Feb. 7, 2012, 5 pages. |
U.S. Appl. No. 10/452,665, filed May 30, 2003, Final Office Action mailed May 9, 2007, 7 pages. |
U.S. Appl. No. 10/452,665, filed May 30, 2003, Office Action mailed Dec. 7, 2006, 8 pages. |
U.S. Appl. No. 10/289,162, filed Nov. 5, 2002, Notice of Allowance mailed Apr. 16, 2008, 13 pages. |
U.S. Appl. No. 10/289,162, filed Nov. 5, 2002, Notice of Allowance mailed Nov. 30, 2007, 12 pages. |
U.S. Appl. No. 10/289,162, filed Nov. 5, 2002, Final Office Action mailed Apr. 20, 2007, 8 pages. |
U.S. Appl. No. 10/289,162, filed Nov. 5, 2002, Office Action mailed Dec. 21, 2005, 12 pages. |
U.S. Appl. No. 12/039,471, filed Feb. 28, 2008, Advisory Action mailed Dec. 30, 2011, 3 pages. |
U.S. Appl. No. 12/039,471, filed Feb. 28, 2008, Final Office Action mailed Oct. 3, 2011, 20 pages. |
U.S. Appl. No. 12/039,471, filed Feb. 28, 2008, Office Action mailed Mar. 31, 2011, 19 pages. |
U.S. Appl. No. 12/039,471, filed Feb. 28, 2008, Advisory Action mailed Sep. 8, 2010, 2 pages. |
U.S. Appl. No. 12/039,471, filed Feb. 28, 2008, Final Office Action mailed Jun. 24, 2010, 20 pages. |
U.S. Appl. No. 12/039,471, filed Feb. 28, 2008, Office Action mailed Dec. 11, 2009, 13 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Notice of Allowance mailed Aug. 21, 2008, 9 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Office Action mailed Feb. 1, 2008, 12 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Advisory Action mailed Oct. 25, 2007, 3 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Final Office Action mailed Aug. 15, 2007, 13 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Office Action mailed Jan. 11, 2007, 10 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Final Office Action mailed Dec. 30, 2005, 10 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Office Action mailed Aug. 8, 2005, 11 pages. |
U.S. Appl. No. 10/237,559, filed Sep. 6, 2002, Office Action mailed Jan. 31, 2005, 11 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Notice of Allowance mailed Dec. 19, 2011, 16 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Office Action mailed Aug. 9, 2011, 35 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Advisory Action mailed May 18, 2011, 3 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Final Office Action mailed Mar. 7, 2011, 30 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Office Action mailed Oct. 26, 2010, 31 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Advisory Action mailed Sep. 2, 2010, 3 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Final Office Action mailed Jun. 25, 2010, 28 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Office Action mailed Jan. 5, 2010, 27 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Final Office Action mailed Sep. 11, 2009, 22 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Office Action mailed Feb. 4, 2009, 19 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Advisory Action mailed Dec. 16, 2008, 3 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Final Office Action mailed Oct. 3, 2008, 18 pages. |
U.S. Appl. No. 11/299,441, filed Dec. 12, 2005, Office Action mailed Feb. 5, 2008, 19 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Notice of Allowance mailed Oct. 27, 2010, 10 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Advisory Action mailed Aug. 23, 2010, 2 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Final Office Action mailed Jun. 17, 2010, 9 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Office Action mailed Jan. 19, 2010, 9 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Advisory Action mailed Sep. 18, 2009, 3 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Final Office Action mailed Jul. 30, 2009, 9 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Office Action mailed Feb. 12, 2009, 8 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Advisory Action mailed Oct. 28, 2008, 3 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Final Office Action mailed Sep. 12, 2008, 10 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Office Action mailed Jan. 4, 2008, 8 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Final Office Action mailed Jun. 21, 2007, 7 pages. |
U.S. Appl. No. 10/391,073, filed Mar. 17, 2003, Office Action mailed Feb. 8, 2007, 7 pages. |
U.S. Appl. No. 12/039,471, filed Feb. 28, 2008, Notice of Allowance mailed Dec. 24, 2012, 10 pages. |
U.S. Appl. No. 11/763,134, filed Jun. 14, 2007, Final Office Action mailed Feb. 12, 2013, 58 pages. |
Anton, J., et al., “Web Catching for Database Applications with Oracle Cache”, Proceedings of the 2002 ACM SIGMOD International Conference on Management of Data, ACM, 2002, pp. 594-599. |
Author Unknown, “Achieving Global Business Visibility With the webMethods Integration Platform,” webMethods, Inc., 2001, 40 pages. |
Author Unknown, “Adding Printing Capabilities,” Interactivetools.com, [online], posted Oct. 19, 2002, [retrieved on Mar. 4, 2004]. Retrieved from: http://www.interactivetools.com/iforums/Products—C.../Adding—Printing—capabilities P3026. 3 pages. |
Author Unknown, “An Introduction to Messaging and Queuing,” IBM Corp., 1995, 48 pages. |
Author Unknown, “Brocade Rapidly Implements Customer and Sales Analytics,” Informatica Corporation, 2002, 2 pages. |
Author Unknown, “Business Intelligence Software: Engendering a Quiet Revolution in the Business Place,” MicroStrategy, 2002, 15 pages. |
Author Unknown, “Business Rules,” Powering Business and E-Business, ILOG, 2001, 24 pages. |
Author Unknown, “Business Transformation Through End-to-End Integration,” International Data Corp., 2002, 17 pages. |
Author Unknown, “Data Warehousing Tutorial,” Paretoanalysts.com, [online], Retrieved on Oct. 7, 2004, 5 pages. |
Author Unknown, “Excel 2000 screen captures,” Microsoft Corp., 1999, 12 pages. |
Author Unknown, “Express Communicator,” ACD Systems Ltd., 2001, 22 pages. |
Author Unknown, “Extensible Markup Language (XML) 1.0 (Second Edition),” W3C, [online], 2000, [retrieved on Jul. 17, 2007]. Retrieved from: http://www.w3.org/TR/2000/REC-xml-20001006.html. |
Author Unknown, “Guidelines for Implementing and Using the NBS Data,” Federal Information Processing Standards Publication 74, 1981, 35 pages. |
Author Unknown, “ILOG Views 2D Graphics: The C++ Library for Interactive 2D Graphics,” ILOG, 2000, 2 pages. |
Author Unknown, “Implementing the RosettaNet eBusiness Standard: Automating High-tech Supply Chains Using Business Ware for RosettaNet,” Vitria Technology Inc., 2000, 16 pages. |
Author Unknown, “Informatica Applications: Informatica Customer Relationship Analytics,” Informatica Corp., 2002, 4 pages. |
Author Unknown, “Informatica Applications: Leverage Your Enterprise Information for Better Decision Making,” Informatica Corporation, 2002, 4 pages. |
Author Unknown, “Introduction to Dynamic HTML,” Microsoft Corp., [online], 2007, retrieved on Jul. 17, 2007. Retrieved from: http://msdn2.microsoft.com/en-us/library/ms533044(d=printer).aspx. |
Author Unknown, “Jabber: About: Technology Overview,” Jabber Software Foundation, 2003, 8 pages. |
Author Unknown, “JavaScript: MSIE 5 Unable to Print Child Window.” Experts Exhange LLC, [online], 2004, retrieved on Mar. 4, 2004. Retrieved from: http://www.experts-exchange.com/Web/.../viewQuestionPrinterFriendly.jsp?quid=1040733. |
Author Unknown, “Microsoft Excel Print Screen Images (figs. 1-6),” Jul. 5, 2007 in U.S. Appl. No. 10/390,945, 6 pages. |
Author Unknown, “Middleware—The Essential Component for Enterprise Client/Server Applications,” International Systems Group, Inc., 1997, 47 pages. |
Author Unknown, “MQSeries Link for R/3,” IBM Corp., 1998, 4 pages. |
Author Unknown, “Print Without Pop Up Window Using Javascript,” Experts Exchange LLC, 2002, 2 pages. |
Author Unknown, “Protecting the Enterprise from Rogue Protocols,” Akonix Systems, Inc., 2002, 11 pages. |
Author Unknown, “Relational OLAP: An Enterprise-Wide Data Delivery Architecture,” MicroStrategy, Inc., 1994, 17 pages. |
Author Unknown, “Sametime 3 Features and Benefits,” IBM Corp., available to Applicant by Mar. 21, 2005 at which time cited in U.S. Appl. No. 10/237,559, 1 page. |
Author Unknown, “Sametime for iSeries 2.5,” IBM Corporation, 2002, 2 pages. |
Author Unknown, “Scripting Support for Web Page Printing Sample,” Microsoft Corp., 2004, 3 pages. |
Author Unknown, “Steel-Belted Radius/Enterprise Edition,” Funk Software, Inc., 2004, 5 pages. |
Author Unknown, “The Basics of the Browser,” Santa Clara County Office of Education (SCCOE) Internet Institutue, [online], 1998-1999, [retrieved on Sep. 20, 2004], 7 pages. Retrieved from: http://www.etc.sccoe.org/i98/I98Binder/Text/Basics.html. |
Author Unknown, “The Business Intelligence Industry's Leading Products and Services,” Business Objects S.A., 2001, 6 pages. |
Author Unknown, “The Sagent Analytic Advantage,” Sagent Technology Inc., 2002, 25 pages. |
Author Unknown, “The Sagent Performance Story,” Sagent Technology, Inc., 2001, 19 pages. |
Author Unknown, “X Window System: Getting Started,” Stanford University, 2000, 6 pages. |
Author Unknown, Using Microsoft Excel 97, Bestseller Edition, Que Corp., 1997, 23 pages. |
Bernstein, Philip A. et al., “Data Warehouse Scenarios for Model Management,” ER Conference Proceedings, 2000, Springer-Verlag Berlin-Heidelberg, 17 pages. |
Brewster, S., “Windowing Systems,” Glasgow Interactive Systems Group, 2001. |
Cimino, S., “How Can I Print a Web Page in ASP?,” Internet.com [online], 2001, [retrieved on Mar. 4, 2004], Retrieved from: http://www.aspfaqs.com/ASPScripts/PrintFAQ.asp?FAQID=164. |
Corke, R., “Keeping Data Warehouse Current: Automating Incremental Updates with Data Movement,” DM Direct, 1999, 4 pages. |
Dabke, P., “Enterprise Integration Via Corba-Based Information Agents,” IEEE Internet Computing, Sep./Oct. 1999, vol. 3, Iss. 5, pp. 49-57. |
Day, M., et al., “A Model for Presences and Instant Messaging,” Request for Comments 2778, The Internet Society, 2000, 17 pages. |
Goldsmith, D. et al., “UTF-7: A Mail-Safe Transformation Format of Unicode,” Network Working Group, Request for Comments: 2152, 1997, 15 pages. |
Gwinn, Allen, “Simple Network Paging Protocol—Version 3—Two-Way Enhanced,” Network Working Group, Request for Comments: 1861, 1995, 23 pages. |
Habraken, J., “Lesson 6, Performing Calculations with Functions,” Ten Minute Guide to Microsoft Excel 2002, 2002, Que Corp., 2 pages. |
Handley, M., et al., “SIP: Session Initiation Protocol,” Network Working Group, Request for Comments: 2543, The Internet Society, 1999, 114 pages. |
Howlett, D., et al., “Delivering Value Back to the Business: A Guide to Successful Portal Selection and Implementation,” TIBCO Software Inc., 2002, 29 pages. |
Howlett, J., “Further Control of Printing,” Codestore, [online], 2002, [retrieved on Mar. 4, 2004]. Retrieved from: http://www.codestore.net/store.nsf/unid/EPSD-55TPMN?OpenDocument. |
Karn, P. et al., “The ESP Triple DES Transform,” Network Working Group, Request for Comments: 1851, 1995, 11 pages. |
Long, A., et al., “PDA and Gesture Use in Practice: Insights for Designers of Pen-based User Interfaces,” University of California at Berkeley, 1997, 5 pages. |
Loo, T., et al., “How Can I Print a Document That is Not Currently Loaded Into a Frame or Window?” FAQTS.com, [online], 2002, retrieved on Mar. 4, 2004. Retrieved from: http://www.faqts.com/knowledge—base/view.phtml/aid.14803. |
Moran, B., et al., “Getting to Know OLAP and MDX,” Windows IT Pro, Instant Doc #5112, 1999, 4 pages. |
Movva, R. et al., “MSN Messenger Service 1.0 Protocol, Internet Draft,” Internet Engineering Task Force, 1999, 19 pages. |
Nonsenko, A., “Scripting Support for Web Page Printing,” Microsoft Corporation, 2000, 5 pages. |
Oikarinen, J., et al., “Internet Relay Chat Protocol,” Network Working Group Request for Comments: 1459, 1993, 58 pages. |
Perfetti, C., et al., “Macromedia Flash: A New Hope for Web Applications.” User Interface Engineering, 2002, 18 pages. |
Pioch, N.,“A Short IRC Primer,” [online], 1993, retrieved on Sep. 20, 2004. Retrieved from: http://irchelp.org/irchelp/ircprimer.html. |
Richardson, T., et al., “The RFB Protocol,” ORL Cambridge, 1998, 26 pages. |
Roman, S., “Chapter 6: Functions and Subroutines,” Writing Excel Macros with VBA: Second Edition, O'Reilly Media, Inc., 2002, 4 pages. |
Schoedl, A., “Issues for Implementing User Interface Software,” Georgia Institute of Technology, 1998, 6 pages. |
Smith, J., “Browser Basics: Printing,” Jan's Illustrated Computer Literacy 101, [online], 2003, [retrieved on Feb. 10, 2003]. Retrieved from : http://www.jegsworks.com/Lessons/web/basics/printing.htm. |
Stephanidis, C., et al., “Design representations and development support for user interface adaptation,” Institute of Computer Science, Foundation for Research and Technology-Hellas, Greece, 1995, 14 pages. |
Tsai, Michael, “The Personal Computing Paradigm,” ATPM Inc., [online], 1998, [retrieved on Feb. 8, 2003]. Retrieved from: http://www.atpm.com/4.12/page7.shtml?print. |
Ünal, A., “Electronic Commerce and Multi-enterprise Supply/Value/Business Chains,” Information Sciences, Aug. 2000, vol. 127, Iss. 1-2, pp. 63-68. |
Wang, W., et al., “Instant Messaging Insight,” Computer Science Department, New York University, 2000, 19 pages. |
Watson, H., “Recent Developments in Data Warehousing,” Communications of the Association for Information Systems, 2001, vol. 8, pp. 1-25. |
Woods, B., “CypherGuard Secures MSN, Windows IM,” Jupitermedia Corp., [online], 2002, [retrieved on Sep. 29, 2010]. Retrieved from: http://web.archive.org/web/20101124102742/http://instantmessagingplanet.com/security/article.php/1475701. |
U.S. Appl. No. 10/289,155, Final Office Action mailed on Jan. 6, 2009, 11 pages. |
U.S. Appl. No. 10/289,155, Final Office Action mailed on Mar. 27, 2007, 12 pages. |
U.S. Appl. No. 10/390,978, Final Office Action mailed on May 18, 2006, 13 pages. |
U.S. Appl. No. 10/391,073, Restriction Requirement mailed on Jun. 30, 2006, 4 pages. |
U.S. Appl. No. 11/299,441, Advisory Action mailed on May 18, 2011, 3 pages. |
U.S. Appl. No. 11/299,441, Advisory Action mailed on Dec. 12, 2005, 3 pages. |
U.S. Appl. No. 11/763,134, Corrected Notice of Allowance mailed on Oct. 7, 2013, 7 pages. |
U.S. Appl. No. 11/763,134, Notice of Allowance mailed on Jun. 18, 2013, 12 pages. |
U.S. Appl. No. 13/079,436, Notice of Allowance mailed on Jun. 18, 2013, 20 pages. |
Muahlen et al., Workflow-based Processing Monitoring and Controlling—Technical and Organizational Issues, Proceedings of the 33rd Hawaii International Conference on System Science, 2000, pp. 1-10. |
Weiss, The Document Object Model Dissected, Jupitermedia Corporation, 2002. |
Number | Date | Country | |
---|---|---|---|
20130185349 A1 | Jul 2013 | US |
Number | Date | Country | |
---|---|---|---|
60410989 | Sep 2002 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10452665 | May 2003 | US |
Child | 13570474 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10237559 | Sep 2002 | US |
Child | 10452665 | US |