1. Field of the Invention
The present invention relates in general to computer network communications. In one aspect, the present invention relates to an apparatus, system and method for selectively deploying web page content.
2. Description of the Related Art
The largest and best-known computer network in the world is the Internet which includes millions of computers that are used for commercial, academic, entertainment and government endeavors. With the advent of graphics-based Web browsers (such as Mosaic, Netscape Navigator, and Internet Explorer), the World Wide Web enabled users to access the exponentially growing content provided on the Internet.
The design, assembly, creation and distribution of web page content 142 or other Internet-based functionality at the web server site 130 can be a complex and expensive undertaking, requiring significant time and expense to assemble a fully functional experience at the server 130. If it is ever necessary or desired that the web page content 142 or other Internet-based functionality at the web server site 130 be enhanced, modified, extended or otherwise altered, the code or architecture at the server 130 must be modified to include the additional content 144 as an alteration to the code or architecture at the server 130. This process is often time-consuming and expensive.
The difficulty of making changes to the code or architecture at the web server 130 also makes it difficult to demonstrate or test new features or functionality for the server 130. For example, the customer who owns a web server 130 may be reluctant to investigate or test new web page features for the web site 130 where the cost, time, risk and effort required to modify the code at the server 130 are significant in comparison to the perceived advantages of the new web page features. An additional challenge is the cost, time, risk and effort required to remove the new feature from the code on the server 130 if the feature demonstration or test is not successful.
To demonstrate the challenges presented by modifying a web site to include additional content 144, consider the example of adding recommendation content or functionality to a retail website hosted at server 130. In this example, the retail website server 130 was initially designed to include a web page content generator 142 which receives order information from the user/client computer 110 and assembles a web page which lists the purchased items contained in a cart for the user. If it is desired to add a purchase recommendation function to the web server 130, this additional functionality can be difficult to add because of the complexity of the required programming and data processing requirements. In particular, now that modern computers can assemble, record and analyze enormous amounts of data, historical transaction data can be collected and analyzed using data mining techniques to generate purchase recommendations for the user to consider based on discovering association relationships in a database by identifying frequently occurring patterns in the database. These association relationships or rules may be applied to extract useful information from large databases in a variety of fields, including selective marketing, market analysis and management applications (such as target marketing, customer relation management, market basket analysis, cross selling, market segmentation), risk analysis and management applications (such as forecasting, customer retention, improved underwriting, quality control, competitive analysis), fraud detection and management applications and other applications (such as text mining (news group, email, documents), stream data mining, web mining, DNA data analysis, etc.). Association rules have been applied to model and emulate consumer purchasing activities by describing how often items are purchased together. Typically, a rule consists of two conditions (e.g., antecedent and consequent) and is denoted as AC where A is the antecedent and C is the consequent. For example, an association rule, “laptopspeaker (80%),” states that four out of five customers that bought a laptop computer also bought speakers.
The difficulty of making recommendations increases as the number and complexity of mined association rules increases, which in turn is caused by an increase in the number of services and/or products, where each service or product may itself comprise a number of constituent services and products. The complexity of recommending a suitable configuration grows further with the number of constituent parts, the external needs of the customer, and the internal needs of the parts when considered as a whole. As will be appreciated, the code required to implement such a recommendation functionality can also be extremely complex so that there can be substantial time and expense required to add such functionality to the web server 130 as additional content 144.
As seen from the conventional approaches, a need exists for methods and/or apparatuses for improving the deployment of web page enhancements that can be quickly and easily integrated with existing web page server systems. There is also a need for improved use, deployment, demonstration and/or testing of data mining techniques to generate purchase recommendations for the end user while minimizing the need to change the coding or architecture at the web server site. There is also a need to seamlessly generate highly granular frequent sets and recommendations for use in an existing web server system without requiring coding changes at the web server. Further limitations and disadvantages of conventional systems will become apparent to one of skill in the art after reviewing the remainder of the present application with reference to the drawings and detailed description which follow.
In accordance with one or more embodiments of the present invention, a system and method are provided for generating and deploying additional web page content or functionality (e.g., retail recommendations) to an existing web page server system. For example, the present invention may be embodied as a recommendation appliance for introducing recommendation messages in a web page server system. The appliance may include a port for communicating with an end user machine that uses a web browser to issue web page requests and to display requested web pages. As will be appreciated, any type of port, including any communication connection methodology using wired or wireless techniques, can be used to communicate with the end user machine(s) and any web server machine(s). The appliance may also include a port for communicating with a web server machine that generates requested web page content in response to a webpage request from the end user machine. The functionality of the appliance is implemented with a processing device and a memory that stores instructions and data which cause the appliance to modify a received web page, such as by inserting recommendation content or functionality into a requested web page before it is forwarded to the end user machine. When a web page request is received from an end user machine, the appliance forwards the request through a port to a web server machine identified in the web page request. In addition, the appliance uses data received from the end user machine (e.g., recommendation context information associated with the end user) to generate additional content or instructions for display to the end user (e.g., creating a purchase recommendation message) or to specify some other modification to be made to the requested web page. As a result, when the requested web page having original web page content is received at the appliance from the server machine, the appliance modifies the original web page content (e.g., inserts the purchase recommendation message or otherwise deletes, inserts or modifies all or part of the original web page content in real time), thereby generating a modified web page, and then returns the modified web page through the first port to the first end user machine. Thus, the modified web page may include content that is static, passively interactive or interactive, in which case the appliance is configured and programmed to respond to any response from the end user machine in response to the interactive content that was not included in the original web page content.
The appliance may also include instruction-based functionality for separating a plurality of end user machines or web page requests into two or more groups, where the first group is to receive modified web pages and the second group is to receive requested web pages that are not modified. The appliance may then separately record transaction activities (e.g., purchase activity) of the first and second groups, so that the transaction activities may be compared to demonstrate the effectiveness of the web page modification.
As will be appreciated, the appliance can be implemented as a reverse proxy server that is operatively coupled in a variety of ways as an intermediate node in a web server system, such as by using a first port to couple the appliance to a load balancing server or other network node and using a second port to couple the appliance to a web server, to a load balancing server (which in turn is operatively coupled to a plurality of web servers), or to another network node.
The objects, advantages and other novel features of the present invention will be apparent from the following detailed description when read in conjunction with the appended claims and attached drawings.
An improved method and apparatus are described for generating and deploying additional, altered or enhanced web page content or functionality (e.g., attribute-based retail recommendations) to an existing web page server system. While various details are set forth in the following description, it will be appreciated that the present invention may be practiced without these specific details. For example, selected aspects are shown in block diagram form, rather than in detail, in order to avoid obscuring the present invention. Some portions of the detailed descriptions provided herein are presented in terms of algorithms or operations on data within a computer memory. Such descriptions and representations are used by those skilled in the computer network communications and data processing arts to describe and convey the substance of their work to others skilled in the art. In general, an algorithm refers to a self-consistent sequence of steps leading to a desired result, where a “step” refers to a manipulation of physical quantities which may, though need not necessarily, take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It is common usage to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. These and similar terms may be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions using terms such as processing, computing, calculating, determining, displaying or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and/or transforms data represented as physical, electronic and/or magnetic quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
Referring now to
In the example of
As will be appreciated, other network arrangements may be used to modify a user interface that is generated by a remote server in response to a user request.
In whatever network arrangement is used, the content modification function may be advantageously implemented as a reverse proxy server to effectively change the content or functionality of the user interface from the server or application. For example, the reverse proxy server 230 may be used to add content 236 (such as instructions for the user) to the content 242 from the local web server or application (e.g., server 238) that is requested by one or more users 201, 202 over a computer network. This content change in the user experience can be implemented by the server 230 in a way that is seamless for the end user(s) and without requiring any change or modification to the code or architecture of the local web server 238.
In operation, the user (e.g., 202) requests a web page by pointing its web browser to the reverse proxy (e.g., 230), or alternatively a network administrator configures the computer network 206 to automatically direct the user 202 to the content modification server 230 instead of the local web server or application (e.g., server 238). The content modification server 230 receives the request for the application from the user 202 and fetches the requested web page URL from the retail web server 238 identified in the web page request. However, before the content 242 from the retail web server 238 is returned to the user 202, the content modification server 230 determines whether any additional content or functionality is to be added to the requested application. For example, the content modification server may analyze data contained in the request from the user 202, or may analyze historical data associated with the user 202, or may analyze the web page content returned from the retail web server 238. Various examples of such data analysis are described in connection with the generation of purchase recommendations based on attribute-based association rules, such as described in the U.S. patent application Ser. No. 10/870,360 (entitled “Attribute Based Association Rule Mining” and filed Jun. 17, 2004), U.S. patent application Ser. No. 10/912,734 (entitled “System and Method for Generating Effective Recommendations” and filed Aug. 5, 2004), U.S. patent application Ser. No. 10/912,743 (entitled “Retail Recommendation Domain Model” and filed Aug. 5, 2004), and U.S. patent application Ser. No. 10/912,699 (entitled “System and Method for Efficiently Generating Association Rules” and filed Aug. 5, 2004), each of which is assigned to Trilogy Development Group and is hereby incorporated by reference in its entirety. Thus, the result of the data analysis may be the generation of new content 236 recommending one or more products for purchase by the user 202 and the insertion of the new content 236 into the web page content 234 that is to be returned to the user 202.
If content modification is required, the content stream 242 from the retail web server 238 may be transformed at the content modification server 230 by deleting, inserting or modifying the content stream in real time before it is sent back to the user 202. In accordance with selected embodiments of the present invention, any new or modified content (referred to as instrumented content) 236 can be completely static, such as when additional textual information is inserted into the web page. In addition or in the alternative, the new or modified content 236 may include interactive content to provide interaction functionality allowed by HTML form elements. In addition or in the alternative, the new or modified content 236 may offer passive content interaction, such as sending a message back to the content modification server when a user moves a mouse icon over, out of or clicks on an HTML element.
As will be appreciated by persons of ordinary skill in the art, the ability of the content modification server 230 to transform the original web page content 242 will require that the content modification server be programmed to “understand” the design, structure, layout and other display-related requirements of the web page content 242 generated by the retail web server 238 and expected at the browser of the user 202. In this way, content modifications can be made without impairing the information contained it the original web page content 242. In addition, if interactive content 236 is added to the web page content 234 to be displayed to the user 202, the reverse proxy 230 may be configured to intercept this interaction which was not in the original application 242, and thus would not be understood by the retail web server 238. In a selected embodiment, the content modification server 230 takes responsibility for taking any action required as a result of receiving notice of the user's interaction with the application having such an interactive content.
Referring now to
As depicted in
In a selected example of how content modifications are generated, a first data set of transaction information is stored in a memory or database 314 that may be accessed directly or indirectly by the server 311. In this example, the first data set identifies the items included in one or more transactions (such as contained in the native order history 351) by including a generic product descriptor 316, 318 for each transaction item, such as the SKU for a purchased product. Thus, a hard drive that was purchased is identified with the hard drive SKU 316 and a desktop computer is identified with the desktop SKU 318. In addition or in the alternative, the first data set of transaction information identifies normalized catalog data 353, customer order-related information, product identifiers for items purchased by the end user and/or other recommendation context data 309 associated with the user at a web client 313.
A transformation or normalizer process 305 maps or otherwise transforms the first data set of transaction information into a second data set of transaction information that provides more detailed information identifying with greater specificity the attributes of the specified product(s). As indicated, if only one of the input data sets (e.g., the cart data 309) requires normalization, then a single normalizer process 305 is used, but if the order history data 351 or the native catalog data (not shown) requires normalization, then separate instances of the normalizer process 305 may be used. In a selected embodiment, the data transformation is implemented with a computer or other data processing functionality (e.g., server 311) which loads a copy of the first data set (e.g., 316, 318 from a database 314) into local memory (e.g., 315). As will be appreciated, the first data set may represent items from the customer cart 309, or may represent items from prior transactions in the order history database 351. Using a product detail knowledge database (such as contained in the domain model schema 352) and/or the normalized catalog database 353 that specify various product feature details for each transaction item, the server 311 invokes the normalizer process 305 to map or transform the generic product descriptors of the first data set (e.g., 316, 318) into a second data set (e.g., 354) that specifies additional details and/or features for the item of interest, such as more detailed product descriptor information. In the depicted embodiment, part numbers in an order (e.g., 316, 318) may be mapped to a part group identifier and to a set of attribute names and values (e.g., 323-326, 327-334, respectively) and stored in the database 314. For example, an 80 Gb, 7200 RPM, SCSI drive identified with the HD-SKU 316 could be mapped to the following numerical, attribute-based transaction items:
_Hard_Drive
_Hard_Drive._Size. 80 Gb
_Hard_Drive._RPM. 7200
_Hard_Drive._Interface. SCSI
In accordance with the invention described herein, the transformation of the native cart or order history data may also use qualitative or time-variant attribute values to represent the normalized data. Such time-variant attribute values can be useful where the relevancy of recommendations, whether automatically or manually generated, can expire over time as new technologies appear or new products are offered. For example, a processor that was the highest performing in its class six months ago is no longer the highest performing in its class today. As a result, the recommendations generated six months ago may no longer be useful if the changes to the product offering and technology over time are not taken into account. Manual recommendation updates are burdensome in requiring, at one extreme, replacement of outdated recommendations with new, but similar, recommendations, and at the other extreme, modifying existing recommendations. To address this problem, the normalizer process 305 may also include a transformation process for adjusting the values of attributes in the normalized data sets 353, 354, 355 to account for the changing technologies and product offerings over time. Products that were “high performance” or products that were “state-of-the-art” at the time the recommendations were originally generated may be adjusted to “moderate performance” or “middle-of-the-road technology.” For example, an 80 Gb, 7200 RPM, SCSI drive identified with the HD-SKU 316 could be mapped to the following qualitative, attribute-based transaction items:
_Hard_Drive
_Hard_Drive._Size.Medium
_Hard_Drive._RPM.Medium
_Hard_Drive._Interface.High
These items are included in a second data set 322 as an entry 323-326 which quantifies the consumer preferences for one or more products and associated product features and which is organized or stored in a structured format, such as a database or table. In this example, the original item description 316 is now expanded and represented by a PartGroup identifier 323 and three attribute items 324, 325, 326. In similar fashion, the original item description 318 for a desktop computer is expanded and represented by a PartGroup identifier 327 and seven attribute items 328-334 (in this example) that are stored as an entry in the second data set 322. These additional attribute items 328-334 specify the processor speed 328, processor class 329, operating system type 330, hard drive size 331, optical drive type 332, software package type 333, and monitor type 334 for the desktop item.
Because of the additional product detail information contained in the second data set (e.g., normalized transaction history 354), it can be used in transaction database applications to provide more meaningful frequent pattern analysis that is performed by the analytics engine 306. A broad variety of efficient algorithms for mining association rules have been developed in recent years, including algorithms based on the level-wise Apriori framework, TreeProjection and FPGrowth techniques. For example, association rules may be generated from the expanded second data set of transaction information that is included as part of a transaction database 340 representing the normalized transaction history 354, as indicated with entries 340a-g in
In the example of
Once the association rules 343 are finalized (which may optionally include an optimization to remove redundant rules), the recommendation engine 308 is invoked to process the recommendation context information generated by the cart 309 to identify potentially matching association rules which are to be further processed for possible issuance as recommendations 360 to be inserted in the requested web page returned from the retail web server 370. To this end, a normalizer process 305 may be executed to generate a normalized representation of the recommendation context 309 based on the domain model schema 352 and/or normalized catalog 353, which may be stored as a normalized transaction data set 355. The normalized transaction representation 355 may be used by the recommendation engine 308 to identify association rules from the mined rules 343 that match the recommendation context 309. For example, the recommendation engine 308 may include a rule evaluation process for evaluating the mined rules 343 against the normalized transaction representation 355 (e.g., [f, c]) to generate a list of candidate rules whose trigger evaluated to true (e.g., R1, R2, R3) in response to the recommendation context 309. In addition, the recommendation engine 308 may exclude any matching rules that do not meet a minimum confidence requirement, leaving only high confidence rules in the candidate rule set. The above-referenced Trilogy patent applications incorporated herein by reference provide additional details concerning the process for generating association rules, for processing, prioritizing, scoring and filtering candidate recommendation rules, and for generating selling point messages to accompany the recommendation rules.
As a standalone or integrated server node, the recommendation appliance apparatus 300 depicted in
As an additional useful demonstration feature, the identification routine 302 may be used to segregate web page requests in a predetermined fashion for purposes of demonstrating the effectiveness of the added content and/or functionality provided by the recommendation appliance apparatus 300. The segregated requests may then be tracked in the user history tracking database 362 to determine how the modified content affected the behavior of the end users. As but one example, a predetermined percentage of web clients submitting web page requests may be filtered or separated out from the remaining web clients by the identification routine 302 to receive purchase recommendations using any desired predetermined recommendation technique (such as time-based filtering, end user identification-based filtering, etc.). Other requests may receive recommendations using a different recommendation technique or may receive no recommendation at all. By assembling transaction purchase data for all the clients in the user history tracking database 362 and comparing the purchase behavior of clients that received recommendations with that of clients that did not receive recommendations (or that received different recommendations), the effectiveness of the recommendation engine or different recommendation techniques may be assessed. With this implementation of the recommendation appliance apparatus 300, the effectiveness of a content modification may be demonstrated without requiring any changes or revisions to the coding or architecture of the retail web server 370. In addition, if the content modification is demonstrated to be ineffective, the content modification may be easily removed by simply removing the recommendation appliance apparatus 300 and connecting the retail access server 320 directly to the retail web server 370, again without requiring any changes or revisions to the coding or architecture of the retail web server 370. Other useful selective modification examples include presenting a different user interface to the end user.
In accordance with selected embodiments of the present invention, an intermediate computing or network node is used to add content or functionality to a user interface or to otherwise enhance, modify, extend or alter the user interface as it is being returned to the requestor. While present invention may be used to modify the user interface in any desired manner,
In operation, a web page request from the client machine 402 is transmitted over a network (e.g., intranet/internet 404) and received by the reverse proxy server 408, where it is forwarded to the web server 420. Based on information contained in or associated with the web page request and/or in response to programming or data contained in memory or storage 422, the web server 420 generates a web page (e.g., web page 424) and sends the generated web page 424 back to the user computer 402. However, the reverse proxy server 408 that is located in the communication path between the client machine 402 and the web server 420 may modify the returned web page 424 to insert additional content and/or functionality, thereby producing a new or modified web page 426. In particular, simultaneously with or subsequent to forwarding of the web page request, the reverse proxy server 408 determines if the requested web page 424 should be enhanced, modified, extended or otherwise altered before being returned to the client machine 402. This determination can be made in a variety of ways, including, but not limited to, using a simple look-up table techniques, using association rule mining techniques to identify content or functionality that is associated with the web page request or the requested web page, or to otherwise correlate additional content or functionality with data contained in or associated with the web page request from the end user. In the example depicted in
Turning now to
The description of the method can begin at step 502, where the intermediate network node receives the user request from the client machine or end user. In a selected embodiment, the intermediate node also receives or accesses recommendation context data from the end user that is associated with the user request. The mechanics of obtaining the recommendation context can be accomplished by a variety of ways, such as by retrieving quote information from the customer cart or by obtaining information from outside of a cart, such as from a simple product page, a configuration page, or even a user's click-path/browse-path/user session history.
At step 501, the user request is forwarded by the intermediate network node to the appropriate retail web server that is to service the user request. The forwarding step may be implemented with any desired network addressing techniques to deliver the user request to the web server location specified in the user request or specified by an intermediate addressing machine, such as a load balancing server.
At step 506, the intermediate network node determines if the user request is to be processed for purposes of adding content or functionality to the requested web page that has been requested by the user. This determination allows different user requests or end user activity to be treated differently, so that some requested web pages are not modified (steps 520, 522), while others are (steps 508, 510, 512, 514). The ability to differentiate the processing of user requests beneficially allows the intermediate network node to efficiently test and/or demonstrate the benefits or drawbacks of content or functionality modification provided by the intermediate network node.
For example, if the intermediate network node determines that a given user request is not to be processed (negative outcome from decision 506), then the intermediate network node simply receives the requested web page from the server (step 520), forwards or returns the requested web page to the end user without modifying its content or functionality (step 522), and optionally updates the user history tracking database to record this handling of the user request (step 524).
On the other hand, if the intermediate network node determines that a given user request is to be processed (affirmative outcome from decision 506), then the intermediate network node analyzes the user request and/or its associated recommendation context data to determine if and how the user requested web page is to be modified (step 508), receives the requested web page from the web server (step 510), and modifies the content or functionality of the requested web page (step 512) before returning the modified requested web page to the end user (step 514). In accordance with an illustrative embodiment, the intermediate network node uses the recommendation context data from the user request to select association rules that match the recommendation context, and these selected association rules are used as a candidate recommendation rule set that is scored, prioritized and filtered to identify one or more recommendation rules to be inserted in the requested web page before its return to the end user. Once the recommendation rules are identified, the intermediate network node inserts the recommendation rule text or functionality as web page content into the requested web page and then forwards the modified web page to the end user. When a requested web page is modified and returned to the end user, the intermediate network node may optionally update the user history tracking database to record this handling of the user request (step 516). With user history tracking data, the purchasing activity of end users may be measured and compared to determine or demonstrate the effectiveness of any particular web page modification undertaken at step 512.
Persons skilled in the art will appreciate that a variety of implementation approaches may be used to modify web page content and functionality in accordance with the present invention. For example,
The operational flow of the system, method and apparatus depicted in
The reverse proxy module 612 in the recommendation appliance 610 translates the web page request of the form http://www.retailer.com/product/info.html to http://old.retailer.com/product/info.html, and makes a request to the new URL at the retailer web server 606 (communication D). All other information about the web page request from the user machine 602 (e.g., cookies and post data) is unchanged.
When the reverse proxy 612 receives the response from old.retailer.com (communication E), the response includes whatever original content was generated by the retailer web server 606 in response to the web page request. For example, a web page 620 may be generated that includes a listing of product information as the original content in response to the web page request seeking product information from the retailer web server 606.
The reverse proxy 612 forwards the original response from the retailer web server 606 to a response interpreter 614 (communication F) which extracts the information needed to determine if or how the original response is to be changed or modified. For example, the response interpreter 614 extracts the information or data from the original response that the recommendation generator 616 will expect. The extracted information or data is returned by the response interpreter 614 to the reverse proxy 612 (communication G), which then submits this information or data as a request to the recommendation generator module 616 (communication H). A response from the recommendation generator 616 (such as a listing of product purchase recommendations) is returned to the reverse proxy 612 (communication I). While the response from the recommendation generator 616 may already be formatted for inclusion in the requested web page, it may alternatively be separately submitted to a format and placement module 618 (communication J) for HTML formatting, with specific instructions about the placement position within the web page response 620 from the retailer web server 606 being returned to the reverse proxy 612 (communication K). The use of a separate format and placement module 618 allows customized formatting for each target retailer web site, as indicated by the depiction of multiple instances of the format and placement module 618 in
In an exemplary embodiment, the system and method for generating and deploying additional web page content or functionality (e.g., retail recommendations) to an existing web page server system may be implemented with a standalone data processing system (such as a recommendation appliance) that modifies the web page content returned to an end user (such as by processing transaction database information to provide attribute-based association rules that are scored and prioritized to generate purchase recommendations with associated selling point/message texts). Various examples of standalone data processing systems for generating purchase recommendations with associated selling point/message texts are described in U.S. patent application Ser. No. 10/912,734 (entitled “System and Method for Generating Effective Recommendations” and filed Aug. 5, 2004) and U.S. patent application Ser. No. 10/912,743 (entitled “Retail Recommendation Domain Model” and filed Aug. 5, 2004), each of which is assigned to Trilogy Development Group and is hereby incorporated by reference in its entirety. For example, data processing may be performed on computer system 300 which may be found in many forms including, for example, mainframes, minicomputers, workstations, servers, personal computers, internet terminals, notebooks, wireless or mobile computing devices (including personal digital assistants), embedded systems and other information handling systems, which are designed to provide computing power to one or more users, either locally or remotely. A computer system 300 includes one or more microprocessor or central processing units (CPU) 312, mass storage memory 314 and local RAM memory 315. The processor 312, in one embodiment, is a 32-bit or 64-bit microprocessor manufactured by Motorola, such as the 680X0 processor or microprocessor manufactured by Intel, such as the 80X86, or Pentium processor, or IBM. However, any other suitable single or multiple microprocessors or microcomputers may be utilized. Computer programs and data are generally stored as instructions and data in mass storage 314 until loaded into main memory 315 for execution. Main memory 315 may be comprised of dynamic random access memory (DRAM). As will be appreciated by those skilled in the art, the CPU 312 may be connected directly (or through an interface or bus) to a variety of peripheral and system components, such as a hard disk drive, cache memory, traditional I/O devices (such as display monitors, mouse-type input devices, floppy disk drives, speaker systems, keyboards, hard drive, CD-ROM drive, modems, printers), network interfaces, terminal devices, televisions, sound devices, voice recognition devices, electronic pen devices, and mass storage devices such as tape drives, hard disks, compact disk (“CD”) drives, digital versatile disk (“DVD”) drives, and magneto-optical drives. The peripheral devices usually communicate with the processor over one or more buses and/or bridges. Thus, persons of ordinary skill in the art will recognize that the foregoing components and devices are used as examples for the sake of conceptual clarity and that various configuration modifications are common.
The above-discussed embodiments include software that performs certain tasks. The software discussed herein may include script, batch, or other executable files. The software may be stored on a machine-readable or computer-readable storage medium, and is otherwise available to direct the operation of the computer system as described herein and claimed below. In one embodiment, the software uses a local or database memory to implement the data transformation and data structures so as to improve the generation of attribute-based rules and purchase recommendations. The local or database memory used for storing firmware or hardware modules in accordance with an embodiment of the invention may also include a semiconductor-based memory, which may be permanently, removably or remotely coupled to a microprocessor system. Other new and various types of computer-readable storage media may be used to store the modules discussed herein. Additionally, those skilled in the art will recognize that the separation of functionality into modules is for illustrative purposes. Alternative embodiments may merge the functionality of multiple software modules into a single module or may impose an alternate decomposition of functionality of modules. For example, a software module for calling sub-modules may be decomposed so that each sub-module performs its function and passes control directly to another sub-module.
The computer-based data processing system described above is for purposes of example only, and may be implemented in any type of computer system or programming or processing environment, or in a computer program, alone or in conjunction with hardware. The present invention may also be implemented in software stored on a computer-readable medium and executed as a computer program on a general purpose or special purpose computer. For clarity, only those aspects of the system germane to the invention are described, and product details well known in the art are omitted. For the same reason, the computer hardware is not described in further detail. It should thus be understood that the invention is not limited to any specific computer language, program, or computer. It is further contemplated that the present invention may be run on a standalone computer system, or may be run from a server computer system that can be accessed by a plurality of client computer systems interconnected over an intranet network, or that is accessible to clients over the Internet. In addition, many embodiments of the present invention have application to a wide range of industries including the following: retail, enterprise and consumer electronics, general retailers, computer hardware and software manufacturing and sales, professional services, financial services, automotive sales and manufacturing, telecommunications sales and manufacturing, medical and pharmaceutical sales and manufacturing, and construction industries.
Although the present invention has been described in detail, it is not intended to limit the invention to the particular form set forth, but on the contrary, is intended to cover such alternatives, modifications and equivalents as may be included within the spirit and scope of the invention as defined by the appended claims so that those skilled in the art should understand that they can make various changes, substitutions and alterations without departing from the spirit and scope of the invention in its broadest form.
Number | Date | Country | |
---|---|---|---|
Parent | 13104233 | May 2011 | US |
Child | 14230759 | US | |
Parent | 10950354 | Sep 2004 | US |
Child | 13104233 | US |