US20210209533A1 - Identifying and managing enterprise product availability - Google Patents

Identifying and managing enterprise product availability Download PDF

Info

Publication number
US20210209533A1
US20210209533A1 US17/205,495 US202117205495A US2021209533A1 US 20210209533 A1 US20210209533 A1 US 20210209533A1 US 202117205495 A US202117205495 A US 202117205495A US 2021209533 A1 US2021209533 A1 US 2021209533A1
Authority
US
United States
Prior art keywords
facility
availability
status
user
update
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
US17/205,495
Inventor
Jeremy Phillips
Shevata TULA
Maxime Moise
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Capital One Services LLC
Original Assignee
Capital One Services LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Capital One Services LLC filed Critical Capital One Services LLC
Priority to US17/205,495 priority Critical patent/US20210209533A1/en
Assigned to CAPITAL ONE SERVICES, LLC reassignment CAPITAL ONE SERVICES, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: Moise, Maxime, PHILLIPS, Jeremy, TULA, SHEVATA
Publication of US20210209533A1 publication Critical patent/US20210209533A1/en
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • G06Q10/063Operations research, analysis or management
    • G06Q10/0631Resource planning, allocation, distributing or scheduling for enterprises or organisations
    • G06Q10/06314Calendaring for a resource
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • G06Q10/063Operations research, analysis or management
    • G06Q10/0631Resource planning, allocation, distributing or scheduling for enterprises or organisations
    • G06Q10/06311Scheduling, planning or task assignment for a person or group
    • G06Q10/063114Status monitoring or status determination for a person or group
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/083Network architectures or network communication protocols for network security for authentication of entities using passwords
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources
    • H04L63/102Entity profiles
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/70Services for machine-to-machine communication [M2M] or machine type communication [MTC]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N20/00Machine learning

