The present disclosure relates generally to methods and systems for managing item assortments. More particularly, the present disclosure describes determining an optimized assortment of items for a particular space.
In various contexts, item assortments are selected in which various items can be presented to a consumer or population of consumers. The items in an item assortment are often selected to maximize the likelihood that any consumer viewing the item assortment will find a satisfactory item to select within a particular available space. This can be applied in various contexts in which a limited assortment of items is to be presented to a population of consumers for purposes of consumer choice. For example, item assortments can be found in retail environments, in the context of consumer or financial products, business-to-business sales, etc. In retail and other sales contexts, the item assortment is often selected with the goal of increasing profits and sales.
In such scenarios, there can be limitations with respect to the items that are included in such an item assortment. For example, in an online retail offering, a particular item assortment may be limited in terms of the numbers and types of items that are offered, because of a limit regarding practical storage space of either physical items or storage of data regarding the item in memory. Furthermore, for digital products, the storage space to hold a large number of digital items (e.g., digital content, such as movies, music, or other multimedia content) might be substantial as well. In a physical item assortment, particularly in a retail environment, the space requirements issue is exacerbated, because both an electronic record and physical inventory must be stored. Because of possible physical and electronic storage limitations, there is a practical limit to a number of items that can be included in such an item assortment.
Entities wishing to develop an item assortment will typically attempt to maximize the extent to which the item assortment includes an item that is “in demand” by a user. The goal of the item assortment is generally to increase profits by maximizing sales of items. Accordingly, two items that are very similar to each other might not be maintained in the same item assortment if it can be determined that, from the perspective of potential users, those items are considered substantially interchangeable, or substitutes, of one another. Therefore, one of the two items might be able to be removed from an item assortment without substantially changing the extent to which users will find a satisfactory item within the item assortment (i.e., the remaining item being considered substitutable for the removed item). However, even if two items are interchangeable, both might remain in an item assortment if it is determined that sales of those items are high or that profits on those items are high.
Item assortments may have other restrictions placed on them in addition to limited space. Laws of and regulations for the jurisdiction in which the item assortment is held may dictate that certain items must be included or excluded. For example, in certain retail stores, items deemed hazardous must not be available for sale. Other limitations on the item assortment may be dictated by the entity managing the item assortment. Such limitations may include preventing the item assortment from changing too much at one time. Other limitations may be in place due to contractual obligations requiring a retail entity to sell or not sell particular items.
Optimizing, or improving, an item assortment can be made more difficult because items may change over time, may become unavailable, or new items may become available that represent a better fit within an overall item assortment. Accordingly, managing an item assortment is an ongoing process in which improvements are continually sought, and a static model is generally unsatisfactory. Retail entities need a way to optimize item assortments while maintaining control over particular parameters or the item assortment that is being offered for sale.
In summary, the present disclosure relates to methods and systems for optimizing an item assortment to increase profit and sales while adhering to user specified constraints. Such constraints include specifying the number of items that can be substituted during optimization, locking in particular items, locking out particular items, and specifying that a particular percentage of the assortment has a particular attribute. Inputs such as demand transfer, demand forecasting, purchase repeat scores, and item attributes are used to calculate the optimal assortment of items. Various aspects are described in this disclosure, which include, but are not limited to, the following aspects.
In one aspect, a system for optimizing an assortment of items is disclosed. The system includes a computing system including a processor, a memory communicatively coupled to the processor, and a content output device. The memory stores instructions executable by the processor to receive, from a user computing device via a tools platform, a request for an optimized item assortment. The request includes an initial item assortment, an item universe, and one or more constraints. The instructions cause the system to access item data from one or more data stores, the data comprising one or more of demand forecasting data, demand transfer data, and item attribute data; determine, at an assortment optimization service, an optimized item assortment based on the item data and constraints; and output the optimized item assortment to the user computing device.
In another aspect, a method of optimizing an assortment of items is disclosed. The method includes receiving, at a computing system, a request from a user computing device for an optimized item assortment, the request comprising a selection of an initial item assortment, an item universe, and one or more constraints for modifying the initial item assortment; accessing one or more databases to retrieve item attribute data; determining an optimized item assortment; and outputting the optimized item assortment.
In yet another aspect, a non-transitory computer-readable storage medium comprising computer-executable instructions is disclosed which, when executed by a computing system, cause the computing system to perform a method of optimizing an item assortment. The method includes receiving, at a computing system, a request for an optimized item assortment, the request comprising a selection of an initial item assortment, an item universe, one or more rules, and at least one optimization goal; analyzing the rules and optimization goal to determine need item attribute data; accessing item attribute data from one or more data stores; determining the optimized item assortment by ranking and applying the rules to the initial item assortment and item universe, ranking the items by match to the at least one optimization goal, and eliminating lowest matching items to reach a final assortment size; and outputting the optimized item assortment.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Various embodiments will be described in detail with reference to the drawings, wherein like reference numerals represent like parts and assemblies throughout the several views. Reference to various embodiments does not limit the scope of the claims attached hereto. Additionally, any examples set forth in this specification are not intended to be limiting and merely set forth some of the many possible embodiments for the appended claims.
In general, the present disclosure relates to methods and systems for managing an item assortment in order to optimize sales and profits. An initial item assortment is received along with parameters for optimizing the assortment. Item data is accessed relating to the items' attributes, demand forecasting, demand transfer, and customer repeat scores. Items within the initial assortment are substituted with other items from an item universe in order to achieve an assortment that has increased sales and profit potential. The parameters restrict the substitutions that can be made.
The item assortment can be for an entire retail establishment or for particular categories of items within a retail establishment. For example, groceries could be a category of items within a retail store. In other examples, the retail store only carries groceries, so the item assortment is for all items within that store. In some examples, the item assortment may be a subgroup of items and the category can be more specific. Using the grocery example, the item assortment could be for all dairy products, for just cheese products, or specifically for just shredded cheese products. It is recognized that a variety of different product collections or product segments could be addressed by the item assortment systems described herein.
In some embodiments, one item assortment may apply to multiple retail stores. In some embodiments, the retail entity is an online marketplace and may only need one assortment of items. In other embodiments, the retail entity is an online marketplace, but must have varying assortments depending on where the customers reside.
The item assortment is optimized by substituting, adding, or subtracting items. Substitutions and additions are made from a chosen item universe. Using the grocery example, the item universe could be all grocery products that a retail store could stock. Or if the item assortment is for a more specific category of items, the item universe could be all cheese that the retail store could carry. If the retail entity is an online retailer, the item universe may consist of all available items in the retailer's warehouse or items that are obtainable by the retailer to sell online. The user may input an item universe or may select from a pre-populated list.
In certain aspects of the present disclosure, item assortments can be classified in a variety of ways. One possible classification system places items into different categories. Categories may be defined at different levels of catalog hierarchy such as department, class, and subclass, in the case of a retail environment. The breadth, depth and composition of the product assortment are chosen to maximize a particular outcome associated with demand for specific items within a collection. For example, in a retail environment, revenue or gross margin might be maximized, while taking into account constraints such as a fixed financial budget, limited shelf space for displaying products, number of vendors needed for each product type, customer preferences and additional objectives such as having a certain percentage of assortment as product types. Such retailers might periodically review their assortment and make changes based on seasonality, trends, new item arrival, consumer tastes, local demographics and competition.
Given the complex nature of assortment planning, entities presenting item assortments, in particular in the retail environment, face fundamental tradeoffs between breadth and depth. In addition, tradeoffs between existing and new, seasonal and non-seasonal, local and national products also need to be addressed, and may change over time. The present disclosure presents a data-driven approach to optimizing item assortments based on analysis of transaction data as well as item attribute data, and determining an optimal assortment of items to present to consumers while staying within specified parameters.
In accordance with the present disclosure, and as reflected in the embodiments below, the present assortment optimization system has a number of technical advantages over existing systems as well as the efficiency advantages described above. In particular, the systems and methods of the present disclosure include an assortment optimization engine that integrates management of item demand considerations with constraints that may run counter to item demand, such that the models may perform a complex multivariate analysis that is not present in current assortment optimization systems, which typically ignore such requirements or constraints (e.g., a constraint to carry a particular type of product to comply with a government or community program or request or requirement). Furthermore, the present system incorporates an automated feedback data flow that returns to an assortment optimization engine changes in item assortment and associated performance, so the assortment optimization engine can iteratively improve item assortments output based on changes to a variety of items concurrently, including observations in the form of item assortment performance, but also in combination with sales forecasts, demand transferability analysis, and updated item availability information.
Referring first to
In the example shown, a tools platform 170 provides an interface between the computing device 102 and computing system 112, and passes messages therebetween via network 110. The tools platform 170 mediates messages passed to the computing system 112 such that many computing devices 102 can transmit requests to and receive data from the computing system 112 concurrently. As shown, the tools platform 170 includes a notification system 172, an ingest service 174, and a trigger 176, each of which are described below.
The computing device 102 operates to present a user interface to a user U. The user U provides inputs to the computing device 102 by use of a mouse, a keyboard, a touchscreen, and the like to make selections. The selections include at least selecting an initial item assortment 104 and one or more constraints 106 to apply to the item assortment 104. Additional selections include choosing an item universe and desired priority for applying constraints to the optimization. One example of a user interface is further described with respect to
In the embodiment shown, the initial item assortment 104 and constraints 106 are communicated to the computing system 112 through the network 110. The network 110 can be any of a variety of types of public or private communications networks, such as, for example, the internet. In some embodiments, a computation trigger microservice, shown as trigger 176, is utilized to communicate requests from the user U to the computing system 112. In example embodiments, the computation trigger microservice is an application developed to allow configuring and triggering Oozie workflows through a common HTTP and JSON-based interface. Data from user-generated HTTP requests is used to make calls to the assortment optimization engine 114 for executing a workflow with the required configuration for the request.
After the assortment optimization engine 114 has determined an optimized item assortment 124, the optimized item assortment 124 is communicated back to the computing device 102 through the network 110. In some embodiments, a notification system 172 is utilized to communicate the status and results of the assortment optimization process. An ingest service 174, implemented as a Kafka topic, provides updates on the state changes of the workflow being executed by the assortment optimization engine 114. Computations will push notifications to this topic as the last step of a workflow, indicating the successful or failed completion of execution.
The computing system 112 includes an assortment optimization engine 114. The assortment optimization engine 114 receives the initial item assortment 104 and constraints 106 from the computing device 102. The assortment optimization engine 114 also accesses data from one or more databases 120. The data includes item data such as item attributes, demand forecasting data, demand transfer data for pairs of items, and repeat purchase data. The databases 120 may be external to the computing system 112 as shown, or may be housed within the computing system 112. The assortment optimization engine 114 operates to calculate and determine an optimized item assortment 124 based on the constraints and item attributes of the assortment. The optimized item assortment 124 is output and communicated back to the computing device 102 through the network 110. The computing system 112 is further described with respect to
In the embodiment shown, data is received at the database 120 via one or more Application Programming Interfaces (“APIs”) connected to external services. As shown, the APIs expose services including an item attributes service 150, a demand forecasting service 152, and a demand transfer service 154. The item attributes service 150 supplies information regarding items available to be included in an assortment, including name, cost, SKU, and various other properties. The demand forecasting service 152 provides, in response to an identification of an item, a location, and a time period, a forecasted demand for that item. The demand transfer service 154 provides information regarding transferability of item demand across pairs or groups of items. An example of a demand transfer service 154 is described in copending U.S. patent application Ser. No. 15/582,244, filed on Apr. 28, 2017, the disclosure of which is hereby incorporated by reference in its entirety.
Referring now to
The mass storage device 214 is connected to the CPU 202 through a mass storage controller (not shown) connected to the system bus 222. The mass storage device 214 and its associated computer-readable storage media provide non-volatile, non-transitory data storage for the computing device 102. Although the description of computer-readable storage media contained herein refers to a mass storage device, such as a hard disk or solid state disk, it should be appreciated by those skilled in the art that computer-readable data storage media can include any available tangible, physical device or article of manufacture from which the CPU 202 can read data and/or instructions. In certain embodiments, the computer-readable storage media comprises entirely non-transitory media.
Computer-readable storage media include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable software instructions, data structures, program modules or other data. Example types of computer-readable data storage media include, but are not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROMs, digital versatile discs (“DVDs”), other optical storage media, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computing device 102.
According to various embodiments of the invention, the computing device 102 may operate in a networked environment using logical connections to remote network devices through a network 110, such as a wireless network, the Internet, or another type of network. The computing device 102 may connect to the network 110 through a network interface unit 204 connected to the system bus 222. It should be appreciated that the network interface unit 204 may also be utilized to connect to other types of networks and remote computing systems. The computing device 102 also includes an input/output controller 206 for receiving and processing input from a number of other devices, including a touch user interface display screen, or another type of input device. Similarly, the input/output controller 206 may provide output to a touch user interface display screen or other type of output device.
As mentioned briefly above, the mass storage device 214 and the RAM 210 of the computing system 200 can store software instructions and data. The software instructions include an operating system 218 suitable for controlling the operation of the computing system 200. The mass storage device 214 and/or the RAM 210 also store software instructions, that when executed by the CPU 202, cause the computing device 102 to provide the functionality of the computing system 200 discussed in this document. For example, the mass storage device 214 and/or the RAM 210 can store software instructions that, when executed by the CPU 202, cause the computing device 102 to receive and analyze transaction data.
In the example embodiment shown, the system memory 200 includes an assortment optimization engine 114. The assortment optimization engine 114 includes a constraint management engine 206, an item attribute engine 208, and a sales and margin calculator 210. The various engines generally are implemented in software modules stored in the system memory 200, and are implemented as discussed in further detail below. The assortment optimization engine 114 accesses data from the data store 116. In the example illustrated in
In example implementations, the item assortment input can be initialized with the current assortment of items within the category or group. Another input is the number of unique items that the user desires to have in that particular assortment. It could be the same number of items, more items, or fewer items. The unique items may be represented as stock keeping units or SKU's, which are assigned to each distinct type of item for sale. For example, a starting item assortment could include 56 unique items having 56 unique SKU's for different baby clothing items. The item assortment is not concerned with how many of each unique item are stocked, but rather with how many unique items are being carried by the retailer. So in this example, there could be 500 items stocked overall in baby clothing, but there are only 56 unique types of items in that category.
The constraint management engine 206 is configured to apply constraints selected by a user to an item assortment. Constraints include rules and goals. The constraint management engine 206 receives an input of an optimization goal for a new item assortment. In some embodiments the goal is a balance of increasing sales and margins. The constraint management engine 206 also receives inputs of rules. The rules include lock in rules, lock out rules, and item attribute rules specified by the user.
The user U may select one or more constraints for the assortment optimizer to apply to the item assortment. The user U can input or select the constraints through the computing device 102. Multiple constraints can be selected at once. However, it is preferable that 2-5 constraints are applied at a time in order to produce the best options for assortment optimization. Selecting too many constraints can limit the assortment optimizer to the extent that no assortment would meet the requirements of the constraints at all.
In some example implementations, constraints can be defined by the user to customize the assortment. Constraints may also include legal regulations that the retail entity is required to abide by. One such regulation could relate to participation in the Women, Infants & Children (WIC) program. In order to comply, the store must carry particular grocery items. A WIC rule would lock in particular items that are required to be carried by the store. In some embodiments, some products would be interchangeable to meet these requirements and could be substituted in the assortment. Other rules may require a predetermined percentage of items in an assortment be an “owned brand” item, or requiring that, in a given iteration of the assortment optimization, a predetermined maximum percentage of products can change, thereby providing some level of product stocking reliability for customers of a particular store.
Constraints can also refer to distribution regulations. Some products can only be sold in particular jurisdictions. Items that are banned will be locked out of the assortment.
Some items can be locked into the assortment by the user. The user may wish to lock in items because of contractual obligations to sell particular products, a desire to sell store-branded products, seasonal items, or new items. These items will remain in the assortment even if they do not meet other constraints. For example, a seasonal item may not have high overall sales or profits, but the retail entity wishes to offer it for sale for the season.
In addition to rigid lock-in or lock-out constraints, the user can define constraints based on a percentage of the overall assortment. For example, the user could implement a constraint that at least 10% of the assortment must be premium products and at least 10% of the assortment must be value products.
Another constraint could limit the amount of overall change that can occur to the item assortment at one time. For example, a constraint could limit the percentage of change to the item assortment to 5%. A constraint could also require that at least 5% of the assortment be exchanged for new items. A retail entity may implement such constraints in an effort to not disrupt the overall assortment too much at once. Changing inventory in a retail entity incurs operational costs. If too much of the inventory is changed at once the benefits of the optimized assortment may be outweighed by the costs of implementing the optimized assortment.
In some instances, the constraint could change the overall number of items in the assortment. Generally, because space is finite for product display, a selected number of products or SKUs may be held constant as a constraint on assortment selection. However, in example instances, a constraint could dictate that the total number of items or SKU's be reduced by 2% in order to save space. Alternatively, if additional space is available, the constraint could dictate that the total number of items or SKU's be increased by 1%. These constraints could also be expressed by number of items instead of a percentage. For example, a constraint could be to add 20 new items to an assortment.
Other constraints can relate to repeat sales scores, overall sales per item, profits per item, item category, item distribution (variety), cost distribution, or other factors that may be desirable to obtain a diverse but profitable assortment.
The constraints may be ranked in order of importance. In some instances, not all of the constraints can be satisfied. By ranking the constraints, the user U can be ensured that the most important constraints will be met. For example, compliance with legal and regulatory rules may be a top priority. Changing the overall number of SKU's or limiting the percentage of change in the item assortment may be the next most important constraint. Then constraints such as repeat purchase score and having a particular percentage of items within a particular category may be least important. The overall goal of increasing sales is still a consideration, but that comes after the other constraints are met. If a constraint is found to be infeasible, it will be skipped or modified. Some constraints can be labeled as mandatory while others are considered non-mandatory. Mandatory constraints must be followed in optimizing an item assortment. For example, following legal regulations could be a mandatory constraint. Reducing the number of items in an assortment may be important, but not at the expense of removing required WIC items from the assortment.
The item attribute engine 208 is configured to access item data relating to items in the item assortment and item universe. The item attribute engine 208 compares the item data with the rules to determine which items within the item universe conform to the rules and are eligible for inclusion in the assortment. Item attributes are accessed from the data store 116.
The margin and sales calculator 210 analyzes the items individually and as a group to determine which combination of items results in the highest margins, sales, or combination. The margin and sales calculator 210 relies on data such as demand transfer data and demand forecasting data to determine which items to include in the assortment to achieve the specified goal.
The data store 116 includes demand transfer data 212, demand forecast data 214, item attribute data 216, and guest score data 218. Additional sources of item data may also be included. In the embodiment shown in
The demand transfer data 212 includes information relating to customer's willingness to substitute a desired item with an alternative item when the desired item is not available. Scores are calculated for pairs of items to indicate the level of substitutability. Such demand transfer data can inform the extent to which similar items, from a demand perspective, are stocked concurrently. One example system for assessing demand transfer is disclosed in U.S. patent application Ser. No. 15/582,244, and entitled “Method and System of Managing Item Assortment Based on Demand Transfer”, the disclosure of which is hereby incorporated by reference in its entirety.
The demand forecast data 214 includes information about projected sales for a particular item over a defined period of time. A demand forecasting engine can supply projections for the expected sales of particular items. In example embodiments, the demand forecast data 214 can be received for a particular or configurable period of time (e.g., daily, weekly, monthly, etc.). Various demand forecasting tools can be used.
Item attribute data 216 includes information about each item and how it is categorized. For example, relevant item attributes could include whether the item is WIC compliant, whether the item is a store-owned brand, whether the item is new, whether the item is a top seller, which category the item belongs to, etc. The item attribute data 216 is utilized to determine which items comply with item attribute rules.
Repeat purchase data 218 includes information about how often the same customers buy the same products. The repeat purchase data can take a variety of forms. In some embodiments, repeat purchase data 218 includes an indication of average frequency of purchasing the product by a given customer; in other examples, the repeat purchase data 218 can include a probability value of repurchase by a same customer. Other representations could be used as well.
Referring now to
At operation 402, a request is received for an optimized item assortment. In some embodiments, the request is received at a computing system, such as the computing system 112 of
At operation 404, item data is accessed for the items in the assortment and the item universe. The data that needs to be accessed may vary depending on the selected constraints for the optimized assortment. Various types of data may be required, which are described above. The item data is accessed from one or more data stores or databases which may be housed in a computing system such as the computing system 112 or in external databases such as the databases 120, 122 depicted in
At operation 406, an optimized item assortment is determined based on the selected initial item assortment, item universe, constraints, and item data. Items within the initial item assortment and item universe are analyzed to identify attributes of those items. Items within the initial item assortment are replaced with items within the item universe to conform to the constraints. Operation 406 is further described with respect to
At operation 408, the optimized item assortment is communicated from the assortment optimization engine 114 to the computing device 102. The optimized item assortment can be output in many different formats depending on the eventual use of the information. In some embodiments, the optimized item assortment may be utilized to create a planogram for a retail store. For example, an optimized item assortment can correspond to an ordered list of products (by SKU) as to the popularity or profitability of such an item; in such an arrangement, that ordered list can be provided to planogram software for deriving an item layout for a store or portion of a store (e.g., an aisle or department). Such planogram software may prioritize locations of items based on, for example, item size, popularity, profitability, or other factors.
At operation 502, an initial item assortment is received. A user U may upload the initial item assortment to a computing device 102 to be communicated to the computing system 112 through a network 110. In some embodiments the initial item assortment is provided in a format that is readable by the computing system 112. In other embodiments, the computing system 112 converts the initial item assortment into an appropriate format upon receipt. For example, the initial item assortment may be identified by SKU number alone, but additional information regarding specific characteristics of the item or product may be required to optimize assortment (e.g., as received from item attribute service 150). These can include, for example, specific characteristics of the item (e.g., size, flavor, style) as well as current price, for purposes of determining a demand forecast for that item. The initial item assortment includes information identifying the different individual items within the assortment, the number of different individual items, and information about the category of items within the assortment. Greater or fewer types of identifying information may be communicated with the initial item assortment.
In some embodiments, the initial item assortment is selected by a user U on a user interface presented on a computing device 102. An example user interface 600 is illustrated in
Returning to
In some embodiments, the item universe is selected by a user U on a user interface presented on a computing device 102, such as the user interface 600 illustrated in
Returning to
In the example user interface illustrated in
At operation 508 of the method 402 in
In the example user interface 600 illustrated in
For example, as seen in
In the example of
Finally, returning to
In the example user interface 600 of
In
The initial item assortment will be modified to accommodate both the rules set by the user and the goal selected by the user. In instances where it is not possible to accommodate both, the rules can be emphasized to take priority over the optimization goal. Locked in and locked items may take priority over other rules and goals. In some embodiments, the user specifies the ranking of the rules.
At operation 904, the required item attribute data is accessed from one or more databases or data stores. The item attribute engine 208 receives the item attribute data.
At operation 1102 of the method 406, the constraints are ranked by priority. In some embodiments, some or all of the constraints are ranked by default by the constraint management engine 206. For example, locked in and locked out items take the highest priority. Optimization goals take lowest priority. User selected item attribute rules fall in between. In some embodiments, the user can select the ranking of priority for the chosen constraints. In the event that not all of the constraints can be met for a particular item assortment, the constraints that are ranked higher take priority over those that are ranked lower. If not enough items meet all of the optimization constraints selected in the example user interface of
At operation 1104, the lock in and lock out rules are applied to the initial item assortment. Lock in rules prevent items having particular attributes from being removed from the initial assortment. Examples of lock in rules may include WIC items, seasonal items appropriate for the season (e.g. pumpkin space flavored items in fall), regional items, items that must be offered for sale to meet contractual obligations, and the like. Lock out rules prevent items having particular attributes from being added to the initial assortment. Examples of lock out rules may include hazardous items, items banned by governmental regulations, seasonal items that are not appropriate for the season (e.g. pumpkin spice flavored items in spring), items that violate contractual obligations, and the like. In some embodiments, lock in rules and lock out rules take priority over other constraints. In some embodiments, if there is more than one lock in or lock out rule, the user can specify the order of priority.
At operation 1106, item attribute rules are applied to the initial item assortment. Item attribute rules are user defined rules based on attributes of the items in the assortment. Such item attributes can include whether an item is new or existed in the initial item assortment, the brand of the item, the product category, a demand transfer score of an item, whether an item is seasonal, and the like. The item attribute engine 208 of the assortment optimization engine 114 utilizes the item attribute data received from one or more databases to determine which items in the initial item assortment and the selected item universe comply with the selected rules. In some embodiments the user can rank the priority of the item attribute rules if there is more than one. This ranking is implemented by the constraint management engine 206.
In some embodiments, such as that displayed in
At operation 1108, items in the initial assortment are ranked by how well they match the optimization goal selected by the user. In some embodiments, the initial item assortment may already be modified based on the user selected rules. The items in the assortment are analyzed to determine the item attributes that are applicable to the optimization goal. In the example of
At operation 1110, the items that match the rules and goals the least are eliminated from the item assortment in order to achieve the desired assortment size. In some embodiments the optimized item assortment is the same size as the initial item assortment. In other embodiments the user may specify that the item assortment should increase or decrease in size. The size of the item assortment may be restricted based on amount of storage space for items or other considerations. This size restriction can be set, for example, by the user U, by selection of a particular store or store group, or otherwise selected.
Embodiments of the present invention, for example, are described above with reference to block diagrams and/or operational illustrations of methods, systems, and computer program products according to embodiments of the invention. The functions/acts noted in the blocks may occur out of the order as shown in any flowchart. For example, two blocks shown in succession may in fact be executed substantially concurrently or the blocks may sometimes be executed in the reverse order, depending upon the functionality/acts involved.
The description and illustration of one or more embodiments provided in this application are not intended to limit or restrict the scope of the invention as claimed in any way. The embodiments, examples, and details provided in this application are considered sufficient to convey possession and enable others to make and use the best mode of claimed invention. The claimed invention should not be construed as being limited to any embodiment, example, or detail provided in this application. Regardless of whether shown and described in combination or separately, the various features (both structural and methodological) are intended to be selectively included or omitted to produce an embodiment with a particular set of features. Having been provided with the description and illustration of the present application, one skilled in the art may envision variations, modifications, and alternate embodiments falling within the spirit of the broader aspects of the general inventive concept embodied in this application that do not depart from the broader scope of the claimed invention.