The present disclosure relates to a system for remotely monitoring utilization of geographically distributed point-of-sale terminals and autonomously activating a quantity of point-of-sale terminals based on the utilization.
An entity operating stores may wish to determine how well the stores are performing relative to a specified goal and/or to each other. The task of evaluating the performance of one or more stores can become increasingly difficult as the number of stores increases and the location of the stores extends over many geographic regions. One reason it can become increasingly difficult to adequately evaluate performances of stores distributed over several geographic regions (e.g., states, countries, continents) is that stores located in the different geographic regions can implement different processes than each other. Conventional performance reporting tools often do not provide a requisite level of visibility into international markets to evaluate how well the current processes of the stores in these markets are working. The lack of visibility can make it difficult to determine whether processes implemented by the stores have been successful or whether adjustments should be made.
In accordance with embodiments of the present disclosure, systems and methods for remotely monitoring utilization of geographically distributed point-of-sale terminals and autonomously activating a quantity of point-of-sale terminals based on the utilization are disclosed. The system comprises geographically distributed point-of-sale terminals configured to perform transactions and collect and transmit point-of-sale data associated with the operation of each point-of-sale terminal to a remote server. The system further comprises the remote server storing the point-of-sale data for the geographically distributed point-of-sale terminals. The point-of-sale data includes a quantity of point-of-sale terminals in operation during a specified time period for each geographic location at which at least one of the point-of-sale terminals is disposed. Transaction data, including transaction process times, customer arrival rates, and customer service rates, is also collected at each of the point-of-sale terminals. The remote server receives the point-of-sale data from the geographically distributed point-of-sale terminals. The remote server caps the transaction process times by a preset time value to ensure accuracy of an estimated queue length and utilization value of the point-of-sale terminals. The remote server estimates the queue length value at the point-of-sale terminals for each of the geographic locations at which at least one point-of-sale terminal is disposed and for the specified period of time based on the point-of-sale data received from the point-of-sale terminals. The remote server estimates the utilization value of the point-of-sale terminals for each of the geographic locations at which at least one point-of-sale terminal is disposed and for the specified time period based on the point-of-sale data received from the point-of-sale terminals. The remote server determines whether the utilization value for each geographic location exceeds an utilization criteria and whether the queue length value for each geographic location exceeds a queue length criteria during a specific time interval. In response to determining that the utilization value for at least one geographic location is less than the utilization criteria and the queue length value for at least one geographic location is greater than the queue length criteria, the remote server adjusts a quantity of point-of-sale terminals to be operated at the at least one geographic location during a subsequent time period to reduce queue lengths for the point-of-sale terminals at the at least one geographic location and/or schedules more cashiers to open point-of-sale terminals based on the adjustment of the quantity of point-of-sale terminals.
In some embodiments, a method of evaluating performance of a store is disclosed. The method includes collecting and storing in a database electronic data representative of a transaction parameter for the store based on transactions at a point-of-sale terminal in the store. The method includes receiving a performance evaluation request in a computer-readable format from a user via a graphical user interface. The performance evaluation request can specify a goal for a key performance indicator, e.g., a queue length compliancy, an ideal register utilization, an ideal register opening performance, an over ideal register opening performance, an under ideal register opening performance, a quantity of items scanned per hour, and the like. The method also includes executing code to query a database for electronic data representative of a transaction parameter for the store based on transactions at a point-of-sale terminal in the store in response to the performance evaluation request. The method further includes programmatically generating performance data for the store based on the transaction parameter. The performance data indicates performance of the store relative to the goal for the key performance indicator. The method includes executing code to output the performance data to the user.
In some embodiments, the methods include comparing the performance data for the store to performance data indicative of performance of at least one alternative store to determine performance of the store relative to the at least one alternative store. In some embodiments, the methods include comparing the performance data to the goal in response to at least one of generation of the performance data and an electronic request from a user. In some embodiments, the methods include determining an arrival rate of customers to the store for a specific time period and a service rate of the customers in the store for the specific time period. In some embodiments, the methods include executing code to determine an ideal register utilization defined by dividing the arrival rate by the service rate. In some embodiments, the methods include executing code to determine a total time spent waiting in line and being served defined by an inverse of a difference between the service rate and the arrival rate. In some embodiments, the methods include executing code to determine an average time waiting in line and being served defined by a difference between the total time spent waiting in line and being served and an inverse of the service rate. In some embodiments, the methods include executing code to determine an average number of customers in the store based on the arrival rate and the total time spent waiting in line and being served per customer. In some embodiments, the methods include executing code to determine an average number of customers in line based on the arrival rate and the average time waiting in line and being served. In some embodiments, the methods include executing code to determine a probability that the store is empty of customers based on the arrival rate, the service rate, and a number of point-of-sale terminals being operated. In some embodiments, the methods include executing code to determine an expected number of customers waiting in line based on the arrival rate, the service rate, the number of point-of-sale terminals being operated, and the probability that the store is empty. In some embodiments, the methods include executing code to determine a transaction time per customer based on a scan time, a tender time, a previous tender time and a miscellaneous time. In some embodiments, the methods include executing code to determine an item per hour based on a total number of items sold during the hour and the transaction time per hour. In some embodiments, at least one of the scan time, the tender time, the previous tender time and the miscellaneous time can be capped to reduce at least one of noise, abnormal values, and unrealistic values in the determination.
In accordance with embodiments of the present disclosure, exemplary non-transitory computer-readable medium storing computer-readable instructions are provided. Execution of the instructions by a processing device causes the processing device to implement a method of evaluating performance of a store that includes collecting and storing in a database electronic data representative of a transaction parameter for the store based on transactions at a point-of-sale terminal in the store. The method implemented upon execution of the instructions includes receiving a performance evaluation request in a computer-readable format from a user via a graphical user interface. The performance evaluation request can specify a goal for a key performance indicator, e.g., a queue length compliancy, an ideal register utilization, an ideal register opening performance, an over ideal register opening performance, an under ideal register opening performance, a quantity of items scanned per hour, and the like. The method implemented upon execution of the instructions also includes executing code to query a database for electronic data representative of a transaction parameter for the store based on transactions at a point-of-sale terminal in the store in response to the performance evaluation request. The method implemented upon execution of the instructions further includes programmatically generating performance data for the store based on the transaction parameter. The performance data indicates performance of the store relative to the goal for the key performance indicator. The method implemented upon execution of the instructions includes executing code to output the performance data to the user.
In some embodiments, execution of the instructions by the processing device can cause the processing device to compare the performance data to the goal in response to at least one of generation of the performance data and an electronic request from a user. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine an arrival rate of customers to the store for a specific time period and a service rate of the customers in the store for the specified time period. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine an ideal register utilization defined by dividing the arrival rate by the service rate. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine a total time spent waiting in line and being served defined by an inverse of a difference between the service rate and the arrival rate. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine an average time waiting in line and being served defined by a difference between the total time spent waiting in line and being served and an inverse of the service rate. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine an average number of customers in the store based on the arrival rate and the total time spent waiting in line and being served per customer. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine an average number of customers in line based on the arrival rate and the average time waiting in line and being served. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine a probability that the store is empty based on the arrival rate, the service rate and a number of point-of-sale terminals being operated. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine an expected number of customers waiting in line based on the arrival rate, the service rate, the number of point-of-sale terminals being operated and the probability that the store is empty. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine a transaction time per customer based on a scan time, a tender time, a previous tender time and a miscellaneous time. In some embodiments, execution of the instructions by the processing device can cause the processing device to determine a scanned items per hour based on a total number of items sold during the hour and the transaction time per hour.
In accordance with embodiments of the present disclosure, exemplary retail performance evaluation systems for evaluating performance of a store are provided that generally include a computer storage device, a graphical user interface, and a processing device. The computer storage device stores electronic data representative of a transaction parameter for the store based on transactions at a point-of-sale terminal in the store. The processing device can be configured to receive a performance evaluation request in a computer-readable format from a user via the graphical user interface. The performance evaluation request can specify a goal for a key performance indicator. The processing device can be configured to execute code to query a database for electronic data representative of a transaction parameter for the store based on transactions at the point-of-sale terminal in the store in response to the performance evaluation request. The processing device can also be configured to programmatically generate performance data for the store based on the transaction parameter. The performance data indicates performance of the store relative to the goal for the key performance indicator. The processing device can be further configured to execute code to output the performance data to the user.
In some embodiments, the graphical user interface can be configured to receive an input of the goal for the key performance indicator. The processing device can be configured to compare the performance data to the goal in response to at least one of generation of the performance data and an electronic request from a user. In some embodiments, the processing device can be configured to execute code to determine an arrival rate of customers to the store for a specific time period and a service rate of the customers in the store for the specified time period. In some embodiments, the processing device can be configured to execute code to determine an ideal register utilization defined by dividing the arrival rate by the service rate. In some embodiments, the processing device can be configured to execute code to determine a total time spent waiting in line and being served defined by an inverse of a difference between the service rate and the arrival rate. In some embodiments, the processing device can be configured to execute code to determine an average time waiting in line and being served defined by a difference between the total time spent waiting in line and being served and an inverse of the service rate.
In some embodiments, the processing device can be configured to execute code to determine an average number of customers in the store based on the arrival rate and the total time spent waiting in line and being served per customer. In some embodiments, the processing device can be configured to execute code to determine an average number of customers in line based on the arrival rate and the average time waiting in line and being served. In some embodiments, the processing device can be configured to execute code to determine a probability that the store is empty of customers based on the arrival rate, the service rate and a number of point-of-sale terminals being operated. In some embodiments, the processing device can be configured to execute code to determine an expected number of customers waiting in line based on the arrival rate, the service rate, the number of point-of-sale terminals being operated and the probability that the store is empty. In some embodiments, the processing device can be configured to execute code to determine a transaction time per customer based on a scan time, a tender time, a previous tender time and a miscellaneous time. In some embodiments, the processing device can be configured to execute code to determine an items per hour based on a total number of items sold during the hour and the transaction time per hour.
Other objects and features will become apparent from the following detailed description considered in conjunction with the accompanying drawings. It is to be understood, however, that the drawings are designed as an illustration only and not as a definition of the limits of the present disclosure.
To assist those of skill in the art in making and using the disclosed systems and associated methods, reference is made to the accompanying figures, wherein:
Exemplary embodiments of the present disclosure provide for a system and methods for remotely monitoring utilization of geographically distributed point-of-sale terminals and autonomously activating a quantity of point-of-sale terminals based on the utilization. The system comprises geographically distributed point-of-sale terminals configured to perform transactions and collect and transmit point-of-sale data associated with the operation of each point-of-sale terminal to a remote server. The system further comprises the remote server storing the point-of-sale data for the geographically distributed point-of-sale terminals. The point-of-sale data includes a quantity of point-of-sale terminals in operation during a specified time period for each geographic location at which at least one of the point-of-sale terminals is disposed. Transaction data, including transaction process times, customer arrival rates, and customer service rates, is also collected at each of the point-of-sale terminals. The remote server receives the point-of-sale data from the geographically distributed point-of-sale terminals. The remote server caps the transaction process times by a preset time value to ensure accuracy of an estimated queue length and utilization value of the point-of-sale terminals. The remote server estimates the queue length value at the point-of-sale terminals for each of the geographic locations at which at least one point-of-sale terminal is disposed and for the specified period of time based on the point-of-sale data received from the point-of-sale terminals. The remote server estimates the utilization value of the point-of-sale terminals for each of the geographic locations at which at least one point-of-sale terminal is disposed and for the specified time period based on the point-of-sale data received from the point-of-sale terminals. The remote server determines whether the utilization value for each geographic location exceeds an utilization criteria and whether the queue length value for each geographic location exceeds a queue length criteria during a specific time interval.
In response to determining that the utilization value for at least one geographic location is less than the utilization criteria and the queue length value for at least one geographic location is greater than the queue length criteria, the remote server adjusts a quantity of point-of-sale terminals to be operated at the at least one geographic location during a subsequent time period to reduce queue lengths for the point-of-sale terminals at the at least one geographic location and/or schedules more cashiers to open point-of-sale terminals based on the adjustment of the quantity of point-of-sale terminals to be operated.
Additional exemplary embodiments of the present disclosure provide for a performance evaluation system that can be used to evaluate a performance of one or more stores across one or more geographic regions that may implement different processes. The evaluation of the performance of the stores can be utilized to determine how well the processes implemented by the stores are working based on POS terminal information collected from POS terminals in the stores. Exemplary embodiments of the performance evaluation system can advantageously provide a common global international reporting platform that can identify and/or calculate key performance indicator metrics for the stores that can be compared to specified goals for the stores and/or to key performance indicator metrics of other stores. As one example, exemplary embodiments of the present disclosure facilitate identifying and/or calculating key performance indicator metrics, such as estimated queue lengths or register utilization to evaluate how efficiently and effectively a store is in processing customer demand.
In some embodiments, the system 100 can include a user interface 103. The user interface 103 can be programmed and/or can include executable code to provide at least one graphical user interface 105 (hereinafter “GUI 105”) through which a user can interact with the system 100. The GUI 105 displayed to users can include data entry areas to receive information from the user and/or can include data outputs to display information to the user. For example, one GUI 105 can allow a user to enter transaction parameters into the system 100, while another GUI 105 can display performance data to the user. Some examples of data entry fields include, but are not limited to, text boxes, check boxes, buttons, dropdown menus and/or any other suitable data entry fields.
In exemplary embodiments, the system 100 can be programmed and/or configured to determine and/or evaluate a performance of one or more stores, determine and/or evaluate an ideal utilization of point-of-sale (POS) terminals in the one or more stores, reduce queue wait times, and/or implement combinations thereof. The system 100 can be utilized by an entity to provide the entity with visibility into one or more stores, which can be distributed across several geographic regions (e.g. domestic and/or international stores) to evaluate how well processes implemented by the stores (e.g., current scheduling protocols) are working in relation to information associated with an operation of POS terminals in the stores (POS terminal information). This POS terminal information can correspond to point-of-sale data (e.g., raw data) collected from the POS terminals at each respective store and can include, for example, transaction times, number of registers opened, register utilization performance, estimated queue lengths, estimated queue wait times, basket sizes, and/or any other suitable information related to an operation of the POS terminals.
Using the collected POS terminal information, the system 100 can calculate a variety of key performance indicator metrics that can be used to evaluate the processes (e.g., scheduling protocols) implemented by the one or more stores. Some examples of key performance indicator metrics can include, for example, estimated queue lengths, average service rates, average arrival rates, register utilization, a number of queue exceptions, basket sizes, a number of transactions, and the like. Using the system 100, the one or more stores can be evaluated based on their individual performance and/or can be evaluated based on a collective performance with other stores (e.g., stores in a common geographic region can be evaluated collectively).
In some embodiments, the key performance indicator metrics can be calculated by the system 100 in specified time intervals (e.g., every fifteen minutes). The key performance indicator metrics calculated for consecutive time intervals (e.g., fifteen minute intervals) can be aggregated by the system to reflect performance of one or more stores over a selected time period (e.g., one hour). For example, the system 100 can provide key performance indicator metrics for an individual store every fifteen minutes and the system 100 can be programmed and/or configured to aggregate the key performance indicator metrics for four consecutive time intervals to generate a key performance indicator metric associated with one hour.
The system 100 can be used to evaluate performance of a store, a district, a region and/or a corporate view and/or can be used to measure the progress and efficiency of the stores and protocols implemented within the stores. In exemplary embodiments, the system 100 can evaluate a customer experience based on the key performance indicator metrics. The key performance indicator metrics can be used to determine how stores reacted to understaffed or overstaffed situations and how such reactions or protocols can be improved. The collected POS terminal information can therefore be turned into useful statistics regarding performance of one or more stores. In some embodiments, the system 100 can be used to evaluate an alternative system, such as a scheduling system for scheduling cashiers or staff. In some embodiments, the system 100 can be programmed and/or configured to determine the key performance indicator metrics and an alternative system, such as a scheduling system for scheduling cashiers or staff, can be use the key performance indicator metrics to correct the overstaffed or understaffed situations. In some embodiments, the system 100 can be programmed and/or configured to open or close a number of POS terminals, as described in
As depicted in
The store number 106 can include one or more integer or alphanumeric indicators representative of a particular store in a specific location. The visit date 108 can include the date or day of the week of interest. The visit time 110 can include the time of day of interest. In some embodiments, the visit time 110 can include a visit time determined in fifteen minute intervals. The customers/transactions 112 can include a number of customers or transactions occurring. The registers opened 114 can include a number of registers which are opened in a particular store. The process time 116 can include a time for processing each customer or transaction at a POS terminal.
The transaction parameters can be utilized as input by engine 102 to calculate an average arrival rate λ (120) of customers to a store and an average service rate μ (118) of customers at the store. The average arrival rate λ can be in units of customers per minute per register and can be calculated based on Equation 1 below:
where Registers Open is a whole numerical value. The average service rate μ can be in units of customers per minute and can be calculated based on Equation 2 below:
where Process Time is a whole numerical value in seconds and Customers is a whole numerical value.
Using the arrival rate λ and the service rate μ per a specified time interval, e.g., a fifteen minute interval, the utilization, time spent in line and average time waiting in line can be computationally determined and output by the engine 102. The utilization or proportion of time that an employee operating a POS terminal is busy can be calculated by the engine 102 based on Equation 3 below.
In some embodiments, the ratio of Equation 4 for utilization can be upheld to ensure that the queue does not grow significantly large.
In an exemplary embodiment, the total time a customer waits in line and is served can be calculated by the engine 102 based on Equation 5 below:
where W represents the total wait time for a customer to stand in line and to be served. An average time waiting in queue or in line and being served (Wq) can be calculated by the engine 102 based on Equation 6 below.
Based on the total time spent waiting in line (W) and the average time waiting in line (Wq), the average number of customers in the system or in the store (L) and the average number of customers in the queue (Lq) can be calculated by the engine 102 with Equations 7 and 8 below:
L=λ×W (7)
L
q
=λ×W
q (8)
Using Equations 7 and 8, the queue length and the queue time per register for a specified time interval, e.g., fifteen minute intervals, can be calculated by the engine 102. As discussed herein, in some embodiments, the calculations performed by the engine 102 and/or the results of the calculations can be provided to a user based on fifteen minute intervals. However, it should be understood that other timeframes can be utilized, e.g., thirty minutes, forty-five minutes, one hour, one day, one week, and the like. For example, in some embodiments, substantially similar calculations can be performed in fifteen minute intervals and the fifteen minute interval calculations can be grouped together to represent the desired timeframe, e.g., if a user wishes to view data representative of one hour, four fifteen minute intervals for the indicated timeframe can be grouped together and provided to the user.
As depicted in
In some embodiments, a ratio defined by Equation 9 can be upheld to ensure that the queue does not grow significantly large.
where s represents the number of POS terminals being operated by store employees.
A probability (P0) that the system is empty (e.g., that there are no lines at the POS terminals) can be calculated by a Markovian process iteration of Equation 10 and an expected value (Lq) of the number of customers waiting in queue can be calculated with Equation 11.
Based on the probability (P0) and the expected value (Lq) of the number of customers waiting in queue computed by the system 100, the engine 104 can be programmed and/or configured to determine whether to schedule more or less cashiers, e.g., whether to open or close POS terminals to accommodate the number of expected customers. Understaffed scenarios can thereby be reduced by opening a determined number of POS terminals in preparation for an increase in customers. Likewise, overstaffed scenarios can thereby be reduced by closing a determined number of POS terminal in preparation for a decrease in customers.
With reference to
The scan time 132 can be the time from the first scanning and/or weighing of an item until a sub-total key on the POS system 130 is pressed to indicate an end of scanning. The tender time 134 can be the time from when the sub-total key is pressed until the tender key is pressed. The tender key can be for, e.g., cash, check, credit card, and the like. The previous tender time 136 can be the time from when a transaction is completed until the cash drawer of the POS system 100 is closed. The miscellaneous time 138 can be the time from when initial sign on occurs until a first scan occurs. The miscellaneous time 138 can also be the time from finalization of the last transaction until the first item of the next transaction is scanned. In exemplary embodiments, the system 130 (or the system 100) can be programmed and/or configured to calculate a transaction time per customer based on Equation 12 below:
Transaction Time=ST+TT+PTT+MT (12)
where ST represents the scan time 132, TT represents the tender time 134, PTT represents the previous tender time 136 and MT represents the miscellaneous time 138. The items per hour, i.e., the items scanned at a POS terminal by a cashier per hour, can be calculated by the system 130 (or system 100) based on Equation 13 below:
where IPH represents the items per hour scanned at a POS terminal, Items Sold represents the total items sold per hour and the Transaction Time represents the total transaction time per hour. The transaction time and the items per hour values can be used by the system 130 (or system 100) to calculate the total process time of a cashier, e.g., a time a cashier took to serve each customer during a specific time interval (e.g., a fifteen minute interval).
In some embodiments, the times recorded to the transaction time categories, e.g., the scan time 132, the tender time 134, the previous tender time 136 and the miscellaneous time 138, can be capped to remove noise and/or abnormal/unrealistic values from the captured transaction times. In particular, the time can be capped for calculating the queue length and remain uncapped for calculating the items per hour. For example, if a price check is necessary during a transaction with a customer, a cashier may spend fifteen minutes determining the correct price, thereby skewing the process time. Such noise and/or abnormal/unrealistic values can be removed by capping each of the transaction times of the POS system 130. Tables 1 and 2, below, indicate the cap which can be placed on the transaction times for each type of calculation.
As depicted in Table 1, for the purpose of calculating the items per hour, the scan time 132 query can be represented by the actual seconds per item scanned. For the purpose of calculating a queue length, in some embodiments and as depicted in Table 2, the scan time 132 query can include a time constraint or cap of approximately 60 seconds per item scanned. If an item takes approximately 60 seconds or more to scan, the POS system 130 can recognize that this is an unrealistic scenario. Such scenarios can occur when a price check is necessary for an item being purchased. The approximately 60 second constraint can therefore ensure that more cashiers are not assigned because of situations such as price checks, customers requesting time to obtain additional merchandise, and the like.
As depicted in Table 1, for the purpose of calculating the items per hour, the tender time 134 query can be represented by the actual seconds per transaction. For the purpose of calculating a queue length, in some embodiments and as depicted in Table 2, the tender time 134 query can include a time constraint or cap of approximately 90 seconds per transaction. If the tender time for an item takes approximately 90 seconds or more, the cap of approximately 90 seconds can be placed on the tender time for the item. In particular, it is understood by those of ordinary skill in the art that the time from when a sub-total key is pressed on the POS terminal until a tender key, e.g., cash, check, credit card, and the like, is pressed generally does not require more than 90 seconds.
As depicted in Table 1, for the purpose of calculating the items per hour, the previous tender time 136 query can be represented by the actual seconds per transaction. For the purpose of calculating a queue length, in some embodiments and as depicted in Table 2, the previous tender time 136 query can include a time constraint or cap of approximately 90 seconds per transaction. In particular, if the time from when a transaction is completed until the cash register of a POS system is closed requires more than 90 seconds, the cap of approximately 90 seconds can be placed on the previous tender time 136 to prevent inaccurate calculations.
As depicted in Table 1, for the purpose of calculating the items per hour, in some embodiments, the miscellaneous time 138 query can include a time constraint or cap of approximately 15 seconds per transaction. For the purpose of calculating a queue length, in some embodiments and as depicted in Table 2, the miscellaneous time 138 query can include a time constraint or cap of approximately 90 seconds per transaction. For example, for the purpose of calculating the queue length or key performance indicator (KPI), if the time from when initial sign on until a first scan occurs or the time from finalization of the last transaction until the first item is scanned in the next transaction surpasses 90 seconds, the cap of approximately 90 seconds can be placed on the miscellaneous time 138 to prevent inaccurate results. For the purpose of calculating items per hour, if the time from when initial sign on until a first scan occurs or the time from finalization of the last transaction until the first item is scanned in the next transaction surpasses 15 seconds, the cap of approximately 15 seconds can be placed on the miscellaneous time 138 to prevent inaccurate results. In some embodiments, a hard sign-off and/or a soft sign-off can reset timers within the POS system 130 without saving the additional time spent during the hard sign-off and/or the soft sign-off and the subsequent transaction. Therefore, a hard sign-off and/or a soft sign-off can stop the miscellaneous time 138 bucket and place the POS terminal in a suspended mode until a subsequent transaction is initiated by signing on to the POS terminal.
For example, if a cashier signs on to the POS terminal, the miscellaneous time 138 counter can start. If a cashier does not want to affect his/her performance of items per hour (IPH), a soft sign-off at the POS terminal can be performed. As a further example, if the cashier wishes to take a bathroom break, a snack break, or to stand in front of the isle and wait for customers, a soft sign-off can be performed. The actual transaction times for each POS terminal or cashier can thereby be captured, while reducing noise and/or abnormal/unrealistic values.
Turning to
Virtualization may be employed in the computing device 200 so that infrastructure and resourced in the computing device 200 may be shared dynamically. A virtual machine 214 may be provided to handle a process running on multiple processors 202 so that the process appears to be using only one computing resource rather than multiple computing resources. Multiple virtual machines may also be used with one processor 202.
Memory 206 may include a computer system memory or random access memory, such as DRAM, SRAM, EDO RAM, and the like. Memory 206 may include other types of memory as well, or combinations thereof.
A user may interact with the computing device 200 through a visual display device 218, such as a computer monitor, which may display one or more graphical user interfaces 105 that may be provided in accordance with exemplary embodiments. The computing device 200 may include other I/O devices for receiving input from a user, for example, a keyboard 208 or any suitable multi-point touch interface, a pointing device 210 (e.g., a mouse), and the like. The keyboard 208 and the pointing device 210 may be coupled to the visual display device 218. The computing device 200 may include other suitable conventional I/O peripherals.
The computing device 200 may also include one or more storage devices 222, such as a hard-drive, CD-ROM, or other computer-readable media, for storing data and computer-readable instructions and/or software that implement exemplary embodiments of the system 100 described herein. Exemplary storage device 222 may also store one or more databases 224 for storing any suitable information required to implement exemplary embodiments. For example, exemplary storage device 222 can store one or more databases 224 for storing information, such as store numbers, visit dates, visit times, customers/transactions, registers opened, process times, scan times, tender times, previous tender times, miscellaneous times, and the like, and values calculated from the transaction parameter values can include line lengths, a need for registers, service rates, arrival rates, number of servers/cashiers, and the like, to be used by embodiments of the system 100. The databases 224 may be updated manually or automatically at any suitable time to add, delete and/or update one or more items in the databases 224.
The computing device 200 can include a network interface 212 configured to interface via one or more network devices 220 with one or more networks, for example, Local Area Network (LAN), Wide Area Network (WAN) or the Internet through a variety of connections including, but not limited to, standard telephone lines, LAN or WAN links (for example, 802.11, T1, T3, 56 kb, X.25), broadband connections (for example, ISDN, Frame Relay, ATM), wireless connections, controller area network (CAN), or some combination of any or all of the above. In exemplary embodiments, the computing device 200 can include one or more antennas 226 to facilitate wireless communication (e.g., via the network interface 212) between the computing device 200 and a network. The network interface 212 may include a built-in network adapter, network interface card, PCMCIA network card, card bus network adapter, wireless network adapter, USB network adapter, modem or any other device suitable for interfacing the computing device 200 to any type of network capable of communication and performing the operations described herein. Moreover, the computing device 200 may be any computer system, such as a workstation, desktop computer, server, laptop, handheld computer, tablet computer (e.g., the iPad™ tablet computer), mobile computing or communication device (e.g., the iPhone™ communication device), point-of-sale terminal, internal corporate devices, or other form of computing or telecommunications device that is capable of communication and that has sufficient processor power and memory capacity to perform the operations described herein.
The computing device 200 may run any operating system 216, such as any of the versions of the Microsoft® Windows® operating systems, the different releases of the Unix and Linux operating systems, any version of the MacOS® for Macintosh computers, any embedded operating system, any real-time operating system, any open source operating system, any proprietary operating system, or any other operating system capable of running on the computing device 200 and performing the operations described herein. In exemplary embodiments, the operating system 216 may be run in native mode or emulated mode. In an exemplary embodiment, the operating system 216 may be run on one or more cloud machine instances.
The client devices 320-324 can include a client side application 336-340 programmed and/or configured to access and/or interface with the system 100. In the present embodiment, the client devices 320-324 can be computing devices including, for example, portable computing devices. In some embodiments, the client-side application 336 implemented by the client device 320 can be a web-browser capable of navigating one or more web pages hosting GUIs 105 of the system 100. In some embodiments, the client-side applications 336-340 implemented by one or more of the client devices 320-324 (e.g., portable computing devices) can be applications specific to the system 100 to permit access to the system 100 or the applications 336-340 can be the system 100. In some embodiments, the application specific to the system 100 can be a mobile application installed and executed by a portable computing device. In exemplary embodiments, the client devices 320-324 can be configured to communicate with the network 350 via wired and/or wireless communication.
The databases 330-334 can store information for use by the system 100. For example, the database 330 can store information related to the engine 102 transaction parameters, the database 332 can store information related to the engine 104 transaction parameters, and the database 334 can store information related to the system 130. In some exemplary embodiments, the databases 330-334 can store a combination of information related to the engine 102 transaction parameters, the engine 104 transaction parameters, and information related to the system 130.
One or more graphical user interfaces can be included in some embodiments to facilitate user interaction with the performance evaluation system 100, the engine 102, the engine 104, the POS 130 and other features disclosed herein. With reference to
A timeframe for generating or displaying data can be selected. For example, the system 100 can display data at a quarter hour level per store as a default setting. The user can suppress the quarter hour level data display by selecting the check box 410 to display data at a daily level. For a greater data display range, the check box 412 can be selected for a week selection. In particular, a week of interest can be input into the field 414 and a fiscal year end can be input into the field 416. In some embodiments, a start date can be selected in the field 418 and a selection of a data display for one day or for the entire week can be made by selecting the appropriate radio button 420. To select a greater data range, the start date can be selected or input into the field 418, the end date radio button 424 can be selected, and an end date can be selected or input into the field 422. An advanced settings or properties menu can be opened via a button 426. The query can be run by the system 100 for the selected fields by actuating the “OK” button 428 and the query can be canceled via the “Cancel” button 430.
The queue length compliance sub-window of the GUI window 450 allows the user to input a queue length and a queue compliancy goal into fields 452 and 454, respectively. For example, in some embodiments, the queue length field 452 can receive an input in the range of one to ten customers. As a further example, the desired queue length field 452 of
The utilization/register opening performance sub-window of the GUI window 450 allows the user to input an ideal utilization goal, an ideal register opening performance (ROP) goal, an over ideal ROP goal and an under ideal ROP goal into fields 456, 458, 460 and 462, respectively. For example, in some embodiments, the ideal utilization goal field 456 can receive an input in the range of approximately 60 percent to approximately 90 percent. As a further example, the ideal utilization goal field 456 of
In some embodiments, an ideal utilization goal between approximately 75 percent and approximately 85 percent can represent a queue length of approximately three customers. In some embodiments, an ideal utilization goal of less than approximately 75 percent can represent a queue length range of approximately zero to two customers. In some embodiments, an ideal utilization goal greater than approximately 85 percent can represent a queue length of approximately five customers or more. The ideal ROP goal, the over ideal ROP goal and the under ideal ROP goal can be calculated based on the ideal utilization goal.
In some embodiments, the number of ideal registers opened as compared to the number of actual registers opened, e.g., the ROP, can be based on the processing time, e.g., the time spent servicing customers, divided by the time interval, e.g., 900 seconds for a fifteen minute interval, and multiplied by the ideal utilization goal value, e.g., 75 percent. The calculated value can further be rounded up to the nearest whole value. For example, if the calculated ROP value is 1.5, the ROP value can be rounded up to two since 1.5 registers cannot be opened. The ideal ROP value can represent the number of registers which should have been opened during a predetermined time interval with a specified ideal utilization goal value, e.g., 75 percent. The actual number of registers opened can then be compared to the number of registers which should have been opened to determine the over ideal ROP and under ideal ROP percentages which represent the over registered and under-registered percentages. The ideal number of registers opened can be calculated based on Equation 14 and the ROP value comparing the actual number of registers opened relative to the number of registers which should have been opened can be calculated based on Equation 15.
It should be understood that the ideal number of registers calculated based on Equation 14 identifies the ideal number of registers for a fifteen minute time interval. In some embodiments, Equation 14 can be modified to include a customer process time for an alternative time interval and the 900 seconds can be modified to reflect the desired time interval, e.g., 1200 seconds for a twenty minute time interval.
The scans per hour/express characteristic sub-window of the GUI window 450 allows the user to input a scans per hour goal and an express lane number of items goal into fields 464 and 466, respectively. In particular, the scans per hour goal can represent the number of items scanned per hour at a regular checkout lane, while the express lane number of items goal can represent the number of items scanned per hour at an express checkout lane. For example, in some embodiments, the scans per hour goal field 464 can receive an input in the range of approximately 600 scans to approximately 1000 scans. As a further example, the scans per hour goal field 464 of
It should be understood that the scans per hour goal and the express lane number of items goal in fields 464 and 466 can be affected or selected by the type of front end process utilized by a specific store, a group of stores or a market. For example, a cashier working in the United States may scan and pack or bag the items sold. In contrast, a cashier working in Mexico may only scan the items sold, while a bagger or the customer packs or bags the items sold. The scans per hour goal set should therefore take into consideration the front end process being utilized at the store, the group of stores or the market. For example, in some embodiments, the scans per hour goal can be approximately 600 items per hour for the cashier in the United States who scans and packs the items sold, while the scans per hour goal can be approximately 900 items per hour for the cashier in Mexico who only scans the items sold. Similarly, the express lane number of items goal should be set while taking into consideration the way express lanes are defined in a store, a group of stores or a market. For example, in some embodiments, express lanes in the United States can be defined as lanes for customers with twenty items or less, while express lanes in Mexico can be defined as lanes for customers with thirteen items or less.
The business unit selection sub-window of the GUI window 450 allows the user to input a starting business unit number and an ending business unit number into fields 468 and 470, respectively, to indicate a range of business unit numbers which represent the stores of interest for which data will be displayed. It should be understood that the business unit selection sub-window can be used to select an individual store for viewing by inputting the same business unit number in the starting and ending business unit number fields 468 and 470. Similarly, the business unit selection sub-window can be used to select a group of stores for viewing by inputting a starting business unit number and an ending business unit number into fields 468 and 470. For example, in some embodiments, the starting business unit number field 468 and the ending business unit number field 470 can receive an input in the range of approximately zero to 9999. As a further example, the starting business unit number field 468 of
Check box 472 can be selected to indicate whether the generated data should include information on stores in the district and/or region. Check box 474 can be selected to indicate that all POS terminals in the store(s) should be included in the generated data. In some embodiments, by default, the GUI window 450 can generate data on only front end POS terminals. In some embodiments, the GUI window 450 can be implemented to select the types of POS terminals for which the data should be generated, e.g., front end POS terminals, self-checkout lanes, electronics department POS terminals, pharmacy department POS terminals, photo department POS terminals, tire and lube department POS terminals, garden department POS terminals, and the like. The advanced properties input in the GUI window 450 can be saved by actuating the “OK” button 476 and the input properties or goals can be canceled by actuating the “Cancel” button 480.
With reference to
The report 500 can include one or more column sub-headings, e.g., a region 506, a banner 508, a format 510, a total number of stores 512, and the like. An array 514 of rows and columns can include the data generated for the respective column header for each listed store or region. It should be understood that the data depicted in the array 514 corresponds to data descriptive of the stores in the country of interest for the week of the fiscal year as indicated by the first section 502. The region 506 can indicate the region within the country for which data is being shown, e.g., region 1, region 2, region 3, and the like. The banner 508 can indicate the type of store for which data is being shown, e.g., a supermarket, a neighborhood market, and the like. The format 510 can indicate a format for a type of store, e.g., HYP for hypermarket, SPM for supermarket, SPC for supercenter, and the like. The total number of stores 512 can indicate the total number of applicable stores for the specific region, e.g., 33 stores for region 1, 57 stores for region 2, and the like.
Although depicted as a total number of stores for a specific region, it should be understood that the reports discussed herein can be generated for each individual store or for groups of two or more stores. In some embodiments, a user can select a row in the array 514 for a specific region by clicking on the respective row which can, in turn, expand a sub-array showing data representative of each individual store in the region. Thus, a user can determine which stores meet the indicated goal and which stores are below the indicated goal. Corrective action can further be taken to improve the performance of the stores which are below the indicated goal.
Similarly, the report 500 can include one or more column sub-headings, e.g., an average 516, a percent of stores meeting goal 518, and the like. An array 520 of rows and columns can include the data generated for the respective column header for each listed store or region. It should be understood that the data depicted in the array 520 corresponds to data relating to the ideal register utilization goal as indicated by the second section 504. The average 516 can indicate the average ideal register utilization for all stores in the respective region as a percentage, e.g., 75.25 percent for stores in region 1, 62.06 percent for stores in region 2, and the like. The percent of stores meeting goal 518 can indicate the percent of stores in the respective region which meet the goal indicated in ideal utilization goal field 456 of GUI window 450, e.g., 57.58 percent for stores in region 1, 5.26 percent for stores in region 2, and the like. Based on the generated data, more or less registers can be opened to raise the percent of stores meeting the goal. As discussed above, the generated data can be based on real data collected at POS terminals such that the system 100 can accurately indicate the number of ideal POS terminals to be opened for different parts of the day, e.g., more POS terminals can be opened during a rush hour portion of the day, less POS terminals can be opened late at night, and the like, due to the variation in the number of customers in the store during different parts of the day.
The scans per hour report 530 can include a first section 502 substantially similar to the first section 502 of the ideal register utilization report 500, which indicates the country, the fiscal year end, and the week for which the report 530 is generated. The report 530 can include one or more column sub-headings, e.g., a region 506, a banner 508, a format 510, a total number of stores 512, and the like, substantially similar to the sub-headings of report 500. The report 530 further includes an array 514 of rows which include the data generated for the respective column header for each listed store or region. It should be understood that the data depicted in the array 514 corresponds to the data descriptive of the stores in the country of interest for the week of the fiscal year end as indicated by the first section 502.
The report 530 further includes a second section 532 or header indicating the goal for which the report 530 is generated. For example,
The queue compliancy report 540 can include a first section 502 substantially similar to the first section 502 of the ideal register utilization report 500, which indicates the country, the fiscal year end, and the week for which the report 540 is generated. The report 540 can include one or more column sub-headings, e.g., a region 506, a banner 508, a format 520, a total number of stores 512, and the like, substantially similar to the sub-headings of report 500. The report 540 further includes an array 514 of rows and columns which include the data generated for the respective column header for each listed store or region. It should be understood that the data depicted in the array 514 corresponds to the data descriptive of the stores in the country of interest for the week of the fiscal year end as indicated by the first section 502.
The report 540 further includes a second section 542 or header indicating the goal for which the report 540 is generated. For example,
With respect to Equation 16, TQH can represent the total number of fifteen minute time intervals and TQHE can represent the total number of fifteen minute time intervals with a queue exception.
The percent of stores meeting goal 548 can indicate the percent of stores in the respective region which meet the goal indicated in the queue compliancy goal field 454 of GUI window 450, e.g., 0 percent for stores in region 1, 12.28 percent for stores in region 2, and the like. It should be noted that if a store and/or a region always meets or exceeds the queue compliancy goal, this may indicate that the particular store and/or region is overstaffed.
The report 560 further includes a second section 562 or header indicating the goal for which the report 560 is generated. In some embodiments, the average queue length goal can be in the range of one to ten customers. For example,
The ideal ROP report 570 can include a first section 502 substantially similar to the first section 502 of the ideal register utilization report 500, which indicates the country, the fiscal year end, and the week for which the report 530 is generated. The report 570 can include one or more column sub-headings, e.g., a region 506, a banner 508, a format 510, a total number of stores 512, and the like, substantially similar to the sub-headings of report 500. The report 570 further includes an array 514 of rows and columns which include the data generated for the respective column header for each listed store or region. It should be understood that the data depicted in the array 514 corresponds to the data descriptive of the stores in the country of interest for the week of the fiscal year end as indicated by the first section 502.
The report 570 further includes a second section 572 or header indicating the goal for which the report 570 is generated. In some embodiments, the ideal ROP goal can be in the range of approximately 75 percent to approximately 100 percent. For example,
The percent over registered report 580 can include a first section 502 substantially similar to the first section 502 of the ideal register utilization report 500, which indicates the country, the fiscal year end, and the week for which the report 580 is generated. The report 580 can include one or more column sub-headings, e.g., a region 506, a banner 508, a format 510, a total number of stores 512, and the like, substantially similar to the sub-headings of report 500. The report 580 further includes an array 514 of rows and columns which include the data generated for the respective column header for each listed store or region. It should be understood that the data depicted in the array 514 corresponds to the data descriptive of the stores in the country of interest for the week of the fiscal year end as indicated by the first section 502.
The report 580 further includes a second section 582 or header indicating the goal for which the report 580 is generated. In some embodiments, the percent over registered goal can be in the range of approximately 5 percent to approximately 35 percent. For example,
The percent under registered report 590 can include a first section 502 substantially similar to the first section 502 of the ideal register utilization report 500, which indicates the country, the fiscal year end, and the week for which the report 590 is generated. The report 590 can include one or more column sub-headings, e.g., a region 506, a banner 508, a format 510, a total number of stores 512, and the like, substantially similar to the sub-headings of report 500. The report 590 further includes an array 514 of rows and columns which include the data generated for the respective column header for each listed store or region. It should be understood that the data depicted in the array 514 corresponds to the data descriptive of the stores in the country of interest for the week of the fiscal year end as indicated by the first section 502.
The report 590 further includes a second section 592 or header indicating the goal for which the report 590 is generated. In some embodiments, the percent under registered goal can be in the range of approximately 0 percent to approximately 25 percent. For example,
The report 600 further includes a second section 602 or header indicating that the report 600 is generated for one or more additional key performance indicators. The second section 602 can include one or more column sub-headings for each of the one or more additional key performance indicators, e.g., an average wait in queue 604 measured in minutes, an average transaction time 606 measured in seconds, an average customers per lane per quarter hour 608, an average basket size 610 based on the number of items in a basket of a customer, a percent transactions 612, a percent transactions 614, a register hours over ideal 616, and the like. In some embodiments, the limit for the percent transactions 612 and/or 614 can be in the range of approximately 5 baskets to approximately 35 baskets. As an example,
The average wait in queue 604 can indicate the average wait time for customers in queue for all stores in the respective region, e.g., 3.6 minutes for stores in region 1, 1.7 minutes for stores in region 2, and the like. The average transaction time 606 can indicate the average time a transaction between a customer and a cashier for all stores in the respective region, e.g., 57 seconds per transaction for stores in region 1, 51 seconds per transaction for stores in region 2, and the like. The average customers per lane per quarter hour 608 indicates the average number of customers in each lane for each fifteen minute time interval for all stores in the respective region, e.g., 12 customers for stores in region 1, 11 customers for stores in region 2, and the like. The average basket size 610 indicates the number of items in a basket of a customer for all stores in the respective region, e.g., 7 items for stores in region 1, 6 items for stores in region 2, and the like. The percent transactions 612 can indicate the percent of transactions within a fifteen minute time interval of less than or equal to 20 baskets for all stores in the respective region, e.g., 95.45 percent for stores in region 1, 95.62 percent for stores in region 2, and the like. The percent transactions 614 can indicate the percent of transactions within a fifteen minute time interval of greater than 20 baskets for all stores in the respective region, e.g., 4.55 percent for stores in region 1, 4.38 percent for stores in region 2, and the like. The register hours over ideal 616 can be calculated daily by subtracting the actual number of POS terminals opened from the ideal number of POS terminals calculated to be opened for each fifteen minute time period of the day. The result can then be converted into daily hours over or under the ideal number of registers calculated to be opened time and the sum of all days in the selected date range for all stores for the respective region can be presented in the array 618, e.g., −260.25 hours under the ideal register opened hours for stores in region 1, 4786.75 hours over the ideal register opened hours for stores in region 2, and the like.
Turning to
The system 800 includes at least one remote server 804 and a number of POS terminals 802 connected to the server 804 over a communications network 805. The system 800 can include an embodiment of the queue or line length calculation engine 102 and/or an embodiment of the register calculation engine 104. In some embodiments, the system 800 includes at least one database 806 containing information on each terminal 802, as described herein.
Each terminal 802 includes client software for interacting with the server 804. The client software also controls a number of input and output devices of the terminal 802. These may include a product scanner for scanning UPC codes, an ATM machine having a magnetic strip reader and a keypad, a cash drawer, a coin dispenser, a display for providing information to a customer, a means for inputting information (such as a touch screen display), and a printer. Depending upon the needs of the particular store, other configurations of devices may be used.
In an exemplary embodiment, one or more of the terminals 802 may be a self-checkout terminal 802 (also known as self-service checkout machine) that provides a mechanism for customers to process their own purchases from a retailer without the assistance of a cashier. Rather, the customer performs the job of the cashier themselves, by scanning and applying payment for the items. As an example, each of the terminals 802 or a subset of the terminals 802 are self-checkout terminals. In one embodiment, the self-checkout terminal 802 includes a self-checkout application module for controlling the self-checkout terminal 802 to perform checkout functions, including peripheral input and output devices at the self-checkout terminal for receiving inputs from, and providing outputs to, a customer. The server 804 is in communication with the self-checkout application module for the self-checkout terminal 802 via communications network 805.
As described above, the system (e.g., system 100 shown in
In response to determining that an utilization value for at least one geographic location is less than a utilization criteria and/or a queue length value for at least one geographic location is greater than a queue length criteria, as described above, the server 804 autonomously interfaces with one or more of the self-checkout terminals to activate or open the one or more self-checkout terminals 802 to adjust a quantity of terminals 802 to be operated at the at least one geographic location during a subsequent time period to reduce queue lengths for the terminals 802 at the at least one geographic location. The server 804 remotely and dynamically controls the operation of the one or more self-checkout terminals to activate the self-checkout terminal so that the shelf-checkout terminal, including its peripheral components are powered on and functional; thereby allowing customers to interact with the one or more self-checkout terminals without an associate/employee having to open or turn on the shelf-checkout terminal. In some embodiments, in order to activate a self-checkout terminals 802, the server 804 logs into a computing device 810 co-located with and communicatively coupled to the self-checkout terminals 802 using a passcode (e.g., a 4 digit passcode). The server 804 via the computing device 810 then logs into each self-checkout terminals 802 using the same passcode or different passcodes. After the server logs into the computing device 810 and the self-checkout terminals, the server remotely activates the self-checkout terminals via the computing device 810. In some embodiments, in order to activate a self-checkout terminals 802, the server 804 logs into the self-checkout terminal 802 using a passcode (e.g., a 4 digit passcode and without first logging into a separate computing device communicatively coupled to the terminals). Each self-checkout terminals 802 may share the same passcode or at least some of the self-checkout terminals 802 may have different passcodes.
In some embodiments, the database 806 stores the status of each self-checkout terminal 802 to determine whether the self-checkout terminal 802 can be activated. For example, the database 806 may include which self-checkout terminals 802 include money/currency to return change to customers, whereas only the self-checkout terminals 802 that contain a specified amount of money may be activated. The database 806 may also, for example, include which self-checkout terminals 802 have equipment failures and therefore cannot be activated.
The system 800 may include any number of self-checkout terminals 802, where each self-checkout terminal 802 includes a self-checkout application module in communicate with the server 804.
In an alternative embodiment, at least one terminal 802 may be cashier operated terminal 802 where the checkout function is performed by a cashier. The cashier operated terminal 802 further includes a keyboard for receiving inputs from the cashier. The cashier operated terminal 802 includes an application module for activating the cashier operated terminal 802, such that the cashier is able to perform the checkout function. The server 804 is in communication with an application module for the cashier operated terminal 802. In response to determining that the utilization value for at least one geographic location is less than the utilization criteria and/or the queue length value for at least one geographic location is greater than the queue length criteria, as described above, the server 804 activates or opens one or more cashier operated terminals 802 to be operated at the at least one geographic location during a subsequent time period to reduce queue lengths for the terminals 802 at the at least one geographic location. Upon activating the one or more cashier operated terminals, the server 804 can secure the one or more cashier operated terminals to prevent unauthorized use of the cashier terminal. For example, the server 804 can activate the one or more cashier operated terminals such that the one or more cashier operated terminals and their peripherals are powered and ready for use, but can configure the one or more cashier operated terminals to require cashiers to log into the one or more cashier operated terminal before the one or more cashier operated terminals and their peripherals are functional.
The server 804 can schedule more cashiers to the activated cashier operated terminal 802 based on the adjustment of the quantity of cashier operated terminal 802 to be operated at the at least one geographic location during a subsequent time period. In one embodiment, the server 804 activates a cashier operated terminal 802 and transmits a notification to a cashier to go to the activated cashier operated terminal 802 to perform checkout functions. In some embodiments, the server 804 may determine a specific cashier to assign to the activated cashier operated terminal 802. For example, the server 804 may consider a service rate of each available cashier. Each cashier operated terminals 802 may include an identifier such that the notified cashier is assigned to a particular cashier operated terminal 802. The server 804 can be programmed and/or configured to determine whether to schedule more or less cashiers, e.g., whether to open or close cashier operated terminals 802 to accommodate a number of current and/or expected customers. In some embodiments, the database 806 stores a schedule of the cashiers to determine which cashiers are available to operate a cashier operated terminals 802 based on the date and time.
The system may include any number of cashier operated terminals 802, where each cashier operated terminal 802 includes an application module in communicate with the server 804.
The system 800 minimizes wear on the terminals 802 by reducing the number of terminal 802 to be open during certain times of the day. The server 804 can be programmed and/or configured to determine whether to activate (open) or deactivate (close) more or less terminals 802 to accommodate a number of current and/or expected customers. Understaffed scenarios can thereby be reduced by automatically opening (remotely activating) a determined number of terminals 802 in preparation for an increase in customers or to reduce lengthy queues. Likewise, overstaffed scenarios can thereby be reduced by closing (remotely deactivating) a determined number of terminal 802 in preparation for a decrease in customers or once the queues have been reduced.
While exemplary embodiments have been described herein, it is expressly noted that these embodiments should not be construed as limiting, but rather that additions and modifications to what is expressly described herein also are included within the scope of the invention. Moreover, it is to be understood that the features of the various embodiments described herein are not mutually exclusive and can exist in various combinations and permutations, even if such combinations or permutations are not made express herein, without departing from the spirit and scope of the invention.
This application is a continuation-in-part of and claims priority to and benefit of U.S. patent application Ser. No. 14/071,914, filed on Nov. 5, 2013, the disclosure of which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 14071914 | Nov 2013 | US |
Child | 15947427 | US |