Definitions

  • Enterprise resources may include or refer to devices, skills, techniques, employees, vendors, or the like used by an enterprise to provide enterprise-offered products.
  • An enterprise may refer to an entity or set of entities, such as businesses or companies, that engages in economic activity to provide products such as goods or services.
  • a bank or banking company may be an enterprise, and products offered by a bank may include financial advising, wealth management, safe deposit boxes, savings accounts, money market accounts, current accounts, individual retirement accounts, fixed deposit accounts, recurring deposit accounts, certificates of deposit, time deposits, mutual funds, mortgages, personal loans, check books, credit cards, debit cards, service by automated teller machines (ATMs), and ATM cards.
  • ATMs automated teller machines
  • Various embodiments described herein may include an apparatus, a device, a method, and so forth including a memory to store instructions, and processing circuitry, coupled with the memory.
  • the processing circuitry is operable to execute the instructions, that when executed, cause the processor to identify a login of a registered user based on receipt of credentials correlated with the registered user and update a user status linked to the registered user based on identification of the login of the registered user.
  • the processor may determine a facility corresponding to the login of the registered user and update a facility status of the facility based on correspondence of the facility to the login of the registered user.
  • the processor may identify two or more resources of the facility, the two or more resources comprising one or more skills associated with the registered user and one or more devices associated with the facility, and the processor may update two or more statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user.
  • the processor may collect sensor data from one or more transducers located at the facility and update one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility.
  • the processor may evaluate the user status, the facility status, the two or more resources statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility.
  • the processor may update an availability record corresponding to the facility based on the set of available products associated with the facility.
  • Various embodiments described herein may include at least one non-transitory computer-readable medium comprising a set of instructions that, in response to being executed by a processor circuit, cause the processor circuit to update a user status linked to a registered user based on identification of a login of the registered user and determine a facility corresponding to the login of the registered user.
  • the instructions may cause the processor circuit to update a facility status of the facility based on correspondence of the facility to the login of the registered user.
  • the instructions may cause the processor circuit to identify two or more resources of the facility, the two or more resources of the facility comprising one or more skills associated with the registered user and one or more devices associated with the facility, and update two or more resource statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user.
  • the instructions may cause the processor circuit to collect sensor data from one or more transducers located at the facility and update one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility.
  • the instructions may cause the processor circuit to evaluate the user status, the facility status, the two or more resources statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility.
  • the instructions may cause the processor circuit to generate an availability record corresponding to the facility based on the set of available products associated with the facility; and provide access to the availability record corresponding to the facility via an application programming interface.
  • Various embodiments described herein may include a computer-implemented method, comprising identifying a login of a registered user based on receipt of credentials correlated with the registered user.
  • the method may include updating a user status linked to the registered user based on identification of the login of the registered user.
  • the method may include determining a facility corresponding to the login of the registered user.
  • the method may include updating a facility status of the facility based on correspondence of the facility to the login of the registered user.
  • the method may include identifying two or more resources of the facility, the two or more resources of the facility comprising one or more skills associated with the registered user and one or more devices associated with the facility.
  • the method may include updating two or more resource statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user.
  • the method may include collecting sensor data from one or more transducers located at the facility.
  • the method may include updating one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility.
  • the method may include evaluating the user status, the facility status, the two or more resources statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility.
  • the method may include updating an availability record corresponding to the facility based on the set of available products associated with the facility.
  • a system and method are provided for identifying the availability of a facility to provide enterprise-offered products.
  • FIG. 1 illustrates exemplary aspects of a system flow according to one or more embodiments described herein.
  • FIG. 2 illustrates exemplary aspects of processing availability information according to one or more embodiments described herein.
  • FIG. 3A illustrates exemplary aspects of processing a user login according to one or more embodiments described herein.
  • FIG. 3B illustrates exemplary aspects of processing information from a back-end application programming interface according to one or more embodiments described herein.
  • FIG. 4 illustrates exemplary aspects of processing historical data according to one or more embodiments described herein.
  • FIG. 5A illustrates a first exemplary logic flow according to one or more embodiments described herein.
  • FIG. 5B illustrates a second exemplary logic flow according to one or more embodiments described herein.
  • FIG. 5C illustrates a third exemplary logic flow according to one or more embodiments described herein.
  • FIG. 6 illustrates an embodiment of a computing architecture according to one or more embodiments described herein.
  • FIG. 7 illustrates an embodiment of a communications architecture according to one or more embodiments described herein.
  • Embodiments described herein are generally directed to techniques for identifying the availability of an enterprise to provide products, for example, banking products and/or services.
  • Embodiments may include using an availability manager informed by resource status data to determine if an enterprise facility is available to provide at least one product.
  • at least some data used to determine the availability of an enterprise facility may be collected from sensors and/or transducers associated with the enterprise facility.
  • Various embodiments may include using a machine learning model to analyze enterprise resource availability to determine enterprise facility availability to provide products.
  • at least one record may be updated with resource status information, facility availability, available product set information, and/or estimated lead time information.
  • determined availability information may be communicated to a user, for example, via an application program interface (API).
  • API application program interface
  • a bank may provide a customer with a physical products such as a debit card, credit card, ATM card, or check book for access to funds in the customer's account, a cashier's check for access to funds guaranteed by the bank, or cash as part of a withdrawal.
  • Intangible services could be provided by a bank, including financial advising, service by a mortgage officer, or opening a savings account.
  • Further examples include a bank providing services comprising a combination of physical products and intangible services, for example, activation of a bank card, access to a safe deposit box, or a wire transfer of funds.
  • a customer may desire a product from a bank and visit a branch location, kiosk, bank café, or other physical facility associated with the bank.
  • a bank branch may include a vault and be able to provide products such as cashier's checks, but a bank café may not.
  • Customers may not understand the differences between different types of enterprise facilities. As a result, they may go to a facility that does not provide the product they desire. For example, a bank customer desiring a cashier's check may visit a bank café only to learn that the bank café is unable to provide the product. Customers may waste time and still have to visit another facility in order to access their desired product.
  • enterprise locations may offer products temporally, for example, at certain times, when certain conditions are met, or when certain resources are available.
  • a bank may be able to provide a customer with a loan greater than a certain sum of money only when a bank manager is present to approve the loan, but the bank manager may work at different bank facilities at different times of the day, or the bank manager may have gotten sick and left work early for the day.
  • a customer may arrive at a facility normally able to provide the desired service only to find that an exception is preventing the facility from providing the desired product.
  • customers may have to wait at a facility, return at another time, or go to another facility in order to have access to their desired product. Again, as with the examples listed above and others, such instances may result in wasted time.
  • these experiences may frustrate customers and negatively affect their relationship with an enterprise.
  • products may be available at an enterprise which are not expected by customers. For example, a customer may wish to deposit a check at a bank branch in the evening, but listed hours for the facility indicate that the branch has already closed for the day. However, in this example, a bank employee may be working extended hours for the day and be available to help the customer. In this example, among others, a customer may miss out on services being currently offered by a facility due to a lack of proper information concerning current product availability. Additionally, an enterprise may miss out on business from a customer.
  • Availability of an enterprise to provide a product may then change from facility to facility, and availability within a single facility may change even within the same day. Attempts to manually communicate such changes to customers, for example, through editing information displayed on a website, may be time consuming and taxing for enterprise employees. In some cases, it may be difficult for an employee at a busy enterprise to manage customer requests for products and simultaneously communicate his or her availability to work on further requests in view of changing availabilities of other resources at the facility.
  • embodiments described herein can remedy one or more of these challenges and weaknesses.
  • embodiments described herein include components that can improve management and communication of information pertaining to enterprise product availability.
  • an availability record for at least one facility may be updated according to recognized activity and resource levels at the at least one facility.
  • data such as registered user logins, associated user and/or facility statuses, facility resource use, and/or product requirements may be monitored to determine enterprise product availability.
  • historical data may be analyzed to estimate product availability.
  • lead times may be estimated for available enterprise products, and in various embodiments, estimation of availability and/or lead time may be informed by a machine learning model.
  • product availability information may be communicated to customers.
  • Components described herein will therefore provide automated, informed determination of enterprise product availability for at least employees and customers of enterprises, thereby improving accuracy, efficiency, and transparency in communicating product availability with respect to enterprise facilities. Accordingly, in various embodiments described herein, management and use of availability information may be implemented in a practical application to increase capabilities of enterprise systems as a whole.
  • one or more of the components, techniques, or aspects described herein may be implemented via one or more computing devices, resulting in increased capability and improved functioning of the computer devices.
  • Specific and particular manners of automatically monitoring facility resource availability, analyzing trends in resource availability, and/or dynamically determining availability statuses may be provided by the components described in various embodiments herein.
  • expected behaviors and behaviors involving the update and management of enterprise facility resources may be performed independently of software utilizing the availability management via familiar, user-friendly interface objects.
  • components, techniques, or aspects described herein may be implemented as a set of rules that improve computer-related technology by allowing a function not previously performable by a computer that enables an improved technological result to be achieved. For example, managing an availability record based on user, resource, facility, and facility sensor statuses may be an improved technological result.
  • FIG. 1 illustrates exemplary aspects of a system flow 100 according to one or more embodiments described herein.
  • the system flow may include a user login 102 , an availability manager 104 , and an availability record 106 .
  • Embodiments are not limited in this context.
  • the user login 102 may be based on input received via a user interface, such as a graphical user interface (GUI) displayed on a desktop computer.
  • GUI graphical user interface
  • the user login may be based on input receive via other sensors, for example, biometric data collected from the user.
  • a user may be an employee of an enterprise, such as a bank.
  • the employee may be a user of a network-connected time recording platform allowing them to clock in and out of work from their computer.
  • an employee may log into a network-enabled workstation.
  • the user may log into a system managed directly by the enterprise.
  • the user may log into a system managed by a third party.
  • the enterprise may have access to information collected by the third party, for example, via an API.
  • An API may operate via a network-based system, a local operating system, a database system, computer hardware, a software library, or any combination thereof.
  • an API may operate as a remote API. Embodiments are not limited in this context.
  • the user login 102 may involve uniquely identifying information for a user.
  • the user login may comprise a user's company-issued or custom username and password.
  • the user login 102 may comprise non-identifying credentials.
  • a user login for a general enterprise account could be used to log in to a workstation or an administrative account could be used to log in to specific machines.
  • the user login 102 may include information pertaining to the system logged into.
  • information pertaining to the system logged into could include the program logged into or a network address of the system logged into.
  • the user login 102 may be identified by an availability manager 104 .
  • the availability manager 104 may receive the user login 102 in a secure manner, for example, encrypted, secure tunnel, and so forth.
  • the availability manager 104 may retrieve and/or process information from the user login.
  • the availability manager 104 may identify a specific user associated with the login or the platform or device which was logged into. Further examples include an internet protocol (IP) address from which the user login 102 was initiated and a time stamp for the user login 102 .
  • IP internet protocol
  • the availability manager 104 may have access to information beyond that included in the user login.
  • the availability manager 104 may have access to a memory, database, or other storage for information.
  • Information identifiable by the user login 102 information may be stored, for example, in a database in association with other detailed information.
  • a user login 102 may be used by the availability manager 104 to identify a unique user who is logging in.
  • the availability manager may be able to search a database for the unique user and identify a specific enterprise facility associated with the user, such as the facility at which the user works.
  • Information available to an availability manager 104 may include data pertaining to enterprise facilities and/or facility employees.
  • data may include services provided at a facility, the presence of equipment and supply quantities needed to provide products, employees present at the facility, employees logged into a system at a facility, such as an electronic time card system, employees currently not engaged in or soon to be engaged in another task, and skills in which present employees have been trained.
  • skills may include technical skills, such as using a card printer, or soft skills, such as customer service.
  • skills may be specific to an enterprise.
  • soft skills for a user associated with a bank may include skills such as permission level, mortgage sales, small business banking, teller, public notary, and training certification.
  • data available to an availability manager 104 include the number of customers at a facility in a waiting queue, regular traffic patterns, and scheduling data such as prescheduled appointments, events scheduled at the facility, including events scheduled for customers and for employees, and appointments requested by walk-in customers. Further examples include utility data relating the facility, such as operating electricity, internet, and water capabilities and rates, and the number of vehicles parked in a parking lot for the facility, as detected by a parking meter, a security camera or sensor, or satellite feed. In some embodiments, such data may be available to the availability manager 104 via at least one transducer associated with the enterprise and/or with a third party. In some embodiments, such data may be available to the availability manager 104 through a third-party system, for example, via an API accessed through a developer exchange program.
  • Information available to an availability manager 104 may be updated in real or near-real time to maintain accuracy of records.
  • information available to an availability manager 104 may be pre-stored.
  • the availability manager 104 may access detailed information based upon layered logic and/or searches. For example, the availability manager 104 may identify a skill set associated with a user identified with a user login 102 , and the availability manager 104 may identify a facility associated with the identified user. In this example, a set of resources may be identified as being associated with the facility, and the availability manager 104 may identify overlap between the user's skill set and facility resources.
  • the availability manager 104 may, in many embodiments, generate, update, and/or provide an availability record 106 based on the user login 102 . In some embodiments, the availability manager 104 may generate, update, and/or provide an availability record 106 based upon the user login 102 and other information available to the availability manager 104 . For example, an availability manager 104 may use overlap between a logged-in user's skill set and resources available at a facility associated with the user to identify products as being available at the facility. Such products may be marked in an availability record 106 as being available at the facility.
  • the availability record may comprise a database, table, or other medium storing data relating to enterprise availability.
  • an availability record 106 may be associated with a specific enterprise facility.
  • the availability record 106 may comprise a table containing availability information for a facility associated with a user identified by the availability manager 104 from the user login 102 .
  • an availability record 106 may be associated with a plurality of enterprise facilities. For example, a single indexable record could be used to store availability information for all facilities.
  • An availability manager 104 may generate, update, and/or provide an availability record 106 with availability data for a single facility or for a plurality of facilities based upon the user login 102 . For example, a user log-in by a particular user may be used to update in the availability record 106 availability at the facility in which he or she logged in. However, if he or she was previously logged in to another facility, the present log in may be used to indicate in the availability record 106 availability at the present facility and unavailability at the previous facility. Embodiments are not limited in this context.
  • the availability manager 104 may not generate, update, and/or provide an availability record 106 based on the user login 102 .
  • an indicator associated with the user login 102 may be recognized by the availability manager 104 indicating partial or lack of action in provision of an availability record 106 .
  • an enterprise employee with a high level of skill, security clearance, or authority may visit a facility to provide a training session to employees of the facility. During this time, he or she may log into an enterprise system.
  • the availability manager 104 may use information available to it, such as a schedule, to recognize the event. In response, the availability manager 104 may not update an availability record 106 to show availability of the enterprise employee's skills for the use of enterprise customers.
  • a user logout may be recognized by an availability manager 104 .
  • a user logout may be recognized by unavailability of recognition of a user login 102 and/or recognition of a signal indicating logout.
  • a user logout may be used by the availability manager 104 to update an availability manager 104 .
  • aspects of an availability record 106 may be maintained in real or near-real time. Additionally, or alternatively, aspects of an availability record 106 may be updated periodically. For example, an availability record 106 may be updated in response to a trigger such as a new user login 102 , an update of information available to an availability manager 104 , in response to an elapsed period of time, or in another request, as described in greater detail herein.
  • a trigger such as a new user login 102 , an update of information available to an availability manager 104 , in response to an elapsed period of time, or in another request, as described in greater detail herein.
  • FIG. 2 illustrates exemplary aspects of processing a user login according to one or more embodiments described herein.
  • a user login 102 may be received by an availability manager 104 .
  • the availability manager may comprise a processing system that includes one or more computing devices that are interconnected via one or more network links, e.g., wired, wireless, fiber, etc.
  • the availability manager may be a distributed computing system with each server comprising one or more cores to process information and data. Embodiments are not limited in this context.
  • the availability manager 104 may include a component correlator 210 which may process the user login 102 .
  • the component correlator 210 may identify from the user login 102 information specific to the user login. For example, the component correlator 210 may identify information identifying a user, information identifying a device or platform being logged into, a location or facility associated with the user login, or any combination of data included in the user login 102 .
  • the component correlator 210 may identify components associated with information identified in the user login 102 .
  • a component may include a facility associated with a user identified by the component correlator 210 from the user login 102 .
  • Further examples of components identified by the component correlator 210 may include devices and resources present and/or available for use at a facility, sensors and/or transducers associated with a facility, and skills identified as being possessed by the logged in user. Further exemplary components are described below.
  • the component correlator 210 may identify components correlated with information identified by a user login 102 via access to at least one memory article, table, datastore, or other suitable type of memory unit. Such memory may be local to the component correlator 210 , available via a network connection, available via a wired connection, available via another known method, or any combination thereof.
  • data associated with various components may be available to a component correlator via a plurality of memories. Data may be collected from memories associated with or managed by the enterprise, in some embodiments. In some embodiments, data may be collected from third-party resources. For example, data may be collected by the component correlator 210 via APIs coordinating with other parties, such as via a developer exchange program. Embodiments are not limited in this context.
  • the component correlator 210 may identify components correlated with at least a user identified by and/or from the user login 102 . For example, a user's availability may be identified. Additionally, further information may be identified in association with the user data. For example, a schedule associated for a user of the user login 102 may be identified. It will be understood that further data useful for ascertaining the availability of a user may be included.
  • a user status updater 212 may be used to update information in a component status datastore 222 , for example, in view of information pertaining to user availability as identified by the component correlator 210 .
  • the component correlator 210 may identify components correlated with the user login 102 that pertain to at least one facility's availability.
  • the facility may be identified from which a user login 102 originated, or a facility may be identified as being associated with a user identified from the user login 102 .
  • Information relating to the facility may be further identified. For example, such information may include a regular schedule of the facility, the number of customers at a facility in a waiting queue, regular traffic patterns, prescheduled appointments, events scheduled at the facility, including events scheduled for customers and for employees, and appointments requested by walk-in customers. It will be understood that further data useful for ascertaining the availability of a facility is not outside the scope of the present disclosure and may be included.
  • Information identified by a component correlator 210 relating to a facility may be used by a facility status updater 214 to update information in a component status datastore 222 .
  • the component correlator 210 may identify components correlated with the user login 102 that pertain to resource availability.
  • Resources may, in various embodiments, be identified as being associated with a user and/or facility identified by the component correlator 210 .
  • User-related resources may comprise examples such as at least one skill identified as being associated with a user, a level of security clearance of a user, or an authority level of a user.
  • a resource skill associated with a user may comprise a technical skill, such as using a card printer, or a soft skill, such as customer service.
  • Facility-related resources may comprise examples such as devices present and/or available for use at a facility or supplies present at a facility.
  • devices available at a bank may include an automated teller machine, a money counter, a vault, safety deposit boxes, coffee machine, a certified check printer, a bank card encoder, and a bank card blank. It will be understood that further data useful for ascertaining the availability of at least one enterprise resource may be included.
  • resources identified by a component correlator 210 may be useful for providing a product to a user.
  • Information identified by a component correlator 210 relating to at least one resource may be used by a resource status updater 216 to update information in a component status datastore 222 .
  • the component correlator 210 may identify components correlated with the user login 102 that pertain to at least one sensor.
  • a sensor may be a transducer associated with the enterprise, the facility, and/or a third party. Sensors may be, in some embodiments, identified as correlating with a facility or resources identified by the component correlator 210 .
  • information pertaining to sensors may be available to the component correlator 210 via access to a memory associated with the enterprise, enterprise facility, and/or third party, such as via an API.
  • Information pertaining to sensors may include data recorded by the sensor pertaining to a facility, devices at the facility, or other resources.
  • Facility-related sensor data may include data such as sensors and/or data collected by sensors pertaining to facility operations and/or traffic. Further examples of data collected and/or available to sensors include utility statuses of the facility, such as operating electricity, internet, and water capabilities and rates, and the number of vehicles parked in a parking lot for the facility, as detected by a parking meter, a security camera or sensor, or satellite feed. One of ordinary skill in the art will recognize that further data collected by sensors and/or useful for assessing the capability of an enterprise facility to handle requests at a particular time may be included. Information identified by a component correlator 210 relating to at least one sensor may be used by a facility sensor status updater 220 to update information in a component status datastore 222 .
  • sensor-related data identified by the component correlator 210 may be used to identify sensors from which further data is desired.
  • a sensor data collector 218 may be used to retrieve further data from sensors.
  • a sensor data collector 218 may comprise a database or other memory system of information collected by sensors.
  • a sensor data collector 218 may comprise a processor and/or set of instructions to gather data from sensors. Data from sensors may be available to the sensor data collector 218 locally and/or via wired, network, or other connection. Data accessible via the sensor data collector 218 may have been previously collected by sensors and/or sensors may be triggered to presently collect data to be available to the availability manager 104 via the sensor data collector 218 . In embodiments, data accessible to the availability manager 104 via the sensor data collector 218 may be used by a facility sensor status updater 220 to update and/or enter information into a component status datastore 222 .
  • a component correlator 210 may pertain to more than one of users, facilities, resources, and sensors.
  • a supply of a resource such as card blanks for a bank
  • a sensor for example, a camera or scanner.
  • historic traffic for a facility may be identified as having been identified by a particular sensor, such as a camera or parking meter.
  • Various embodiments may associate data identified by the component correlator 210 with one or more of the categories listed above, and one or more of the status updaters 212 , 214 , 216 , and 220 as described above may be used to update a component status datastore 222 accordingly.
  • one or more of status updaters 212 , 214 , 216 , and 220 may inform one or more of the other status updaters 212 , 214 , 216 , and 220 .
  • a user status being updated to show availability may inform a status update of availability for a facility associated with that user. Any combination and/or ordering of the status updaters 212 , 214 , 216 , and 220 to inform each other in this manner is within the scope of the current discussion.
  • the status updaters 212 , 214 , 216 , and 220 may, in some embodiments, exist as unique and separate components. In other embodiments, any combination of the status updaters 212 , 214 , 216 , and 220 may exist as a single component. A component may exist in a single location as part of the availability manager 104 or be distributed, for example, across one or more servers. Embodiments are not limited in this context.
  • the status updaters 212 , 214 , 216 , and 220 may process the data collected by the component correlator 210 to identify the availability of at least one user, facility, resource, and/or facility sensor as a status.
  • this status may represent a binary availability level, for example, available or unavailable.
  • status may include greater detail. For example, levels of operating electricity may be indicated.
  • the status updaters 212 , 214 , 216 , and 220 may be used to update the component status datastore 222 with at least one status.
  • a user status updater 212 may be used to update a user status 228 in the component status datastore 222
  • a facility status updater 214 may be used to update a facility status 230 in the component status datastore 222
  • a resource status updater 216 may be used to update a resource status 224 in the component status datastore 222
  • a facility sensor status updater 220 may be used to update a facility sensor status 226 in the component status datastore 222 .
  • the status information of the component status datastore 222 as updated by the status updaters 212 , 214 , 216 , and 220 may be useful for determining availability of at least one facility to provide at least one enterprise service.
  • the component status datastore 222 may, in some embodiments, exist as a table, database, or other memory system accessible to the availability manager 104 . In some embodiments, the component status datastore 222 may be local to the availability manager 104 . In other embodiments, the component status datastore 22 may be available to the availability manager 104 at least in part via wired, network, or other connection.
  • the component status datastore 222 may be used to probabilistically determine an enterprise's ability to provide a service or product. This determination may be made, in some embodiments, with the use of at least one machine learning model 232 . In some embodiments, a machine learning model 232 may be informed by the component status datastore 222 . A machine learning model 232 may, in various embodiments, be based on historic availability data and/or historic component status data from the component status datastore 222 . Historic availability data and historic component status data may be used by the machine learning model 232 to estimate availability of a facility based on component status data.
  • a machine learning model may be informed by product requirements 233 .
  • product requirements 233 may exist in a storage system coupled to the availability manager 104 .
  • the storage system may contain data structures, such as one or more databases, to store information.
  • the availability manager 104 may be coupled to the storage system via one or more wired and/or wireless networking links, and the storage system may be local to the availability manager 104 or in a different location.
  • Product requirements 233 may comprise associated resources, skills, facility functionalities, and other components necessary for an enterprise to provide a product.
  • a machine learning model 232 informed by product requirements 233 may be better suited to assess not only availability of an enterprise to provide service, but more specific and/or accurate availability of an enterprise to provide specific products to customers.
  • An available product set 236 based on use of at least one machine learning model 232 may be provided to an availability updater 234 .
  • a machine learning model 232 may be used not only to assess current availability of an enterprise, but estimated availability and/or an enterprise's estimated ability to provide a product or service based on that availability.
  • a machine learning model may be used to estimate lead times necessary to provide products or services. Estimated lead times 238 may be provided to an availability updater 234 , in various embodiments.
  • An availability updater 234 may receive availability information understood by components of the availability manager 104 , such as by use of a machine learning model 232 .
  • the availability updater 234 may, in various embodiments, be able to estimate or have access to an estimated available product set 236 and/or estimated lead times 238 for provision of products. Information may be specific to at least one enterprise facility as specified by the component correlator 210 .
  • the availability updater 234 may be used to update an availability record 106 .
  • an availability updater 234 may be used to update an availability record 106 in view of an available product set 236 and/or estimated lead times 238 .
  • FIG. 3A illustrates exemplary aspects of utilizing a component correlator to inform resource status updater components according to one or more embodiments described herein.
  • a user login 102 is processed by a component correlator 210 .
  • the component correlator 210 may inform at least one status updater based on the user login 102 .
  • Embodiments are not limited in this context.
  • a component correlator 210 may identify a registered user 340 from the user login 102 .
  • the registered user 340 may be a recognized and/or authorized user of a platform, such as a software and/or device.
  • the recognition of a registered user 340 from a user login 102 may inform a user status updater 212 .
  • a user status updater may update the status of a registered user to be listed as available in response to that user being recognized as having logged in.
  • the component correlator 210 may access and/or refer to a user profile 342 associated with a recognized registered user 340 .
  • User profile 342 information may exist in a memory system coupled to the component correlator via a wired or wireless network, and the memory system may be local to the component correlator or exist in a separate location.
  • a user profile 342 may contain detailed information concerning a registered user 340 .
  • a user profile 342 may include skills 344 or a schedule 346 associated with the registered user 340 .
  • Skills 344 may comprise technical or soft skills in which the registered user is trained in or otherwise qualified to provide. For example, if the registered user is a bank employee, technical skills may include examples such as being able to operate a card printer or operate a coffee machine. Further examples include mortgage sales, small business banking, teller, public notary, training certification, financial advising and customer service. In various embodiments, skills 344 may include security, permission, and/or authorization levels. In some embodiments, soft or technical skills included in skills 344 may be associated with specific security and/or authorization levels.
  • a schedule 346 may comprise data indicating a registered user's 340 estimated presence at a facility or multiple facilities.
  • a schedule 346 may include scheduled appointments and/or estimated periods of unavailability.
  • a schedule 346 may be associated in the user profile 342 with a specific enterprise facility or multiple facilities, such as facility 348 - 1 .
  • a plurality of facilities 1 through n may be identified as being associated with a registered user 340 or schedule 346 .
  • a schedule 346 may be used to identify a particular facility at which an employee is estimated to be present.
  • a facility 348 - 1 is illustrated for the sake of simplicity. However, it will be understood that if 1 through n facilities are associated with a registered user 340 , facility 348 - 1 . . . n may be identified just as readily as being that at which the registered user 340 is present in accordance with a schedule 346 .
  • a facility 348 - 1 may not be associated with a schedule 346 , but the facility 348 - 1 may be identified from the user login 102 nonetheless.
  • the user login 102 may be associated with a device known to exist at a particular facility 348 - 1 .
  • Embodiments are not limited in this context.
  • a component correlator's 210 identification of a facility 348 - 1 associated with a user login 102 may inform a facility status updater 214 . This may include association via identification with a schedule 346 , etc., as described above.
  • a facility 348 - 1 status may be updated to show availability by a facility status updater 214 in response to identification to a registered user's 340 user login 102 at the facility 348 - 1 .
  • a facility status updater 214 may update availability statuses for multiple facilities based upon a component correlator 210 's identification of a facility 328 - 1 in association with a user login 102 .
  • a user login 102 for the registered user 340 subsequently associated with a facility 348 - 1 may be used to update the status of facility 348 - 1 to show availability and to update the status of a facility 348 - n to show unavailability.
  • a component correlator 210 may have access to and/or keep track of facility resources 350 .
  • Facility resources 350 may exist in a memory system coupled to the component correlator via a wired or wireless network, and the memory system may be local to the component correlator or exist in a separate location.
  • Facility resources 350 may indicate resources available for at least one enterprise facility.
  • Skills 344 identified in association with a particular user profile 342 may be used to inform facility resources 350 .
  • skills 344 associated with the user profile 342 of a registered user 340 recognized to be present at a particular facility 348 - 1 may be available at that facility 348 - 1 and therefore used to inform a total set of skills 352 available as part of facility resources 350 .
  • a facility 348 - 1 recognized by the component correlator 210 may be used to inform facility resources 350 .
  • a facility 348 - 1 may be associated with a set of devices, supplies, or other tangible resources which may then be recognized as being available as part of facility resources 350 .
  • a set of such resources may be maintained as devices 354 recognized to be available as part of facility resources 350 .
  • facility resources 350 may be determined to be available based upon a plurality of recognized skills 352 and/or devices 354 .
  • a bank card printer may be determined to be an available resource at a facility if and only if a card printer and a user with the technical skill to use it are both present at a facility.
  • skills 352 and/or devices 354 may pertain to one or a plurality of users and/or facilities.
  • skills 344 may include skills recognized as being available as relating to a single registered user 340 or to a collection of users.
  • Skills 352 and/or devices 354 may pertain to a single facility 348 - 1 or to a plurality of facilities 348 - 1 . . . n.
  • Aspects of facility resources 350 , including skills 352 and devices 354 may exist in a single memory system or a plurality of memory systems and may be either local to a single location or distributed. Embodiments are not limited in this context.
  • Facility resources 350 identified by the component correlator 210 may inform a resource status updater 216 .
  • a resource status updater 216 may update and/or provide availability information for resources relating to skills 352 , devices 354 , and/or any combination thereof as related to a registered user 340 and/or facility 348 - 1 as described above.
  • a component correlator 210 may identify a transducer set 356 as being associated with a facility 348 - 1 .
  • Transducers may be enabled to gather data pertaining to an enterprise and/or facility.
  • a transducer may be a camera, satellite, global positioning system, parking meter, water meter, electricity meter, thermostat, scanning system, or other known device which may be used for monitoring use of an enterprise and/or facility. Aspects of transducers may be local and/or remote to an enterprise facility 348 - 1 .
  • Transducers may be managed and/or operated by an enterprise, a facility, by a third-party, or by any partnership therebetween.
  • at least one transducer of a transducer set may be accessed by the component correlator via an API.
  • a sensor data collector 218 may be used according to an identified transducer set 356 .
  • a sensor data collector 218 may be used to retrieve further data from transducers.
  • a sensor data collector 218 may comprise a database or other memory system of information collected by transducers.
  • a sensor data collector 218 may comprise a processor and/or set of instructions to gather data from transducers. Data from transducers may be available to the sensor data collector 218 locally and/or via wired, network, or other connection. Data accessible via the sensor data collector 218 may have been previously collected by transducers and/or transducers may be triggered to presently collect data via the sensor data collector 218 .
  • FIG. 3B illustrates exemplary aspects of providing information pertaining to enterprise availability according to one or more aspects described herein. Embodiments are not limited in this context.
  • an availability updater 234 informs a back-end application programming interface (API) 358 to update an availability record 106 .
  • API application programming interface
  • Availability information is provided from the availability record 106 to a consumer device 362 via a front-end API 360 .
  • Embodiments are not limited in this context.
  • An availability updater 234 may, in embodiments, be informed by known and/or estimated availability information relating to at least one enterprise, enterprise facility, and/or enterprise product.
  • an availability updater 234 may include aspects of an availability manager 104 as described in association with FIG. 2 .
  • an availability updater 234 may update an availability record 106 via at least one back-end API 358 .
  • a back-end API 358 may operate via a network-based system, a local operating system, a database system, computer hardware, a software library, or any combination thereof. In some embodiments, a back-end API 358 may operate as a remote API.
  • An availability record 106 may comprise information concerning an enterprise's availability to provide at least one product and/or service.
  • a service may be regarded as an enterprise product.
  • Product availability may, in various embodiments, be related to specific enterprise facilities. For each facility, there may be information relating to the availability of various enterprise products.
  • available products may be associated with lead times estimated for a facility to be able to provide that product. In some embodiments, lead times may be estimated by use of a machine learning model 232 .
  • a facility 348 - 1 may be available to provide an available product 364 - 1 with an estimated lead time 366 - 1 , an available product 364 - 2 with an estimated lead time 366 - 2 , an available product 364 - n with an estimated lead time 366 - n.
  • an availability record 106 may comprise records for a single facility 348 - 1 , as exemplarily described in association with FIG. 2 .
  • an availability record 106 may comprise availability information for a plurality of facilities 348 - 1 , 348 - 2 , . . . and 348 - n , where n.
  • Each facility may, in embodiments, have a different set of products associated with it in the availability record 106 such that are available at that facility.
  • facility 348 - 2 may be available to provide an available product 368 - 1 with lead time 370 - 1 , an available product 368 - 2 with lead time 370 - 2 , and available product 368 - n with lead time 370 - n
  • facility 348 - n may be available to provide an available product 372 - 1 with lead time 374 - 1 , an available product 372 - 2 with lead time 3742 - 2 , and an available product 372 - n with lead time 374 - n.
  • an availability record 106 may be used to communicate information concerning enterprise availability to an enterprise and/or enterprise customers.
  • a front-end API 360 may be used to provide an availability record and/or information therein to be displayed on a consumer device 362 .
  • a front-end API 360 may operate via a network-based system, a local operating system, a database system, computer hardware, a software library, or any combination thereof.
  • a front-end API 360 may operate as a remote API. Embodiments are not limited in this context.
  • a consumer device 362 may comprise a device owned and/or managed by an enterprise or an enterprise customer.
  • a consumer device 362 may be a smart phone, laptop, desktop, tablet computer, or server.
  • a copy of information related to enterprise availability may be sent to the consumer device 362 .
  • information may be relayed for display on the consumer device 362 , such as via a website.
  • availability information may be communicated via a GUI on the consumer device 362 .
  • Availability information may be communicated to the user so as to display facilities in association with available products and estimated lead times.
  • availability information communicated to the consumer device 362 may be processed and/or filtered based upon facility details. For example, facilities may or may not be communicated and/or displayed on the consumer device 362 according to facility location and/or distance from a consumer device 362 , the availability of at least one product, or lead times for product availability.
  • a consumer device 362 may receive input from a user, for example, via a GUI.
  • display of availability information via the consumer device may be adjusted according to the user input. For example, facilities may be displayed in order of estimated lead times for a specific product according to a received filter request from a user.
  • availability information may be refreshed and/or updated on a consumer device 362 in response to received user input.
  • an availability record 106 may be updated in response to user input received by a consumer device 362 .
  • FIG. 4 illustrates exemplary aspects of the use of a machine learning model to update an availability record 106 according to one or more embodiments described herein.
  • a machine learning model may comprise a machine learning model 232 as described with regards to FIG. 2 .
  • a model trainer 480 may be informed by historical data such as historical status data 476 and historical performance data 478 .
  • the model trainer 480 may be used to produce a machine learning model 232
  • an availability updater 234 may use the machine learning model 232 to update an availability record 106 .
  • Embodiments are not limited in this context.
  • a model trainer 480 may be used to generate a machine learning model 232 .
  • the model trainer 480 may be informed by historical status data 476 and/or historical performance data 478 .
  • Either or both of historical status data 476 and historical performance data 478 may be stored in at least one database, table, or other memory system coupled to the model trainer 480 . Coupling may be via a wired and/or wireless network, and aspects of the memory system may be local to the system, remote, consolidated, and/or distributed.
  • Historical status data 476 may comprise a record of historical records of statuses.
  • status data may comprise resource statuses 224 , facility sensor statuses 226 , user status 228 , and facility status 230 data.
  • Historical status data 476 may be specific to a single enterprise facility or comprise data relating to multiple enterprise facilities.
  • historical status data 476 may include historical status updates in association with timestamps of the updates.
  • Historical performance data 478 may comprise a record of historical records of enterprise performance relating to providing products and/or services.
  • historical performance data may comprise historical data relating the time it took for an enterprise to provide a particular product and/or service.
  • historical performance data 478 may be related to a particular facility and/or user.
  • historical performance data 478 may be related to multiple facilities and/or users.
  • Historical performance data 478 may, in embodiments, comprise timestamp data in association with performance data.
  • historical performance data 478 may include data describing how long it took for a particular user at an enterprise facility to provide a particular product, or how long it took for a particular enterprise facility to provide a particular set of products on a particular day.
  • historical performance data 478 may include a measure of the quality of the product and/or service provided by an enterprise. For example, a product of a bank card misprinted by a bank such that a customer requested a reprint may be associated with a low measure of product quality. In an alternative example, a product provided without flaw by a facility may be associated with a high measure of product quality.
  • historical performance data 478 may include feedback from enterprise customers concerning enterprise performance regarding the provision of at least one product and/or service. Historical performance data 478 may be specific to a single enterprise facility or comprise data relating to multiple enterprise facilities. It will be understood that further data useful for the tracking of enterprise performance may be included in historical performance data 478 .
  • the model trainer 480 may receive historical status data 476 and/or historical performance data 478 relating to at least one enterprise facility. In embodiments, the model trainer 480 may make use of the data available to it via use of a machine learning algorithm 482 .
  • a machine learning algorithm 482 may employ supervised learning, unsupervised learning, reinforcement learning, or any other method commonly known in the art. Aspects of the model trainer 480 may, in embodiments, use historical status data 476 and/or historical performance data 478 to estimate product availability in association with status data.
  • the model trainer 480 may generate a machine learning model 232 .
  • the machine learning model 232 may be a model such as described with respect to FIG. 2 .
  • a machine learning model 232 may comprise estimated enterprise product availability. Aspects of the machine learning model 232 may be based upon current and/or recent status data.
  • a machine learning model 232 may comprise estimated lead times for products estimated to be available.
  • An availability updater 234 may use a machine learning model 232 to update an availability record 106 .
  • the availability updater 234 may be able to update the availability record 106 according to not only instantaneous status data, but according to estimated availability and/or performance for an enterprise to provide at least one product and/or service.
  • FIG. 5A illustrates exemplary aspects of a first logic flow according to one or more embodiments described herein.
  • user login may be used to update an availability record corresponding to a facility.
  • Embodiments are not limited in this context.
  • a login of a registered user is identified based on receipt of credentials correlated with the registered user. For example, a user name and password combination may be used to recognize a user.
  • a user status linked to the registered user is updated based on identification of the registered user of block 502 .
  • a registered user's login may be used to update the registered user's status to show availability.
  • a facility is determined to correspond to the login of the registered user.
  • the correspondence may be based on preconfigured information, such as a known place of the user's employment, or the correspondence may be based upon information received in association with the user login, such as a location or IP address.
  • a facility status of a facility is updated based on correspondence of the facility to the login of the registered user. For example, the first login of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is open. In another example, the last logout of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is closed.
  • two or more resources of a facility may be identified.
  • the two or more resources of the facility may comprise one or more skills associated with the registered user and one or more devices associated with the facility.
  • at least one skill associated with the registered user may be related to the use of the one or more devices associated with the facility.
  • two or more resource statuses may be updated based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user. In some embodiments, two or more resource statuses may be updated in conjunction with each other. In some embodiments, two or more resource statuses may be updated independently.
  • sensor data is collected from one or more transducers located at the facility.
  • sensor data may be pre-recorded.
  • sensor data may be actively recorded by the transducers.
  • one or more facility sensor statuses may be updated based on the sensor data collected from the one or more transducers located at the facility. For example, availability of devices and/or resources at a facility may be updated according to collected sensor data. Similarly, up-to-date employee busyness and/or traffic levels at an enterprise may be updated according to collected sensor data. Sensor data may, in some embodiments, be collected via the use of at least one API.
  • user status, facility status, the two or more resource statuses, and the one or more facility sensor statuses may be evaluated with a machine learning model to determine a set of available products associated with the facility.
  • the machine learning model may have been trained using historic data relating to statuses and performance measures associated with the facility.
  • an availability record may be updated, where the availability record corresponds to the facility based on the set of available products associated with the facility. In some embodiments, an availability record may be further updated with estimated lead times of the available products associated with the facility.
  • FIG. 5B illustrates exemplary aspects of a logic flow according to one or more embodiments described herein.
  • a login of a registered user may be used to generate an availability record, which may be made accessible via an API.
  • an availability record which may be made accessible via an API.
  • Embodiments are not limited in this context.
  • a user status linked to a registered user may be updated based on identification of a login of the registered user.
  • a status may be a binary indicator of availability or unavailability.
  • greater detail may be provided, for example, by a selection of or an enumerated encoding of status options. For example, different status options may show a user to be absent, present, busy, or available.
  • a facility may be determined to correspond to the login of the registered user.
  • Correspondence of a facility with a registered user may be preset, or it may be determined actively according to specific details of the login of the registered user and/or the platform for which the registered user logged in.
  • a facility status of the facility may be updated based on correspondence of the facility to the login of the registered user.
  • a status may be a binary indicator of availability or unavailability.
  • greater detail may be provided, for example, by a selection of or an enumerated encoding of status options. For example, different status options may show a facility to be open, closed, or having a set of employees available.
  • two or more resources of the facility may be identified.
  • the resources of the facility may comprise one or more skills associated with the registered user and one or more devices associated with a facility.
  • identified resources may comprise resources already having been identified in association with the facility.
  • two or more resource statuses may be updated based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user.
  • a resource status may be updated to show binary availability or unavailability of a resource.
  • a resource status may be updated to show an updated quantity of a resource. For example, a resource status may be updated from showing availability of a single employee at a bank having training in financial counseling to showing availability of two employees having training in financial counseling.
  • sensor data is collected from one or more transducers located at the facility.
  • transducers may be used to determine availability of human resources and/or at the facility.
  • transducers may be used to determine availability of supplies, use of utilities, power to enterprise devices, or use of other technical resource.
  • one or more facility sensor statuses may be updated based on the sensor data collected from the one or more transducers located at the facility.
  • a status may be a binary indicator of availability or unavailability.
  • greater detail may be provided, for example, by a selection of or an enumerated encoding of status options.
  • status may be determined according to sensor data being above and/or below a certain threshold.
  • the user status, the facility status, the two or more resource statuses, and the one or more facility sensor statuses may be evaluated with a machine learning model to determine a set of available products associated with the facility.
  • the machine learning model may be used to estimate lead times for the facility to provide each product in the set of products.
  • an availability record corresponding to the facility is generated.
  • the availability record is generated based on the set of available products associated with the facility.
  • an availability record may comprise a stored data system or portion thereof.
  • access to the availability record corresponding to the facility may be provided via an application program interface.
  • an application program interface may be associated with a developer exchange program.
  • FIG. 5C illustrates exemplary aspects of a logic flow according to one or more embodiments described herein.
  • logic flow 500 C a method describes a way to determine availability of enterprise products at a facility. Embodiments are not limited in this context.
  • the illustrated method includes identifying a login of a registered user based on receipt of credentials correlated with the registered user. For example, a user name and password combination may be used to recognize a user.
  • the illustrated method includes updating a user status linked to the registered user based on identification of the login of the registered user. For example, a registered user's login may be used to update the registered user's status to show availability.
  • the illustrated method includes determining a facility corresponding to the login of the registered user.
  • the correspondence may be based on preconfigured information, such as a known place of the user's employment, or the correspondence may be based upon information received in association with the user login, such as a location or IP address.
  • the illustrated method includes updating a facility status of the facility based on correspondence of the facility to the login of the registered. For example, the first login of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is open. In another example, the last logout of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is closed.
  • the illustrated method includes identifying two or more resources of the facility, the two or more resources of the facility comprising one or more skills associated with the registered user and one or more devices associated with the facility.
  • at least one skill associated with the registered user may be related to the use of the one or more devices associated with the facility.
  • the illustrated method includes updating two or more resource statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user.
  • two or more resource statuses may be updated in conjunction with each other.
  • two or more resource statuses may be updated independently.
  • the illustrated method includes collecting sensor data from one or more transducers located at the facility.
  • sensor data may be pre-recorded.
  • sensor data may be actively recorded by the transducers.
  • the illustrated method includes updating one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility. For example, availability of devices and/or resources at a facility may be updated according to collected sensor data. Similarly, up-to-date employee busyness and/or traffic levels at an enterprise may be updated according to collected sensor data. Sensor data may, in some embodiments, be collected via the use of at least one API.
  • the illustrated method evaluating the user status, the facility status, the two or more resource statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility.
  • the machine learning model may have been trained using historic data relating to statuses and performance measures associated with the facility.
  • the illustrated method includes updating an availability record corresponding to the facility based on the set of available products associated with the facility.
  • an availability record may be further updated with estimated lead times of the available products associated with the facility.
  • FIG. 6 illustrates an embodiment of an exemplary computing architecture 600 that may be suitable for implementing various embodiments as previously described.
  • the computing architecture 600 may comprise or be implemented as part of an electronic device.
  • the computing architecture 600 may be representative, for example, of one or more component described herein.
  • computing architecture 600 may be representative, for example, of a computing device that implements or utilizes one or more of availability manager 104 , component correlator 210 , status updaters 212 , 214 , 214 , and 220 , and/or one or more techniques described herein. Embodiments are not limited in this context.
  • a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer.
  • a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer.
  • an application running on a server and the server can be a component.
  • One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Further, components may be communicatively coupled to each other by various types of communications media to coordinate operations. The coordination may involve the uni-directional or bi-directional exchange of information. For instance, the components may communicate information in the form of signals communicated over the communications media. The information can be implemented as signals allocated to various signal lines. In such allocations, each message is a signal. Further embodiments, however, may alternatively employ data messages. Such data messages may be sent across various connections. Exemplary connections include parallel interfaces, serial interfaces, and bus interfaces.
  • the computing architecture 600 includes various common computing elements, such as one or more processors, multi-core processors, co-processors, memory units, chipsets, controllers, peripherals, interfaces, oscillators, timing devices, video cards, audio cards, multimedia input/output (I/O) components, power supplies, and so forth.
  • processors multi-core processors
  • co-processors memory units
  • chipsets controllers
  • peripherals peripherals
  • oscillators oscillators
  • timing devices video cards
  • audio cards audio cards
  • multimedia input/output (I/O) components power supplies, and so forth.
  • the embodiments are not limited to implementation by the computing architecture 600 .
  • the computing architecture 600 comprises a processing unit 604 , a system memory 606 and a system bus 608 .
  • the processing unit 604 can be any of various commercially available processors, including without limitation an AMD® Athlon®, Duron® and Opteron® processors; ARM® application, embedded and secure processors; IBM® and Motorola® DragonBall® and PowerPC® processors; IBM and Sony® Cell processors; Intel® Celeron®, Core (2) Duo®, Itanium®, Pentium®, Xeon®, and XScale® processors; and similar processors. Dual microprocessors, multi-core processors, and other multi-processor architectures may also be employed as the processing unit 604 .
  • the system bus 608 provides an interface for system components including, but not limited to, the system memory 606 to the processing unit 604 .
  • the system bus 608 can be any of several types of bus structure that may further interconnect to a memory bus (with or without a memory controller), a peripheral bus, and a local bus using any of a variety of commercially available bus architectures.
  • Interface adapters may connect to the system bus 608 via a slot architecture.
  • Example slot architectures may include without limitation Accelerated Graphics Port (AGP), Card Bus, (Extended) Industry Standard Architecture ((E)ISA), Micro Channel Architecture (MCA), NuBus, Peripheral Component Interconnect (Extended) (PCI(X)), PCI Express, Personal Computer Memory Card International Association (PCMCIA), and the like.
  • the system memory 606 may include various types of computer-readable storage media in the form of one or more higher speed memory units, such as read-only memory (ROM), random-access memory (RAM), dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), programmable ROM (PROM), erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), flash memory (e.g., one or more flash arrays), polymer memory such as ferroelectric polymer memory, ovonic memory, phase change or ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, magnetic or optical cards, an array of devices such as Redundant Array of Independent Disks (RAID) drives, solid state memory devices (e.g., USB memory, solid state drives (SSD) and any other type of storage media suitable for storing information.
  • ROM read-only memory
  • RAM random-access memory
  • DRAM dynamic
  • system memory 606 can include non-volatile memory 610 and/or volatile memory 612 .
  • system memory 606 may include main memory.
  • a basic input/output system (BIOS) can be stored in the non-volatile memory 610 .
  • the computer 602 may include various types of computer-readable storage media in the form of one or more lower speed memory units, including an internal (or external) hard disk drive (HDD) 614 , a magnetic floppy disk drive (FDD) 616 to read from or write to a removable magnetic disk 618 , and an optical disk drive 620 to read from or write to a removable optical disk 622 (e.g., a CD-ROM or DVD).
  • the HDD 614 , FDD 616 and optical disk drive 620 can be connected to the system bus 608 by a HDD interface 624 , an FDD interface 626 and an optical drive interface 628 , respectively.
  • the HDD interface 624 for external drive implementations can include at least one or both of Universal Serial Bus (USB) and Institute of Electrical and Electronics Engineers (IEEE) 694 interface technologies. In various embodiments, these types of memory may not be included in main memory or system memory.
  • USB Universal Serial Bus
  • IEEE Institute of Electrical and Electronics Engineers
  • the drives and associated computer-readable media provide volatile and/or nonvolatile storage of data, data structures, computer-executable instructions, and so forth.
  • a number of program modules can be stored in the drives and memory units 610 , 612 , including an operating system 630 , one or more application programs 632 , other program modules 634 , and program data 636 .
  • the one or more application programs 632 , other program modules 634 , and program data 636 can include or implement, for example, the various techniques, applications, and/or components described herein.
  • a user can enter commands and information into the computer 602 through one or more wire/wireless input devices, for example, a keyboard 638 and a pointing device, such as a mouse 640 .
  • Other input devices may include microphones, infra-red (IR) remote controls, radio-frequency (RF) remote controls, game pads, stylus pens, card readers, dongles, finger print readers, gloves, graphics tablets, joysticks, keyboards, retina readers, touch screens (e.g., capacitive, resistive, etc.), trackballs, trackpads, sensors, styluses, and the like.
  • IR infra-red
  • RF radio-frequency
  • input devices are often connected to the processing unit 604 through an input device interface 642 that is coupled to the system bus 608 , but can be connected by other interfaces such as a parallel port, IEEE 994 serial port, a game port, a USB port, an IR interface, and so forth.
  • a monitor 644 or other type of display device is also connected to the system bus 608 via an interface, such as a video adaptor 646 .
  • the monitor 644 may be internal or external to the computer 602 .
  • a computer typically includes other peripheral output devices, such as speakers, printers, and so forth.
  • the computer 602 may operate in a networked environment using logical connections via wire and/or wireless communications to one or more remote computers, such as a remote computer 648 .
  • a remote computer 648 can be a workstation, a server computer, a router, a personal computer, portable computer, microprocessor-based entertainment appliance, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 602 , although, for purposes of brevity, only a memory/storage device 650 is illustrated.
  • the logical connections depicted include wire/wireless connectivity to a local area network (LAN) 652 and/or larger networks, for example, a wide area network (WAN) 654 .
  • LAN local area network
  • WAN wide area network
  • Such LAN and WAN networking environments are commonplace in offices and companies, and facilitate enterprise-wide computer networks, such as intranets, all of which may connect to a global communications network, for example, the Internet.
  • the computer 602 When used in a LAN networking environment, the computer 602 is connected to the LAN 652 through a wire and/or wireless communication network interface or adaptor 656 .
  • the adaptor 656 can facilitate wire and/or wireless communications to the LAN 652 , which may also include a wireless access point disposed thereon for communicating with the wireless functionality of the adaptor 656 .
  • the computer 602 can include a modem 658 , or is connected to a communications server on the WAN 654 , or has other means for establishing communications over the WAN 654 , such as by way of the Internet.
  • the modem 658 which can be internal or external and a wire and/or wireless device, connects to the system bus 608 via the input device interface 642 .
  • program modules depicted relative to the computer 602 can be stored in the remote memory/storage device 650 . It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers can be used.
  • the computer 602 is operable to communicate with wire and wireless devices or entities using the IEEE 802 family of standards, such as wireless devices operatively disposed in wireless communication (e.g., IEEE 802.16 over-the-air modulation techniques).
  • wireless communication e.g., IEEE 802.16 over-the-air modulation techniques.
  • the communication can be a predefined structure as with a conventional network or simply an ad hoc communication between at least two devices.
  • Wi-Fi networks use radio technologies called IEEE 802.11x (a, b, g, n, etc.) to provide secure, reliable, fast wireless connectivity.
  • a Wi-Fi network can be used to connect computers to each other, to the Internet, and to wire networks (which use IEEE 802.3-related media and functions).
  • FIG. 7 illustrates a block diagram of an exemplary communications architecture 700 suitable for implementing various embodiments as previously described.
  • the communications architecture 700 includes various common communications elements, such as a transmitter, receiver, transceiver, radio, network interface, baseband processor, antenna, amplifiers, filters, power supplies, and so forth.
  • the embodiments, however, are not limited to implementation by the communications architecture 700 .
  • the communications architecture 700 comprises includes one or more clients 702 and servers 704 .
  • communications architecture may include or implement one or more portions of components, applications, and/or techniques described herein.
  • the clients 702 and the servers 704 are operatively connected to one or more respective client data stores 708 and server data stores 710 that can be employed to store information local to the respective clients 702 and servers 704 , such as cookies and/or associated contextual information.
  • any one of servers 704 may implement one or more of logic flows or operations described herein in conjunction with storage of data received from any one of clients 702 on any of server data stores 710 .
  • one or more of client data store(s) 708 or server data store(s) 710 may include memory accessible to one or more portions of components, applications, and/or techniques described herein.
  • the clients 702 and the servers 704 may communicate information between each other using a communication framework 706 .
  • the communications framework 706 may implement any well-known communications techniques and protocols.
  • the communications framework 706 may be implemented as a packet-switched network (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), a circuit-switched network (e.g., the public switched telephone network), or a combination of a packet-switched network and a circuit-switched network (with suitable gateways and translators).
  • the communications framework 706 may implement various network interfaces arranged to accept, communicate, and connect to a communications network.
  • a network interface may be regarded as a specialized form of an input output interface.
  • Network interfaces may employ connection protocols including without limitation direct connect, Ethernet (e.g., thick, thin, twisted pair 10/100/1900 Base T, and the like), token ring, wireless network interfaces, cellular network interfaces, IEEE 802.11a-x network interfaces, IEEE 802.16 network interfaces, IEEE 802.20 network interfaces, and the like.
  • multiple network interfaces may be used to engage with various communications network types. For example, multiple network interfaces may be employed to allow for the communication over broadcast, multicast, and unicast networks.
  • a communications network may be any one and the combination of wired and/or wireless networks including without limitation a direct interconnection, a secured custom connection, a private network (e.g., an enterprise intranet), a public network (e.g., the Internet), a Personal Area Network (PAN), a Local Area Network (LAN), a Metropolitan Area Network (MAN), an Operating Missions as Nodes on the Internet (OMNI), a Wide Area Network (WAN), a wireless network, a cellular network, and other communications networks.
  • a private network e.g., an enterprise intranet
  • a public network e.g., the Internet
  • PAN Personal Area Network
  • LAN Local Area Network
  • MAN Metropolitan Area Network
  • OMNI Operating Missions as Nodes on the Internet
  • WAN Wide Area Network
  • wireless network a cellular network, and other communications networks.
  • Various embodiments may be implemented using hardware elements, software elements, or a combination of both.
  • hardware elements may include processors, microprocessors, circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth.
  • Examples of software may include software components, programs, applications, computer programs, application programs, system programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, APIs, instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. Determining whether an embodiment is implemented using hardware elements and/or software elements may vary in accordance with any number of factors, such as desired computational rate, power levels, heat tolerances, processing cycle budget, input data rates, output data rates, memory resources, data bus speeds and other design or performance constraints.
  • One or more aspects of at least one embodiment may be implemented by representative instructions stored on a machine-readable medium which represents various logic within the processor, which when read by a machine causes the machine to fabricate logic to perform the techniques described herein.
  • Such representations known as “IP cores” may be stored on a tangible, machine readable medium and supplied to various users or manufacturing facilities to load into the fabrication machines that actually make the logic or processor.
  • Some embodiments may be implemented, for example, using a machine-readable medium or article which may store an instruction or a set of instructions that, if executed by a machine, may cause the machine to perform a method and/or operations in accordance with the embodiments.
  • Such a machine may include, for example, any suitable processing platform, computing platform, computing device, processing device, computing system, processing system, computer, processor, or the like, and may be implemented using any suitable combination of hardware and/or software.
  • the machine-readable medium or article may include, for example, any suitable type of memory unit, memory device, memory article, memory medium, storage device, storage article, storage medium and/or storage unit, for example, memory, removable or non-removable media, erasable or non-erasable media, writeable or re-writeable media, digital or analog media, hard disk, floppy disk, Compact Disk Read Only Memory (CD-ROM), Compact Disk Recordable (CD-R), Compact Disk Rewriteable (CD-RW), optical disk, magnetic media, magneto-optical media, removable memory cards or disks, various types of Digital Versatile Disk (DVD), a tape, a cassette, or the like.
  • CD-ROM Compact Disk Read Only Memory
  • CD-R Compact Disk Recordable
  • CD-RW Compact Dis
  • the instructions may include any suitable type of code, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, encrypted code, and the like, implemented using any suitable high-level, low-level, object-oriented, visual, compiled and/or interpreted programming language.

Landscapes

  • Business, Economics & Management (AREA)
  • Human Resources & Organizations (AREA)
  • Engineering & Computer Science (AREA)
  • Economics (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Strategic Management (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • General Business, Economics & Management (AREA)
  • Computing Systems (AREA)
  • Quality & Reliability (AREA)
  • Tourism & Hospitality (AREA)
  • Marketing (AREA)
  • Game Theory and Decision Science (AREA)
  • Educational Administration (AREA)
  • Development Economics (AREA)
  • General Engineering & Computer Science (AREA)
  • Operations Research (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Hardware Design (AREA)
  • Software Systems (AREA)
  • Artificial Intelligence (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Data Mining & Analysis (AREA)
  • Evolutionary Computation (AREA)
  • Medical Informatics (AREA)
  • Mathematical Physics (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

Various embodiments described herein are generally directed to techniques for identifying the availability of an enterprise to provide products, for example, banking products and/or services. Embodiments may include using an availability manager informed by resource status data to determine if an enterprise facility is available to provide at least one product. In some embodiments, at least some data used to determine the availability of an enterprise facility may be collected from sensors and/or transducers associated with the enterprise facility. Various embodiments may include using a machine learning model to analyze enterprise resource availability to determine enterprise facility availability to provide products. In some aspects described herein, at least one record may be updated with resource status information, facility availability, available product set information, and/or estimated lead time information. In some embodiments, determined availability information may be communicated to a user, for example, via an application program interface (API).

Description

    RELATED APPLICATIONS
  • This application is a continuation of U.S. patent application Ser. No. 16/517,181, titled “IDENTIFYING AND MANAGING ENTERPRISE PRODUCT AVAILABILITY” filed on Jul. 19, 2019. The contents of the aforementioned application are incorporated herein by reference.
  • BACKGROUND
  • Enterprise resources may include or refer to devices, skills, techniques, employees, vendors, or the like used by an enterprise to provide enterprise-offered products. An enterprise may refer to an entity or set of entities, such as businesses or companies, that engages in economic activity to provide products such as goods or services. For example, a bank or banking company may be an enterprise, and products offered by a bank may include financial advising, wealth management, safe deposit boxes, savings accounts, money market accounts, current accounts, individual retirement accounts, fixed deposit accounts, recurring deposit accounts, certificates of deposit, time deposits, mutual funds, mortgages, personal loans, check books, credit cards, debit cards, service by automated teller machines (ATMs), and ATM cards. In order for an enterprise product to be provided, enterprise resources to provide the product must be available. For example, in order for a bank branch to provide financial advising, an employee trained in financial advising may need to be present at the bank branch.
  • SUMMARY
  • Various embodiments described herein may include an apparatus, a device, a method, and so forth including a memory to store instructions, and processing circuitry, coupled with the memory. In some embodiments, the processing circuitry is operable to execute the instructions, that when executed, cause the processor to identify a login of a registered user based on receipt of credentials correlated with the registered user and update a user status linked to the registered user based on identification of the login of the registered user. In various aspects, the processor may determine a facility corresponding to the login of the registered user and update a facility status of the facility based on correspondence of the facility to the login of the registered user. In some embodiments, the processor may identify two or more resources of the facility, the two or more resources comprising one or more skills associated with the registered user and one or more devices associated with the facility, and the processor may update two or more statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user. In some aspects, the processor may collect sensor data from one or more transducers located at the facility and update one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility. In various embodiments, the processor may evaluate the user status, the facility status, the two or more resources statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility. In some embodiments, the processor may update an availability record corresponding to the facility based on the set of available products associated with the facility.
  • Various embodiments described herein may include at least one non-transitory computer-readable medium comprising a set of instructions that, in response to being executed by a processor circuit, cause the processor circuit to update a user status linked to a registered user based on identification of a login of the registered user and determine a facility corresponding to the login of the registered user. In some embodiments, the instructions may cause the processor circuit to update a facility status of the facility based on correspondence of the facility to the login of the registered user. In various embodiments, the instructions may cause the processor circuit to identify two or more resources of the facility, the two or more resources of the facility comprising one or more skills associated with the registered user and one or more devices associated with the facility, and update two or more resource statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user. In some embodiments, the instructions may cause the processor circuit to collect sensor data from one or more transducers located at the facility and update one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility. In various aspects, the instructions may cause the processor circuit to evaluate the user status, the facility status, the two or more resources statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility. In some embodiments, the instructions may cause the processor circuit to generate an availability record corresponding to the facility based on the set of available products associated with the facility; and provide access to the availability record corresponding to the facility via an application programming interface.
  • Various embodiments described herein may include a computer-implemented method, comprising identifying a login of a registered user based on receipt of credentials correlated with the registered user. In some embodiments, the method may include updating a user status linked to the registered user based on identification of the login of the registered user. In some embodiments, the method may include determining a facility corresponding to the login of the registered user. In various embodiments, the method may include updating a facility status of the facility based on correspondence of the facility to the login of the registered user. The method may include identifying two or more resources of the facility, the two or more resources of the facility comprising one or more skills associated with the registered user and one or more devices associated with the facility. In some embodiments, the method may include updating two or more resource statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user. In various embodiments, the method may include collecting sensor data from one or more transducers located at the facility. In various aspects, the method may include updating one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility. The method may include evaluating the user status, the facility status, the two or more resources statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility. In various embodiments, the method may include updating an availability record corresponding to the facility based on the set of available products associated with the facility.
  • With such an arrangement, a system and method are provided for identifying the availability of a facility to provide enterprise-offered products.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 illustrates exemplary aspects of a system flow according to one or more embodiments described herein.
  • FIG. 2 illustrates exemplary aspects of processing availability information according to one or more embodiments described herein.
  • FIG. 3A illustrates exemplary aspects of processing a user login according to one or more embodiments described herein.
  • FIG. 3B illustrates exemplary aspects of processing information from a back-end application programming interface according to one or more embodiments described herein.
  • FIG. 4 illustrates exemplary aspects of processing historical data according to one or more embodiments described herein.
  • FIG. 5A illustrates a first exemplary logic flow according to one or more embodiments described herein.
  • FIG. 5B illustrates a second exemplary logic flow according to one or more embodiments described herein.
  • FIG. 5C illustrates a third exemplary logic flow according to one or more embodiments described herein.
  • FIG. 6 illustrates an embodiment of a computing architecture according to one or more embodiments described herein.
  • FIG. 7 illustrates an embodiment of a communications architecture according to one or more embodiments described herein.
  • DETAILED DESCRIPTION
  • Various embodiments described herein are generally directed to techniques for identifying the availability of an enterprise to provide products, for example, banking products and/or services. Embodiments may include using an availability manager informed by resource status data to determine if an enterprise facility is available to provide at least one product. In some embodiments, at least some data used to determine the availability of an enterprise facility may be collected from sensors and/or transducers associated with the enterprise facility. Various embodiments may include using a machine learning model to analyze enterprise resource availability to determine enterprise facility availability to provide products. In some aspects described herein, at least one record may be updated with resource status information, facility availability, available product set information, and/or estimated lead time information. In some embodiments, determined availability information may be communicated to a user, for example, via an application program interface (API).
  • Various enterprises often provide customers with products as part of their services. Such products may comprise physical products, intangible services, or a combination thereof. For example, a bank may provide a customer with a physical products such as a debit card, credit card, ATM card, or check book for access to funds in the customer's account, a cashier's check for access to funds guaranteed by the bank, or cash as part of a withdrawal. Intangible services, for example, could be provided by a bank, including financial advising, service by a mortgage officer, or opening a savings account. Further examples include a bank providing services comprising a combination of physical products and intangible services, for example, activation of a bank card, access to a safe deposit box, or a wire transfer of funds. However, challenges exist in communicating access to enterprise products.
  • For example, a customer may desire a product from a bank and visit a branch location, kiosk, bank café, or other physical facility associated with the bank. However, not all enterprise facilities may offer all enterprise products. For example, a bank branch may include a vault and be able to provide products such as cashier's checks, but a bank café may not. Customers may not understand the differences between different types of enterprise facilities. As a result, they may go to a facility that does not provide the product they desire. For example, a bank customer desiring a cashier's check may visit a bank café only to learn that the bank café is unable to provide the product. Customers may waste time and still have to visit another facility in order to access their desired product.
  • In some cases, enterprise locations may offer products temporally, for example, at certain times, when certain conditions are met, or when certain resources are available. For example, a bank may be able to provide a customer with a loan greater than a certain sum of money only when a bank manager is present to approve the loan, but the bank manager may work at different bank facilities at different times of the day, or the bank manager may have gotten sick and left work early for the day. In this example, a customer may arrive at a facility normally able to provide the desired service only to find that an exception is preventing the facility from providing the desired product. In such cases, customers may have to wait at a facility, return at another time, or go to another facility in order to have access to their desired product. Again, as with the examples listed above and others, such instances may result in wasted time. Furthermore, these experiences may frustrate customers and negatively affect their relationship with an enterprise.
  • In some cases, products may be available at an enterprise which are not expected by customers. For example, a customer may wish to deposit a check at a bank branch in the evening, but listed hours for the facility indicate that the branch has already closed for the day. However, in this example, a bank employee may be working extended hours for the day and be available to help the customer. In this example, among others, a customer may miss out on services being currently offered by a facility due to a lack of proper information concerning current product availability. Additionally, an enterprise may miss out on business from a customer.
  • Availability of an enterprise to provide a product may then change from facility to facility, and availability within a single facility may change even within the same day. Attempts to manually communicate such changes to customers, for example, through editing information displayed on a website, may be time consuming and taxing for enterprise employees. In some cases, it may be difficult for an employee at a busy enterprise to manage customer requests for products and simultaneously communicate his or her availability to work on further requests in view of changing availabilities of other resources at the facility.
  • Challenges such as those listed above, among others, may result in missed opportunities, wasted time, and/or frustration on the parts of customers and/or enterprise employees. Miscommunications about product availability at a facility may result in unacceptable delays in providing a customer with a product. Inefficiencies in attempting to communicate availability to customers may cost enterprises time and ability to provide attentive customer service.
  • Various embodiments described herein can remedy one or more of these challenges and weaknesses. Particularly, embodiments described herein include components that can improve management and communication of information pertaining to enterprise product availability. In embodiments, an availability record for at least one facility may be updated according to recognized activity and resource levels at the at least one facility. In various embodiments, data such as registered user logins, associated user and/or facility statuses, facility resource use, and/or product requirements may be monitored to determine enterprise product availability. In some embodiments, historical data may be analyzed to estimate product availability. In various embodiments, lead times may be estimated for available enterprise products, and in various embodiments, estimation of availability and/or lead time may be informed by a machine learning model. In embodiments, product availability information may be communicated to customers. Components described herein will therefore provide automated, informed determination of enterprise product availability for at least employees and customers of enterprises, thereby improving accuracy, efficiency, and transparency in communicating product availability with respect to enterprise facilities. Accordingly, in various embodiments described herein, management and use of availability information may be implemented in a practical application to increase capabilities of enterprise systems as a whole.
  • In various embodiments, one or more of the components, techniques, or aspects described herein may be implemented via one or more computing devices, resulting in increased capability and improved functioning of the computer devices. Specific and particular manners of automatically monitoring facility resource availability, analyzing trends in resource availability, and/or dynamically determining availability statuses may be provided by the components described in various embodiments herein. In several embodiments, expected behaviors and behaviors involving the update and management of enterprise facility resources may be performed independently of software utilizing the availability management via familiar, user-friendly interface objects.
  • In various embodiments, components, techniques, or aspects described herein may be implemented as a set of rules that improve computer-related technology by allowing a function not previously performable by a computer that enables an improved technological result to be achieved. For example, managing an availability record based on user, resource, facility, and facility sensor statuses may be an improved technological result.
  • With general reference to notations and nomenclature used herein, one or more portions of the detailed description which follows may be presented in terms of program procedures executed on a computer or network of computers. These procedural descriptions and representations are used by those skilled in the art to most effectively convey the substances of their work to others skilled in the art. A procedure is here, and generally, conceived to be a self-consistent sequence of operations leading to a desired result. These operations are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical, magnetic, or optical signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It proves convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. It should be noted, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to those quantities.
  • Further, these manipulations are often referred to in terms, such as adding or comparing, which are commonly associated with mental operations performed by a human operator. However, no such capability of a human operator is necessary, or desirable in most cases, in any of the operations described herein that form part of one or more embodiments. Rather, these operations are machine operations. Useful machines for performing operations of various embodiments include general purpose digital computers as selectively activated or configured by a computer program stored within that is written in accordance with the teachings herein, and/or include apparatus specially constructed for the required purpose. Various embodiments also relate to apparatus or systems for performing these operations. These apparatuses may be specially constructed for the required purpose or may include a general-purpose computer. The required structure for a variety of these machines will be apparent from the description given.
  • Reference is now made to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purpose of explanation, numerous specific details are set forth in order to provide a thorough understanding thereof. It may be evident, however, that the novel embodiments can be practiced without these specific details. In other instances, well known structures and devices are shown in block diagram form to facilitate a description thereof. The intention is to cover all modification, equivalents, and alternatives within the scope of the claims.
  • FIG. 1 illustrates exemplary aspects of a system flow 100 according to one or more embodiments described herein. The system flow may include a user login 102, an availability manager 104, and an availability record 106. Embodiments are not limited in this context.
  • The user login 102 may be based on input received via a user interface, such as a graphical user interface (GUI) displayed on a desktop computer. In some embodiments, the user login may be based on input receive via other sensors, for example, biometric data collected from the user.
  • In some embodiments, a user may be an employee of an enterprise, such as a bank. For example, the employee may be a user of a network-connected time recording platform allowing them to clock in and out of work from their computer. In another example, an employee may log into a network-enabled workstation. In some embodiments, the user may log into a system managed directly by the enterprise. In other embodiments, the user may log into a system managed by a third party. In such embodiments, the enterprise may have access to information collected by the third party, for example, via an API. An API may operate via a network-based system, a local operating system, a database system, computer hardware, a software library, or any combination thereof. In some embodiments, an API may operate as a remote API. Embodiments are not limited in this context.
  • In some embodiments, the user login 102 may involve uniquely identifying information for a user. For example, the user login may comprise a user's company-issued or custom username and password. In other embodiments, the user login 102 may comprise non-identifying credentials. For example, a user login for a general enterprise account could be used to log in to a workstation or an administrative account could be used to log in to specific machines.
  • In various embodiments, the user login 102 may include information pertaining to the system logged into. For example, such information could include the program logged into or a network address of the system logged into.
  • The user login 102 may be identified by an availability manager 104. The availability manager 104 may receive the user login 102 in a secure manner, for example, encrypted, secure tunnel, and so forth. In various embodiments, the availability manager 104 may retrieve and/or process information from the user login. For example, the availability manager 104 may identify a specific user associated with the login or the platform or device which was logged into. Further examples include an internet protocol (IP) address from which the user login 102 was initiated and a time stamp for the user login 102.
  • In various embodiments, the availability manager 104 may have access to information beyond that included in the user login. For example, the availability manager 104 may have access to a memory, database, or other storage for information. Information identifiable by the user login 102 information may be stored, for example, in a database in association with other detailed information. For example, a user login 102 may be used by the availability manager 104 to identify a unique user who is logging in. In this example, the availability manager may be able to search a database for the unique user and identify a specific enterprise facility associated with the user, such as the facility at which the user works.
  • Information available to an availability manager 104 may include data pertaining to enterprise facilities and/or facility employees. For instance, such data may include services provided at a facility, the presence of equipment and supply quantities needed to provide products, employees present at the facility, employees logged into a system at a facility, such as an electronic time card system, employees currently not engaged in or soon to be engaged in another task, and skills in which present employees have been trained. Such skills may include technical skills, such as using a card printer, or soft skills, such as customer service. In some embodiments, skills may be specific to an enterprise. For example, soft skills for a user associated with a bank may include skills such as permission level, mortgage sales, small business banking, teller, public notary, and training certification.
  • Further examples of data available to an availability manager 104 include the number of customers at a facility in a waiting queue, regular traffic patterns, and scheduling data such as prescheduled appointments, events scheduled at the facility, including events scheduled for customers and for employees, and appointments requested by walk-in customers. Further examples include utility data relating the facility, such as operating electricity, internet, and water capabilities and rates, and the number of vehicles parked in a parking lot for the facility, as detected by a parking meter, a security camera or sensor, or satellite feed. In some embodiments, such data may be available to the availability manager 104 via at least one transducer associated with the enterprise and/or with a third party. In some embodiments, such data may be available to the availability manager 104 through a third-party system, for example, via an API accessed through a developer exchange program.
  • One of ordinary skill in the art will recognize that further data useful for assessing the availability of an enterprise facility to provide products at a particular time may be included. Information available to an availability manager 104 may be updated in real or near-real time to maintain accuracy of records. In addition, or alternatively, information available to an availability manager 104 may be pre-stored.
  • In some embodiments, the availability manager 104 may access detailed information based upon layered logic and/or searches. For example, the availability manager 104 may identify a skill set associated with a user identified with a user login 102, and the availability manager 104 may identify a facility associated with the identified user. In this example, a set of resources may be identified as being associated with the facility, and the availability manager 104 may identify overlap between the user's skill set and facility resources.
  • The availability manager 104 may, in many embodiments, generate, update, and/or provide an availability record 106 based on the user login 102. In some embodiments, the availability manager 104 may generate, update, and/or provide an availability record 106 based upon the user login 102 and other information available to the availability manager 104. For example, an availability manager 104 may use overlap between a logged-in user's skill set and resources available at a facility associated with the user to identify products as being available at the facility. Such products may be marked in an availability record 106 as being available at the facility.
  • The availability record may comprise a database, table, or other medium storing data relating to enterprise availability. In some embodiments, an availability record 106 may be associated with a specific enterprise facility. For example, the availability record 106 may comprise a table containing availability information for a facility associated with a user identified by the availability manager 104 from the user login 102. In some embodiments, an availability record 106 may be associated with a plurality of enterprise facilities. For example, a single indexable record could be used to store availability information for all facilities.
  • An availability manager 104 may generate, update, and/or provide an availability record 106 with availability data for a single facility or for a plurality of facilities based upon the user login 102. For example, a user log-in by a particular user may be used to update in the availability record 106 availability at the facility in which he or she logged in. However, if he or she was previously logged in to another facility, the present log in may be used to indicate in the availability record 106 availability at the present facility and unavailability at the previous facility. Embodiments are not limited in this context.
  • In some embodiments, the availability manager 104 may not generate, update, and/or provide an availability record 106 based on the user login 102. In such instances, an indicator associated with the user login 102 may be recognized by the availability manager 104 indicating partial or lack of action in provision of an availability record 106. For example, an enterprise employee with a high level of skill, security clearance, or authority may visit a facility to provide a training session to employees of the facility. During this time, he or she may log into an enterprise system. The availability manager 104 may use information available to it, such as a schedule, to recognize the event. In response, the availability manager 104 may not update an availability record 106 to show availability of the enterprise employee's skills for the use of enterprise customers.
  • In some embodiments, a user logout may be recognized by an availability manager 104. A user logout may be recognized by unavailability of recognition of a user login 102 and/or recognition of a signal indicating logout. A user logout may be used by the availability manager 104 to update an availability manager 104.
  • Aspects of an availability record 106 may be maintained in real or near-real time. Additionally, or alternatively, aspects of an availability record 106 may be updated periodically. For example, an availability record 106 may be updated in response to a trigger such as a new user login 102, an update of information available to an availability manager 104, in response to an elapsed period of time, or in another request, as described in greater detail herein.
  • FIG. 2 illustrates exemplary aspects of processing a user login according to one or more embodiments described herein. In architecture 200, a user login 102 may be received by an availability manager 104. The availability manager may comprise a processing system that includes one or more computing devices that are interconnected via one or more network links, e.g., wired, wireless, fiber, etc. In some embodiments, the availability manager may be a distributed computing system with each server comprising one or more cores to process information and data. Embodiments are not limited in this context.
  • The availability manager 104 may include a component correlator 210 which may process the user login 102. The component correlator 210 may identify from the user login 102 information specific to the user login. For example, the component correlator 210 may identify information identifying a user, information identifying a device or platform being logged into, a location or facility associated with the user login, or any combination of data included in the user login 102.
  • In various embodiments, the component correlator 210 may identify components associated with information identified in the user login 102. For example, a component may include a facility associated with a user identified by the component correlator 210 from the user login 102. Further examples of components identified by the component correlator 210 may include devices and resources present and/or available for use at a facility, sensors and/or transducers associated with a facility, and skills identified as being possessed by the logged in user. Further exemplary components are described below.
  • The component correlator 210 may identify components correlated with information identified by a user login 102 via access to at least one memory article, table, datastore, or other suitable type of memory unit. Such memory may be local to the component correlator 210, available via a network connection, available via a wired connection, available via another known method, or any combination thereof. In some embodiments, data associated with various components may be available to a component correlator via a plurality of memories. Data may be collected from memories associated with or managed by the enterprise, in some embodiments. In some embodiments, data may be collected from third-party resources. For example, data may be collected by the component correlator 210 via APIs coordinating with other parties, such as via a developer exchange program. Embodiments are not limited in this context.
  • In some embodiments, the component correlator 210 may identify components correlated with at least a user identified by and/or from the user login 102. For example, a user's availability may be identified. Additionally, further information may be identified in association with the user data. For example, a schedule associated for a user of the user login 102 may be identified. It will be understood that further data useful for ascertaining the availability of a user may be included. In embodiments, a user status updater 212 may be used to update information in a component status datastore 222, for example, in view of information pertaining to user availability as identified by the component correlator 210.
  • In some embodiments, the component correlator 210 may identify components correlated with the user login 102 that pertain to at least one facility's availability. For example, the facility may be identified from which a user login 102 originated, or a facility may be identified as being associated with a user identified from the user login 102. Information relating to the facility may be further identified. For example, such information may include a regular schedule of the facility, the number of customers at a facility in a waiting queue, regular traffic patterns, prescheduled appointments, events scheduled at the facility, including events scheduled for customers and for employees, and appointments requested by walk-in customers. It will be understood that further data useful for ascertaining the availability of a facility is not outside the scope of the present disclosure and may be included. Information identified by a component correlator 210 relating to a facility may be used by a facility status updater 214 to update information in a component status datastore 222.
  • In some embodiments, the component correlator 210 may identify components correlated with the user login 102 that pertain to resource availability. Resources may, in various embodiments, be identified as being associated with a user and/or facility identified by the component correlator 210. User-related resources may comprise examples such as at least one skill identified as being associated with a user, a level of security clearance of a user, or an authority level of a user. A resource skill associated with a user may comprise a technical skill, such as using a card printer, or a soft skill, such as customer service. Facility-related resources may comprise examples such as devices present and/or available for use at a facility or supplies present at a facility. For example, devices available at a bank may include an automated teller machine, a money counter, a vault, safety deposit boxes, coffee machine, a certified check printer, a bank card encoder, and a bank card blank. It will be understood that further data useful for ascertaining the availability of at least one enterprise resource may be included. In embodiments, resources identified by a component correlator 210 may be useful for providing a product to a user. Information identified by a component correlator 210 relating to at least one resource may be used by a resource status updater 216 to update information in a component status datastore 222.
  • In some embodiments, the component correlator 210 may identify components correlated with the user login 102 that pertain to at least one sensor. A sensor may be a transducer associated with the enterprise, the facility, and/or a third party. Sensors may be, in some embodiments, identified as correlating with a facility or resources identified by the component correlator 210. As with previous information described as being available to the component correlator 210, information pertaining to sensors may be available to the component correlator 210 via access to a memory associated with the enterprise, enterprise facility, and/or third party, such as via an API. Information pertaining to sensors may include data recorded by the sensor pertaining to a facility, devices at the facility, or other resources.
  • Facility-related sensor data may include data such as sensors and/or data collected by sensors pertaining to facility operations and/or traffic. Further examples of data collected and/or available to sensors include utility statuses of the facility, such as operating electricity, internet, and water capabilities and rates, and the number of vehicles parked in a parking lot for the facility, as detected by a parking meter, a security camera or sensor, or satellite feed. One of ordinary skill in the art will recognize that further data collected by sensors and/or useful for assessing the capability of an enterprise facility to handle requests at a particular time may be included. Information identified by a component correlator 210 relating to at least one sensor may be used by a facility sensor status updater 220 to update information in a component status datastore 222.
  • In some embodiments, sensor-related data identified by the component correlator 210 may be used to identify sensors from which further data is desired. In embodiments such as these, a sensor data collector 218 may be used to retrieve further data from sensors. In some embodiments, a sensor data collector 218 may comprise a database or other memory system of information collected by sensors. In some embodiments, a sensor data collector 218 may comprise a processor and/or set of instructions to gather data from sensors. Data from sensors may be available to the sensor data collector 218 locally and/or via wired, network, or other connection. Data accessible via the sensor data collector 218 may have been previously collected by sensors and/or sensors may be triggered to presently collect data to be available to the availability manager 104 via the sensor data collector 218. In embodiments, data accessible to the availability manager 104 via the sensor data collector 218 may be used by a facility sensor status updater 220 to update and/or enter information into a component status datastore 222.
  • It will be recognized by one skilled in the art that various examples of information identified by a component correlator 210 as listed above, among others, may pertain to more than one of users, facilities, resources, and sensors. For example, a supply of a resource, such as card blanks for a bank, may be identified as relating to a resource, as listed above, or identified by a sensor, for example, a camera or scanner. Similarly, historic traffic for a facility may be identified as having been identified by a particular sensor, such as a camera or parking meter. Various embodiments may associate data identified by the component correlator 210 with one or more of the categories listed above, and one or more of the status updaters 212, 214, 216, and 220 as described above may be used to update a component status datastore 222 accordingly. In various embodiments, one or more of status updaters 212, 214, 216, and 220 may inform one or more of the other status updaters 212, 214, 216, and 220. For example, a user status being updated to show availability may inform a status update of availability for a facility associated with that user. Any combination and/or ordering of the status updaters 212, 214, 216, and 220 to inform each other in this manner is within the scope of the current discussion.
  • The status updaters 212, 214, 216, and 220 may, in some embodiments, exist as unique and separate components. In other embodiments, any combination of the status updaters 212, 214, 216, and 220 may exist as a single component. A component may exist in a single location as part of the availability manager 104 or be distributed, for example, across one or more servers. Embodiments are not limited in this context.
  • In some embodiments, the status updaters 212, 214, 216, and 220 may process the data collected by the component correlator 210 to identify the availability of at least one user, facility, resource, and/or facility sensor as a status. In some embodiments, this status may represent a binary availability level, for example, available or unavailable. In other embodiments, status may include greater detail. For example, levels of operating electricity may be indicated.
  • The status updaters 212, 214, 216, and 220 may be used to update the component status datastore 222 with at least one status. For example, a user status updater 212 may be used to update a user status 228 in the component status datastore 222, a facility status updater 214 may be used to update a facility status 230 in the component status datastore 222, a resource status updater 216 may be used to update a resource status 224 in the component status datastore 222, and a facility sensor status updater 220 may be used to update a facility sensor status 226 in the component status datastore 222. The status information of the component status datastore 222 as updated by the status updaters 212, 214, 216, and 220 may be useful for determining availability of at least one facility to provide at least one enterprise service.
  • The component status datastore 222 may, in some embodiments, exist as a table, database, or other memory system accessible to the availability manager 104. In some embodiments, the component status datastore 222 may be local to the availability manager 104. In other embodiments, the component status datastore 22 may be available to the availability manager 104 at least in part via wired, network, or other connection.
  • In various embodiments, the component status datastore 222 may be used to probabilistically determine an enterprise's ability to provide a service or product. This determination may be made, in some embodiments, with the use of at least one machine learning model 232. In some embodiments, a machine learning model 232 may be informed by the component status datastore 222. A machine learning model 232 may, in various embodiments, be based on historic availability data and/or historic component status data from the component status datastore 222. Historic availability data and historic component status data may be used by the machine learning model 232 to estimate availability of a facility based on component status data.
  • In some embodiments, a machine learning model may be informed by product requirements 233. In embodiments, product requirements 233 may exist in a storage system coupled to the availability manager 104. The storage system may contain data structures, such as one or more databases, to store information. The availability manager 104 may be coupled to the storage system via one or more wired and/or wireless networking links, and the storage system may be local to the availability manager 104 or in a different location.
  • Product requirements 233 may comprise associated resources, skills, facility functionalities, and other components necessary for an enterprise to provide a product. A machine learning model 232 informed by product requirements 233 may be better suited to assess not only availability of an enterprise to provide service, but more specific and/or accurate availability of an enterprise to provide specific products to customers. An available product set 236 based on use of at least one machine learning model 232 may be provided to an availability updater 234.
  • A machine learning model 232 may be used not only to assess current availability of an enterprise, but estimated availability and/or an enterprise's estimated ability to provide a product or service based on that availability. In embodiments, a machine learning model may be used to estimate lead times necessary to provide products or services. Estimated lead times 238 may be provided to an availability updater 234, in various embodiments.
  • An availability updater 234 may receive availability information understood by components of the availability manager 104, such as by use of a machine learning model 232. The availability updater 234 may, in various embodiments, be able to estimate or have access to an estimated available product set 236 and/or estimated lead times 238 for provision of products. Information may be specific to at least one enterprise facility as specified by the component correlator 210. The availability updater 234 may be used to update an availability record 106. In embodiments, an availability updater 234 may be used to update an availability record 106 in view of an available product set 236 and/or estimated lead times 238.
  • FIG. 3A illustrates exemplary aspects of utilizing a component correlator to inform resource status updater components according to one or more embodiments described herein. In architecture 300A, a user login 102 is processed by a component correlator 210. The component correlator 210 may inform at least one status updater based on the user login 102. Embodiments are not limited in this context.
  • Specifically, a component correlator 210 may identify a registered user 340 from the user login 102. The registered user 340 may be a recognized and/or authorized user of a platform, such as a software and/or device.
  • In various embodiments, the recognition of a registered user 340 from a user login 102 may inform a user status updater 212. For example, a user status updater may update the status of a registered user to be listed as available in response to that user being recognized as having logged in.
  • In various embodiments, the component correlator 210 may access and/or refer to a user profile 342 associated with a recognized registered user 340. User profile 342 information may exist in a memory system coupled to the component correlator via a wired or wireless network, and the memory system may be local to the component correlator or exist in a separate location.
  • A user profile 342 may contain detailed information concerning a registered user 340. In various embodiments, a user profile 342 may include skills 344 or a schedule 346 associated with the registered user 340.
  • Skills 344 may comprise technical or soft skills in which the registered user is trained in or otherwise qualified to provide. For example, if the registered user is a bank employee, technical skills may include examples such as being able to operate a card printer or operate a coffee machine. Further examples include mortgage sales, small business banking, teller, public notary, training certification, financial advising and customer service. In various embodiments, skills 344 may include security, permission, and/or authorization levels. In some embodiments, soft or technical skills included in skills 344 may be associated with specific security and/or authorization levels.
  • A schedule 346 may comprise data indicating a registered user's 340 estimated presence at a facility or multiple facilities. In some embodiments, a schedule 346 may include scheduled appointments and/or estimated periods of unavailability. In embodiments, a schedule 346 may be associated in the user profile 342 with a specific enterprise facility or multiple facilities, such as facility 348-1. In some embodiments, a plurality of facilities 1 through n may be identified as being associated with a registered user 340 or schedule 346.
  • In various embodiments, a schedule 346 may be used to identify a particular facility at which an employee is estimated to be present. In architecture 300A, a facility 348-1 is illustrated for the sake of simplicity. However, it will be understood that if 1 through n facilities are associated with a registered user 340, facility 348-1 . . . n may be identified just as readily as being that at which the registered user 340 is present in accordance with a schedule 346.
  • In some embodiments, a facility 348-1 may not be associated with a schedule 346, but the facility 348-1 may be identified from the user login 102 nonetheless. For example, the user login 102 may be associated with a device known to exist at a particular facility 348-1. Embodiments are not limited in this context.
  • In numerous embodiments, a component correlator's 210 identification of a facility 348-1 associated with a user login 102 may inform a facility status updater 214. This may include association via identification with a schedule 346, etc., as described above. For example, a facility 348-1 status may be updated to show availability by a facility status updater 214 in response to identification to a registered user's 340 user login 102 at the facility 348-1. In some embodiments, a facility status updater 214 may update availability statuses for multiple facilities based upon a component correlator 210's identification of a facility 328-1 in association with a user login 102. For example, if a registered user 340 has been recognized as being the only user logged in for a facility 348-n, a user login 102 for the registered user 340 subsequently associated with a facility 348-1 may be used to update the status of facility 348-1 to show availability and to update the status of a facility 348-n to show unavailability.
  • In various embodiments, a component correlator 210 may have access to and/or keep track of facility resources 350. Facility resources 350 may exist in a memory system coupled to the component correlator via a wired or wireless network, and the memory system may be local to the component correlator or exist in a separate location. Facility resources 350 may indicate resources available for at least one enterprise facility.
  • Skills 344 identified in association with a particular user profile 342 may be used to inform facility resources 350. For example, skills 344 associated with the user profile 342 of a registered user 340 recognized to be present at a particular facility 348-1 may be available at that facility 348-1 and therefore used to inform a total set of skills 352 available as part of facility resources 350.
  • Similarly, a facility 348-1 recognized by the component correlator 210 may be used to inform facility resources 350. In some embodiments, a facility 348-1 may be associated with a set of devices, supplies, or other tangible resources which may then be recognized as being available as part of facility resources 350. A set of such resources may be maintained as devices 354 recognized to be available as part of facility resources 350.
  • In some embodiments, facility resources 350 may be determined to be available based upon a plurality of recognized skills 352 and/or devices 354. For example, a bank card printer may be determined to be an available resource at a facility if and only if a card printer and a user with the technical skill to use it are both present at a facility.
  • In the same way that facility resources 350 may pertain to one or a plurality of enterprise facilities, skills 352 and/or devices 354 may pertain to one or a plurality of users and/or facilities. In other words, skills 344 may include skills recognized as being available as relating to a single registered user 340 or to a collection of users. Skills 352 and/or devices 354 may pertain to a single facility 348-1 or to a plurality of facilities 348-1 . . . n. Aspects of facility resources 350, including skills 352 and devices 354, may exist in a single memory system or a plurality of memory systems and may be either local to a single location or distributed. Embodiments are not limited in this context.
  • Facility resources 350 identified by the component correlator 210 may inform a resource status updater 216. A resource status updater 216 may update and/or provide availability information for resources relating to skills 352, devices 354, and/or any combination thereof as related to a registered user 340 and/or facility 348-1 as described above.
  • In various embodiments, a component correlator 210 may identify a transducer set 356 as being associated with a facility 348-1. Transducers may be enabled to gather data pertaining to an enterprise and/or facility. For example, a transducer may be a camera, satellite, global positioning system, parking meter, water meter, electricity meter, thermostat, scanning system, or other known device which may be used for monitoring use of an enterprise and/or facility. Aspects of transducers may be local and/or remote to an enterprise facility 348-1. Transducers may be managed and/or operated by an enterprise, a facility, by a third-party, or by any partnership therebetween. In some embodiments, at least one transducer of a transducer set may be accessed by the component correlator via an API.
  • A sensor data collector 218, in some embodiments, may be used according to an identified transducer set 356. A sensor data collector 218 may be used to retrieve further data from transducers. In some embodiments, a sensor data collector 218 may comprise a database or other memory system of information collected by transducers. In some embodiments, a sensor data collector 218 may comprise a processor and/or set of instructions to gather data from transducers. Data from transducers may be available to the sensor data collector 218 locally and/or via wired, network, or other connection. Data accessible via the sensor data collector 218 may have been previously collected by transducers and/or transducers may be triggered to presently collect data via the sensor data collector 218.
  • FIG. 3B illustrates exemplary aspects of providing information pertaining to enterprise availability according to one or more aspects described herein. Embodiments are not limited in this context. In architecture 300B, an availability updater 234 informs a back-end application programming interface (API) 358 to update an availability record 106. Availability information is provided from the availability record 106 to a consumer device 362 via a front-end API 360. Embodiments are not limited in this context.
  • An availability updater 234 may, in embodiments, be informed by known and/or estimated availability information relating to at least one enterprise, enterprise facility, and/or enterprise product. For example, an availability updater 234 may include aspects of an availability manager 104 as described in association with FIG. 2.
  • In various embodiments, an availability updater 234 may update an availability record 106 via at least one back-end API 358. A back-end API 358 may operate via a network-based system, a local operating system, a database system, computer hardware, a software library, or any combination thereof. In some embodiments, a back-end API 358 may operate as a remote API.
  • An availability record 106, may comprise information concerning an enterprise's availability to provide at least one product and/or service. For the discussion herein, a service may be regarded as an enterprise product. Product availability may, in various embodiments, be related to specific enterprise facilities. For each facility, there may be information relating to the availability of various enterprise products. In various embodiments, available products may be associated with lead times estimated for a facility to be able to provide that product. In some embodiments, lead times may be estimated by use of a machine learning model 232. For example, a facility 348-1 may be available to provide an available product 364-1 with an estimated lead time 366-1, an available product 364-2 with an estimated lead time 366-2, an available product 364-n with an estimated lead time 366-n.
  • In various embodiments, an availability record 106 may comprise records for a single facility 348-1, as exemplarily described in association with FIG. 2. In other embodiments, such as that illustrated in FIG. 3B, an availability record 106 may comprise availability information for a plurality of facilities 348-1, 348-2, . . . and 348-n, where n. Each facility may, in embodiments, have a different set of products associated with it in the availability record 106 such that are available at that facility. For example, facility 348-2 may be available to provide an available product 368-1 with lead time 370-1, an available product 368-2 with lead time 370-2, and available product 368-n with lead time 370-n, while facility 348-n may be available to provide an available product 372-1 with lead time 374-1, an available product 372-2 with lead time 3742-2, and an available product 372-n with lead time 374-n.
  • In some embodiments, an availability record 106 may be used to communicate information concerning enterprise availability to an enterprise and/or enterprise customers. In some embodiments, a front-end API 360 may be used to provide an availability record and/or information therein to be displayed on a consumer device 362. A front-end API 360 may operate via a network-based system, a local operating system, a database system, computer hardware, a software library, or any combination thereof. In some embodiments, a front-end API 360 may operate as a remote API. Embodiments are not limited in this context.
  • A consumer device 362 may comprise a device owned and/or managed by an enterprise or an enterprise customer. For example, a consumer device 362 may be a smart phone, laptop, desktop, tablet computer, or server. In some embodiments, a copy of information related to enterprise availability may be sent to the consumer device 362. In other embodiments, information may be relayed for display on the consumer device 362, such as via a website. In various embodiments, availability information may be communicated via a GUI on the consumer device 362. Availability information may be communicated to the user so as to display facilities in association with available products and estimated lead times.
  • In some embodiments, availability information communicated to the consumer device 362 may be processed and/or filtered based upon facility details. For example, facilities may or may not be communicated and/or displayed on the consumer device 362 according to facility location and/or distance from a consumer device 362, the availability of at least one product, or lead times for product availability.
  • In various embodiments, a consumer device 362 may receive input from a user, for example, via a GUI. In some embodiments, display of availability information via the consumer device may be adjusted according to the user input. For example, facilities may be displayed in order of estimated lead times for a specific product according to a received filter request from a user. In some embodiments, availability information may be refreshed and/or updated on a consumer device 362 in response to received user input. In various embodiments, an availability record 106 may be updated in response to user input received by a consumer device 362.
  • FIG. 4 illustrates exemplary aspects of the use of a machine learning model to update an availability record 106 according to one or more embodiments described herein. For example, a machine learning model may comprise a machine learning model 232 as described with regards to FIG. 2. In architecture 400, a model trainer 480 may be informed by historical data such as historical status data 476 and historical performance data 478. The model trainer 480 may be used to produce a machine learning model 232, and an availability updater 234 may use the machine learning model 232 to update an availability record 106. Embodiments are not limited in this context.
  • A model trainer 480 may be used to generate a machine learning model 232. In various embodiments, the model trainer 480 may be informed by historical status data 476 and/or historical performance data 478. Either or both of historical status data 476 and historical performance data 478 may be stored in at least one database, table, or other memory system coupled to the model trainer 480. Coupling may be via a wired and/or wireless network, and aspects of the memory system may be local to the system, remote, consolidated, and/or distributed.
  • Historical status data 476 may comprise a record of historical records of statuses. For example, status data may comprise resource statuses 224, facility sensor statuses 226, user status 228, and facility status 230 data. Historical status data 476 may be specific to a single enterprise facility or comprise data relating to multiple enterprise facilities. In embodiments, historical status data 476 may include historical status updates in association with timestamps of the updates.
  • Historical performance data 478 may comprise a record of historical records of enterprise performance relating to providing products and/or services. For example, historical performance data may comprise historical data relating the time it took for an enterprise to provide a particular product and/or service. In some embodiments, historical performance data 478 may be related to a particular facility and/or user. In some embodiments, historical performance data 478 may be related to multiple facilities and/or users. Historical performance data 478 may, in embodiments, comprise timestamp data in association with performance data. For example, historical performance data 478 may include data describing how long it took for a particular user at an enterprise facility to provide a particular product, or how long it took for a particular enterprise facility to provide a particular set of products on a particular day.
  • In some embodiments, historical performance data 478 may include a measure of the quality of the product and/or service provided by an enterprise. For example, a product of a bank card misprinted by a bank such that a customer requested a reprint may be associated with a low measure of product quality. In an alternative example, a product provided without flaw by a facility may be associated with a high measure of product quality. In some embodiments, historical performance data 478 may include feedback from enterprise customers concerning enterprise performance regarding the provision of at least one product and/or service. Historical performance data 478 may be specific to a single enterprise facility or comprise data relating to multiple enterprise facilities. It will be understood that further data useful for the tracking of enterprise performance may be included in historical performance data 478.
  • The model trainer 480 may receive historical status data 476 and/or historical performance data 478 relating to at least one enterprise facility. In embodiments, the model trainer 480 may make use of the data available to it via use of a machine learning algorithm 482. A machine learning algorithm 482 may employ supervised learning, unsupervised learning, reinforcement learning, or any other method commonly known in the art. Aspects of the model trainer 480 may, in embodiments, use historical status data 476 and/or historical performance data 478 to estimate product availability in association with status data.
  • The model trainer 480 may generate a machine learning model 232. For example, the machine learning model 232 may be a model such as described with respect to FIG. 2. In various embodiments, a machine learning model 232 may comprise estimated enterprise product availability. Aspects of the machine learning model 232 may be based upon current and/or recent status data. In some embodiments, a machine learning model 232 may comprise estimated lead times for products estimated to be available.
  • An availability updater 234 may use a machine learning model 232 to update an availability record 106. By using a machine learning model 232, the availability updater 234 may be able to update the availability record 106 according to not only instantaneous status data, but according to estimated availability and/or performance for an enterprise to provide at least one product and/or service.
  • FIG. 5A illustrates exemplary aspects of a first logic flow according to one or more embodiments described herein. In logic flow 500A, user login may be used to update an availability record corresponding to a facility. Embodiments are not limited in this context.
  • In block 502, a login of a registered user is identified based on receipt of credentials correlated with the registered user. For example, a user name and password combination may be used to recognize a user.
  • In block 504, a user status linked to the registered user is updated based on identification of the registered user of block 502. For example, a registered user's login may be used to update the registered user's status to show availability.
  • In block 506, a facility is determined to correspond to the login of the registered user. The correspondence may be based on preconfigured information, such as a known place of the user's employment, or the correspondence may be based upon information received in association with the user login, such as a location or IP address.
  • In block 508, a facility status of a facility is updated based on correspondence of the facility to the login of the registered user. For example, the first login of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is open. In another example, the last logout of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is closed.
  • In block 510, two or more resources of a facility may be identified. The two or more resources of the facility may comprise one or more skills associated with the registered user and one or more devices associated with the facility. In embodiments, at least one skill associated with the registered user may be related to the use of the one or more devices associated with the facility.
  • In block 512, two or more resource statuses may be updated based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user. In some embodiments, two or more resource statuses may be updated in conjunction with each other. In some embodiments, two or more resource statuses may be updated independently.
  • In block 514, sensor data is collected from one or more transducers located at the facility. In some embodiments, sensor data may be pre-recorded. In some embodiments, sensor data may be actively recorded by the transducers.
  • In block 516, one or more facility sensor statuses may be updated based on the sensor data collected from the one or more transducers located at the facility. For example, availability of devices and/or resources at a facility may be updated according to collected sensor data. Similarly, up-to-date employee busyness and/or traffic levels at an enterprise may be updated according to collected sensor data. Sensor data may, in some embodiments, be collected via the use of at least one API.
  • In block 518, user status, facility status, the two or more resource statuses, and the one or more facility sensor statuses may be evaluated with a machine learning model to determine a set of available products associated with the facility. In some embodiments, the machine learning model may have been trained using historic data relating to statuses and performance measures associated with the facility.
  • In block 520, an availability record may be updated, where the availability record corresponds to the facility based on the set of available products associated with the facility. In some embodiments, an availability record may be further updated with estimated lead times of the available products associated with the facility.
  • FIG. 5B illustrates exemplary aspects of a logic flow according to one or more embodiments described herein. In logic flow 500B, a login of a registered user may be used to generate an availability record, which may be made accessible via an API. Embodiments are not limited in this context.
  • In block 530, a user status linked to a registered user may be updated based on identification of a login of the registered user. In some embodiments, a status may be a binary indicator of availability or unavailability. In some embodiments, greater detail may be provided, for example, by a selection of or an enumerated encoding of status options. For example, different status options may show a user to be absent, present, busy, or available.
  • In block 532, a facility may be determined to correspond to the login of the registered user. Correspondence of a facility with a registered user may be preset, or it may be determined actively according to specific details of the login of the registered user and/or the platform for which the registered user logged in.
  • In block 534, a facility status of the facility may be updated based on correspondence of the facility to the login of the registered user. In some embodiments, a status may be a binary indicator of availability or unavailability. In some embodiments, greater detail may be provided, for example, by a selection of or an enumerated encoding of status options. For example, different status options may show a facility to be open, closed, or having a set of employees available.
  • In block 536, two or more resources of the facility may be identified. The resources of the facility may comprise one or more skills associated with the registered user and one or more devices associated with a facility. In some embodiments, identified resources may comprise resources already having been identified in association with the facility.
  • In block 538, two or more resource statuses may be updated based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user. In some embodiments, a resource status may be updated to show binary availability or unavailability of a resource. In some embodiments, a resource status may be updated to show an updated quantity of a resource. For example, a resource status may be updated from showing availability of a single employee at a bank having training in financial counseling to showing availability of two employees having training in financial counseling.
  • In block 540, sensor data is collected from one or more transducers located at the facility. In some embodiments, transducers may be used to determine availability of human resources and/or at the facility. In some embodiments, transducers may be used to determine availability of supplies, use of utilities, power to enterprise devices, or use of other technical resource.
  • In block 542, one or more facility sensor statuses may be updated based on the sensor data collected from the one or more transducers located at the facility. In some embodiments, a status may be a binary indicator of availability or unavailability. In some embodiments, greater detail may be provided, for example, by a selection of or an enumerated encoding of status options. In some embodiments, status may be determined according to sensor data being above and/or below a certain threshold.
  • In block 544, the user status, the facility status, the two or more resource statuses, and the one or more facility sensor statuses may be evaluated with a machine learning model to determine a set of available products associated with the facility. In various embodiments, the machine learning model may be used to estimate lead times for the facility to provide each product in the set of products.
  • In block 546, an availability record corresponding to the facility is generated. The availability record is generated based on the set of available products associated with the facility. In some embodiments, an availability record may comprise a stored data system or portion thereof.
  • In block 548, access to the availability record corresponding to the facility may be provided via an application program interface. In some embodiments, an application program interface may be associated with a developer exchange program.
  • FIG. 5C illustrates exemplary aspects of a logic flow according to one or more embodiments described herein. In logic flow 500C, a method describes a way to determine availability of enterprise products at a facility. Embodiments are not limited in this context.
  • In block 560, the illustrated method includes identifying a login of a registered user based on receipt of credentials correlated with the registered user. For example, a user name and password combination may be used to recognize a user.
  • In block 562, the illustrated method includes updating a user status linked to the registered user based on identification of the login of the registered user. For example, a registered user's login may be used to update the registered user's status to show availability.
  • In block 564, the illustrated method includes determining a facility corresponding to the login of the registered user. The correspondence may be based on preconfigured information, such as a known place of the user's employment, or the correspondence may be based upon information received in association with the user login, such as a location or IP address.
  • In block 566, the illustrated method includes updating a facility status of the facility based on correspondence of the facility to the login of the registered. For example, the first login of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is open. In another example, the last logout of a day of a registered user associated with a facility may be used to update the facility status to show that the facility is closed.
  • In block 568, the illustrated method includes identifying two or more resources of the facility, the two or more resources of the facility comprising one or more skills associated with the registered user and one or more devices associated with the facility. In embodiments, at least one skill associated with the registered user may be related to the use of the one or more devices associated with the facility.
  • In block 570, the illustrated method includes updating two or more resource statuses based on identification of the two or more resources of the facility corresponding to the user status linked to the registered user. In some embodiments, two or more resource statuses may be updated in conjunction with each other. In some embodiments, two or more resource statuses may be updated independently.
  • In block 572, the illustrated method includes collecting sensor data from one or more transducers located at the facility. In some embodiments, sensor data may be pre-recorded. In some embodiments, sensor data may be actively recorded by the transducers.
  • In block 574, the illustrated method includes updating one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility. For example, availability of devices and/or resources at a facility may be updated according to collected sensor data. Similarly, up-to-date employee busyness and/or traffic levels at an enterprise may be updated according to collected sensor data. Sensor data may, in some embodiments, be collected via the use of at least one API.
  • In block 576, the illustrated method evaluating the user status, the facility status, the two or more resource statuses, and the one or more facility sensor statuses with a machine learning model to determine a set of available products associated with the facility. In some embodiments, the machine learning model may have been trained using historic data relating to statuses and performance measures associated with the facility.
  • In block 578, the illustrated method includes updating an availability record corresponding to the facility based on the set of available products associated with the facility. In some embodiments, an availability record may be further updated with estimated lead times of the available products associated with the facility.
  • FIG. 6 illustrates an embodiment of an exemplary computing architecture 600 that may be suitable for implementing various embodiments as previously described. In various embodiments, the computing architecture 600 may comprise or be implemented as part of an electronic device. In some embodiments, the computing architecture 600 may be representative, for example, of one or more component described herein. In some embodiments, computing architecture 600 may be representative, for example, of a computing device that implements or utilizes one or more of availability manager 104, component correlator 210, status updaters 212, 214, 214, and 220, and/or one or more techniques described herein. Embodiments are not limited in this context.
  • As used in this application, the terms “system” and “component” and “module” are intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution, examples of which are provided by the exemplary computing architecture 600. For example, a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Further, components may be communicatively coupled to each other by various types of communications media to coordinate operations. The coordination may involve the uni-directional or bi-directional exchange of information. For instance, the components may communicate information in the form of signals communicated over the communications media. The information can be implemented as signals allocated to various signal lines. In such allocations, each message is a signal. Further embodiments, however, may alternatively employ data messages. Such data messages may be sent across various connections. Exemplary connections include parallel interfaces, serial interfaces, and bus interfaces.
  • The computing architecture 600 includes various common computing elements, such as one or more processors, multi-core processors, co-processors, memory units, chipsets, controllers, peripherals, interfaces, oscillators, timing devices, video cards, audio cards, multimedia input/output (I/O) components, power supplies, and so forth. The embodiments, however, are not limited to implementation by the computing architecture 600.
  • As shown in FIG. 6, the computing architecture 600 comprises a processing unit 604, a system memory 606 and a system bus 608. The processing unit 604 can be any of various commercially available processors, including without limitation an AMD® Athlon®, Duron® and Opteron® processors; ARM® application, embedded and secure processors; IBM® and Motorola® DragonBall® and PowerPC® processors; IBM and Sony® Cell processors; Intel® Celeron®, Core (2) Duo®, Itanium®, Pentium®, Xeon®, and XScale® processors; and similar processors. Dual microprocessors, multi-core processors, and other multi-processor architectures may also be employed as the processing unit 604.
  • The system bus 608 provides an interface for system components including, but not limited to, the system memory 606 to the processing unit 604. The system bus 608 can be any of several types of bus structure that may further interconnect to a memory bus (with or without a memory controller), a peripheral bus, and a local bus using any of a variety of commercially available bus architectures. Interface adapters may connect to the system bus 608 via a slot architecture. Example slot architectures may include without limitation Accelerated Graphics Port (AGP), Card Bus, (Extended) Industry Standard Architecture ((E)ISA), Micro Channel Architecture (MCA), NuBus, Peripheral Component Interconnect (Extended) (PCI(X)), PCI Express, Personal Computer Memory Card International Association (PCMCIA), and the like.
  • The system memory 606 may include various types of computer-readable storage media in the form of one or more higher speed memory units, such as read-only memory (ROM), random-access memory (RAM), dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), programmable ROM (PROM), erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), flash memory (e.g., one or more flash arrays), polymer memory such as ferroelectric polymer memory, ovonic memory, phase change or ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, magnetic or optical cards, an array of devices such as Redundant Array of Independent Disks (RAID) drives, solid state memory devices (e.g., USB memory, solid state drives (SSD) and any other type of storage media suitable for storing information. In the illustrated embodiment shown in FIG. 6, the system memory 606 can include non-volatile memory 610 and/or volatile memory 612. In some embodiments, system memory 606 may include main memory. A basic input/output system (BIOS) can be stored in the non-volatile memory 610.
  • The computer 602 may include various types of computer-readable storage media in the form of one or more lower speed memory units, including an internal (or external) hard disk drive (HDD) 614, a magnetic floppy disk drive (FDD) 616 to read from or write to a removable magnetic disk 618, and an optical disk drive 620 to read from or write to a removable optical disk 622 (e.g., a CD-ROM or DVD). The HDD 614, FDD 616 and optical disk drive 620 can be connected to the system bus 608 by a HDD interface 624, an FDD interface 626 and an optical drive interface 628, respectively. The HDD interface 624 for external drive implementations can include at least one or both of Universal Serial Bus (USB) and Institute of Electrical and Electronics Engineers (IEEE) 694 interface technologies. In various embodiments, these types of memory may not be included in main memory or system memory.
  • The drives and associated computer-readable media provide volatile and/or nonvolatile storage of data, data structures, computer-executable instructions, and so forth. For example, a number of program modules can be stored in the drives and memory units 610, 612, including an operating system 630, one or more application programs 632, other program modules 634, and program data 636. In one embodiment, the one or more application programs 632, other program modules 634, and program data 636 can include or implement, for example, the various techniques, applications, and/or components described herein.
  • A user can enter commands and information into the computer 602 through one or more wire/wireless input devices, for example, a keyboard 638 and a pointing device, such as a mouse 640. Other input devices may include microphones, infra-red (IR) remote controls, radio-frequency (RF) remote controls, game pads, stylus pens, card readers, dongles, finger print readers, gloves, graphics tablets, joysticks, keyboards, retina readers, touch screens (e.g., capacitive, resistive, etc.), trackballs, trackpads, sensors, styluses, and the like. These and other input devices are often connected to the processing unit 604 through an input device interface 642 that is coupled to the system bus 608, but can be connected by other interfaces such as a parallel port, IEEE 994 serial port, a game port, a USB port, an IR interface, and so forth.
  • A monitor 644 or other type of display device is also connected to the system bus 608 via an interface, such as a video adaptor 646. The monitor 644 may be internal or external to the computer 602. In addition to the monitor 644, a computer typically includes other peripheral output devices, such as speakers, printers, and so forth.
  • The computer 602 may operate in a networked environment using logical connections via wire and/or wireless communications to one or more remote computers, such as a remote computer 648. In various embodiments, one or more interactions described herein migrations may occur via the networked environment. The remote computer 648 can be a workstation, a server computer, a router, a personal computer, portable computer, microprocessor-based entertainment appliance, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 602, although, for purposes of brevity, only a memory/storage device 650 is illustrated. The logical connections depicted include wire/wireless connectivity to a local area network (LAN) 652 and/or larger networks, for example, a wide area network (WAN) 654. Such LAN and WAN networking environments are commonplace in offices and companies, and facilitate enterprise-wide computer networks, such as intranets, all of which may connect to a global communications network, for example, the Internet.
  • When used in a LAN networking environment, the computer 602 is connected to the LAN 652 through a wire and/or wireless communication network interface or adaptor 656. The adaptor 656 can facilitate wire and/or wireless communications to the LAN 652, which may also include a wireless access point disposed thereon for communicating with the wireless functionality of the adaptor 656.
  • When used in a WAN networking environment, the computer 602 can include a modem 658, or is connected to a communications server on the WAN 654, or has other means for establishing communications over the WAN 654, such as by way of the Internet. The modem 658, which can be internal or external and a wire and/or wireless device, connects to the system bus 608 via the input device interface 642. In a networked environment, program modules depicted relative to the computer 602, or portions thereof, can be stored in the remote memory/storage device 650. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers can be used.
  • The computer 602 is operable to communicate with wire and wireless devices or entities using the IEEE 802 family of standards, such as wireless devices operatively disposed in wireless communication (e.g., IEEE 802.16 over-the-air modulation techniques). This includes at least Wi-Fi (or Wireless Fidelity), WiMax, and Bluetooth™ wireless technologies, among others. Thus, the communication can be a predefined structure as with a conventional network or simply an ad hoc communication between at least two devices. Wi-Fi networks use radio technologies called IEEE 802.11x (a, b, g, n, etc.) to provide secure, reliable, fast wireless connectivity. A Wi-Fi network can be used to connect computers to each other, to the Internet, and to wire networks (which use IEEE 802.3-related media and functions).
  • FIG. 7 illustrates a block diagram of an exemplary communications architecture 700 suitable for implementing various embodiments as previously described. The communications architecture 700 includes various common communications elements, such as a transmitter, receiver, transceiver, radio, network interface, baseband processor, antenna, amplifiers, filters, power supplies, and so forth. The embodiments, however, are not limited to implementation by the communications architecture 700.
  • As shown in FIG. 7, the communications architecture 700 comprises includes one or more clients 702 and servers 704. In some embodiments communications architecture may include or implement one or more portions of components, applications, and/or techniques described herein. The clients 702 and the servers 704 are operatively connected to one or more respective client data stores 708 and server data stores 710 that can be employed to store information local to the respective clients 702 and servers 704, such as cookies and/or associated contextual information. In various embodiments, any one of servers 704 may implement one or more of logic flows or operations described herein in conjunction with storage of data received from any one of clients 702 on any of server data stores 710. In one or more embodiments, one or more of client data store(s) 708 or server data store(s) 710 may include memory accessible to one or more portions of components, applications, and/or techniques described herein.
  • The clients 702 and the servers 704 may communicate information between each other using a communication framework 706. The communications framework 706 may implement any well-known communications techniques and protocols. The communications framework 706 may be implemented as a packet-switched network (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), a circuit-switched network (e.g., the public switched telephone network), or a combination of a packet-switched network and a circuit-switched network (with suitable gateways and translators).
  • The communications framework 706 may implement various network interfaces arranged to accept, communicate, and connect to a communications network. A network interface may be regarded as a specialized form of an input output interface. Network interfaces may employ connection protocols including without limitation direct connect, Ethernet (e.g., thick, thin, twisted pair 10/100/1900 Base T, and the like), token ring, wireless network interfaces, cellular network interfaces, IEEE 802.11a-x network interfaces, IEEE 802.16 network interfaces, IEEE 802.20 network interfaces, and the like. Further, multiple network interfaces may be used to engage with various communications network types. For example, multiple network interfaces may be employed to allow for the communication over broadcast, multicast, and unicast networks. Should processing requirements dictate a greater amount speed and capacity, distributed network controller architectures may similarly be employed to pool, load balance, and otherwise increase the communicative bandwidth required by clients 702 and the servers 704. A communications network may be any one and the combination of wired and/or wireless networks including without limitation a direct interconnection, a secured custom connection, a private network (e.g., an enterprise intranet), a public network (e.g., the Internet), a Personal Area Network (PAN), a Local Area Network (LAN), a Metropolitan Area Network (MAN), an Operating Missions as Nodes on the Internet (OMNI), a Wide Area Network (WAN), a wireless network, a cellular network, and other communications networks.
  • Various embodiments may be implemented using hardware elements, software elements, or a combination of both. Examples of hardware elements may include processors, microprocessors, circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth. Examples of software may include software components, programs, applications, computer programs, application programs, system programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, APIs, instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. Determining whether an embodiment is implemented using hardware elements and/or software elements may vary in accordance with any number of factors, such as desired computational rate, power levels, heat tolerances, processing cycle budget, input data rates, output data rates, memory resources, data bus speeds and other design or performance constraints.
  • One or more aspects of at least one embodiment may be implemented by representative instructions stored on a machine-readable medium which represents various logic within the processor, which when read by a machine causes the machine to fabricate logic to perform the techniques described herein. Such representations, known as “IP cores” may be stored on a tangible, machine readable medium and supplied to various users or manufacturing facilities to load into the fabrication machines that actually make the logic or processor. Some embodiments may be implemented, for example, using a machine-readable medium or article which may store an instruction or a set of instructions that, if executed by a machine, may cause the machine to perform a method and/or operations in accordance with the embodiments. Such a machine may include, for example, any suitable processing platform, computing platform, computing device, processing device, computing system, processing system, computer, processor, or the like, and may be implemented using any suitable combination of hardware and/or software. The machine-readable medium or article may include, for example, any suitable type of memory unit, memory device, memory article, memory medium, storage device, storage article, storage medium and/or storage unit, for example, memory, removable or non-removable media, erasable or non-erasable media, writeable or re-writeable media, digital or analog media, hard disk, floppy disk, Compact Disk Read Only Memory (CD-ROM), Compact Disk Recordable (CD-R), Compact Disk Rewriteable (CD-RW), optical disk, magnetic media, magneto-optical media, removable memory cards or disks, various types of Digital Versatile Disk (DVD), a tape, a cassette, or the like. The instructions may include any suitable type of code, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, encrypted code, and the like, implemented using any suitable high-level, low-level, object-oriented, visual, compiled and/or interpreted programming language.

Claims (20)

1. An apparatus, comprising:
a processor; and
a memory comprising instructions that when executed by the processor cause the processor to:
identify a login of a registered user based on receipt of credentials correlated with the registered user;
update a user status linked to the registered user based on identification of the login of the registered user;
determine a facility corresponding to the login of the registered user; and
update a facility status of the facility based on correspondence of the facility to the login of the registered user.
2. The apparatus of claim 1, the memory comprising instruction that when executed by the processor cause the processor to update an availability of an enterprise product at the facility based, at least in part, on update to one or more of the user status and the facility status.
3. The apparatus of claim 2, the memory comprising instruction that when executed by the processor cause the processor to:
collect sensor data from one or more transducers located at the facility; and
estimate a lead time for the enterprise product based on the sensor data.
4. The apparatus of claim 2, the enterprise product comprising a service.
5. The apparatus of claim 1, the memory comprising instruction that when executed by the processor cause the processor to:
identify a skill associated with the registered user; and
update a first resource status associated with the facility to indicate an availability of the skill at the facility.
6. The apparatus of claim 5, the memory comprising instruction that when executed by the processor cause the processor to update an availability of at least one enterprise product at the facility based, at least in part, on update of the resource status.
7. The apparatus of claim 5, the memory comprising instruction that when executed by the processor cause the processor to:
identify a device associated with the facility;
collect sensor data from one or more transducers located at the facility; and
update a second resource status associated with the facility to indicate an availability of the device at the facility based on the sensor data.
8. The apparatus of claim 7, the memory comprising instruction that when executed by the processor cause the processor to update an availability of at least one enterprise product at the facility based, at least in part, on update of the first and second resource statuses.
9. The apparatus of claim 1, the memory comprising instruction that when executed by the processor cause the processor to:
collect sensor data from one or more transducers located at the facility; and
update one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility.
10. At least one non-transitory computer-readable medium comprising a set of instructions that, in response to being executed by a processor circuit, cause the processor circuit to:
identify a login of a registered user based on receipt of credentials correlated with the registered user;
update a user status linked to the registered user based on identification of the login of the registered user;
determine a facility corresponding to the login of the registered user; and
update a facility status of the facility based on correspondence of the facility to the login of the registered user.
11. The at least one non-transitory computer-readable medium of claim 10, comprising instructions that, in response to being executed by the processor circuit cause the processor circuit to update an availability of an enterprise product at the facility based, at least in part, on update to one or more of the user status and the facility status.
12. The at least one non-transitory computer-readable medium of claim 11, comprising instructions that, in response to being executed by the processor circuit cause the processor circuit to:
collect sensor data from one or more transducers located at the facility; and
estimate a lead time for the enterprise product based on the sensor data.
13. The at least one non-transitory computer-readable medium of claim 10, comprising instructions that, in response to being executed by the processor circuit cause the processor circuit to:
identify a skill associated with the registered user; and
update a first resource status associated with the facility to indicate an availability of the skill at the facility.
14. The at least one non-transitory computer-readable medium of claim 13, comprising instructions that, in response to being executed by the processor circuit cause the processor circuit to update an availability of at least one enterprise product at the facility based, at least in part, on update of the resource status.
15. The at least one non-transitory computer-readable medium of claim 13, comprising instructions that, in response to being executed by the processor circuit cause the processor circuit to:
identify a device associated with the facility;
collect sensor data from one or more transducers located at the facility; and
update a second resource status associated with the facility to indicate an availability of the device at the facility based on the sensor data.
16. The at least one non-transitory computer-readable medium of claim 15, comprising instructions that, in response to being executed by the processor circuit cause the processor circuit to update an availability of at least one enterprise product at the facility based, at least in part, on update of the first and second resource statuses.
17. The at least one non-transitory computer-readable medium of claim 10, comprising instructions that, in response to being executed by the processor circuit cause the processor circuit to:
collect sensor data from one or more transducers located at the facility; and
update one or more facility sensor statuses based on the sensor data collected from the one or more transducers located at the facility.
18. A computer-implemented method, comprising:
identifying a login of a registered user based on receipt of credentials correlated with the registered user;
updating a user status linked to the registered user based on identification of the login of the registered user;
determining a facility corresponding to the login of the registered user; and
updating a facility status of the facility based on correspondence of the facility to the login of the registered user.
19. The computer-implemented method of claim 18, comprising updating an availability of an enterprise product at the facility based, at least in part, on update to one or more of the user status and the facility status.
20. The computer-implemented method of claim 19, comprising:
collecting sensor data from one or more transducers located at the facility; and
estimating a lead time for the enterprise product based on the sensor data.
US17/205,495 2019-07-19 2021-03-18 Identifying and managing enterprise product availability Pending US20210209533A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US17/205,495 US20210209533A1 (en) 2019-07-19 2021-03-18 Identifying and managing enterprise product availability

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US16/517,181 US10963828B2 (en) 2019-07-19 2019-07-19 Identifying and managing enterprise product availability
US17/205,495 US20210209533A1 (en) 2019-07-19 2021-03-18 Identifying and managing enterprise product availability

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US16/517,181 Continuation US10963828B2 (en) 2019-07-19 2019-07-19 Identifying and managing enterprise product availability

Publications (1)

Publication Number Publication Date
US20210209533A1 true US20210209533A1 (en) 2021-07-08

Family

ID=74344129

Family Applications (2)

Application Number Title Priority Date Filing Date
US16/517,181 Active US10963828B2 (en) 2019-07-19 2019-07-19 Identifying and managing enterprise product availability
US17/205,495 Pending US20210209533A1 (en) 2019-07-19 2021-03-18 Identifying and managing enterprise product availability

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US16/517,181 Active US10963828B2 (en) 2019-07-19 2019-07-19 Identifying and managing enterprise product availability

Country Status (1)

Country Link
US (2) US10963828B2 (en)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2023012928A1 (en) * 2021-08-04 2023-02-09 日本電信電話株式会社 Device estimation system, device estimation apparatus, packet analysis model training apparatus, waveform analysis model training apparatus, and program
US11966333B1 (en) * 2022-10-14 2024-04-23 Capital One Services, Llc Automated predictive caching of cloud-sourced data and methods of use thereof

Citations (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2001006338A2 (en) * 1999-07-20 2001-01-25 Diebold, Incorporated Automated banking machine system and development method
US20080059274A1 (en) * 2006-08-22 2008-03-06 Stuart Holliday Automatic self-optimizing queue management system
US20110137776A1 (en) * 2009-12-09 2011-06-09 Allconnect, Inc. Systems and methods for managing and/or recommending third party products and services provided to a user
US8091778B1 (en) * 2007-11-13 2012-01-10 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system computer determines nearest bank able to process a customer's transaction request, provides directions to the bank, and sends transaction request information and customer's image to the bank before the customer arrives at the bank
US8474701B1 (en) * 1998-11-27 2013-07-02 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system controlled responsive to data bearing records to sequentially provide preassigned ordered marketing and campaign presentations to a particular individual over different transactions
US8479983B1 (en) * 2002-11-26 2013-07-09 Diebold Self-Service Systems Division Of Diebold, Incorporated Automated banking machine operation authorization based on user location verified by data read from data bearing records
US8496168B1 (en) * 1998-04-17 2013-07-30 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system controlled responsive to data bearing records
US8505814B1 (en) * 2002-11-26 2013-08-13 Diebold Self-Service Systems Division Of Diebold, Incorporated Cash dispensing automated banking machine with GPS
US8579192B1 (en) * 1998-04-17 2013-11-12 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system controlled responsive to data read from data bearing records
US8699370B2 (en) * 2010-08-24 2014-04-15 Euclid, Inc. Method and apparatus for analysis of user traffic within a predefined area
US8733635B2 (en) * 1998-04-17 2014-05-27 Diebold Self-Service Systems, division of Diebold Incorporated Banking system controlled responsive to data bearing records and user input of a phone received security code
US20140189808A1 (en) * 2012-12-28 2014-07-03 Lookout, Inc. Multi-factor authentication and comprehensive login system for client-server networks
US20140201100A1 (en) * 2013-01-15 2014-07-17 Mident, LLC Confirmation of identity
US20140201001A1 (en) * 2013-01-15 2014-07-17 Nicholas Rellas Distribution of products
US8814043B2 (en) * 2006-04-05 2014-08-26 Diebold Self-Service Systems Division Of Diebold, Incorporated Determining an automated banking machine for check cashing
US9088891B2 (en) * 2012-08-13 2015-07-21 Wells Fargo Bank, N.A. Wireless multi-factor authentication with captive portals
US20160048841A1 (en) * 2014-08-15 2016-02-18 Bank Of America Corporation Seamless customer transfer in a video conferencing system
US20160110692A1 (en) * 2012-10-19 2016-04-21 Diebold Self-Service Systems, Division Of Diebold, Incorporated Time analysis of a banking system
US20160314528A1 (en) * 2015-04-24 2016-10-27 Bank Of America Corporation System for spend analysis data transformation for life event inference tracking
US20170032303A1 (en) * 2015-07-30 2017-02-02 Espresa, Inc. Platform for boarding a vendor at a workplace
CA2944180A1 (en) * 2015-10-30 2017-04-30 The Toronto-Dominion Bank Systems and methods for context-based event detection and determination
US9640040B2 (en) * 2012-08-09 2017-05-02 Diebold Self-Service Systems Division Of Diebold, Incorporated Accepting a check deposit from a mobile device in communication with an automated teller machine
US9654477B1 (en) * 2015-05-05 2017-05-16 Wells Fargo Bank, N. A. Adaptive authentication
US20170228802A1 (en) * 2016-02-09 2017-08-10 Jeremy Maynard Online Real-Time Business Information
US9754492B2 (en) * 2014-07-08 2017-09-05 The Toronto-Dominion Bank Systems and methods for providing sensor-based location proximity detection and notification
US20170280459A1 (en) * 2016-03-28 2017-09-28 Bank Of America Corporation Intelligent resource procurement system based on physical proximity to related resources
US20170310770A1 (en) * 2016-04-20 2017-10-26 Tize Technologies Inc. (AccompliceTM) C/O WeWork System and method for cloud computing on-demand dynamic service management engine
US20170315697A1 (en) * 2016-04-27 2017-11-02 Crestron Electronics, Inc. Three-dimensional building management system visualization
US20170323345A1 (en) * 2016-05-05 2017-11-09 State Farm Mutual Automobile Insurance Co Using cognitive computing to provide targeted offers for preferred products to a user via a mobile device
US20180020348A1 (en) * 2016-07-13 2018-01-18 Bank Of America Corporation System for authenticating a user and enabling real-time approval notifications
US20180032966A1 (en) * 2016-07-30 2018-02-01 Jeremy Maynard Appointment-based notification of real-time business information
US20180032946A1 (en) * 2016-07-31 2018-02-01 Jeremy Maynard Online real-time business information including local inventory
US20180040064A1 (en) * 2016-08-04 2018-02-08 Xero Limited Network-based automated prediction modeling
US20180054490A1 (en) * 2016-08-22 2018-02-22 fybr System for distributed intelligent remote sensing systems
US20180096311A1 (en) * 2016-09-30 2018-04-05 The Toronto-Dominion Bank Devices, Systems and Methods for Determining Suggested Action Initiation Times for Interactions
US9984520B1 (en) * 2015-06-29 2018-05-29 Good2Go, LLC Facility and resource access system
US9990636B1 (en) * 2012-05-24 2018-06-05 Jpmorgan Chase Bank, N.A. Enterprise fulfillment system with dynamic prefetching, secured data access, system monitoring, and performance optimization capabilities
US10038607B2 (en) * 2016-06-17 2018-07-31 Bank Of America Corporation System for aggregated machine-initiated resource distribution
US10063438B2 (en) * 2016-03-28 2018-08-28 Bank Of America Corporation Security implementation for resource distribution
WO2018160833A1 (en) * 2017-03-01 2018-09-07 Diebold Nixdorf Incorporated Automated transaction system and method
US20180276710A1 (en) * 2017-03-17 2018-09-27 Edatanetworks Inc. Artificial Intelligence Engine Incenting Merchant Transaction With Consumer Affinity
US10157396B1 (en) * 2017-12-19 2018-12-18 Capital One Services, Llc Allocation of service provider resources based on a capacity to provide the service
US10192264B2 (en) * 2014-07-18 2019-01-29 The Toronto-Dominion Bank Multiple party branch recommendation
US20190057340A1 (en) * 2016-11-11 2019-02-21 Kevin Sunlin Wang Method and system for automated time management
US10237298B1 (en) * 2014-06-17 2019-03-19 Wells Fargo Bank, N.A. Session management
US20190156281A1 (en) * 2017-11-22 2019-05-23 Bank Of America Corporation Real-time data services based on geo-location information
US20190180358A1 (en) * 2017-12-11 2019-06-13 Accenture Global Solutions Limited Machine learning classification and prediction system
US10360525B1 (en) * 2016-02-16 2019-07-23 Wells Fargo Bank, N.A. Timely quality improvement of an inventory of elements
US20190228348A1 (en) * 2018-01-17 2019-07-25 WeWork Companies Inc. Reservation system in a shared workspace
US10452897B1 (en) * 2018-08-06 2019-10-22 Capital One Services, Llc System for verifying the identity of a user
US20190333025A1 (en) * 2015-10-03 2019-10-31 WeWork Companies Inc. Providing an opportunity for redundant meeting invitees to opt out
US20190340564A1 (en) * 2017-03-29 2019-11-07 WeWork Companies Inc. Monitoring Network Traffic to Determine Asset Utilization
CA3009685A1 (en) * 2018-06-27 2019-12-27 The Toronto-Dominion Bank Automatic generation and population of digital interfaces based on adaptively processed image data
US10531226B1 (en) * 2015-07-10 2020-01-07 WeWork Companies Inc. Determining qualified devices using zone information
US20200179760A1 (en) * 2018-12-06 2020-06-11 International Business Machines Corporation Equipment use tracking and availability prediction
US20210019514A1 (en) * 2018-09-21 2021-01-21 The Toronto-Dominion Bank Systems and methods for obtaining product information in real-time

Family Cites Families (36)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7848765B2 (en) * 2005-05-27 2010-12-07 Where, Inc. Location-based services
US8335593B2 (en) * 2009-11-12 2012-12-18 Bank Of America Corporation Power-using device monitor
US20110112875A1 (en) * 2009-11-12 2011-05-12 Bank Of America Corporation Site survey and installation for remote facility management system
US8645495B2 (en) * 2009-11-12 2014-02-04 Bank Of America Corporation Facility maintenance and management system
US20110113360A1 (en) * 2009-11-12 2011-05-12 Bank Of America Corporation Facility monitoring and control system interface
US20130191898A1 (en) * 2012-01-04 2013-07-25 Harold H. KRAFT Identity verification credential with continuous verification and intention-based authentication systems and methods
US10402760B2 (en) * 2012-11-15 2019-09-03 Impel It! Inc. Methods and systems for the sale of consumer services
US10115166B2 (en) * 2014-01-21 2018-10-30 Capital One Services, Llc System and method for account transaction and balance prediction
US20160232546A1 (en) * 2014-06-13 2016-08-11 Connect Financial LLC Computer processing of financial product information and information about consumers of financial products
US10963810B2 (en) 2014-06-30 2021-03-30 Amazon Technologies, Inc. Efficient duplicate detection for machine learning data sets
US10452992B2 (en) 2014-06-30 2019-10-22 Amazon Technologies, Inc. Interactive interfaces for machine learning model evaluations
US10055726B2 (en) * 2014-07-14 2018-08-21 Jpmorgan Chase Bank, N.A. Systems and methods for management of mobile banking resources
CA3001304C (en) 2015-06-05 2021-10-19 C3 Iot, Inc. Systems, methods, and devices for an enterprise internet-of-things application development platform
US10402792B2 (en) * 2015-08-13 2019-09-03 The Toronto-Dominion Bank Systems and method for tracking enterprise events using hybrid public-private blockchain ledgers
US20170178048A1 (en) * 2015-12-22 2017-06-22 Microsoft Technology Licensing, Llc Identification and presentation of tasks based on predicted periods of user availability
US10346003B2 (en) * 2016-02-16 2019-07-09 Bank Of America Corporation Integrated geolocation resource transfer platform
US10361942B2 (en) * 2016-02-26 2019-07-23 Bank Of America Corporation System for allocation of resources based on resource utilization
US10165393B2 (en) * 2016-05-27 2018-12-25 Bank Of America Corporation System for monitoring resource utilization and resource optimization
US10264049B2 (en) * 2016-05-27 2019-04-16 Bank Of America Corporation System for facilitating utilization of resources
US10409782B2 (en) 2016-06-15 2019-09-10 Chen Zhang Platform, system, process for distributed graph databases and computing
US20180041447A1 (en) * 2016-08-08 2018-02-08 Bank Of America Corporation System for resource allocation at time of use and conservation of unused portion
US10678894B2 (en) * 2016-08-24 2020-06-09 Experian Information Solutions, Inc. Disambiguation and authentication of device users
US10430239B2 (en) * 2016-08-24 2019-10-01 Clari Inc. Method and system for predicting task completion of a time period based on task completion rates of prior time periods using machine learning
US10846643B2 (en) * 2016-08-24 2020-11-24 Clari Inc. Method and system for predicting task completion of a time period based on task completion rates and data trend of prior time periods in view of attributes of tasks using machine learning models
US10310852B2 (en) * 2016-09-29 2019-06-04 Entit Software Llc Timing estimations for application lifecycle management work items determined through machine learning
US9965797B1 (en) * 2016-10-22 2018-05-08 Capital One Services, Llc System and method for generating user customized order interface
US10423911B2 (en) * 2017-01-19 2019-09-24 Bank Of America Corporation System for platform activity gathering for achievement leveraging virtual visualization
US10313441B2 (en) * 2017-02-13 2019-06-04 Bank Of America Corporation Data processing system with machine learning engine to provide enterprise monitoring functions
US10325224B1 (en) * 2017-03-23 2019-06-18 Palantir Technologies Inc. Systems and methods for selecting machine learning training data
US20180285900A1 (en) * 2017-03-28 2018-10-04 Wipro Limited Method and system for determining a predictive model for estimating target output for an enterprise
US11276015B2 (en) * 2017-04-20 2022-03-15 Capital One Services, Llc Machine learning artificial intelligence system for predicting hours of operation
US20180374020A1 (en) * 2017-06-26 2018-12-27 Hessam Ahani Techniques multi-factor location analysis of resources for managing services
US10360214B2 (en) 2017-10-19 2019-07-23 Pure Storage, Inc. Ensuring reproducibility in an artificial intelligence infrastructure
US20190147430A1 (en) 2017-11-10 2019-05-16 Apple Inc. Customizing payment sessions with machine learning models
US20190325355A1 (en) * 2018-04-24 2019-10-24 Jpmorgan Chase Bank, N.A. System and method for implementing a capacity management and live user location tool
SG11202010188PA (en) 2018-05-28 2020-11-27 Royal Bank Of Canada System and method for secure electronic transaction platform

Patent Citations (63)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8733635B2 (en) * 1998-04-17 2014-05-27 Diebold Self-Service Systems, division of Diebold Incorporated Banking system controlled responsive to data bearing records and user input of a phone received security code
US8579192B1 (en) * 1998-04-17 2013-11-12 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system controlled responsive to data read from data bearing records
US8496168B1 (en) * 1998-04-17 2013-07-30 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system controlled responsive to data bearing records
US8474701B1 (en) * 1998-11-27 2013-07-02 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system controlled responsive to data bearing records to sequentially provide preassigned ordered marketing and campaign presentations to a particular individual over different transactions
WO2001006338A2 (en) * 1999-07-20 2001-01-25 Diebold, Incorporated Automated banking machine system and development method
US8479983B1 (en) * 2002-11-26 2013-07-09 Diebold Self-Service Systems Division Of Diebold, Incorporated Automated banking machine operation authorization based on user location verified by data read from data bearing records
US8505814B1 (en) * 2002-11-26 2013-08-13 Diebold Self-Service Systems Division Of Diebold, Incorporated Cash dispensing automated banking machine with GPS
US8814043B2 (en) * 2006-04-05 2014-08-26 Diebold Self-Service Systems Division Of Diebold, Incorporated Determining an automated banking machine for check cashing
US20080059274A1 (en) * 2006-08-22 2008-03-06 Stuart Holliday Automatic self-optimizing queue management system
US8091778B1 (en) * 2007-11-13 2012-01-10 Diebold Self-Service Systems Division Of Diebold, Incorporated Banking system computer determines nearest bank able to process a customer's transaction request, provides directions to the bank, and sends transaction request information and customer's image to the bank before the customer arrives at the bank
US20110137776A1 (en) * 2009-12-09 2011-06-09 Allconnect, Inc. Systems and methods for managing and/or recommending third party products and services provided to a user
US8699370B2 (en) * 2010-08-24 2014-04-15 Euclid, Inc. Method and apparatus for analysis of user traffic within a predefined area
US9990636B1 (en) * 2012-05-24 2018-06-05 Jpmorgan Chase Bank, N.A. Enterprise fulfillment system with dynamic prefetching, secured data access, system monitoring, and performance optimization capabilities
US9640040B2 (en) * 2012-08-09 2017-05-02 Diebold Self-Service Systems Division Of Diebold, Incorporated Accepting a check deposit from a mobile device in communication with an automated teller machine
US9088891B2 (en) * 2012-08-13 2015-07-21 Wells Fargo Bank, N.A. Wireless multi-factor authentication with captive portals
US20160110692A1 (en) * 2012-10-19 2016-04-21 Diebold Self-Service Systems, Division Of Diebold, Incorporated Time analysis of a banking system
US20140189808A1 (en) * 2012-12-28 2014-07-03 Lookout, Inc. Multi-factor authentication and comprehensive login system for client-server networks
US20140201001A1 (en) * 2013-01-15 2014-07-17 Nicholas Rellas Distribution of products
US20140201100A1 (en) * 2013-01-15 2014-07-17 Mident, LLC Confirmation of identity
US10237298B1 (en) * 2014-06-17 2019-03-19 Wells Fargo Bank, N.A. Session management
US9754492B2 (en) * 2014-07-08 2017-09-05 The Toronto-Dominion Bank Systems and methods for providing sensor-based location proximity detection and notification
US10192264B2 (en) * 2014-07-18 2019-01-29 The Toronto-Dominion Bank Multiple party branch recommendation
US20160048841A1 (en) * 2014-08-15 2016-02-18 Bank Of America Corporation Seamless customer transfer in a video conferencing system
US20160314528A1 (en) * 2015-04-24 2016-10-27 Bank Of America Corporation System for spend analysis data transformation for life event inference tracking
US9654477B1 (en) * 2015-05-05 2017-05-16 Wells Fargo Bank, N. A. Adaptive authentication
US9984520B1 (en) * 2015-06-29 2018-05-29 Good2Go, LLC Facility and resource access system
US10531226B1 (en) * 2015-07-10 2020-01-07 WeWork Companies Inc. Determining qualified devices using zone information
US20170053246A1 (en) * 2015-07-30 2017-02-23 Espresa, Inc. Cloud based platform for vehicle related services
US20170032330A1 (en) * 2015-07-30 2017-02-02 Espresa, Inc. Cloud based platform for workplace services management
US20170032303A1 (en) * 2015-07-30 2017-02-02 Espresa, Inc. Platform for boarding a vendor at a workplace
US20190333025A1 (en) * 2015-10-03 2019-10-31 WeWork Companies Inc. Providing an opportunity for redundant meeting invitees to opt out
US20170124626A1 (en) * 2015-10-30 2017-05-04 The Toronto-Dominion Bank Systems and methods for context-based event triggered product and/or service offerings
CA2944180A1 (en) * 2015-10-30 2017-04-30 The Toronto-Dominion Bank Systems and methods for context-based event detection and determination
US10600119B2 (en) * 2015-10-30 2020-03-24 The Toronto-Dominion Bank Systems and methods for context-based event triggered product and/or service offerings
US20170228802A1 (en) * 2016-02-09 2017-08-10 Jeremy Maynard Online Real-Time Business Information
US10360525B1 (en) * 2016-02-16 2019-07-23 Wells Fargo Bank, N.A. Timely quality improvement of an inventory of elements
US20170280459A1 (en) * 2016-03-28 2017-09-28 Bank Of America Corporation Intelligent resource procurement system based on physical proximity to related resources
US10524268B2 (en) * 2016-03-28 2019-12-31 Bank Of America Corporation Intelligent resource procurement system based on physical proximity to related resources
US10063438B2 (en) * 2016-03-28 2018-08-28 Bank Of America Corporation Security implementation for resource distribution
US20170310770A1 (en) * 2016-04-20 2017-10-26 Tize Technologies Inc. (AccompliceTM) C/O WeWork System and method for cloud computing on-demand dynamic service management engine
US20170315697A1 (en) * 2016-04-27 2017-11-02 Crestron Electronics, Inc. Three-dimensional building management system visualization
US20170323345A1 (en) * 2016-05-05 2017-11-09 State Farm Mutual Automobile Insurance Co Using cognitive computing to provide targeted offers for preferred products to a user via a mobile device
US10038607B2 (en) * 2016-06-17 2018-07-31 Bank Of America Corporation System for aggregated machine-initiated resource distribution
US20180020348A1 (en) * 2016-07-13 2018-01-18 Bank Of America Corporation System for authenticating a user and enabling real-time approval notifications
US20180032966A1 (en) * 2016-07-30 2018-02-01 Jeremy Maynard Appointment-based notification of real-time business information
US20180032946A1 (en) * 2016-07-31 2018-02-01 Jeremy Maynard Online real-time business information including local inventory
US20180040064A1 (en) * 2016-08-04 2018-02-08 Xero Limited Network-based automated prediction modeling
US20180054490A1 (en) * 2016-08-22 2018-02-22 fybr System for distributed intelligent remote sensing systems
AU2017316645A1 (en) * 2016-08-22 2019-04-11 fybr System for distributed intelligent remote sensing systems
US20180096311A1 (en) * 2016-09-30 2018-04-05 The Toronto-Dominion Bank Devices, Systems and Methods for Determining Suggested Action Initiation Times for Interactions
US20190057340A1 (en) * 2016-11-11 2019-02-21 Kevin Sunlin Wang Method and system for automated time management
WO2018160833A1 (en) * 2017-03-01 2018-09-07 Diebold Nixdorf Incorporated Automated transaction system and method
US20180276710A1 (en) * 2017-03-17 2018-09-27 Edatanetworks Inc. Artificial Intelligence Engine Incenting Merchant Transaction With Consumer Affinity
US20190340564A1 (en) * 2017-03-29 2019-11-07 WeWork Companies Inc. Monitoring Network Traffic to Determine Asset Utilization
US20190156281A1 (en) * 2017-11-22 2019-05-23 Bank Of America Corporation Real-time data services based on geo-location information
AU2018271385A1 (en) * 2017-12-11 2019-06-27 Accenture Global Solutions Limited Machine learning classification and prediction system
US20190180358A1 (en) * 2017-12-11 2019-06-13 Accenture Global Solutions Limited Machine learning classification and prediction system
US10157396B1 (en) * 2017-12-19 2018-12-18 Capital One Services, Llc Allocation of service provider resources based on a capacity to provide the service
US20190228348A1 (en) * 2018-01-17 2019-07-25 WeWork Companies Inc. Reservation system in a shared workspace
CA3009685A1 (en) * 2018-06-27 2019-12-27 The Toronto-Dominion Bank Automatic generation and population of digital interfaces based on adaptively processed image data
US10452897B1 (en) * 2018-08-06 2019-10-22 Capital One Services, Llc System for verifying the identity of a user
US20210019514A1 (en) * 2018-09-21 2021-01-21 The Toronto-Dominion Bank Systems and methods for obtaining product information in real-time
US20200179760A1 (en) * 2018-12-06 2020-06-11 International Business Machines Corporation Equipment use tracking and availability prediction

Non-Patent Citations (5)

* Cited by examiner, † Cited by third party
Title
Kaur, Dr, et al. "Banking 4.0:‘The Influence of Artificial Intelligence on the Banking Industry & How AI Is Changing the Face of Modern Day Banks’." International Journal of Management 11.6 (2020). (Year: 2020) *
Kyritsis, Athanasios I., and Michel Deriaz. "A machine learning approach to waiting time prediction in queueing scenarios." 2019 Second International Conference on Artificial Intelligence for Industries (AI4I). IEEE, 2019. (Year: 2019) *
Lázaro, Jorge López, Álvaro Barbero Jiménez, and Akiko Takeda. "Improving cash logistics in bank branches by coupling machine learning and robust optimization." Expert Systems With Applications 92 (2018): 236-255. (Year: 2018) *
Rajarajeswari, P., M. Sreevani, and P. Lalitha Suryakumari. "Secure Cloud Risk Architecture analysis for Mobile Banking system and its performance analysis based on Machine learning approaches." Journal of Physics: Conference Series. Vol. 2089. No. 1. IOP Publishing, 2021. (Year: 2021) *
Ramalingam, Hariharan, and V. Prasanna Venkatesan. "Conceptual analysis of Internet of Things use cases in Banking domain." TENCON 2019-2019 IEEE Region 10 Conference (TENCON). IEEE, 2019. (Year: 2019) *

Also Published As

Publication number Publication date
US20210019676A1 (en) 2021-01-21
US10963828B2 (en) 2021-03-30

Similar Documents

Publication Publication Date Title
US9514231B2 (en) Computer-based system for use in providing advisory services
US10810528B1 (en) Identifying and utilizing the availability of enterprise resources
Ogwueleka et al. Neural network and classification approach in identifying customer behavior in the banking sector: A case study of an international bank
US8126742B2 (en) Automated assignment of insurable events
US20180315145A1 (en) Managing school systems on a blockchain
US10963960B1 (en) Computer system for automatic credit allocation of a shared line of credit
US7698248B2 (en) Method and system for auditing processes and projects for process improvement
US20080080526A1 (en) Migrating data to new cloud
CN113545026A (en) System and method for vulnerability assessment and remedial action identification
US20170093651A1 (en) Channel accessible single function micro service data collection process for light analytics
US11080795B1 (en) Identifying and utilizing the availability of enterprise resources
US20200242615A1 (en) First party fraud detection
US11640470B1 (en) System and methods for reducing an organization's cybersecurity risk by determining the function and seniority of employees
JP2020506473A (en) Method for adjusting risk parameters and method and device for risk identification
US20210209533A1 (en) Identifying and managing enterprise product availability
US11144990B1 (en) Credit offers based on non-transactional data
US20200118056A1 (en) Method and system of processing data
Tan et al. Predicting the closing price of cryptocurrencies: a comparative study
US20170091666A1 (en) System framework processor for channel contacts
AU2021236587A1 (en) TranspairPLUS: devices, architectures and methods to improve regulation of economic assets including international monitoring using emerging digital processing technologies including block chain over diverse and expandable types and formats with offline AI, visualization systems, options related to direct tax collection or registration of obligations of payment and matching cash payments to legitimate sources.
US11983654B2 (en) Method of observing and evaluating processes and user action efficiency with recommendations on change
US20240185350A1 (en) System, method, and apparatus for operating a wealth management platform
US20230066770A1 (en) Cross-channel actionable insights
US11551310B1 (en) Smart engine risk assessments
Strohmeier et al. Evaluating major human resource information systems design characteristics–an empirical study

Legal Events

Date Code Title Description
AS Assignment

Owner name: CAPITAL ONE SERVICES, LLC, VIRGINIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:PHILLIPS, JEREMY;TULA, SHEVATA;MOISE, MAXIME;REEL/FRAME:055640/0136

Effective date: 20190719

STPP Information on status: patent application and granting procedure in general

Free format text: APPLICATION DISPATCHED FROM PREEXAM, NOT YET DOCKETED

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: ADVISORY ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE AFTER FINAL ACTION FORWARDED TO EXAMINER

STPP Information on status: patent application and granting procedure in general

Free format text: ADVISORY ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED