US20220261812A1 - Interfacing with a point of sale system from a computer vision system - Google Patents

Interfacing with a point of sale system from a computer vision system Download PDF

Info

Publication number
US20220261812A1
US20220261812A1 US17/592,287 US202217592287A US2022261812A1 US 20220261812 A1 US20220261812 A1 US 20220261812A1 US 202217592287 A US202217592287 A US 202217592287A US 2022261812 A1 US2022261812 A1 US 2022261812A1
Authority
US
United States
Prior art keywords
user
person
association
checkout
computing device
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/592,287
Inventor
William Glaser
Brian Van Osdol
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.)
Grabango Co
Original Assignee
Grabango Co
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 Grabango Co filed Critical Grabango Co
Priority to US17/592,287 priority Critical patent/US20220261812A1/en
Assigned to Grabango Co. reassignment Grabango Co. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: VAN OSDOL, Brian, GLASER, WILLIAM
Publication of US20220261812A1 publication Critical patent/US20220261812A1/en
Assigned to GLICKBERG, DANIEL reassignment GLICKBERG, DANIEL SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: Grabango Co.
Assigned to FIRST-CITIZEN BANK & TRUST COMPANY reassignment FIRST-CITIZEN BANK & TRUST COMPANY SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: Grabango Co.
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/31User authentication
    • G06F21/32User authentication using biometric data, e.g. fingerprints, iris scans or voiceprints
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • 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
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/08Payment architectures
    • G06Q20/20Point-of-sale [POS] network systems
    • 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
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/08Payment architectures
    • G06Q20/20Point-of-sale [POS] network systems
    • G06Q20/204Point-of-sale [POS] network systems comprising interface for record bearing medium or carrier for electronic funds transfer or payment credit
    • 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
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/08Payment architectures
    • G06Q20/20Point-of-sale [POS] network systems
    • G06Q20/206Point-of-sale [POS] network systems comprising security or operator identification provisions, e.g. password entry
    • 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
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/08Payment architectures
    • G06Q20/20Point-of-sale [POS] network systems
    • G06Q20/208Input by product or record sensing, e.g. weighing or scanner processing
    • 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
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/38Payment protocols; Details thereof
    • G06Q20/40Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
    • G06Q20/401Transaction verification
    • G06Q20/4014Identity check for transactions
    • G06Q20/40145Biometric identity checks
    • 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
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/38Payment protocols; Details thereof
    • G06Q20/40Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
    • G06Q20/401Transaction verification
    • G06Q20/4016Transaction verification involving fraud or risk level assessment in transaction processing
    • 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
    • G06Q30/00Commerce
    • G06Q30/06Buying, selling or leasing transactions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/10Image acquisition
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V40/00Recognition of biometric, human-related or animal-related patterns in image or video data
    • G06V40/10Human or animal bodies, e.g. vehicle occupants or pedestrians; Body parts, e.g. hands
    • G06V40/103Static body considered as a whole, e.g. static pedestrian or occupant recognition
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V40/00Recognition of biometric, human-related or animal-related patterns in image or video data
    • G06V40/10Human or animal bodies, e.g. vehicle occupants or pedestrians; Body parts, e.g. hands
    • G06V40/16Human faces, e.g. facial parts, sketches or expressions
    • G06V40/172Classification, e.g. identification
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V40/00Recognition of biometric, human-related or animal-related patterns in image or video data
    • G06V40/20Movements or behaviour, e.g. gesture recognition

Definitions

  • This invention relates generally to the field of computer vision, and more specifically to a new and useful system and method for personalized interactivity with a shared computer vision system.
  • FIG. 1 is a schematic representation of an exemplary implementation of a system of a preferred embodiment
  • FIGS. 2-4 are schematic representations of exemplary forms of associations
  • FIG. 5 is a schematic representation of an exemplary implementation of the system applied across multiple humans in an environment
  • FIG. 6 is a flowchart representation of a method of a preferred embodiment
  • FIG. 7 is a flowchart representation of a variations of establishing associations
  • FIGS. 8 and 9 are schematic representations of exemplary variations of establishing an association with a device instance
  • FIGS. 10A-10F are schematic representations of exemplary variations of establishing an association during a pairing process of a device instance
  • FIG. 11 is a schematic representation of a sequence of association mechanisms
  • FIGS. 12-14 are schematic representations of coordinating with a secondary device.
  • a system and method for interfacing with a computing device from a computer vision system functions to enable computing devices in an environment to pair, synchronize, or otherwise associate with a computer vision (CV) detected and monitored person or object.
  • CV computer vision
  • the system and method are preferably used in coordinating an interactive experience that is in part based on a computer vision (CV) model of the environment and one or more computing devices in that environment.
  • the computer vision model may model people, objects, the environment and interactions/events in that environment, and/or other aspects.
  • the system could similarly be applied to other sensor-driven interaction experiences.
  • the system and method are used to synchronize state information associated with a CV monitored person to a computing device as the person comes into proximity of the computing device. This can be used to transfer data from the computing platform of the CV system to the computing device. This may also be used to relay communication from the computing device back to the computing platform and associated or used with the CV-based data modeling in the computing platform.
  • a checkout station i.e., a point of sale system
  • checkout list information collected by the CV monitoring system on behalf of a customer can be automatically transferred to a checkout station when it is the customer's turn to checkout, thereby expediting and speeding up the checkout process.
  • the process could similarly be used in transferring payment information for performing a transaction.
  • the system and method may be applied to other suitable applications as described herein, but in general, the system and method are described as they would apply to commerce and in particular the checkout process with a checkout station.
  • Integrating with computing device infrastructure of an environment can enable CV-based monitoring or other forms of sensor-based monitoring to drive or facilitate interaction experiences involving these computing devices.
  • These computing devices could be checkout stations (as discussed above), informational kiosks, automated teller machines of a bank, vending machines, and/or any suitable type of computing device or machine.
  • interfacing with the computing device infrastructure can involve a physical interface device which can act as a proxy for digitally interfacing.
  • a programmatic interface such as a network accessible application programming interface to remotely interface with a computing device (e.g., a POS station). This could be wirelessly or in a wired connection.
  • the system and method can be used in large scale CV-driven applications where CV-based modeling of people, objects, the environment, and interactions in that environment are used across independent and personalized digital experiences of different participants.
  • these CV-driven applications can be across large environments such as a grocery store, a mall, or any suitable environment that would depend on multiple camera imaging.
  • CV-driven interactivity may be enabled ad-hoc for people in the environment.
  • the system may apply a process of establishing associations between CV modeled people with other elements.
  • the association(s) established by the system and method can be between a CV-person, a user-record and or a user-account, and then preferably with some other associative element.
  • the additional associative element can be a human (wherein direct or indirect properties of a person can be used to identify a person) and/or a computing device (e.g., a physical computing device, and/or some application instance on a computing device). These associations can additionally be scoped to a particular environment or space and period of time.
  • the system and method may additionally support operating with different types of association “topologies”.
  • a CV-person i.e., a computer vision modeled person
  • a CV-person may, or may not, have any personally identifying information or person-associated metadata.
  • the CV-person will generally represent the presence of a person in an environment and optionally the location, actions, activity, CV-derived properties, and/or other information based on image processing.
  • a CV-person could have a tracked location or position, body properties (e.g., pose, clothing, or other visual properties), and/or other properties.
  • CV-detected events, gestures or states may additionally be detected in relationship to the CV-person and form part of the data model/representation of that physical person.
  • a CV monitoring system characterizes an imaging system and/or processing system employing computer vision to facilitate the detection and tracking of objects, detecting actions, and performing other CV-based operations.
  • the system and method is described as it applies to CV-based modeling of people, but a CV monitoring system may additionally or alternatively model other entities or objects such as animals, vehicles, automated devices/robots, or other suitable objects.
  • a user-record as used herein characterizes a computer record that is associated with a single human or being.
  • a user-record can preferably be associated with a CV-person to uniquely identify, track, and record state of the CV-person.
  • a user-record will preferably include various properties. Properties of a user-record may include personal identifiable information, but it may alternatively not include any identifiable information.
  • a user-record in some implementations may also include payment information, user settings, user history, privilege settings/permissions, and/or other information. Properties of a user-record may initially use default settings that are used as placeholders until these properties can be updated. Properties may be updated as a result of association with other elements or through CV-based monitoring of the CV-person.
  • a user-record can additionally be used in modeling the state of an entity within a system, which will generally be directing in part a digital interactive experience.
  • the user-record may be the record used to record the items selected for purchase forming some.
  • a user-record can be an internal model of a human.
  • the user-record could be an ephemeral user-record that is preserved for essentially over the duration that the CV-person is detected in the environment.
  • a user-record can be created and updated for the duration that a shopper is present in a store.
  • a user-record may bridge the CV-modeling of a person across non-continuous CV monitoring of a person.
  • a first instance of a CV-person monitored in one location at one particular time period and a second instance of a CV person monitored at one location and at second time period could be associated with the same user-record.
  • a user-record could additionally be persistent over multiple visits or system sessions, wherein a user-record may be reestablished for a human over multiple visits to the environment.
  • a user may not explicitly create nor have direct access to manage the user-record.
  • the user-record can be, include, or reference a user-account, where at least a part of the user-record may be user managed.
  • the system and method may operate with a unified concept of user-record and user-account.
  • the user-record can be a user-account with user managed authentication credentials.
  • verified user-accounts and ephemeral/anonymous user accounts could be used in a similar manner. Other suitable user modeling could similarly be applied.
  • a user-account characterizes an account in the system that can be accessed and manipulated by a user.
  • a user-account will generally be accompanied with some authorization process such as a username and password or other authentication credentials or process.
  • the user-account may reference a user-account of an outside system such as a social media platform.
  • a user-account may be used to enable a user to register an application instance, edit payment methods, change account settings, view shopping history, edit shopping lists, and/or perform other actions.
  • a user-account could be implemented as an optional associative element for humans in the environment.
  • CV-driven applications may handle humans with only ephemeral user-records as well as humans with user-accounts.
  • a user-record can optionally include or reference (through some link or association) a user-account.
  • some humans will have only a user-record used in internally modeling state and referencing CV-related data. These humans may not have a user-account.
  • some other humans will have a user-record that is associated with or is their user-account.
  • only humans with explicitly created user-accounts may be stored.
  • Supporting both ephemeral/anonymous user-records and user-accounts can have the benefit of enabling ad-hoc association of a new user-account with an existing user-record.
  • a user that creates a user account in the middle of a shopping trip can gain access to their CV-based modeling (e.g., a virtual cart for automatic or expedited checkout) that was tracked through a previously anonymous user-record.
  • a user-record will generally be used to reference the generic user-record, which may or may not have association to a user-account with authentication credentials, user-account will generally be used in situations where there is a user-created record that the user is able to authenticate into unless otherwise specified.
  • a human as used herein characterizes a human being with a unique identity.
  • a human is sometimes referred to as the user, customer, worker, or other human label where appropriate.
  • a human can be someone who is a shopper, a worker in the store, or is otherwise present in the environment.
  • a human could similarly generalize to other living or non-living entities such as farm animals, pets, vehicles, robots, and the like.
  • a device instance as used herein characterizes a unique instantiation of a stateful device present in the environment.
  • a device instance in many cases is a computing device such as smart phone, a wearable computer, a tablet, a personal computer, or a computing kiosk/station.
  • a device instance is preferably uniquely identifiable.
  • a first type of device instance (sometimes referred to simply as a computing device) is the one to which the computing platform is interfacing with.
  • the computing device instance could be computing devices accessible within the environment such as a point of sale (POS) payment kiosk, a help kiosk, or any suitable type of computing device.
  • POS point of sale
  • a device instance may be an application instance on a device such as an application installed by a user.
  • instance is used to distinguish a unique installation and instantiation of an application on a particular device.
  • the application instance can be an application of the automatic checkout service that a shopper can use to view their currently selected items, to complete checkout, to modify settings, and/or perform other tasks.
  • the system and method can facilitate synchronizing the state of the application instance with the user-record.
  • An association as used herein is some variation of symbolic linking or connecting of at least two associative elements selected from the set of a CV-person, a user-record, user-account, a device instance, and/or a human. More preferably, the association is a three-element association of a CV-person and a user-record with at least one of a user-account, a device instance, and or a human.
  • a CV-person is preferably detected and then matched to a corresponding identifying associative element.
  • the identifying associative element can be a device instance, human, or an identifier of a user-account. The identifying associative element may then be linked to a user-record.
  • An association with computing device infrastructure preferably includes an association with at least a user-record to which CV-based data modeling is connected. For example, a checkout list for a particular customer can be stored in association with the user-record. That checkout list (or other user-record related data) can be transferred in part or whole to a computing device.
  • An association that includes a human association as shown in FIG. 2 can provide positive confirmation of that human.
  • An association with a human can be through biometric detection of the human through the CV monitoring system.
  • a human association could also be indirectly established through biometric identification through a device/application.
  • a human association could additionally use other identifying properties of a human such as interaction patterns (e.g., shopping patterns), clothing patterns, patterns in accompanying humans, and/or other properties.
  • An association that includes a device instance association as shown in FIG. 3 can establish state synchronization with the device and/or application. Interactions with an app can influence the CV monitoring system and similarly detected information from the CV monitoring system can be pushed to the device or application instance.
  • An association that includes a user-account as shown in FIG. 4 can establish state synchronization with the user-account to leverage stored user associated data and settings.
  • Stored settings of an account can influence the CV monitoring system and similarly detected information from the CV monitoring system can be used to update the user-account.
  • An association with a user-record preferably provides a level of indirection between the CV-person and identifying associative elements so that CV modeling updates can be resilient to delays in establishing an identifying association or changes in associations.
  • An association is preferably maintained during the duration of the CV-person (e.g., duration of a shopper shopping in a store).
  • the association is preferably maintained across multiple visits to multiple stores—the association will generally be reestablished for each visit.
  • the system and method can facilitate the establishment and/or reestablishment of the association.
  • An association can additionally be expanded to include other associative elements. Elements of an association could however undergo permanent disassociation (e.g., removing a device instance) or temporary disassociation (e.g., disassociating a user-account for anonymous shopping during a single visit).
  • An association topology generally describes a collection of associations to different associative elements as shown in FIG. 1 . Different topologies may lend themselves to different capabilities. Different interaction experiences may also depend on or benefit from particular types of topologies.
  • the association topology may additionally involve the type of association that was established.
  • the type of association can be linked to different levels of identification confidence, privileges, or other aspects. For example, identification of a computing device using one technique may be treated differently from identification through another technique. Additionally, associations can be reinforced or occur at different times and/or locations to affirm the correct association.
  • understanding of associations can be applied longitudinally with the monitoring of a person, which is to say, an association established at one point in time could be applied to future occurrences or retroactively applied, even altering previous state based on the new association information.
  • the system and method could additionally be extended to providing shared digital experiences and interactions for groups.
  • multiple humans and/or multiple devices may have a shared digital experience as shown in FIG. 5 .
  • a family shopping together would be represented as multiple CV-people, but those modeled interactions may all be linked back to a shared family user-account.
  • the environment as used herein characterizes the site where a CV monitoring system is installed and operational.
  • the system and method can be made to work for a wide variety of environments.
  • the environment is a shopping environment such as a grocery store, convenience store, micro-commerce & unstaffed store, bulk-item store, pharmacy, bookstore, warehouse, mall, market, and/or any suitable environment that promotes commerce or exchange of goods or services.
  • the environment can include a household, an office setting, a school, an airport, a public/city space, a gym, and/or any suitable location.
  • the environment can be a locally contained environment but may alternatively be a distributed system with wide coverage.
  • the system and method may be used for any suitable video monitoring application.
  • the system and method is for CV-based computing applications, which may include automated self-checkout, inventory tracking, security surveillance, environmental event detection and tracking, and/or other suitable applications.
  • automatic self-checkout is used as the main exemplary application of the system and method, but any suitable application may be used.
  • Automatic self-checkout is primarily characterized by a system or method that generates or maintains a virtual cart during the shopping process of a customer (or group of customers) with the objective of knowing the possessed items when a customer leaves a store.
  • An automatic checkout system may additionally automatically charge an account of a customer for the total of a virtual cart (e.g., predicted list of items selected for purchase).
  • the automatic checkout system could alternatively be used to expedite entry of items for payment.
  • the system and method as described herein can be used to synchronize a CV-person and a resulting generated virtual cart (as detected in part or whole through the CV monitoring system) with a user-record, user-account, device instance, and/or a human. This could then be used to enable automatically charging of a stored payment method, authorizing purchase of restricted items (e.g., alcoholic beverages and the like), or execute other tasks.
  • restricted items e.g., alcoholic beverages and the like
  • the system and method may alternatively be used to account for the removal of a good by a customer such as in a library, a rental store, a warehouse, or any suitable item storage facility and update an associative element appropriately.
  • the system and method may alternatively be used to permit or restrict access to locations, to charge for such access, to enable authentication with shared computing devices, or for any use case.
  • the system can be made to work for a wide variety of shopping environments such as grocery stores, convenience stores, micro-commerce & unstaffed stores, bulk-item stores, pharmacies, bookstores, warehouses, malls, markets, and/or any suitable environment that promotes commerce or exchange of goods or services.
  • the system and method can also be used in other situations or in other environments.
  • the system is primarily described as employing a network of multiple video monitoring nodes.
  • the system could additionally be applied to a single camera and optionally audio monitoring and may additionally include other forms of sensing that may be used independently or in combination with video monitoring. These might include lidar, sonar, infrared, ultraviolet, radio frequency, capacitance, magnetic, scales, pressure, volume, climate sensing, and the like.
  • the system and method can be applied for synchronizing user-account data or application state of CV-based monitoring of a CV-person with encountered or used computing devices. This may even be performed independent of the user having ever used or downloaded an application for the checkout service before or creating a user-account for such a service.
  • This synchronization of state between a CV monitoring system and a device can be coordinated with a human's proximity to a device or usage of the device. In one example this may be used in coordinating communication of user-record data such as a virtual cart with store installed computing devices like a checkout station.
  • a virtual cart generated for a CV-person could be communicated to a POS system when the CV-person becomes associated with the POS system after the CV-person is within some spatial proximity of the POS system.
  • the system and method can be used to synchronize information with a publicly accessible kiosk when the human walks up and starts interacting with the kiosk. From the perspective of the human, the kiosk would seemingly automatically recognize them and personalize the interactions.
  • the system and method can provide a seamless user experience.
  • Data, information, and state collected using a CV-based monitoring system and/or other sensing systems can be automatically synchronized with a computing device when the person comes within a defined proximity of the computing device.
  • the system and method can enhance efficiency for many systems.
  • the checkout process can be made significantly faster by automatically feeding a checkout list to a checkout station.
  • the system and method can be integrated with existing systems of the environment.
  • the system and method can be integrated with the point-of-sale system used by the store.
  • a point and sale system is often deeply integrated into the operations of a store. Integrating with an existing point of sale system may offer a number of potential benefits: the existing point of sale can serve as a presumably reliable fail over system; workers may require only minimal amount of training if any; secondary systems built on top of or also integrated with a POS can remain operational such as couponing systems, loyalty rewards programs, inventory systems, and the like; support for a wide variety of custom systems or setups; and other potential benefits.
  • the system and method may have particular applications to provide longitudinal tracking through a CV monitoring system across time and space and applying the generated modeled data in connection to a particular computing device encountered in the environment.
  • selection of items by a customer throughout the store can be tracked and then applied when the customer approaches a computing device such as a checkout station.
  • a system for interfacing with a computing device from a computer vision system of a preferred embodiment can include a CV monitoring system integrated with an imaging system.
  • the CV monitoring system is preferably used within a computing platform 100 managing a user interaction experience.
  • the computing platform 100 will preferably include a data management system and other supplementary system elements of a computing platform 100 , service, or application.
  • the system may additionally include or interface with a user application and/or connected computing devices.
  • the system can include a proxy interface device 140 .
  • a CV monitoring system 110 functions to process and generate conclusions from one or more sources of image data.
  • the CV monitoring system no can provide: person detection; person identification; person tracking; object detection; object tracking; extraction of information from device interface sources; gesture, event, or interaction detection; and/or any suitable form of information collection using computer vision and optionally other processing techniques.
  • the CV monitoring system no is preferably used to drive CV-based applications such as generation of a checkout list during shopping, tracking inventory state, tracking user interactions with objects, controlling devices in coordination with CV-derived observations, and/or other interactions.
  • the CV monitoring system 110 preferably operates in connection to an imaging system 112 installed in the environment.
  • the imaging system 112 functions to collect image data within the environment.
  • the imaging system 112 preferably includes a set of image capture devices.
  • the imaging system 112 might collect some combination of visual, infrared, depth-based, lidar, radar, sonar, and/or other types of image data.
  • the imaging system 112 is preferably positioned at a range of distinct vantage points. However, in one variation, the imaging system 112 may include only a single image capture device.
  • the image data is preferably video but can alternatively be a set of periodic static images.
  • the imaging system 112 may collect image data from existing surveillance or video systems.
  • the image capture devices may be permanently situated in fixed locations. Alternatively, some or all may be moved, panned, zoomed, or carried throughout the facility in order to acquire more varied perspective views.
  • a computing platform 100 functions to coordinate or otherwise execute some application, service, or workflow.
  • the computing platform 100 facilitates executing a digital user interaction experience.
  • the computing platform 100 may facilitate a user interaction experience around or related to automated checkout and/or expedited checkout for customers.
  • the computing platform 100 may include local computing resources at the environment to coordinate with devices present in the environment.
  • the computing platform 100 may additionally or alternatively be remote computing resources wherein local computing systems in the environment communicate and coordinate over the internet (or other communication channel) with resources of the computing platform 100 .
  • the computing platform 100 preferably includes or otherwise interfaces with the CV monitoring system 110 , which functions to detect and model CV-people and/or other CV-based information.
  • the computing platform 100 may additionally include or otherwise interface with one or more associative element monitoring system, which functions to establish an association with one or more associative element.
  • the computing platform 100 can additionally include a data management system 130 , which functions to manage and maintain user-records and/or user-accounts or other data modeling resources to support the objectives of the system.
  • the association monitoring system 120 functions as an associative or synchronization mechanism to establish one or more forms of association with a human and/or a computing device.
  • the association monitoring system 120 is part of another system element such as the CV monitoring system 110 and/or for an application service of the computing platform 100 to coordinate with a computing device instance (e.g., a user app).
  • the association monitoring system 120 can be an active sensing or interrogation system such as a wireless communication system, an RF/NFC interrogator, Bluetooth beacon, an audio sensor system, a specialized CV monitoring submodule, specialized application service, or other suitable type of system.
  • the system may include an application service which functions to manage substantially real-time communication and interaction with application instances installed and operating on a user's device.
  • the system may include one identification system, but may additionally include multiple types of association monitoring systems 120 that can be used redundantly or cooperatively.
  • a wireless communication system can function to monitor and detect the presence of device signatures in the environment.
  • Multiple wireless communication units e.g., WiFi routers, RF/NFC interrogators, and the like
  • Their distributed location can be used to correlate the detection of a device signature with at least an approximate location.
  • Bluetooth beacons could be used in a similar manner.
  • a specialized CV monitoring submodule can perform some form of CV-based analysis to assist in detecting. In one variation, this may include performing biometric identification or classification of CV-person.
  • One specialized CV submodule could perform activity classification or modeling for a CV-person which could be matched to motion patterns detected from a special motion detection application service enabled on a device.
  • a CV monitoring submodule could detect particular gestures performed by a user.
  • Another specialized CV monitoring submodule could detect visual patterns displayed by a computing device. A variety of types of CV monitoring submodules may be use.
  • An audio sensor system may function to detect audible signals in the environment.
  • audio signals detected by a computing device could be mapped to audio signals detected by microphones installed throughout the store. This could be used in determining approximate location.
  • specialized and potentially nearly inaudible signals could be output by the computing device and/or speakers in the environment. Detection of these unique signals by the device and/or microphones distributed in the environment could function to determine location and thereby selecting a candidate pool of CV-people for a computing device.
  • the data management system 130 functions to store user-records and/or user-account information.
  • the system will generally include other elements to support the CV-based computing application and/or to provide a platform for CV-based computing applications implemented in multiple stores and/or for different use cases.
  • the user-records and/or user-accounts may be linked or otherwise pre-associated with one or more types of identifying associative elements. For example, CV-based identification of an individual may generate an identity signature that is associated with a user-record. In another example, an identifier for a particular device instance may be associated with a user-record such that when that device instance is detected in the store, the mapped user-record can be identified and accessed.
  • User Applications and/or connected computing devices function as client devices that may participate in CV-based computing applications.
  • a user application of the store and/or operator of the CV monitoring system no can be made accessible to users of the CV monitoring system 110 (e.g., customers of a store).
  • the user application can facilitate associating a user-account, providing biometric authentication through the device (e.g., fingerprint, voice recognition, facial identification or other forms of biometric authentication), collecting user input, and/or performing other tasks.
  • a connected computing device can be computing devices that may be installed or provided within the environment.
  • the connected computing devices may be customer service kiosks or stations, networked smart devices (e.g., smart lock, smart lights, etc.), a worker station, and/or any suitable computing devices.
  • a user application instance or a connected computing device are preferably addressable endpoints within the system such that the CV-system or an alternative component can transmit data or information can be communicated to the user application instance or the connected computing device.
  • An SDK and/or API may be provided such that third party applications can establish such integration with a CV monitoring system 110 and/or platform.
  • the system may additionally include computing devices installed within the environment.
  • the environment-installed computing devices are configured and directly integrated with the system and computing platform such that they can be accessed and controlled at least in part.
  • the system may include a proxy interface device 140 that functions as a gateway or edge device that facilitates communication and interactions with outside devices.
  • existing computing devices like a POS system could be used with the system without making direct changes to the existing computing devices.
  • the proxy interface device 140 of a preferred embodiment functions to be a system controllable device/resource that interfaces with environmentally installed computing infrastructure.
  • the proxy interface device 140 impersonates an expected form of data entry.
  • a preferred variation of the proxy interface device 140 is used to interface and augment an existing payment system.
  • the proxy interface device 140 is used expediting the checkout process by assisting in the entry of product information into an existing POS station.
  • the proxy interface device 140 may be used in assisting in delivering pre-authorized payment mechanisms so that a user could pay possibly without any explicit action (other than perhaps confirming payment/purchase).
  • Interfacing with an environment-installed computing device and/or a proxy interface device 140 would have applications in other areas as well.
  • a digital ordering kiosk could automatically bring up a customized ordering interface (e.g., showing customer order history, starred items, personalized recommendations, loyalty reward options) based on CV-based identification of the user.
  • a personalized user interface can be automatically presented based on CV-based identification of the user and/or previously tracked activity in the gym.
  • a check-in kiosk could be controlled to automatically enter ticket information.
  • a proxy interface device 140 preferably emulates an input device for a target computing device.
  • the proxy interface device 140 could be a keyboard or barcode scanner emulator (i.e., product entry emulator).
  • the proxy interface device 140 may alternatively communicate data that then uses an installed service to communicate with or otherwise interact with a target computing device.
  • a proxy interface device 140 preferably includes a communication module and a device interface module.
  • the proxy interface device 140 may additionally be delivered as an attachment device encased within a body structure.
  • the proxy interface device 140 may additionally include additional ports.
  • the proxy interface device 140 can include a product entry interface module so that the proxy interface device 140 can be connected between a barcode scanner and a checkout station.
  • the proxy interface device 140 communicatively couples the system (more specifically the CV-based monitoring system) with a computing device.
  • the computing device is a point of sale checkout station, but the communicatively coupled computing device could be any suitable type of computing device such as an informational computing kiosk or computing devices for other purposes.
  • the communication module functions to allow the device to be remotely controlled.
  • the communication module can preferably communicatively coupled with the CV-based monitoring system.
  • the communication module is preferably a wireless communication module where the wireless communication module can include Wi-Fi communication module, a Bluetooth or RF communication module, a cellular communication module, or any suitable type of communication module.
  • the communication module could additionally be a wired communication module wherein the proxy interface device 140 communicate over a wired or physical connection.
  • the communication module is preferably registered to the CV-based monitoring system.
  • the communication module can additionally be registered in association with a target computing device.
  • the location and/or target association could be registered during an enrollment period.
  • the proxy interface device 140 could be registered and manually, automatically, or semi-automatically associated with that location and connected computing device (e.g., a POS station).
  • the proxy interface device 140 could include an active or passive identifier to announce itself to the CV monitoring system for registration and location determination.
  • the device interface module which functions to communicatively connect or interface to one or more computing devices. In one variation this could be a wired connection.
  • the proxy interface device 140 connects to a POS station through a port typically used by a barcode scanner. In some implementations it may replace a connection of a barcode scanner. In other implementations it may be connected to the POS in addition to one or more barcode scanners.
  • the proxy interface device 140 and/or the computing platform more generally can wirelessly communicate with a computing device like a checkout station.
  • the proxy interface device 140 may connect to a checkout station through the device interface module using a standard electrical interface like a USB interface or other data port.
  • the proxy interface device 140 and more specifically the device interface module can generate and transmit the appropriate electrical signals for communicating with the checkout station.
  • Product entry module in a preferred implementation can transfer the universal product codes (UPCs) of the modeled checkout list. For some POS stations this can be UPCs communicated as simulated keyboard entries. These can be transferred in some serial sequence such that from the POS station it appears as rapidly entered products.
  • the product entry emulator may additionally include an interface to one or more product entry devices (like a barcode scanner or a keyboard) such that the product entry emulator can be used in line with such entry devices as shown in FIG. 13 .
  • the product entry interface module can be a corresponding communication port to that used by the device interface module. This is preferably used so that use of the proxy interface device 140 preserves the option of the checkout station from using existing infrastructure like a barcode scanner. Accordingly, the product entry interface module could be a female USB port. Data received through this port may be automatically relayed through the device interface module to the connected computing device. Additionally or alternatively, data received through the product entry interface module can be captured and/or optionally processed. In a preferred implementation, UPC data collected through the product entry interface module can be relayed to the connected checkout station, but also communicated to the computing platform. This can be used as training data for CV, AI, and/or machine learning algorithms. Especially since, product information received through the product entry interface module will generally occur when there was an exception or issue with generating a checkout list.
  • the proxy interface device 140 can preferably be encased in a rigid structure.
  • the proxy interface device 140 will additionally include a microprocessor or other form of processing unit along with memory, power system, and/or other suitable elements.
  • the proxy interface devices 140 may be used for each checkout station. Alternatively, a single proxy interface device 140 may interface and manage multiple checkout stations.
  • the proxy interface device preferably includes user interface elements.
  • the user interface elements are preferably provided to communicate with a user of the connected computing device.
  • the user interface elements can function to facilitate conveying system state and optionally collecting user input from a worker managing a POS station.
  • User interface elements may additionally or alternatively be configured for use by other users like a customer.
  • the user interface elements include one or more forms of a user interface output.
  • a user interface output could be a visual output, an audio output, a tactile output, and/or any suitable type of output.
  • a visual output could be some form of a visual indicators (e.g., LED lights or gauges) or even a graphical display.
  • an indicator light(s) could signal when a checkout list is transferred/received for updating a POS system.
  • the display could blink green when a customer's selected items are automatically entered into a POS station thereby signaling to the worker that they do not need to scan items for entry and proceed to finalizing payment.
  • the visual output could indicate when a checkout list cannot be automatically entered, if part of the checkout list can/was entered, and/or any other suitable exception.
  • a graphical display could visually display the virtual checkout items that were relayed or suggested for being relayed to a POS station. The worker may even be requested to verify the list and select an option to enter them into the POS station. Changes could be made if a mistake was made. These changes could be relayed back to the CV-based monitoring system as feedback for quality control and monitoring enhancements.
  • An audio output could be used along with a visual output or by itself.
  • An audio could be an audible tone or signal that triggers for different events. For example, there could be a tone or jingle that plays when a customer with valid checkout list approaches the “primary position” of the POS station (i.e., the person/group ready for checkout) which can indicate to the worker that they can skip the scanning/entry of items. Similarly, a tone may play when a checkout list is not available or not valid for entry, which can indicate to the worker that they should manually enter items selected by the customer.
  • the user interface elements could similarly include user input elements like buttons, dials, touch screens, microphone (for audio commands), and the like. These may be used in various ways to allow the worker to input information or communicate with the system. In one implementation, items are not automatically entered into a POS station until a worker positively confirms the items for entry.
  • a preferred variation of the proxy interface device is one that interfaces with a POS station for the purposes of relaying item information based on a checkout list generated by the CV-based monitoring system.
  • method for interfacing with a computing device from a computer vision system of a preferred embodiment can include detecting and tracking a human as a CV-person within an environment S 110 , establishing a user-record associated with the CV-person S 120 , modeling interactions of the CV-person as modeled data that is associated with the user record S 132 , detecting the CV-person in proximity to a computing device in the environment S 140 , and transmitting modeled data associated with the user-record to the computing device S 150 .
  • Block S 110 which includes detecting and tracking a human as a CV-person within an environment, functions to establish a CV-person within an environment.
  • Block S 110 is preferably implemented through or in connection with a CV system, which could be part of a computing platform such as was described above.
  • Detecting and tracking a human as a CV-person preferably includes collecting image data and applying person detection computer vision processing to the image data.
  • Image data is preferably collected and then processed by the CV system.
  • the CV system can acquire the human as a CV-person. That CV-person can be tracked during the human's time in the environment. Continuous tracking may be maintained, but the system could additionally handle discontinuous tracking where tracking of a CV-person may be lost temporarily and then reacquired. Modeling of a CV-person is preferably abandoned, expired, or made inactive after the CV-person exits an environment.
  • Detection and tracking are preferably facilitated through various computer vision approaches.
  • tracking may be achieved through a visual “lock”, wherein movement between frames of a detectable CV-person can be tracked.
  • a physics or modeling system can be introduced to facilitate tracking the CV-person across frames and to recover when a user is temporarily or partially occluded.
  • Human identification can include biometric identification such as facial identification, gait identification, voice identification and the like. Human identification may additionally include more general characterizations of a human such as visual properties, clothing properties, height and weight estimations, age estimation, and/or possession properties (e.g., holding a bag, using an identifiable shopping cart, etc.). Human identification can be used to uniquely identify a human but may additionally be used to reduce the possible candidates of if not uniquely identifier the identities of humans within an environment. Tracking a CV-person could use human identification to assist in reacquisition of that CV-person.
  • the CV-system can additionally provide additional CV-based analysis of the image data such as object detection, object-human interaction detection/classification, human gesture detection, and/or other suitable forms of CV-based modeling based in part on the image data.
  • object detection object-human interaction detection/classification
  • human gesture detection and/or other suitable forms of CV-based modeling based in part on the image data.
  • the items selected by a CV-person and/or added to a cart of a CV-person can be added to a checkout list, which can be modeled and stored in association with that CV-person.
  • the CV system can sense and generate predicative models based on image data and supplementary data sets (e.g., shopping history, user profile information, product information, etc.).
  • the CV system may additionally work in combination with other sensing systems such as a smart shelving system with sensors, an RFID sensing system, 3D spatial sensing system, and/or any suitable type of environmental sensing system.
  • the method may operate based on detected and tracked mobile computing devices.
  • the detected computing device will generally be a personal computing device such as a mobile phone, a wearable computer, or some other type of computing device.
  • the detected computing device could alternatively be a non-personal computing device such as a computing device provided by the operators of the environment.
  • a smart shopping cart or basket may be used in place of a personal computing device.
  • Detecting and tracking a mobile computing device may be used in combination or independently from detecting and tracking a CV-person.
  • some variations described herein could alternatively be performed where a detected computing device (that will generally have some form of relationship to one or more users) can be used in place of a CV-person.
  • an application that enables user-managed scanning of items within a shopping environment may be detected and it's proximity to a checkout station tracked to facilitate transfer of a generated checkout list to the checkout station.
  • Block S 120 which includes establishing a user-record associated with the CV-person, functions to link or set a user-record to be associated with a CV-person.
  • the user-record could be set by default and used to collect or model CV-based observations of the CV-person.
  • Exact data model architecture could be approached in a variety of ways and in some implementations, there may be no explicit distinction of a user-record from the CV-person.
  • the CV-person data model may serve as the user-record. Without additional association information, the identity of the corresponding human may not be identified or linked, personal computing devices of the corresponding human may not be linked, and/or other historical data beyond what was tracked in this session by the CV-based monitoring system may also not be linked.
  • a user-record and/or a user-account may establish an association with the CV-person using a variety of associative/synchronization mechanisms. This may enable human identification (e.g., for the purposes of monitoring across visits to the environment), verified human identification (e.g., affirmative confirmation of the identity of a human), interfacing with another device instance (e.g., a computing device of the human), and/or access to a user-account.
  • the variations described in illustrate optional association channels through which an interaction experience like checkout could be further enhanced or enriched.
  • Block S 120 which includes establishing an association between the CV-person and at least one associative element, functions to synchronize and/or link a computer vision derived model of a human to at least one other data model related to the human.
  • at least one association is established to an associative element.
  • This associative element may function as a human identifier or entity identifier.
  • this human or entity identifier could be token-based (e.g., like a device associated with the human), biological-based, or pattern-based (e.g., behavioral pattern detection).
  • the method is preferably executed so as to establish an association with a user-record and/or user-account.
  • associations may be established for a particular human.
  • multiple associations may be established at different times, which can work to provide multiple factors of identification and/or to appropriately augment the confidence of a mapping between a CV-person and a user-record.
  • These associations can additionally act as additional factors in having high confidence in other associations like when associating a CV-person with environment-installed computing devices like a checkout station.
  • Some forms of associations may enable particular functionality. For example, restricted products like alcohol could be permitted for purchase by using a validated identity established through forming some form of human identity association.
  • Establishing an association with a user-record and/or user-account is preferably established through at least one identifying associative element like a device instance, application instance, and/or a human identifier.
  • One or more associative mechanisms may be used to establish the association.
  • the identifying associative element With an association established to an identifying associative element, the identifying associative element can be used to indirectly establish an association with an appropriate user-record or user-account.
  • the user-record or user-account can be stored and queried using a key, identifier, signature, or properties acquired from the identifying associative element.
  • block S 120 will generally include establishing an association between the computer vision modeled person and at least one associative element and thereby associating the computer vision modeled person and a user-record linked through the associative element. Effectively, the method establishes a three-element association between: a CV-person; one or both of a user-record and user-account; and at least one of a device instance, an application instance, and/or a human identifier.
  • An association to a user-record which may specifically be a user-account, can expand the understanding of a CV-person to platform-managed data and/or to a historical record of the human entity.
  • payment information, shopping history, personalized loyalty program rewards, and/or other information may be exposed for use in combination with CV modeled data.
  • An association to a user-record is preferably made in connection with some identifying association such as with a device instance association or association with human identity.
  • An association to a device instance can facilitate identifying a human associated device.
  • the association with the device instance may further enable a communication link between the CV monitoring system and a device and/or application that is accessible to the corresponding human.
  • An association to a human identity may enable authentication of the identity of the human corresponding to the CV-person.
  • an association to a human can be performed directly through CV-driven analysis of the CV-person.
  • biometric identification may be used.
  • authentication and more specifically biometric authentication may be facilitated by an accessible computing device such as a personal computing device or kiosk using biometric authentication.
  • Establishing an association with a CV-person can involve the use of one or more associative mechanisms for establishing associations. Different associative mechanisms may have different levels of reliability, security, and/or be usable for adding associations to different associative elements. A subset of these associative mechanisms may be classified as system initiated associative mechanisms and another subset of associative mechanisms may be classified as user-initiated associative mechanisms. Establishing an association may involve executing variations of such associative mechanisms as shown in FIG. 7 .
  • System-initiated associative mechanisms can leverage natural conditions without depending on some form of active user participation to work.
  • System-initiated associative mechanisms can be used in automatically establishing at least part of an association. They will generally operate in the background and may be transparent to a user.
  • System-initiated associative mechanisms may be used in establishing an association automatically—possibly without active participation by a human at the time of association.
  • Three potential types of system-initiated associative mechanisms can be biometric, passive, and active.
  • a biometric type of system-initiated associative mechanism preferably uses biometric input collected in real-time from a CV-person in the environment. This biometric identification can preferably be performed remotely through the image data used by the CV monitoring system. Biometric identification may be used in combination with other associative mechanisms to increase the confidence in biometric identification. For example, using device signature detection and/or gross device location information, the candidate pool of user identities can be reduced such that the confidence in biometric identification can be made more resilient.
  • a facial recognition CV process could be configured to identify a face out of a pool of 300 candidates near the store location as opposed to millions of potential candidates encountered at some time across many sites.
  • a passive type of system-initiated associative mechanism can be an “always on” technology that is typically exposed by a computing device carried by a human. These signals may be unique to each device or at least provide distinguishing features within a limited sample of devices, and therefore can be used to form connections between devices and CV-persons with a relatively high degree of certainty. Passive associative mechanisms may not establish a positively confirmed association in some situations since devices can be shared or stolen, but passive background device detection may be used to establish a probabilistically likely association and/or to narrow the scope of associative elements for other association techniques like the automatic biometric analysis above. Such signals can include WiFi, Bluetooth, MAC addresses, cellular signature and the like. Such signals may not be 100% accurate associations because smart devices can be shared or stolen by different humans.
  • Such signals can at least be useful with humans during a single visit. They may additionally be useful device signatures for humans with a personal computing device but without an installed application and/or without a user-account.
  • a human without installing a user application on their smart device can have a smart device passively facilitate associating a CV-person to a device instance and by association a user-record with purchase history and payment information.
  • An active type of system-initiated associative mechanism may be some user installed or initiated technology, which, in some cases, can affirmatively link CV-people with a computing device.
  • This variation of system-initiated associative mechanism may operate without explicit device usage by a human while in the store. However, they may depend on installing an application, installing or enabling a service.
  • Bluetooth LE beaconing, background app refresh, geofencing, GPS or relative GPS, other location services, and/or other device functionality may expose signals by which a device could be detected and associated with a user-record or user-account.
  • Use-initiated associative mechanisms can include an associative mechanism dependent on user action.
  • One variation can be device-based initiation.
  • Other forms of user-initiated associative mechanisms can be various forms of user check-ins.
  • Some preferred associative mechanisms could include detecting a human associated device instance S 121 and/or collecting real-time image data of a CV-person in the environment and applying a form of biometric identification S 125 , and/or receiving registration at a registration device S 126 .
  • Some preferred variations of detecting a human associated device instance S 121 can include: detecting a device signature exposed by devices carried by a human S 122 , detecting a device usage-mechanism explicitly or implicitly enabled by a user S 123 , and establishing an association during a pairing process of a device instance S 124 .
  • Block S 121 which includes detecting a human associated device instance functions to use the presence of an identifiable device to establish an association.
  • Block S 121 will generally involve: through a device identification system, detecting a device instance coincident to the CV-person and then selecting a user-record by an identifier of the device instance. This functions to associate the CV-person, the device instance, and the user-record.
  • the device instance could be some human identifiable device such personal computing device like a smart phone, a personal computer, a wearable computer, and the like.
  • the device instance could alternatively be an instance of an application installed on a device, a browser session, or any suitable client detectable and associated with a user.
  • the device instance could be a shared environment-installed computing device.
  • a shared computing device will have shared usage by multiple users at different instances.
  • a shared computing device may be directly used by the human when establishing the association (e.g., an informational kiosk or self-checkout station).
  • the shared computing device may alternatively be used to serve a particular human when establishing the association (e.g., a worker-staffed checkout station).
  • the condition of coincidence characterizes some form of associated proximity, which could include spatial proximity and/or temporal proximity.
  • a device instance may be spatially coincident when the device instance is detected in a location that corresponds to a modeled location of the CV-person. Detection of a device is preferably isolated to a particular region or location. This location can be mapped to a corresponding location in the environmental model of the CV-system. If a CV-person is detected in the corresponding location, an association can be established between the device and the CV-person. Depending on the spatial resolution of either the device instance or the CV-person, different thresholds of proximity may be used.
  • gross spatial proximity e.g., detected within 50 feet range of each other
  • a device may be temporally coincident when the device instance is detected within a similar time window. For example, if a device instance is detected in the environment within one minute of detection of a CV-person then those could be paired.
  • device detection may occur at multiple locations in an environment and a CV-person association to a device instance can be established through longitudinal analysis of past instances of device detection. This can include looking at the tracked movements of a device instance, analyzing the sets of candidate device instances and CV-people, and/or using other suitable techniques. For example, a device may be detected at the entrance of a store. However, there may be multiple candidate CV-people so a confirmed association may not be established initially. The same device instance may be detected at a second location. Even if the number of candidate CV-people is still large, the CV-people detected at the entrance and the second location can narrow the candidate CV-people.
  • Detecting a device instance may be used in identifying and selecting a corresponding user-record associated with the device instance.
  • the device instance may provide some distinguishing key or identifier by which a user-record stored in association with that identifier can be found and accessed.
  • the detection of a device instance can be used to re-establish a previous user-record. This accessed user-record can be merged with or replace a current associated user-record.
  • a device instance may be used in establishing an association with a user-account.
  • the application instance may be associated with a user-account (e.g., if a human has signed into their account within the application), wherein, establishing association to a device instance will by association establish a user-account association.
  • using a device instance to establish an association with a user account may include authenticating a user-account at the device instance; selecting a user-record based on the user-account authenticated on the device instance when the device instance is detected.
  • the computing platform will generally have access to the device instance and therefore could map the user-account logged into the particular device instance with the CV-person.
  • a device instance and/or an application instance can facilitate human identification and so may be establish a validated association with a human.
  • This human association with the application instance can be transferred to an association with a CV-person as well.
  • fingerprint identification, facial identification, voice identification, or other forms of biometric identification performed within the application instance can establish human identity association.
  • the block S 121 may include detecting a device signature exposed by devices carried by a human S 122 , detecting a device-usage mechanism explicitly or implicitly enabled by a user S 123 , and/or establishing an association during a pairing process of a device instance S 124 .
  • Block S 122 which includes detecting device signatures exposed by devices carried by a human, functions to facilitate passive background device detection. Passive background device detection is preferably used in establishing an association to a device instance through exposed communication device signatures.
  • Device signatures preferably include communication signals from a device that are generally unique to a device and therefore can be used to form associations between a device instance and a CV-person.
  • a device signature can be detectable properties or identifiers exposed over Wi-Fi, over Bluetooth, through MAC addresses, through cellular signals, and/or other exposed emissions.
  • Block S 122 can preferably operate as a system-initiated associative mechanism, and may be used to assist providing enhancement functionality to users even if they are not registered or enrolled with a user-account.
  • Block S 123 which includes detecting a device usage mechanism explicitly or implicitly enabled by a user, functions to facilitate user-enabled background device detection. There are various options that when activated by a user will facilitate automatic establishment of associations of that particular user. In one variation, a user may explicitly enable geofencing to automatically detect when they enter a store.
  • a user may implicitly enable a detection mechanism by registering a user-account to access Wi-Fi in the environment.
  • a user may enable kinematic monitoring for synchronizing human motion to CV-person motion. These options may depend on a user installing an application and/or enabling or confirming particular device permissions.
  • User-enabled background device detection can be performed substantially similar to passive background device detection described above.
  • user-enabled background device detection may use detection approaches like Bluetooth LE beaconing, background app refresh, geofencing, LED positioning, GPS, relative positioning in the environment, and the like.
  • the system may be actively notified when the device instance is present in the environment.
  • that device instance and previously associated humans, user-accounts, and/or user-records may become candidates for associations with a CV-person.
  • detecting the device instance can include detecting location and/or presence of an identifiable device instance.
  • a CV-person can be mapped to and associated with a device instance when there is a unique correspondence of coincidence across a set of detection events as shown in FIG. 8 .
  • the detected device instance and CV-person can be associated.
  • a CV-person can be associated with the device instance if the CV-person is the uniquely present CV-person in the regions of the various beacons at the time of the detection events.
  • detecting the device instance can include detecting location of a device instance within the environment, and associating the device instance to a CV-person modeled with a corresponding location as shown in FIG. 9 . Multiple samples of location and/or the change in location can additionally be used. In a manner similar to the Bluetooth beaconing approach, sampling across many regions can be used to reduce a pool of candidate CV-people down to one selected CV-person.
  • the method may include, at the device instance, sensing device motion and/or orientation.
  • This device motion and/or orientation can then be used in a variation where block S 123 includes detecting an associated device instance with device motion that satisfies a synchronization condition with activity of the CV-person.
  • motion of the device instance is matched to CV-person motion.
  • An inertial measurement unit which can include accelerometers, gyroscopes, magnetometers (for direction), and/or other sensors may detect motion like walking motion, stops and stops, hand motion, body orientation changes, and the like. By comparing these actions to motion and orientation properties of a CV-person, a CV-person can be linked to a corresponding device instance.
  • Use of motion as a synchronization mechanism may be dependent primarily on coincidence in time and may not factor in location though location can additionally be used.
  • establishing an association may initiate confirming of the association, which functions to trigger user affirmation to establish an association.
  • Confirming an association can include requesting confirmation through communication to a human (generally through a device instance).
  • an association may include a confirmed or possible association to a device instance. That device instance may have a communication address (e.g., phone number, application instance identifier, push notification endpoint, etc.).
  • a message or notification can be transmitted to the communication address, and a human can confirm or deny the request.
  • the method can proceed with establishing the association.
  • the possible association may involve a user-record or a user-account, which may have a configured communication address like a phone number of application instance identifier. A message or notification can be similarly transmitted.
  • Confirmation may request explicit confirmation by a human.
  • a human may receive a text message saying, “Looks like you are at the supermarket. Replay 1 for yes and 2 for no”.
  • a confirmation may alternatively notify a human but require explicit denial to cancel/prevent the association.
  • a human may receive a push notification saying “Enjoy your shopping experience today! Select cancel if you received this in error”.
  • a confirmation may alternatively be automatically approved if a human selects a user-account option to not confirm new sessions. Confirmation could similarly be applied before performing particular interactions that depend on an established association. For example, a user may receive a push notification on an application asking if they want to automatically push checkout list information to a checkout station when they are within proximity.
  • Block S 124 which includes establishing an association during a pairing process of a device instance, functions to have a device or more preferably an application facilitate establishment of an association.
  • a physical computing device may be designed to enter a pairing mode or continuously perform some pairing action.
  • the pairing mode may be configured to generate an identifying signal through a user interface output of the device instance.
  • the graphical display and speakers may both generate signals usable to detect a device.
  • sensed data may be collected and used during the pairing mode.
  • an application instance installed on a user device can be actively involved in performing actions that may enable unique detection of that application instance by the CV-system and thereby be associated with a CV-person.
  • the pairing process of an application instance is described but it similarly applies to a device instance.
  • the pairing process is preferably initialized when the application instance becomes active (e.g., is brought into the foreground of a modal operating system). Activation of the application instance can result in the application instance registering the pairing state of the application instance with the CV monitoring system such that the CV monitoring system can begin to cooperatively establish an association.
  • one or more signaling mechanisms may be used.
  • the examples of signaling mechanisms can include use of a camera, a display or visual output, an audio system, an inertial measurement unit (IMU), application interactions, and/or stored data.
  • an application instance can use the camera of the computing device to capture an image that can then be used to determine position.
  • various visual identifiers e.g., a QR code or data encoded image
  • Capturing image data from the application can be used to determine the position of the human operating the application when the image data contains the visual identifier.
  • the human operator of the application may be directed to take a picture of a cart of selected items or some other artifact, which can be used as an identifier.
  • the camera may be activated in the background with the goal of observing the scene. This activation of the camera may be based on detected orientation of the device (e.g., is the device being held up by human). Observations of the scene can act as a visual signature that can be mapped to images captured by the CV monitoring system as another approach to locating the device within the environment.
  • an application instance may capture images while the user is using the application. If an image of a shelf of items is captured, that image can be used to determine the location of the user within the store and thereby associate the application instance with a CV-person.
  • Visual identifiers may be integrated into the environment such as on the ground, ceiling, shelving, walls, and the like to enhance mapping of visual signatures and positioning within the environment.
  • an application instance can use the display or other mechanisms for visual output in pairing an application instance with a CV-person.
  • the display of a smart device can be set to display a visual identifier.
  • the visual identifier can be a static graphic but could alternatively be a time variable visual display.
  • the application instance communicates with the system so that detection of that visual identifier by the CV-system can be associated with the application instance.
  • the imaging system used by the CV monitoring system will preferably be able to identify the displayed identifier and map an appropriate CV-person to the application instance.
  • a visual identifier could alternatively be produced by other device elements such as an LED light.
  • an application instance can use the audio output in pairing an application instance with a CV-person.
  • An audio signal is generated with a unique identifier. Detection of that audio signal can then be used to determine location and then used in selecting candidate CV-people.
  • the audio signal is preferably in a frequency range on the edge or beyond the hearing range of a human, but could also be a sound audible by a human.
  • the application instance generates the audio signal and microphones distributed within the environment can detect the audio signal.
  • the microphones are associated with a general region within the environment or may be used in triangulating a more precise location.
  • speakers distributed across the environment generate audio signals that can be detected by an application instance. Each speaker preferably produces a unique audio signal such that the detected audio signal can be mapped to a positioned speaker and/or a location. Detection of multiple audio signals may be used to triangulate a more precise location.
  • an application instance can use movement of the device as detected by an inertial measurement unit in pairing an application instance with a CV-person.
  • the inertial measurement unit can include a digital accelerometer, gyroscope, magnetometer, and the like.
  • the movements, orientation, and/or direction can be monitored to establish human movements.
  • the CV monitoring system can similarly detect CV-person movements for candidate CV-people. CV-people with corresponding movement patterns at a similar time can be associated with the device instance.
  • an application instance can use application interaction as a mechanism for pairing an application instance with a CV-person.
  • An application interaction may be used by detecting human operation of the application and using the CV monitoring system to detect candidate CV-people performing similar actions.
  • Application interaction may be used passively, which preferably use normal interactions with the application instance as CV-detectable actions.
  • the application instance may require a human to perform a check-in action to use an automatic self-checkout feature.
  • the act of pulling out a smart device and pressing a check-in button on the application instance can be detected as actions performed by a CV-person.
  • the timing of activating the check-in button as detected by the application instance can be used to determine CV-people performing that action in synchronization with that act.
  • block S 120 can include directing a physical action by the user and detecting a corresponding physical action of the CV-person.
  • the device instance can be associated with the CV-person.
  • Application interactions may be actively directed by the application instance where an application instance instructs a human to perform some action or gesture such as waving his or her hand, holding out the smart device, pointing at an object, or any suitable action. These human gestures may be more detectable than interactions with the application instance.
  • the timing of the actions can be orchestrated by the application instance. Additionally, the nature of action may be controlled and changed to help in establishing the association. For example, different types of actions may be directed so that the type as well as location and timing can better establish an association with high confidence. Device movement as discussed above can similarly be used in combination with directed actions.
  • Establishing an association during a pairing process of a device instance may additionally or alternatively use collected information from the application instance.
  • a pairing mode is activated, preferably by the human, then the system may begin using stored information associated with the application instance and/or account to establish an association.
  • the CV monitoring system can compare that shopping list to the checkout lists of current CV-people.
  • a CV-person detected to have some subset of the shopping list may be associated with that application instance as shown in FIG. 10F .
  • Shopping history, favorited products, and/or other information can similarly be used.
  • Block S 125 which includes collecting real-time image data of a CV-person in the environment and applying a form of biometric identification, functions to facilitate automatic biometric analysis of a CV-person.
  • biometric identification techniques may be used such as facial identification, gait identification, retina identification, physical property identification (e.g., height, weight, gender, etc.), and/or other forms of biometric identification.
  • Biometric analysis may be used to establish a human association when a unique human identity is determined. Automatic biometric analysis may additionally establish associations with other associative elements like a user-record.
  • biometric identification sensing capabilities of a computing device may be used when a computing device can be communicatively coupled and associated with a CV-person (e.g., using one of the approaches above).
  • This variation can include, at the device instance, receiving biometric identification; and associating human identity confirmation with the modeled person and user-record.
  • Receiving biometric identification can act to confirm or specify the human identify of the current user of the computing device.
  • Receiving biometric identification could include checking a fingerprint, facial pattern, voice, vital sign (e.g., heart rate, respiration rate), and/or any suitable biometric identification. These may be provided on a personal computing device or some shared computing device like a check-in kiosk in the environment.
  • Block S 126 which includes receiving registration at a registration device, functions to establish an association during active registration of a user-record, user-account, human, and/or application instance.
  • the registration device can be a kiosk or check-in station installed in the environment.
  • the human will preferably perform some interaction with the registration device to establish an association.
  • the mode of registering at the registration device can take many forms such as swiping/scanning a card (e.g., a payment card), presenting NFC device, QR code or barcode scanning, biometric scanning, entering of account credentials, entering a pin code, and/or any suitable action.
  • a registration device could additionally include biometric sensors for establishing human associations. Some of these registration techniques may not require possession of a device instance and/or other physical tokens.
  • Location of the registration device(s) and proximity of a CV-person during the time of registration can be used to associate with a CV-person.
  • the method may use registration regions where some registration can occur without a physical registration device.
  • the mechanism for establishing an association can be one or more of the mechanisms described herein. In some cases, multiple association mechanisms are used in combination to narrow a pool of candidate CV-people to a single confirmed CV-person.
  • the method can additionally redundantly confirm associations as a form of multi-factor authentication to enhance accuracy, reliability, and/or security.
  • establishing an association can include progressively attempting a sequence of association mechanisms. When one association mechanism does not succeed, a backup association mechanism can be used. The sequence of association mechanisms may start off with less intrusive user experiences and then escalates to association mechanisms with higher reliability but possibly more reliance on human participation.
  • establishing an association to an application instance can initialize by passively using the location of the application instance and identification of a displayed static graphic.
  • the application may escalate to displaying an animated graphic with instructions to hold their phone outwards with display up. If an association is not established again the application instance can start an audible jingle while flashing an LED light. If an association is still not established, the application instance can direct the user to use a check-in station. From the user perspective, this pairing process can be presented as a seamless pairing process that slowly builds up. Ideally, an association is established quickly so that most users do not experience the more obvious association mechanisms.
  • association may depend on the associative elements, mechanism for establishing associations, and/or user selected options.
  • There could be an anonymous association where a CV-person is treated as a generic user.
  • There could be an incognito association mode where information and capabilities enabled by associations to a user-record, user-account, application record, and/or a human may be used but where the session is not committed to the data records of those associations within the system.
  • Associations are preferably established prior to performing some action requiring permission confirmed through the association.
  • associations are established in response to nearing or entering an environment.
  • the method can support retroactively applying an association.
  • the method can support establishing an association immediately prior to the human entering the store and being acquired as a CV-person, immediately before a transaction during an automatic self-checkout, and/or in conjunction with the transaction.
  • Associations can additionally be built up during the duration of the time that the human is in the environment, wherein establishing an association can include wherein establishing an association through multiple associative mechanisms performed at different locations and times in the environment.
  • a CV-person may initially be associated with a user record, then an application instance can be added and then a human association. Associations can additionally happen after a CV-person has left the store where actions like a billing transaction can happen in absentia. This can even happen over multiple visits to the environment by a human. For example, a shoplifter that later creates a user-account may have previous activities and illicit behavior retroactively associated with the new user-account.
  • Block S 132 which includes modeling interactions of the CV-person as modeled data that is associated with the user record, functions to sense information about the CV-person.
  • modeling interactions of the CV-person comprises modeling a checkout list of items selected by the user in the environment. Modeling a checkout list, functions to generate list of items selected by a human.
  • the checkout list is at least partially based on CV-based monitoring of the CV-person.
  • the CV-based monitoring can be stored in association with the user-record such that established associations with a computing device can leverage user-record information such as current checkout list/virtual cart.
  • the CV monitoring system can additionally provide additional CV-based analysis of the image data such as object detection, object-human interaction detection/classification, human gesture detection, and/or other suitable forms of CV-based modeling based in part on the image data.
  • object detection object-human interaction detection/classification
  • human gesture detection and/or other suitable forms of CV-based modeling based in part on the image data.
  • the items selected by a CV-person and/or added to a cart of a CV-person can be added to a checkout list, which can be modeled and stored in association with that CV-person.
  • the CV monitoring system can sense and generate predicative models based on image data and supplementary data sets (e.g., shopping history, user profile information, product information, etc.).
  • the CV monitoring system may additionally work in combination with other sensing systems such as a smart shelving system with sensors, an RFID sensing system, 3D spatial sensing system, and/or any suitable type of environmental sensing system.
  • Checkout lists may alternatively be generated and associated with a user-record in other ways. For example, a customer may use an application to scan items for purchase and self-populate a checkout list. In this variation, the CV-person may not be tracked throughout the environment and only in the region of a computing device of interest.
  • Block S 132 is preferably part of managing state and/or modeled data in association with the user-record S 130 , wherein the origin or nature of the modeled data can vary. Accordingly, the method may additionally or alternatively include managing user-record data in association with the user record S 134 , collecting user input through an associated application instance of the user-record S 136 , and/or other suitable variations.
  • Block S 134 which includes managing user-record data in association with the user record, functions to use other types of data associated with a user-record.
  • the data may originate from user history data, user preference/configuration data, data or state information from a device associated with the user-record/user-account.
  • the user-record data could include payment mechanism data which can be transferred or otherwise used with a payment-oriented computing device so that a person could pay by approaching the computing device.
  • the user approaches the payment device, the balance is entered in some manner (possibly also provided through the CV monitoring system), the user is presented with the checkout information and asked to confirm payment using this synchronized payment mechanism, and a payment transaction is executed with the payment mechanism if the user provides confirmation.
  • Block S 136 which includes collecting user input through an associated application instance of the user-record, functions to use user interface input, sensed data, or other data generated at a user-controlled device to be delivered to a target device.
  • a target device For example, a user may walk up to a payment kiosk, and the payment kiosk may ask for some form of user input which is then requested and provided through an application operable on the user's personal computing device.
  • a similar variation of the method can be applied so that user interface input, sensed data, state information, or other data generated at a target computing device can be delivered to a target device.
  • state and/or data from a target device is relayed to a user device/application.
  • Some variations may support a bi-directional flow of data between two computing devices (e.g., a target device and a user device).
  • Block S 140 which includes detecting the CV-person in proximity to a computing device in the environment, functions to establish an association between a detected computing device and a CV-person. This preferably establishes a multi-element association of a detected computing device, a CV-person (and CV-modeled data or events), and a corresponding user-record. This may further be used to establish an association with another computing device (e.g., a personal computing device of a user), a user-account, and/or a human-identity.
  • Another computing device e.g., a personal computing device of a user
  • a user-account e.g., a user-account
  • human-identity e.g., a human-identity
  • the computing device can be a kiosk, a computing station, networked smart device (e.g., smart lock, smart lights, smart scales, etc.), and/or any suitable computing device.
  • the computing device in the environment can a checkout station used to perform a checkout process. At or near a checkout station there is generally a line of people waiting to checkout. Various rules, heuristics, and autonomous processes can be used in checking a proximity condition.
  • a checkout station there will generally be a single CV-person that can be associated with at one time. This will generally be the CV-person modeled within some defined payment region and/or closest to a defined payment point of the checkout station.
  • the locations of the checkout stations may be preconfigured within the CV monitoring system so that analysis on CV-people in near proximity can be isolated to that segment of image data.
  • a computing device may be dynamically detected and located within the environment. Furthermore, the identity of the computing device is detected or known so that association can be established with the correct computing device.
  • a defined space possibly marked on the floor could be used in indicating who is able to associate and synchronize with a checkout station.
  • the conveyor belt of a checkout station, the items on that checkout station, and the divider used to mark separation between customers could be monitored, analyzed, and used in determining who has the primary position of proximity to the checkout station.
  • the next customers items move towards the front of the conveyor belt.
  • Detecting removal of the divider for example could be used trigger associating that corresponding user-record and synchronizing the checkout list with the checkout station.
  • a worker may provide some form of explicit user input to mark when and who should be processed and synchronized with the checkout station.
  • association with a checkout station may not be limited to a single user-record/checkout list. Multiple individuals in a defined region may have a checkout list synchronized with a checkout station. For example, a family shopping together would be represented as multiple CV-people, but those modeled interactions and resulting checkout lists may all synchronized with a checkout station when the family moves to a defined payment region.
  • Block S 150 which includes transmitting modeled data associated with the user-record to the computing device, functions to communicate with an associated computing device.
  • This synchronization of data preferably synchronizes data specific to the CV-person and/or device instance. Data and information can flow in one direction from user-record related data, but data and information could similarly flow in multiple directions.
  • this synchronization with a computing device is preferably simultaneously orchestrated by a computing platform across multiple humans.
  • the computing platform can communicate the modeled data directly to the computing device through a wireless or wired connection as shown in FIG. 12 .
  • the computing device may have an exposed interface protocol through which the computing platform can use.
  • the computing platform can communicate the modeled data indirectly to the computing device by communicating modeled data to a proxy interface device as shown in FIG. 13 .
  • the proxy interface device preferably relays that data to the targeted computing device.
  • the proxy interface device can use an exposed interface to gain interactive access to the computing device.
  • the computing device can be a proxy interface device and the modeled data can include a checkout list.
  • the method will preferably include relaying an itemized checkout list data to the checkout station.
  • the proxy interface device can simulate a barcode reader and enter UPC information.
  • the checkout list is preferably received at the proxy interface device, and then it may be relayed through a device interface module as a series of UPC codes entered as simulated keyboard entries. This functions to emulate a barcode scanner or a keyboard for product code entries. Other suitable protocols could alternatively be used.
  • the proxy interface device may additionally connect to a product entry device like a barcode scanner or a manual product code entry tool like a keyboard.
  • the proxy interface device can be communicatively coupled with the product entry device.
  • the method can include relaying the item data to the checkout station. This functions to maintain normal operation of the product entry device—the scanning information passes through.
  • the proxy interface device can process and use the item data received from a product entry device. Accordingly, the method may additionally include upon receiving item data from the product entry device communicating the item data to the computing platform.
  • the modeled data could be payment details linked to a user-record (or more generally a user-account).
  • the payment details could be transferred as shown in FIG. 14 .
  • the computing device and/or the proxy interface device can be a digital payment transmitter which is configured to transfer payment details (e.g., payment mechanism tokens) digitally at a point-of-sale device.
  • a proxy interface device may emulate some payment mechanism behavior such as emulating an NFC payment mechanism or emulating a present credit card.
  • the proxy interface device is preferably addressable based on the desired checkout station. In the event a proxy interface device connects to multiple checkout stations, communication with the proxy interface device can specify a checkout station identifier/address.
  • the method may additionally include altering the proxy interface device depending on the state of association. Updating a user interface output at the proxy interface device can facilitate communication of machine state to a human (e.g., worker and/or a customer).
  • the user interface output can be used to indicate if and when modeled data was transmitted, the nature of that transferred data, and/or other information.
  • a user interface output can communicate if modeled data (e.g., a checkout list) was successfully transferred and/or if modeled data was not successfully transferred.
  • a checkout list is preferably successfully transferred when the CV-based modeling of the checkout list has a high confidence level.
  • a checkout list may encounter an exception or error if modeling of the checkout list has low confidence for one or more items, if one or more products is ineligible for automatic entry, if the user is not permitted to or does not have a checkout list, and/or any suitable issue.
  • the method can include in response to receiving a checkout list at the proxy interface device triggering a user interface output.
  • a user interface output is preferably triggered in response to receiving a checkout list at the proxy interface device.
  • the user interface output could be an audible tone, activation of some display state, graphical representation of the modeled data on a graphical display, or other suitable forms of output.
  • Triggering user interface output can include, If the transmitted checkout list qualifies, outputting a confirmation signal through the user interface output, which functions to communicate a successful checkout list transfer.
  • the output may be generated when a checkout list is received at a proxy interface device. Receiving worker and/or customer confirmation may be requested before finalizing transfer to the checkout station for processing.
  • the user interface output may be triggered when the checkout list is successfully transmitted or delivered to the checkout station.
  • triggering the user interface output comprises of, if the checkout list transfer has an exception, outputting an exception signal through the user interface. This functions to signal to a user that there was an issue. In some cases, the issue can be resolved, and this may be presented through the user interface output. For example, an exception may indicate that certain classes of items need to be manually entered. Items such as restricted items like alcohol, difficult to identify products like produce, items sold by weight, and other types of items may trigger exceptions. In other instances, a checkout list may not be usable or available for use and a signal could be triggered indicating this. When not able to resolve the exception, the worker may use that signal to proceed with a manual product entry checkout process.
  • the method additionally can additionally include disassociating a CV-person and a computing device.
  • a CV-person is preferably disassociated when the CV-person loses priority status.
  • the priority status may be lost when the human associated with the CV-person leaves a particular region.
  • the priority status may be lost when a second human is assigned priority status if for example, if the second human moves to be the closest human.
  • Various heuristics, rules, and detection processes may be used in determining which individual or group of users should be treated as the primary. In some variations, though multiple users may be simultaneously synched with a target computing device. For example, if a group of four people all select items in the store, those individually detected checkout lists can be grouped for checkout by the associated humans all entering a checkout region next to a checkout station.
  • a first user will enter the store and select various items as the user walks through the store.
  • the CV monitoring system (or some other sensing system) can track a checkout list of the first user that represents predicted “cart” contents for the user.
  • the cart contents may be stored in the cart but could alternatively be store in a basket, held in bag, held in the hand, stuck into pocket.
  • the first user can approach a checkout station.
  • Other users may be in front of the first user, and those users may have similar process applied to their checkout experience.
  • these other users may have a tracked checkout list automatically entered into the checkout station for expedited checkout, part of the checkout list automatically entered, and/or assisted in any suitable manner.
  • the systems and methods of the embodiments can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions.
  • the instructions can be executed by computer-executable components integrated with the application, applet, host, server, network, website, communication service, communication interface, hardware/firmware/software elements of a user computer or mobile device, wristband, smartphone, or any suitable combination thereof.
  • Other systems and methods of the embodiment can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions.
  • the instructions can be executed by computer-executable components integrated with apparatuses and networks of the type described above.
  • the computer-readable medium can be stored on any suitable computer readable media such as RAMs, ROMs, flash memory, EEPROMs, optical devices (CD or DVD), hard drives, floppy drives, or any suitable device.
  • the computer-executable component can be a processor, but any suitable dedicated hardware device can (alternatively or additionally) execute the instructions.

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Accounting & Taxation (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Finance (AREA)
  • Strategic Management (AREA)
  • General Business, Economics & Management (AREA)
  • Computer Security & Cryptography (AREA)
  • Multimedia (AREA)
  • Human Computer Interaction (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Health & Medical Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Development Economics (AREA)
  • Economics (AREA)
  • Computer Hardware Design (AREA)
  • Social Psychology (AREA)
  • Psychiatry (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Oral & Maxillofacial Surgery (AREA)
  • Marketing (AREA)
  • Cash Registers Or Receiving Machines (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Alarm Systems (AREA)
  • Image Analysis (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
  • Studio Devices (AREA)

Abstract

A system and method for interfacing with a point of sale system from a computer vision system that includes, through a CV monitoring system, detecting a computer vision modeled person and setting a user-record in association with a modeled person, the CV monitoring system being part of a computing platform; modeling interactions of the modeled person as modeled data associated with the user-record; detecting the modeled person in proximity to a computing device in the environment and thereby establishing an association of the computing device with the modeled person; and after establishing an association of the computing device with the modeled person, transmitting at least a part of the modeled data from the computing platform to the computing device.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This Application is a Continuation Application of U.S. patent application Ser. No. 16/015,181, filed on 21 Jun. 2018, which claims the benefit of U.S. Provisional Application No. 62/523,183, filed on 21 Jun. 2017, both of which are incorporated in their entirety by this reference.
  • TECHNICAL FIELD
  • This invention relates generally to the field of computer vision, and more specifically to a new and useful system and method for personalized interactivity with a shared computer vision system.
  • BACKGROUND
  • Computer vision and sensor fusion have seen some early applications to commerce and payment. Many of these applications though are limited in nature. Many applications that expand partially beyond basic functionality rely on a fully integrated system and thus are cost and logistically prohibitive for such systems to be used in existing places of business. Thus, there is a need in the computer vision field to create a new and useful system and method for interfacing with a computing device from a computer vision system. This invention provides such a new and useful system and method.
  • BRIEF DESCRIPTION OF THE FIGURES
  • FIG. 1 is a schematic representation of an exemplary implementation of a system of a preferred embodiment;
  • FIGS. 2-4 are schematic representations of exemplary forms of associations;
  • FIG. 5 is a schematic representation of an exemplary implementation of the system applied across multiple humans in an environment;
  • FIG. 6 is a flowchart representation of a method of a preferred embodiment;
  • FIG. 7 is a flowchart representation of a variations of establishing associations;
  • FIGS. 8 and 9 are schematic representations of exemplary variations of establishing an association with a device instance;
  • FIGS. 10A-10F are schematic representations of exemplary variations of establishing an association during a pairing process of a device instance;
  • FIG. 11 is a schematic representation of a sequence of association mechanisms;
  • FIGS. 12-14 are schematic representations of coordinating with a secondary device.
  • DESCRIPTION OF THE EMBODIMENTS
  • The following description of the embodiments of the invention is not intended to limit the invention to these embodiments but rather to enable a person skilled in the art to make and use this invention.
  • 1. Overview
  • A system and method for interfacing with a computing device from a computer vision system functions to enable computing devices in an environment to pair, synchronize, or otherwise associate with a computer vision (CV) detected and monitored person or object.
  • The system and method are preferably used in coordinating an interactive experience that is in part based on a computer vision (CV) model of the environment and one or more computing devices in that environment. The computer vision model may model people, objects, the environment and interactions/events in that environment, and/or other aspects. The system could similarly be applied to other sensor-driven interaction experiences.
  • In a preferred variation, the system and method are used to synchronize state information associated with a CV monitored person to a computing device as the person comes into proximity of the computing device. This can be used to transfer data from the computing platform of the CV system to the computing device. This may also be used to relay communication from the computing device back to the computing platform and associated or used with the CV-based data modeling in the computing platform. While there are a wide variety of applications, one preferred application is in the interfacing of a checkout station (i.e., a point of sale system) from a computer vision system. In particular, checkout list information collected by the CV monitoring system on behalf of a customer can be automatically transferred to a checkout station when it is the customer's turn to checkout, thereby expediting and speeding up the checkout process. The process could similarly be used in transferring payment information for performing a transaction. The system and method may be applied to other suitable applications as described herein, but in general, the system and method are described as they would apply to commerce and in particular the checkout process with a checkout station.
  • Integrating with computing device infrastructure of an environment can enable CV-based monitoring or other forms of sensor-based monitoring to drive or facilitate interaction experiences involving these computing devices. These computing devices could be checkout stations (as discussed above), informational kiosks, automated teller machines of a bank, vending machines, and/or any suitable type of computing device or machine. In some variations, interfacing with the computing device infrastructure can involve a physical interface device which can act as a proxy for digitally interfacing. In other variations, a programmatic interface such as a network accessible application programming interface to remotely interface with a computing device (e.g., a POS station). This could be wirelessly or in a wired connection.
  • The system and method can be used in large scale CV-driven applications where CV-based modeling of people, objects, the environment, and interactions in that environment are used across independent and personalized digital experiences of different participants. For example, these CV-driven applications can be across large environments such as a grocery store, a mall, or any suitable environment that would depend on multiple camera imaging. Furthermore, such CV-driven interactivity may be enabled ad-hoc for people in the environment.
  • The system may apply a process of establishing associations between CV modeled people with other elements.
  • The association(s) established by the system and method can be between a CV-person, a user-record and or a user-account, and then preferably with some other associative element. The additional associative element can be a human (wherein direct or indirect properties of a person can be used to identify a person) and/or a computing device (e.g., a physical computing device, and/or some application instance on a computing device). These associations can additionally be scoped to a particular environment or space and period of time. The system and method may additionally support operating with different types of association “topologies”.
  • A CV-person (i.e., a computer vision modeled person) as used herein characterizes a detected and optionally tracked physical person modeled and represented by a CV monitoring system. A CV-person may, or may not, have any personally identifying information or person-associated metadata. The CV-person will generally represent the presence of a person in an environment and optionally the location, actions, activity, CV-derived properties, and/or other information based on image processing. For example, a CV-person could have a tracked location or position, body properties (e.g., pose, clothing, or other visual properties), and/or other properties. CV-detected events, gestures or states may additionally be detected in relationship to the CV-person and form part of the data model/representation of that physical person. Here a CV monitoring system characterizes an imaging system and/or processing system employing computer vision to facilitate the detection and tracking of objects, detecting actions, and performing other CV-based operations. Herein, the system and method is described as it applies to CV-based modeling of people, but a CV monitoring system may additionally or alternatively model other entities or objects such as animals, vehicles, automated devices/robots, or other suitable objects.
  • A user-record as used herein characterizes a computer record that is associated with a single human or being. A user-record can preferably be associated with a CV-person to uniquely identify, track, and record state of the CV-person. A user-record will preferably include various properties. Properties of a user-record may include personal identifiable information, but it may alternatively not include any identifiable information. A user-record in some implementations may also include payment information, user settings, user history, privilege settings/permissions, and/or other information. Properties of a user-record may initially use default settings that are used as placeholders until these properties can be updated. Properties may be updated as a result of association with other elements or through CV-based monitoring of the CV-person.
  • A user-record can additionally be used in modeling the state of an entity within a system, which will generally be directing in part a digital interactive experience. For example, in a variation of the system and method applied to automatic checkout powered by CV, the user-record may be the record used to record the items selected for purchase forming some.
  • A user-record can be an internal model of a human. As an internal model of a human, the user-record could be an ephemeral user-record that is preserved for essentially over the duration that the CV-person is detected in the environment. For example, a user-record can be created and updated for the duration that a shopper is present in a store. Additionally, a user-record may bridge the CV-modeling of a person across non-continuous CV monitoring of a person. For example, a first instance of a CV-person monitored in one location at one particular time period and a second instance of a CV person monitored at one location and at second time period (e.g., there may be a gap in video capture as the person enters an unmonitored area) could be associated with the same user-record. A user-record could additionally be persistent over multiple visits or system sessions, wherein a user-record may be reestablished for a human over multiple visits to the environment. As an internal model of a human, a user may not explicitly create nor have direct access to manage the user-record. In one variation, the user-record can be, include, or reference a user-account, where at least a part of the user-record may be user managed. In some implementations, the system and method may operate with a unified concept of user-record and user-account. In such an implementation, the user-record can be a user-account with user managed authentication credentials. In other implementations, verified user-accounts and ephemeral/anonymous user accounts could be used in a similar manner. Other suitable user modeling could similarly be applied.
  • A user-account as used herein characterizes an account in the system that can be accessed and manipulated by a user. A user-account will generally be accompanied with some authorization process such as a username and password or other authentication credentials or process. The user-account may reference a user-account of an outside system such as a social media platform. In the exemplary use case of the system applied to an automatic checkout, a user-account may be used to enable a user to register an application instance, edit payment methods, change account settings, view shopping history, edit shopping lists, and/or perform other actions. These actions can be synchronized with the user-account and can be performed outside of a CV-system, but can preferably be leveraged by a CV-system when the system and method associates a CV-person and a user-account. In some variations, a user-account could be implemented as an optional associative element for humans in the environment. CV-driven applications may handle humans with only ephemeral user-records as well as humans with user-accounts.
  • In some variations, a user-record can optionally include or reference (through some link or association) a user-account. In the situations where the system and method can optionally use a user-account, some humans will have only a user-record used in internally modeling state and referencing CV-related data. These humans may not have a user-account. In this exemplary situation, some other humans will have a user-record that is associated with or is their user-account. In other implementations, only humans with explicitly created user-accounts may be stored. Supporting both ephemeral/anonymous user-records and user-accounts can have the benefit of enabling ad-hoc association of a new user-account with an existing user-record. For example, a user that creates a user account in the middle of a shopping trip can gain access to their CV-based modeling (e.g., a virtual cart for automatic or expedited checkout) that was tracked through a previously anonymous user-record.
  • As will be appreciated by one knowledgeable in the art, the exact data model architecture of such records can take many forms. Herein, a user-record will generally be used to reference the generic user-record, which may or may not have association to a user-account with authentication credentials, user-account will generally be used in situations where there is a user-created record that the user is able to authenticate into unless otherwise specified.
  • A human as used herein characterizes a human being with a unique identity. A human is sometimes referred to as the user, customer, worker, or other human label where appropriate. In the exemplary use case of the system applied to automatic checkout, a human can be someone who is a shopper, a worker in the store, or is otherwise present in the environment. A human could similarly generalize to other living or non-living entities such as farm animals, pets, vehicles, robots, and the like. Herein, we will primarily reference humans but one knowledgeable in the art would appreciate that the system and method are not limited to use with humans.
  • A device instance as used herein characterizes a unique instantiation of a stateful device present in the environment. A device instance in many cases is a computing device such as smart phone, a wearable computer, a tablet, a personal computer, or a computing kiosk/station. A device instance is preferably uniquely identifiable. A first type of device instance (sometimes referred to simply as a computing device) is the one to which the computing platform is interfacing with. As such the computing device instance could be computing devices accessible within the environment such as a point of sale (POS) payment kiosk, a help kiosk, or any suitable type of computing device.
  • In some cases, the system and method may additionally use other types of device instances in establishing an association and/or collecting or delivering data. In some variations, a device instance may be an application instance on a device such as an application installed by a user. Here, instance is used to distinguish a unique installation and instantiation of an application on a particular device. Continuing with the use case of the system applied to automatic checkout, the application instance can be an application of the automatic checkout service that a shopper can use to view their currently selected items, to complete checkout, to modify settings, and/or perform other tasks. In some instances, the system and method can facilitate synchronizing the state of the application instance with the user-record.
  • An association as used herein is some variation of symbolic linking or connecting of at least two associative elements selected from the set of a CV-person, a user-record, user-account, a device instance, and/or a human. More preferably, the association is a three-element association of a CV-person and a user-record with at least one of a user-account, a device instance, and or a human. A CV-person is preferably detected and then matched to a corresponding identifying associative element. The identifying associative element can be a device instance, human, or an identifier of a user-account. The identifying associative element may then be linked to a user-record.
  • An association with computing device infrastructure preferably includes an association with at least a user-record to which CV-based data modeling is connected. For example, a checkout list for a particular customer can be stored in association with the user-record. That checkout list (or other user-record related data) can be transferred in part or whole to a computing device.
  • An association that includes a human association as shown in FIG. 2 can provide positive confirmation of that human. An association with a human can be through biometric detection of the human through the CV monitoring system. A human association could also be indirectly established through biometric identification through a device/application. A human association could additionally use other identifying properties of a human such as interaction patterns (e.g., shopping patterns), clothing patterns, patterns in accompanying humans, and/or other properties.
  • An association that includes a device instance association as shown in FIG. 3 can establish state synchronization with the device and/or application. Interactions with an app can influence the CV monitoring system and similarly detected information from the CV monitoring system can be pushed to the device or application instance.
  • An association that includes a user-account as shown in FIG. 4 can establish state synchronization with the user-account to leverage stored user associated data and settings. Stored settings of an account can influence the CV monitoring system and similarly detected information from the CV monitoring system can be used to update the user-account.
  • An association with a user-record preferably provides a level of indirection between the CV-person and identifying associative elements so that CV modeling updates can be resilient to delays in establishing an identifying association or changes in associations.
  • An association is preferably maintained during the duration of the CV-person (e.g., duration of a shopper shopping in a store). The association is preferably maintained across multiple visits to multiple stores—the association will generally be reestablished for each visit. The system and method can facilitate the establishment and/or reestablishment of the association. An association can additionally be expanded to include other associative elements. Elements of an association could however undergo permanent disassociation (e.g., removing a device instance) or temporary disassociation (e.g., disassociating a user-account for anonymous shopping during a single visit).
  • An association topology generally describes a collection of associations to different associative elements as shown in FIG. 1. Different topologies may lend themselves to different capabilities. Different interaction experiences may also depend on or benefit from particular types of topologies. The association topology may additionally involve the type of association that was established. The type of association can be linked to different levels of identification confidence, privileges, or other aspects. For example, identification of a computing device using one technique may be treated differently from identification through another technique. Additionally, associations can be reinforced or occur at different times and/or locations to affirm the correct association. Furthermore, understanding of associations can be applied longitudinally with the monitoring of a person, which is to say, an association established at one point in time could be applied to future occurrences or retroactively applied, even altering previous state based on the new association information. In viewing the interaction experience as being based around an association topology, the system and method could additionally be extended to providing shared digital experiences and interactions for groups. In this way, multiple humans and/or multiple devices may have a shared digital experience as shown in FIG. 5. For example, a family shopping together would be represented as multiple CV-people, but those modeled interactions may all be linked back to a shared family user-account.
  • The environment as used herein characterizes the site where a CV monitoring system is installed and operational. The system and method can be made to work for a wide variety of environments. In a preferred implementation, the environment is a shopping environment such as a grocery store, convenience store, micro-commerce & unstaffed store, bulk-item store, pharmacy, bookstore, warehouse, mall, market, and/or any suitable environment that promotes commerce or exchange of goods or services. In alternate use cases, the environment can include a household, an office setting, a school, an airport, a public/city space, a gym, and/or any suitable location. The environment can be a locally contained environment but may alternatively be a distributed system with wide coverage.
  • The system and method may be used for any suitable video monitoring application. In particular, the system and method is for CV-based computing applications, which may include automated self-checkout, inventory tracking, security surveillance, environmental event detection and tracking, and/or other suitable applications.
  • Herein, automatic self-checkout is used as the main exemplary application of the system and method, but any suitable application may be used. Automatic self-checkout is primarily characterized by a system or method that generates or maintains a virtual cart during the shopping process of a customer (or group of customers) with the objective of knowing the possessed items when a customer leaves a store. An automatic checkout system may additionally automatically charge an account of a customer for the total of a virtual cart (e.g., predicted list of items selected for purchase). The automatic checkout system could alternatively be used to expedite entry of items for payment. The system and method as described herein can be used to synchronize a CV-person and a resulting generated virtual cart (as detected in part or whole through the CV monitoring system) with a user-record, user-account, device instance, and/or a human. This could then be used to enable automatically charging of a stored payment method, authorizing purchase of restricted items (e.g., alcoholic beverages and the like), or execute other tasks.
  • The system and method may alternatively be used to account for the removal of a good by a customer such as in a library, a rental store, a warehouse, or any suitable item storage facility and update an associative element appropriately. The system and method may alternatively be used to permit or restrict access to locations, to charge for such access, to enable authentication with shared computing devices, or for any use case. The system can be made to work for a wide variety of shopping environments such as grocery stores, convenience stores, micro-commerce & unstaffed stores, bulk-item stores, pharmacies, bookstores, warehouses, malls, markets, and/or any suitable environment that promotes commerce or exchange of goods or services. The system and method can also be used in other situations or in other environments.
  • The system is primarily described as employing a network of multiple video monitoring nodes. The system could additionally be applied to a single camera and optionally audio monitoring and may additionally include other forms of sensing that may be used independently or in combination with video monitoring. These might include lidar, sonar, infrared, ultraviolet, radio frequency, capacitance, magnetic, scales, pressure, volume, climate sensing, and the like.
  • As one potential use, the system and method can be applied for synchronizing user-account data or application state of CV-based monitoring of a CV-person with encountered or used computing devices. This may even be performed independent of the user having ever used or downloaded an application for the checkout service before or creating a user-account for such a service. This synchronization of state between a CV monitoring system and a device can be coordinated with a human's proximity to a device or usage of the device. In one example this may be used in coordinating communication of user-record data such as a virtual cart with store installed computing devices like a checkout station. For example, a virtual cart generated for a CV-person could be communicated to a POS system when the CV-person becomes associated with the POS system after the CV-person is within some spatial proximity of the POS system. In another example, the system and method can be used to synchronize information with a publicly accessible kiosk when the human walks up and starts interacting with the kiosk. From the perspective of the human, the kiosk would seemingly automatically recognize them and personalize the interactions.
  • As another potential benefit, the system and method can provide a seamless user experience. Data, information, and state collected using a CV-based monitoring system and/or other sensing systems can be automatically synchronized with a computing device when the person comes within a defined proximity of the computing device.
  • Related to this enhanced user experience, the system and method can enhance efficiency for many systems. In applying the system and method to commerce, the checkout process can be made significantly faster by automatically feeding a checkout list to a checkout station.
  • As one potential benefit, the system and method can be integrated with existing systems of the environment. In a store for example, the system and method can be integrated with the point-of-sale system used by the store. A point and sale system is often deeply integrated into the operations of a store. Integrating with an existing point of sale system may offer a number of potential benefits: the existing point of sale can serve as a presumably reliable fail over system; workers may require only minimal amount of training if any; secondary systems built on top of or also integrated with a POS can remain operational such as couponing systems, loyalty rewards programs, inventory systems, and the like; support for a wide variety of custom systems or setups; and other potential benefits.
  • The system and method may have particular applications to provide longitudinal tracking through a CV monitoring system across time and space and applying the generated modeled data in connection to a particular computing device encountered in the environment. In the case of assisting in the product checkout process, selection of items by a customer throughout the store can be tracked and then applied when the customer approaches a computing device such as a checkout station.
  • 2. System
  • As shown in FIG. 1, a system for interfacing with a computing device from a computer vision system of a preferred embodiment can include a CV monitoring system integrated with an imaging system. The CV monitoring system is preferably used within a computing platform 100 managing a user interaction experience. The computing platform 100 will preferably include a data management system and other supplementary system elements of a computing platform 100, service, or application. The system may additionally include or interface with a user application and/or connected computing devices. In some variations, the system can include a proxy interface device 140.
  • A CV monitoring system 110 functions to process and generate conclusions from one or more sources of image data. The CV monitoring system no can provide: person detection; person identification; person tracking; object detection; object tracking; extraction of information from device interface sources; gesture, event, or interaction detection; and/or any suitable form of information collection using computer vision and optionally other processing techniques. The CV monitoring system no is preferably used to drive CV-based applications such as generation of a checkout list during shopping, tracking inventory state, tracking user interactions with objects, controlling devices in coordination with CV-derived observations, and/or other interactions.
  • The CV monitoring system 110 preferably operates in connection to an imaging system 112 installed in the environment. The imaging system 112 functions to collect image data within the environment. The imaging system 112 preferably includes a set of image capture devices. The imaging system 112 might collect some combination of visual, infrared, depth-based, lidar, radar, sonar, and/or other types of image data. The imaging system 112 is preferably positioned at a range of distinct vantage points. However, in one variation, the imaging system 112 may include only a single image capture device. The image data is preferably video but can alternatively be a set of periodic static images. In one implementation, the imaging system 112 may collect image data from existing surveillance or video systems. The image capture devices may be permanently situated in fixed locations. Alternatively, some or all may be moved, panned, zoomed, or carried throughout the facility in order to acquire more varied perspective views.
  • A computing platform 100 functions to coordinate or otherwise execute some application, service, or workflow. In a preferred implementation, the computing platform 100 facilitates executing a digital user interaction experience. For example, the computing platform 100 may facilitate a user interaction experience around or related to automated checkout and/or expedited checkout for customers. The computing platform 100 may include local computing resources at the environment to coordinate with devices present in the environment. The computing platform 100 may additionally or alternatively be remote computing resources wherein local computing systems in the environment communicate and coordinate over the internet (or other communication channel) with resources of the computing platform 100.
  • The computing platform 100 preferably includes or otherwise interfaces with the CV monitoring system 110, which functions to detect and model CV-people and/or other CV-based information. The computing platform 100 may additionally include or otherwise interface with one or more associative element monitoring system, which functions to establish an association with one or more associative element. The computing platform 100 can additionally include a data management system 130, which functions to manage and maintain user-records and/or user-accounts or other data modeling resources to support the objectives of the system.
  • The association monitoring system 120 functions as an associative or synchronization mechanism to establish one or more forms of association with a human and/or a computing device. In some variations, the association monitoring system 120 is part of another system element such as the CV monitoring system 110 and/or for an application service of the computing platform 100 to coordinate with a computing device instance (e.g., a user app). In other variations, the association monitoring system 120 can be an active sensing or interrogation system such as a wireless communication system, an RF/NFC interrogator, Bluetooth beacon, an audio sensor system, a specialized CV monitoring submodule, specialized application service, or other suitable type of system. In the variations that use an application instance to detect a device, the system may include an application service which functions to manage substantially real-time communication and interaction with application instances installed and operating on a user's device. The system may include one identification system, but may additionally include multiple types of association monitoring systems 120 that can be used redundantly or cooperatively.
  • A wireless communication system can function to monitor and detect the presence of device signatures in the environment. Multiple wireless communication units (e.g., WiFi routers, RF/NFC interrogators, and the like) can be positioned throughout the store. Their distributed location can be used to correlate the detection of a device signature with at least an approximate location. Bluetooth beacons could be used in a similar manner.
  • A specialized CV monitoring submodule can perform some form of CV-based analysis to assist in detecting. In one variation, this may include performing biometric identification or classification of CV-person. One specialized CV submodule could perform activity classification or modeling for a CV-person which could be matched to motion patterns detected from a special motion detection application service enabled on a device. In a similar manner, a CV monitoring submodule could detect particular gestures performed by a user. Another specialized CV monitoring submodule could detect visual patterns displayed by a computing device. A variety of types of CV monitoring submodules may be use.
  • An audio sensor system may function to detect audible signals in the environment. In one variation, audio signals detected by a computing device could be mapped to audio signals detected by microphones installed throughout the store. This could be used in determining approximate location. In some instances, specialized and potentially nearly inaudible signals could be output by the computing device and/or speakers in the environment. Detection of these unique signals by the device and/or microphones distributed in the environment could function to determine location and thereby selecting a candidate pool of CV-people for a computing device.
  • The data management system 130 functions to store user-records and/or user-account information. The system will generally include other elements to support the CV-based computing application and/or to provide a platform for CV-based computing applications implemented in multiple stores and/or for different use cases. The user-records and/or user-accounts may be linked or otherwise pre-associated with one or more types of identifying associative elements. For example, CV-based identification of an individual may generate an identity signature that is associated with a user-record. In another example, an identifier for a particular device instance may be associated with a user-record such that when that device instance is detected in the store, the mapped user-record can be identified and accessed.
  • User Applications and/or connected computing devices function as client devices that may participate in CV-based computing applications. In a preferred implementation, a user application of the store and/or operator of the CV monitoring system no can be made accessible to users of the CV monitoring system 110 (e.g., customers of a store). The user application can facilitate associating a user-account, providing biometric authentication through the device (e.g., fingerprint, voice recognition, facial identification or other forms of biometric authentication), collecting user input, and/or performing other tasks. A connected computing device can be computing devices that may be installed or provided within the environment. The connected computing devices may be customer service kiosks or stations, networked smart devices (e.g., smart lock, smart lights, etc.), a worker station, and/or any suitable computing devices.
  • A user application instance or a connected computing device are preferably addressable endpoints within the system such that the CV-system or an alternative component can transmit data or information can be communicated to the user application instance or the connected computing device. An SDK and/or API may be provided such that third party applications can establish such integration with a CV monitoring system 110 and/or platform.
  • The system may additionally include computing devices installed within the environment. In one variation, the environment-installed computing devices are configured and directly integrated with the system and computing platform such that they can be accessed and controlled at least in part. In another variation, the system may include a proxy interface device 140 that functions as a gateway or edge device that facilitates communication and interactions with outside devices. In this variation, existing computing devices like a POS system could be used with the system without making direct changes to the existing computing devices.
  • The proxy interface device 140 of a preferred embodiment functions to be a system controllable device/resource that interfaces with environmentally installed computing infrastructure. In some variations, the proxy interface device 140 impersonates an expected form of data entry. A preferred variation of the proxy interface device 140 is used to interface and augment an existing payment system. In one variation, the proxy interface device 140 is used expediting the checkout process by assisting in the entry of product information into an existing POS station. In another variation, the proxy interface device 140 may be used in assisting in delivering pre-authorized payment mechanisms so that a user could pay possibly without any explicit action (other than perhaps confirming payment/purchase).
  • Interfacing with an environment-installed computing device and/or a proxy interface device 140 would have applications in other areas as well. For example, in a restaurant, a digital ordering kiosk could automatically bring up a customized ordering interface (e.g., showing customer order history, starred items, personalized recommendations, loyalty reward options) based on CV-based identification of the user. In a gym, a user may be able to walk up to a device distributed through the gym and a personalized user interface can be automatically presented based on CV-based identification of the user and/or previously tracked activity in the gym. In an airport setting, a check-in kiosk could be controlled to automatically enter ticket information. These and other applications could be implemented through the system and method using a proxy interface device 140 and/or directly connecting to the appropriate computing device.
  • A proxy interface device 140 preferably emulates an input device for a target computing device. For example, the proxy interface device 140 could be a keyboard or barcode scanner emulator (i.e., product entry emulator). The proxy interface device 140 may alternatively communicate data that then uses an installed service to communicate with or otherwise interact with a target computing device.
  • A proxy interface device 140 preferably includes a communication module and a device interface module. The proxy interface device 140 may additionally be delivered as an attachment device encased within a body structure. The proxy interface device 140 may additionally include additional ports. In the checkout station use case, the proxy interface device 140 can include a product entry interface module so that the proxy interface device 140 can be connected between a barcode scanner and a checkout station.
  • The proxy interface device 140 communicatively couples the system (more specifically the CV-based monitoring system) with a computing device. A preferred implementation, the computing device is a point of sale checkout station, but the communicatively coupled computing device could be any suitable type of computing device such as an informational computing kiosk or computing devices for other purposes.
  • The communication module functions to allow the device to be remotely controlled. The communication module can preferably communicatively coupled with the CV-based monitoring system. The communication module is preferably a wireless communication module where the wireless communication module can include Wi-Fi communication module, a Bluetooth or RF communication module, a cellular communication module, or any suitable type of communication module. The communication module could additionally be a wired communication module wherein the proxy interface device 140 communicate over a wired or physical connection.
  • The communication module is preferably registered to the CV-based monitoring system. The communication module can additionally be registered in association with a target computing device. The location and/or target association could be registered during an enrollment period. As part of the enrollment process, the proxy interface device 140 could be registered and manually, automatically, or semi-automatically associated with that location and connected computing device (e.g., a POS station). In one variation, the proxy interface device 140 could include an active or passive identifier to announce itself to the CV monitoring system for registration and location determination.
  • The device interface module, which functions to communicatively connect or interface to one or more computing devices. In one variation this could be a wired connection. In one example, the proxy interface device 140 connects to a POS station through a port typically used by a barcode scanner. In some implementations it may replace a connection of a barcode scanner. In other implementations it may be connected to the POS in addition to one or more barcode scanners. In another variation, the proxy interface device 140 and/or the computing platform more generally can wirelessly communicate with a computing device like a checkout station.
  • The proxy interface device 140 may connect to a checkout station through the device interface module using a standard electrical interface like a USB interface or other data port. The proxy interface device 140 and more specifically the device interface module can generate and transmit the appropriate electrical signals for communicating with the checkout station. Product entry module in a preferred implementation can transfer the universal product codes (UPCs) of the modeled checkout list. For some POS stations this can be UPCs communicated as simulated keyboard entries. These can be transferred in some serial sequence such that from the POS station it appears as rapidly entered products. The product entry emulator may additionally include an interface to one or more product entry devices (like a barcode scanner or a keyboard) such that the product entry emulator can be used in line with such entry devices as shown in FIG. 13.
  • The product entry interface module can be a corresponding communication port to that used by the device interface module. This is preferably used so that use of the proxy interface device 140 preserves the option of the checkout station from using existing infrastructure like a barcode scanner. Accordingly, the product entry interface module could be a female USB port. Data received through this port may be automatically relayed through the device interface module to the connected computing device. Additionally or alternatively, data received through the product entry interface module can be captured and/or optionally processed. In a preferred implementation, UPC data collected through the product entry interface module can be relayed to the connected checkout station, but also communicated to the computing platform. This can be used as training data for CV, AI, and/or machine learning algorithms. Especially since, product information received through the product entry interface module will generally occur when there was an exception or issue with generating a checkout list.
  • The proxy interface device 140 can preferably be encased in a rigid structure. The proxy interface device 140 will additionally include a microprocessor or other form of processing unit along with memory, power system, and/or other suitable elements. The proxy interface devices 140 may be used for each checkout station. Alternatively, a single proxy interface device 140 may interface and manage multiple checkout stations.
  • The proxy interface device preferably includes user interface elements. The user interface elements are preferably provided to communicate with a user of the connected computing device. For example, the user interface elements can function to facilitate conveying system state and optionally collecting user input from a worker managing a POS station. User interface elements may additionally or alternatively be configured for use by other users like a customer.
  • In one preferred variation, the user interface elements include one or more forms of a user interface output. A user interface output could be a visual output, an audio output, a tactile output, and/or any suitable type of output.
  • A visual output could be some form of a visual indicators (e.g., LED lights or gauges) or even a graphical display. In one implementation, an indicator light(s) could signal when a checkout list is transferred/received for updating a POS system. For example, the display could blink green when a customer's selected items are automatically entered into a POS station thereby signaling to the worker that they do not need to scan items for entry and proceed to finalizing payment. Additionally or alternatively, the visual output could indicate when a checkout list cannot be automatically entered, if part of the checkout list can/was entered, and/or any other suitable exception. In another implementation, a graphical display could visually display the virtual checkout items that were relayed or suggested for being relayed to a POS station. The worker may even be requested to verify the list and select an option to enter them into the POS station. Changes could be made if a mistake was made. These changes could be relayed back to the CV-based monitoring system as feedback for quality control and monitoring enhancements.
  • An audio output could be used along with a visual output or by itself. An audio could be an audible tone or signal that triggers for different events. For example, there could be a tone or jingle that plays when a customer with valid checkout list approaches the “primary position” of the POS station (i.e., the person/group ready for checkout) which can indicate to the worker that they can skip the scanning/entry of items. Similarly, a tone may play when a checkout list is not available or not valid for entry, which can indicate to the worker that they should manually enter items selected by the customer.
  • The user interface elements could similarly include user input elements like buttons, dials, touch screens, microphone (for audio commands), and the like. These may be used in various ways to allow the worker to input information or communicate with the system. In one implementation, items are not automatically entered into a POS station until a worker positively confirms the items for entry.
  • A preferred variation of the proxy interface device is one that interfaces with a POS station for the purposes of relaying item information based on a checkout list generated by the CV-based monitoring system.
  • 3. Method
  • As shown in FIG. 6, method for interfacing with a computing device from a computer vision system of a preferred embodiment can include detecting and tracking a human as a CV-person within an environment S110, establishing a user-record associated with the CV-person S120, modeling interactions of the CV-person as modeled data that is associated with the user record S132, detecting the CV-person in proximity to a computing device in the environment S140, and transmitting modeled data associated with the user-record to the computing device S150.
  • Block S110, which includes detecting and tracking a human as a CV-person within an environment, functions to establish a CV-person within an environment. Block S110 is preferably implemented through or in connection with a CV system, which could be part of a computing platform such as was described above. Detecting and tracking a human as a CV-person preferably includes collecting image data and applying person detection computer vision processing to the image data.
  • Image data is preferably collected and then processed by the CV system. When a human enters an environment with an operating CV system, the CV system can acquire the human as a CV-person. That CV-person can be tracked during the human's time in the environment. Continuous tracking may be maintained, but the system could additionally handle discontinuous tracking where tracking of a CV-person may be lost temporarily and then reacquired. Modeling of a CV-person is preferably abandoned, expired, or made inactive after the CV-person exits an environment.
  • Detection and tracking are preferably facilitated through various computer vision approaches. In one implementation, tracking may be achieved through a visual “lock”, wherein movement between frames of a detectable CV-person can be tracked. A physics or modeling system can be introduced to facilitate tracking the CV-person across frames and to recover when a user is temporarily or partially occluded.
  • Detection and tracking may additionally use human identification. Human identification can include biometric identification such as facial identification, gait identification, voice identification and the like. Human identification may additionally include more general characterizations of a human such as visual properties, clothing properties, height and weight estimations, age estimation, and/or possession properties (e.g., holding a bag, using an identifiable shopping cart, etc.). Human identification can be used to uniquely identify a human but may additionally be used to reduce the possible candidates of if not uniquely identifier the identities of humans within an environment. Tracking a CV-person could use human identification to assist in reacquisition of that CV-person.
  • In addition to detecting and tracking of a CV person, the CV-system can additionally provide additional CV-based analysis of the image data such as object detection, object-human interaction detection/classification, human gesture detection, and/or other suitable forms of CV-based modeling based in part on the image data. For example, in a shopping environment, the items selected by a CV-person and/or added to a cart of a CV-person can be added to a checkout list, which can be modeled and stored in association with that CV-person. The CV system can sense and generate predicative models based on image data and supplementary data sets (e.g., shopping history, user profile information, product information, etc.). The CV system may additionally work in combination with other sensing systems such as a smart shelving system with sensors, an RFID sensing system, 3D spatial sensing system, and/or any suitable type of environmental sensing system.
  • In an alternative variation, the method may operate based on detected and tracked mobile computing devices. The detected computing device will generally be a personal computing device such as a mobile phone, a wearable computer, or some other type of computing device. The detected computing device could alternatively be a non-personal computing device such as a computing device provided by the operators of the environment. For example, a smart shopping cart or basket may be used in place of a personal computing device. Detecting and tracking a mobile computing device may be used in combination or independently from detecting and tracking a CV-person. As such some variations described herein could alternatively be performed where a detected computing device (that will generally have some form of relationship to one or more users) can be used in place of a CV-person. For example, an application that enables user-managed scanning of items within a shopping environment may be detected and it's proximity to a checkout station tracked to facilitate transfer of a generated checkout list to the checkout station.
  • Block S120, which includes establishing a user-record associated with the CV-person, functions to link or set a user-record to be associated with a CV-person.
  • In one variation, the user-record could be set by default and used to collect or model CV-based observations of the CV-person. Exact data model architecture could be approached in a variety of ways and in some implementations, there may be no explicit distinction of a user-record from the CV-person. For example, the CV-person data model may serve as the user-record. Without additional association information, the identity of the corresponding human may not be identified or linked, personal computing devices of the corresponding human may not be linked, and/or other historical data beyond what was tracked in this session by the CV-based monitoring system may also not be linked.
  • In other variations, a user-record and/or a user-account may establish an association with the CV-person using a variety of associative/synchronization mechanisms. This may enable human identification (e.g., for the purposes of monitoring across visits to the environment), verified human identification (e.g., affirmative confirmation of the identity of a human), interfacing with another device instance (e.g., a computing device of the human), and/or access to a user-account. The variations described in illustrate optional association channels through which an interaction experience like checkout could be further enhanced or enriched.
  • Block S120, which includes establishing an association between the CV-person and at least one associative element, functions to synchronize and/or link a computer vision derived model of a human to at least one other data model related to the human. Preferably, at least one association is established to an associative element. This associative element may function as a human identifier or entity identifier. In some variations, this human or entity identifier could be token-based (e.g., like a device associated with the human), biological-based, or pattern-based (e.g., behavioral pattern detection). In general, the method is preferably executed so as to establish an association with a user-record and/or user-account.
  • Multiple types and/or instances of associations may be established for a particular human. In some variations, multiple associations may be established at different times, which can work to provide multiple factors of identification and/or to appropriately augment the confidence of a mapping between a CV-person and a user-record. These associations can additionally act as additional factors in having high confidence in other associations like when associating a CV-person with environment-installed computing devices like a checkout station. Some forms of associations may enable particular functionality. For example, restricted products like alcohol could be permitted for purchase by using a validated identity established through forming some form of human identity association.
  • Establishing an association with a user-record and/or user-account is preferably established through at least one identifying associative element like a device instance, application instance, and/or a human identifier. One or more associative mechanisms may be used to establish the association. With an association established to an identifying associative element, the identifying associative element can be used to indirectly establish an association with an appropriate user-record or user-account. The user-record or user-account can be stored and queried using a key, identifier, signature, or properties acquired from the identifying associative element. Accordingly, block S120 will generally include establishing an association between the computer vision modeled person and at least one associative element and thereby associating the computer vision modeled person and a user-record linked through the associative element. Effectively, the method establishes a three-element association between: a CV-person; one or both of a user-record and user-account; and at least one of a device instance, an application instance, and/or a human identifier.
  • An association to a user-record, which may specifically be a user-account, can expand the understanding of a CV-person to platform-managed data and/or to a historical record of the human entity. In an automated checkout implementation, payment information, shopping history, personalized loyalty program rewards, and/or other information may be exposed for use in combination with CV modeled data.
  • An association to a user-record is preferably made in connection with some identifying association such as with a device instance association or association with human identity.
  • An association to a device instance (or in some variations an application instance) can facilitate identifying a human associated device. The association with the device instance may further enable a communication link between the CV monitoring system and a device and/or application that is accessible to the corresponding human. An association to a human identity may enable authentication of the identity of the human corresponding to the CV-person. In one variation, an association to a human can be performed directly through CV-driven analysis of the CV-person. For example, biometric identification may be used. In another variation, authentication and more specifically biometric authentication may be facilitated by an accessible computing device such as a personal computing device or kiosk using biometric authentication.
  • Establishing an association with a CV-person can involve the use of one or more associative mechanisms for establishing associations. Different associative mechanisms may have different levels of reliability, security, and/or be usable for adding associations to different associative elements. A subset of these associative mechanisms may be classified as system initiated associative mechanisms and another subset of associative mechanisms may be classified as user-initiated associative mechanisms. Establishing an association may involve executing variations of such associative mechanisms as shown in FIG. 7.
  • System-initiated associative mechanisms can leverage natural conditions without depending on some form of active user participation to work. System-initiated associative mechanisms can be used in automatically establishing at least part of an association. They will generally operate in the background and may be transparent to a user. System-initiated associative mechanisms may be used in establishing an association automatically—possibly without active participation by a human at the time of association. Three potential types of system-initiated associative mechanisms can be biometric, passive, and active.
  • A biometric type of system-initiated associative mechanism preferably uses biometric input collected in real-time from a CV-person in the environment. This biometric identification can preferably be performed remotely through the image data used by the CV monitoring system. Biometric identification may be used in combination with other associative mechanisms to increase the confidence in biometric identification. For example, using device signature detection and/or gross device location information, the candidate pool of user identities can be reduced such that the confidence in biometric identification can be made more resilient. A facial recognition CV process could be configured to identify a face out of a pool of 300 candidates near the store location as opposed to millions of potential candidates encountered at some time across many sites.
  • A passive type of system-initiated associative mechanism can be an “always on” technology that is typically exposed by a computing device carried by a human. These signals may be unique to each device or at least provide distinguishing features within a limited sample of devices, and therefore can be used to form connections between devices and CV-persons with a relatively high degree of certainty. Passive associative mechanisms may not establish a positively confirmed association in some situations since devices can be shared or stolen, but passive background device detection may be used to establish a probabilistically likely association and/or to narrow the scope of associative elements for other association techniques like the automatic biometric analysis above. Such signals can include WiFi, Bluetooth, MAC addresses, cellular signature and the like. Such signals may not be 100% accurate associations because smart devices can be shared or stolen by different humans. However, such signals can at least be useful with humans during a single visit. They may additionally be useful device signatures for humans with a personal computing device but without an installed application and/or without a user-account. For example, a human without installing a user application on their smart device can have a smart device passively facilitate associating a CV-person to a device instance and by association a user-record with purchase history and payment information.
  • An active type of system-initiated associative mechanism may be some user installed or initiated technology, which, in some cases, can affirmatively link CV-people with a computing device. This variation of system-initiated associative mechanism may operate without explicit device usage by a human while in the store. However, they may depend on installing an application, installing or enabling a service. Bluetooth LE beaconing, background app refresh, geofencing, GPS or relative GPS, other location services, and/or other device functionality may expose signals by which a device could be detected and associated with a user-record or user-account.
  • Use-initiated associative mechanisms can include an associative mechanism dependent on user action. One variation can be device-based initiation. Other forms of user-initiated associative mechanisms can be various forms of user check-ins.
  • Some preferred associative mechanisms could include detecting a human associated device instance S121 and/or collecting real-time image data of a CV-person in the environment and applying a form of biometric identification S125, and/or receiving registration at a registration device S126. Some preferred variations of detecting a human associated device instance S121 can include: detecting a device signature exposed by devices carried by a human S122, detecting a device usage-mechanism explicitly or implicitly enabled by a user S123, and establishing an association during a pairing process of a device instance S124.
  • Block S121 which includes detecting a human associated device instance functions to use the presence of an identifiable device to establish an association. Block S121 will generally involve: through a device identification system, detecting a device instance coincident to the CV-person and then selecting a user-record by an identifier of the device instance. This functions to associate the CV-person, the device instance, and the user-record. Here, the device instance could be some human identifiable device such personal computing device like a smart phone, a personal computer, a wearable computer, and the like. The device instance could alternatively be an instance of an application installed on a device, a browser session, or any suitable client detectable and associated with a user. In some variations, the device instance could be a shared environment-installed computing device. A shared computing device will have shared usage by multiple users at different instances. A shared computing device may be directly used by the human when establishing the association (e.g., an informational kiosk or self-checkout station). The shared computing device may alternatively be used to serve a particular human when establishing the association (e.g., a worker-staffed checkout station).
  • Here, the condition of coincidence characterizes some form of associated proximity, which could include spatial proximity and/or temporal proximity. A device instance may be spatially coincident when the device instance is detected in a location that corresponds to a modeled location of the CV-person. Detection of a device is preferably isolated to a particular region or location. This location can be mapped to a corresponding location in the environmental model of the CV-system. If a CV-person is detected in the corresponding location, an association can be established between the device and the CV-person. Depending on the spatial resolution of either the device instance or the CV-person, different thresholds of proximity may be used. In some cases, gross spatial proximity (e.g., detected within 50 feet range of each other) can be sufficient such as when the pool of possible candidate pairings of CV-people and device instances is not high. A device may be temporally coincident when the device instance is detected within a similar time window. For example, if a device instance is detected in the environment within one minute of detection of a CV-person then those could be paired.
  • In a crowded environment, device detection may occur at multiple locations in an environment and a CV-person association to a device instance can be established through longitudinal analysis of past instances of device detection. This can include looking at the tracked movements of a device instance, analyzing the sets of candidate device instances and CV-people, and/or using other suitable techniques. For example, a device may be detected at the entrance of a store. However, there may be multiple candidate CV-people so a confirmed association may not be established initially. The same device instance may be detected at a second location. Even if the number of candidate CV-people is still large, the CV-people detected at the entrance and the second location can narrow the candidate CV-people.
  • Detecting a device instance may be used in identifying and selecting a corresponding user-record associated with the device instance. In one variation, the device instance may provide some distinguishing key or identifier by which a user-record stored in association with that identifier can be found and accessed. In this variation, the detection of a device instance can be used to re-establish a previous user-record. This accessed user-record can be merged with or replace a current associated user-record.
  • Furthermore, a device instance may be used in establishing an association with a user-account. In some cases, the application instance may be associated with a user-account (e.g., if a human has signed into their account within the application), wherein, establishing association to a device instance will by association establish a user-account association. Accordingly, using a device instance to establish an association with a user account may include authenticating a user-account at the device instance; selecting a user-record based on the user-account authenticated on the device instance when the device instance is detected. The computing platform will generally have access to the device instance and therefore could map the user-account logged into the particular device instance with the CV-person.
  • Similarly, a device instance and/or an application instance can facilitate human identification and so may be establish a validated association with a human. This human association with the application instance can be transferred to an association with a CV-person as well. For example, fingerprint identification, facial identification, voice identification, or other forms of biometric identification performed within the application instance can establish human identity association.
  • Detection of a device instance may be performed through a variety of approaches. As discussed above, the block S121 may include detecting a device signature exposed by devices carried by a human S122, detecting a device-usage mechanism explicitly or implicitly enabled by a user S123, and/or establishing an association during a pairing process of a device instance S124.
  • Block S122, which includes detecting device signatures exposed by devices carried by a human, functions to facilitate passive background device detection. Passive background device detection is preferably used in establishing an association to a device instance through exposed communication device signatures. Device signatures preferably include communication signals from a device that are generally unique to a device and therefore can be used to form associations between a device instance and a CV-person. A device signature can be detectable properties or identifiers exposed over Wi-Fi, over Bluetooth, through MAC addresses, through cellular signals, and/or other exposed emissions. Block S122 can preferably operate as a system-initiated associative mechanism, and may be used to assist providing enhancement functionality to users even if they are not registered or enrolled with a user-account. As a user-initiated association, the user may set some option to enable (or disable) the user of device signatures. If a device instance was previously associated with a device-record or more preferably a user-account, then the device signature can be used in establishing associations to other associative elements. Block S123, which includes detecting a device usage mechanism explicitly or implicitly enabled by a user, functions to facilitate user-enabled background device detection. There are various options that when activated by a user will facilitate automatic establishment of associations of that particular user. In one variation, a user may explicitly enable geofencing to automatically detect when they enter a store. In another variation, a user may implicitly enable a detection mechanism by registering a user-account to access Wi-Fi in the environment. In another variation, a user may enable kinematic monitoring for synchronizing human motion to CV-person motion. These options may depend on a user installing an application and/or enabling or confirming particular device permissions.
  • User-enabled background device detection can be performed substantially similar to passive background device detection described above. However, user-enabled background device detection may use detection approaches like Bluetooth LE beaconing, background app refresh, geofencing, LED positioning, GPS, relative positioning in the environment, and the like.
  • With techniques like Bluetooth beaconing and geofencing, the system may be actively notified when the device instance is present in the environment. With knowledge of the presence of a device instance, that device instance and previously associated humans, user-accounts, and/or user-records may become candidates for associations with a CV-person.
  • When using Bluetooth beaconing, detecting the device instance can include detecting location and/or presence of an identifiable device instance. When Bluetooth beaconing is used in multiple locations, a CV-person can be mapped to and associated with a device instance when there is a unique correspondence of coincidence across a set of detection events as shown in FIG. 8. When there is only one CV-person in the region of a first beacon during a first detection event, then the detected device instance and CV-person can be associated. When there are multiple people during multiple detection events, a CV-person can be associated with the device instance if the CV-person is the uniquely present CV-person in the regions of the various beacons at the time of the detection events.
  • When using location detection, detecting the device instance can include detecting location of a device instance within the environment, and associating the device instance to a CV-person modeled with a corresponding location as shown in FIG. 9. Multiple samples of location and/or the change in location can additionally be used. In a manner similar to the Bluetooth beaconing approach, sampling across many regions can be used to reduce a pool of candidate CV-people down to one selected CV-person.
  • In a kinematic monitoring variation, the method may include, at the device instance, sensing device motion and/or orientation. This device motion and/or orientation can then be used in a variation where block S123 includes detecting an associated device instance with device motion that satisfies a synchronization condition with activity of the CV-person. In other words, motion of the device instance is matched to CV-person motion. An inertial measurement unit which can include accelerometers, gyroscopes, magnetometers (for direction), and/or other sensors may detect motion like walking motion, stops and stops, hand motion, body orientation changes, and the like. By comparing these actions to motion and orientation properties of a CV-person, a CV-person can be linked to a corresponding device instance. Use of motion as a synchronization mechanism may be dependent primarily on coincidence in time and may not factor in location though location can additionally be used.
  • In one variation, establishing an association may initiate confirming of the association, which functions to trigger user affirmation to establish an association. Confirming an association can include requesting confirmation through communication to a human (generally through a device instance). In one variation, an association may include a confirmed or possible association to a device instance. That device instance may have a communication address (e.g., phone number, application instance identifier, push notification endpoint, etc.). A message or notification can be transmitted to the communication address, and a human can confirm or deny the request. Upon receiving affirmative confirmation, the method can proceed with establishing the association. In another variation, the possible association may involve a user-record or a user-account, which may have a configured communication address like a phone number of application instance identifier. A message or notification can be similarly transmitted.
  • Confirmation may request explicit confirmation by a human. For example, a human may receive a text message saying, “Looks like you are at the supermarket. Replay 1 for yes and 2 for no”. A confirmation may alternatively notify a human but require explicit denial to cancel/prevent the association. For example, a human may receive a push notification saying “Enjoy your shopping experience today! Select cancel if you received this in error”. A confirmation may alternatively be automatically approved if a human selects a user-account option to not confirm new sessions. Confirmation could similarly be applied before performing particular interactions that depend on an established association. For example, a user may receive a push notification on an application asking if they want to automatically push checkout list information to a checkout station when they are within proximity.
  • Block S124, which includes establishing an association during a pairing process of a device instance, functions to have a device or more preferably an application facilitate establishment of an association. In some variations, a physical computing device may be designed to enter a pairing mode or continuously perform some pairing action. The pairing mode may be configured to generate an identifying signal through a user interface output of the device instance. As will be described below, the graphical display and speakers may both generate signals usable to detect a device. Similarly, sensed data may be collected and used during the pairing mode. In other variations, an application instance installed on a user device can be actively involved in performing actions that may enable unique detection of that application instance by the CV-system and thereby be associated with a CV-person. Herein, the pairing process of an application instance is described but it similarly applies to a device instance.
  • The pairing process is preferably initialized when the application instance becomes active (e.g., is brought into the foreground of a modal operating system). Activation of the application instance can result in the application instance registering the pairing state of the application instance with the CV monitoring system such that the CV monitoring system can begin to cooperatively establish an association. Once in the pairing mode, one or more signaling mechanisms may be used. The examples of signaling mechanisms can include use of a camera, a display or visual output, an audio system, an inertial measurement unit (IMU), application interactions, and/or stored data.
  • As shown in FIG. 10A, an application instance can use the camera of the computing device to capture an image that can then be used to determine position. In one variation, various visual identifiers (e.g., a QR code or data encoded image) can be positioned throughout the store. Capturing image data from the application can be used to determine the position of the human operating the application when the image data contains the visual identifier. In a related variation, the human operator of the application may be directed to take a picture of a cart of selected items or some other artifact, which can be used as an identifier.
  • In another variation, the camera may be activated in the background with the goal of observing the scene. This activation of the camera may be based on detected orientation of the device (e.g., is the device being held up by human). Observations of the scene can act as a visual signature that can be mapped to images captured by the CV monitoring system as another approach to locating the device within the environment. For example, an application instance may capture images while the user is using the application. If an image of a shelf of items is captured, that image can be used to determine the location of the user within the store and thereby associate the application instance with a CV-person. Visual identifiers may be integrated into the environment such as on the ground, ceiling, shelving, walls, and the like to enhance mapping of visual signatures and positioning within the environment.
  • As shown in FIG. 10B, an application instance can use the display or other mechanisms for visual output in pairing an application instance with a CV-person. In a preferred variation, the display of a smart device can be set to display a visual identifier. The visual identifier can be a static graphic but could alternatively be a time variable visual display. When displaying the visual identifier, the application instance communicates with the system so that detection of that visual identifier by the CV-system can be associated with the application instance. The imaging system used by the CV monitoring system will preferably be able to identify the displayed identifier and map an appropriate CV-person to the application instance. A visual identifier could alternatively be produced by other device elements such as an LED light.
  • As shown in FIG. 10C, an application instance can use the audio output in pairing an application instance with a CV-person. An audio signal is generated with a unique identifier. Detection of that audio signal can then be used to determine location and then used in selecting candidate CV-people. The audio signal is preferably in a frequency range on the edge or beyond the hearing range of a human, but could also be a sound audible by a human. In one variation, the application instance generates the audio signal and microphones distributed within the environment can detect the audio signal. The microphones are associated with a general region within the environment or may be used in triangulating a more precise location. In another variation, speakers distributed across the environment generate audio signals that can be detected by an application instance. Each speaker preferably produces a unique audio signal such that the detected audio signal can be mapped to a positioned speaker and/or a location. Detection of multiple audio signals may be used to triangulate a more precise location.
  • As shown in FIG. 10D, an application instance can use movement of the device as detected by an inertial measurement unit in pairing an application instance with a CV-person. The inertial measurement unit can include a digital accelerometer, gyroscope, magnetometer, and the like. During a pairing mode, the movements, orientation, and/or direction can be monitored to establish human movements. The CV monitoring system can similarly detect CV-person movements for candidate CV-people. CV-people with corresponding movement patterns at a similar time can be associated with the device instance.
  • As shown in FIG. 10E, an application instance can use application interaction as a mechanism for pairing an application instance with a CV-person. An application interaction may be used by detecting human operation of the application and using the CV monitoring system to detect candidate CV-people performing similar actions. Application interaction may be used passively, which preferably use normal interactions with the application instance as CV-detectable actions. For example, the application instance may require a human to perform a check-in action to use an automatic self-checkout feature. The act of pulling out a smart device and pressing a check-in button on the application instance can be detected as actions performed by a CV-person. Additionally, the timing of activating the check-in button as detected by the application instance can be used to determine CV-people performing that action in synchronization with that act.
  • During a pairing mode of the application instance, block S120 can include directing a physical action by the user and detecting a corresponding physical action of the CV-person. In matching the sensed motion at the device instance to modeled motion of the CV-person, the device instance can be associated with the CV-person. For example, Application interactions may be actively directed by the application instance where an application instance instructs a human to perform some action or gesture such as waving his or her hand, holding out the smart device, pointing at an object, or any suitable action. These human gestures may be more detectable than interactions with the application instance. The timing of the actions can be orchestrated by the application instance. Additionally, the nature of action may be controlled and changed to help in establishing the association. For example, different types of actions may be directed so that the type as well as location and timing can better establish an association with high confidence. Device movement as discussed above can similarly be used in combination with directed actions.
  • Establishing an association during a pairing process of a device instance may additionally or alternatively use collected information from the application instance. When a pairing mode is activated, preferably by the human, then the system may begin using stored information associated with the application instance and/or account to establish an association. As one specific example, if a customer has entered a shopping list into an application, then the CV monitoring system can compare that shopping list to the checkout lists of current CV-people. A CV-person detected to have some subset of the shopping list may be associated with that application instance as shown in FIG. 10F. Shopping history, favorited products, and/or other information can similarly be used.
  • Block S125, which includes collecting real-time image data of a CV-person in the environment and applying a form of biometric identification, functions to facilitate automatic biometric analysis of a CV-person. A variety of types of biometric identification techniques may be used such as facial identification, gait identification, retina identification, physical property identification (e.g., height, weight, gender, etc.), and/or other forms of biometric identification. Biometric analysis may be used to establish a human association when a unique human identity is determined. Automatic biometric analysis may additionally establish associations with other associative elements like a user-record.
  • As an alternative or additional approach to biometric identification, biometric identification sensing capabilities of a computing device may be used when a computing device can be communicatively coupled and associated with a CV-person (e.g., using one of the approaches above). This variation can include, at the device instance, receiving biometric identification; and associating human identity confirmation with the modeled person and user-record. Receiving biometric identification can act to confirm or specify the human identify of the current user of the computing device. Receiving biometric identification could include checking a fingerprint, facial pattern, voice, vital sign (e.g., heart rate, respiration rate), and/or any suitable biometric identification. These may be provided on a personal computing device or some shared computing device like a check-in kiosk in the environment.
  • Block S126, which includes receiving registration at a registration device, functions to establish an association during active registration of a user-record, user-account, human, and/or application instance. The registration device can be a kiosk or check-in station installed in the environment. The human will preferably perform some interaction with the registration device to establish an association. The mode of registering at the registration device can take many forms such as swiping/scanning a card (e.g., a payment card), presenting NFC device, QR code or barcode scanning, biometric scanning, entering of account credentials, entering a pin code, and/or any suitable action. A registration device could additionally include biometric sensors for establishing human associations. Some of these registration techniques may not require possession of a device instance and/or other physical tokens. This may provide an option for humans that want to participate in the system without using a physical device. Location of the registration device(s) and proximity of a CV-person during the time of registration can be used to associate with a CV-person. In one alternative, the method may use registration regions where some registration can occur without a physical registration device.
  • The mechanism for establishing an association can be one or more of the mechanisms described herein. In some cases, multiple association mechanisms are used in combination to narrow a pool of candidate CV-people to a single confirmed CV-person. The method can additionally redundantly confirm associations as a form of multi-factor authentication to enhance accuracy, reliability, and/or security. In one variation, establishing an association can include progressively attempting a sequence of association mechanisms. When one association mechanism does not succeed, a backup association mechanism can be used. The sequence of association mechanisms may start off with less intrusive user experiences and then escalates to association mechanisms with higher reliability but possibly more reliance on human participation. In one example shown in FIG. 11, establishing an association to an application instance can initialize by passively using the location of the application instance and identification of a displayed static graphic. If an association is not established, then the application may escalate to displaying an animated graphic with instructions to hold their phone outwards with display up. If an association is not established again the application instance can start an audible jingle while flashing an LED light. If an association is still not established, the application instance can direct the user to use a check-in station. From the user perspective, this pairing process can be presented as a seamless pairing process that slowly builds up. Ideally, an association is established quickly so that most users do not experience the more obvious association mechanisms.
  • There may also be different modes of associations that may depend on the associative elements, mechanism for establishing associations, and/or user selected options. There could be an anonymous association where a CV-person is treated as a generic user. There could be an incognito association mode, where information and capabilities enabled by associations to a user-record, user-account, application record, and/or a human may be used but where the session is not committed to the data records of those associations within the system. There could also be various forms of confirmed identity associations. For example, an association can be an association with confirmed human-identity wherein secure permissions can be enabled such as those that traditionally require review of form of physical identification.
  • Associations are preferably established prior to performing some action requiring permission confirmed through the association. In a preferred implementation, associations are established in response to nearing or entering an environment. However, the method can support retroactively applying an association. As an illustration of the flexibility in establishing an association, the method can support establishing an association immediately prior to the human entering the store and being acquired as a CV-person, immediately before a transaction during an automatic self-checkout, and/or in conjunction with the transaction. Associations can additionally be built up during the duration of the time that the human is in the environment, wherein establishing an association can include wherein establishing an association through multiple associative mechanisms performed at different locations and times in the environment. For example, a CV-person may initially be associated with a user record, then an application instance can be added and then a human association. Associations can additionally happen after a CV-person has left the store where actions like a billing transaction can happen in absentia. This can even happen over multiple visits to the environment by a human. For example, a shoplifter that later creates a user-account may have previous activities and illicit behavior retroactively associated with the new user-account.
  • Block S132, which includes modeling interactions of the CV-person as modeled data that is associated with the user record, functions to sense information about the CV-person. In one preferred variation, modeling interactions of the CV-person comprises modeling a checkout list of items selected by the user in the environment. Modeling a checkout list, functions to generate list of items selected by a human. The checkout list is at least partially based on CV-based monitoring of the CV-person. The CV-based monitoring can be stored in association with the user-record such that established associations with a computing device can leverage user-record information such as current checkout list/virtual cart. As discussed above the CV monitoring system can additionally provide additional CV-based analysis of the image data such as object detection, object-human interaction detection/classification, human gesture detection, and/or other suitable forms of CV-based modeling based in part on the image data. In a shopping environment, the items selected by a CV-person and/or added to a cart of a CV-person can be added to a checkout list, which can be modeled and stored in association with that CV-person. The CV monitoring system can sense and generate predicative models based on image data and supplementary data sets (e.g., shopping history, user profile information, product information, etc.). The CV monitoring system may additionally work in combination with other sensing systems such as a smart shelving system with sensors, an RFID sensing system, 3D spatial sensing system, and/or any suitable type of environmental sensing system. Checkout lists may alternatively be generated and associated with a user-record in other ways. For example, a customer may use an application to scan items for purchase and self-populate a checkout list. In this variation, the CV-person may not be tracked throughout the environment and only in the region of a computing device of interest.
  • Block S132 is preferably part of managing state and/or modeled data in association with the user-record S130, wherein the origin or nature of the modeled data can vary. Accordingly, the method may additionally or alternatively include managing user-record data in association with the user record S134, collecting user input through an associated application instance of the user-record S136, and/or other suitable variations.
  • Block S134, which includes managing user-record data in association with the user record, functions to use other types of data associated with a user-record. The data may originate from user history data, user preference/configuration data, data or state information from a device associated with the user-record/user-account. In one example, the user-record data could include payment mechanism data which can be transferred or otherwise used with a payment-oriented computing device so that a person could pay by approaching the computing device. In one preferred implementation, the user approaches the payment device, the balance is entered in some manner (possibly also provided through the CV monitoring system), the user is presented with the checkout information and asked to confirm payment using this synchronized payment mechanism, and a payment transaction is executed with the payment mechanism if the user provides confirmation.
  • Block S136, which includes collecting user input through an associated application instance of the user-record, functions to use user interface input, sensed data, or other data generated at a user-controlled device to be delivered to a target device. In this variation state and/or data from a user device is relayed to a target device. For example, a user may walk up to a payment kiosk, and the payment kiosk may ask for some form of user input which is then requested and provided through an application operable on the user's personal computing device.
  • A similar variation of the method can be applied so that user interface input, sensed data, state information, or other data generated at a target computing device can be delivered to a target device. In this variation state and/or data from a target device is relayed to a user device/application. Some variations may support a bi-directional flow of data between two computing devices (e.g., a target device and a user device).
  • Block S140, which includes detecting the CV-person in proximity to a computing device in the environment, functions to establish an association between a detected computing device and a CV-person. This preferably establishes a multi-element association of a detected computing device, a CV-person (and CV-modeled data or events), and a corresponding user-record. This may further be used to establish an association with another computing device (e.g., a personal computing device of a user), a user-account, and/or a human-identity. These different types of associations that can be dynamically established can offer various forms and interaction capabilities.
  • The computing device can be a kiosk, a computing station, networked smart device (e.g., smart lock, smart lights, smart scales, etc.), and/or any suitable computing device. As discussed, in a preferred implementation, the computing device in the environment can a checkout station used to perform a checkout process. At or near a checkout station there is generally a line of people waiting to checkout. Various rules, heuristics, and autonomous processes can be used in checking a proximity condition. For a checkout station there will generally be a single CV-person that can be associated with at one time. This will generally be the CV-person modeled within some defined payment region and/or closest to a defined payment point of the checkout station. The locations of the checkout stations may be preconfigured within the CV monitoring system so that analysis on CV-people in near proximity can be isolated to that segment of image data. Alternatively, a computing device may be dynamically detected and located within the environment. Furthermore, the identity of the computing device is detected or known so that association can be established with the correct computing device.
  • In one implementation, a defined space, possibly marked on the floor could be used in indicating who is able to associate and synchronize with a checkout station.
  • As another heuristic, the conveyor belt of a checkout station, the items on that checkout station, and the divider used to mark separation between customers could be monitored, analyzed, and used in determining who has the primary position of proximity to the checkout station. Preferably, as the items are moved off the conveyor belt, the next customers items move towards the front of the conveyor belt. Detecting removal of the divider for example, could be used trigger associating that corresponding user-record and synchronizing the checkout list with the checkout station. As one variation, a worker may provide some form of explicit user input to mark when and who should be processed and synchronized with the checkout station.
  • As another variation, association with a checkout station may not be limited to a single user-record/checkout list. Multiple individuals in a defined region may have a checkout list synchronized with a checkout station. For example, a family shopping together would be represented as multiple CV-people, but those modeled interactions and resulting checkout lists may all synchronized with a checkout station when the family moves to a defined payment region.
  • Block S150, which includes transmitting modeled data associated with the user-record to the computing device, functions to communicate with an associated computing device. This synchronization of data preferably synchronizes data specific to the CV-person and/or device instance. Data and information can flow in one direction from user-record related data, but data and information could similarly flow in multiple directions. As the CV monitoring system will preferably be used simultaneously by multiple distinct humans, this synchronization with a computing device is preferably simultaneously orchestrated by a computing platform across multiple humans.
  • In one variation, the computing platform can communicate the modeled data directly to the computing device through a wireless or wired connection as shown in FIG. 12. In this variation, the computing device may have an exposed interface protocol through which the computing platform can use.
  • In another variation, the computing platform can communicate the modeled data indirectly to the computing device by communicating modeled data to a proxy interface device as shown in FIG. 13. The proxy interface device preferably relays that data to the targeted computing device. In some variations, the proxy interface device can use an exposed interface to gain interactive access to the computing device.
  • In a preferred implementation, the computing device can be a proxy interface device and the modeled data can include a checkout list. Upon receiving the checkout list from the computing platform, the method will preferably include relaying an itemized checkout list data to the checkout station. The proxy interface device can simulate a barcode reader and enter UPC information. The checkout list is preferably received at the proxy interface device, and then it may be relayed through a device interface module as a series of UPC codes entered as simulated keyboard entries. This functions to emulate a barcode scanner or a keyboard for product code entries. Other suitable protocols could alternatively be used.
  • As discussed above, the proxy interface device may additionally connect to a product entry device like a barcode scanner or a manual product code entry tool like a keyboard. The proxy interface device can be communicatively coupled with the product entry device. Upon receiving item data from the product entry device, the method can include relaying the item data to the checkout station. This functions to maintain normal operation of the product entry device—the scanning information passes through. Additionally, the proxy interface device can process and use the item data received from a product entry device. Accordingly, the method may additionally include upon receiving item data from the product entry device communicating the item data to the computing platform.
  • In another variation, the modeled data could be payment details linked to a user-record (or more generally a user-account). The payment details could be transferred as shown in FIG. 14. In some variations, the computing device and/or the proxy interface device can be a digital payment transmitter which is configured to transfer payment details (e.g., payment mechanism tokens) digitally at a point-of-sale device. In another variation, as with the barcode scanner emulation described above, a proxy interface device may emulate some payment mechanism behavior such as emulating an NFC payment mechanism or emulating a present credit card.
  • The proxy interface device is preferably addressable based on the desired checkout station. In the event a proxy interface device connects to multiple checkout stations, communication with the proxy interface device can specify a checkout station identifier/address.
  • In connection to the proxy interface device, the method may additionally include altering the proxy interface device depending on the state of association. Updating a user interface output at the proxy interface device can facilitate communication of machine state to a human (e.g., worker and/or a customer). In general, the user interface output can be used to indicate if and when modeled data was transmitted, the nature of that transferred data, and/or other information. In one implementation, a user interface output can communicate if modeled data (e.g., a checkout list) was successfully transferred and/or if modeled data was not successfully transferred. For example, a checkout list is preferably successfully transferred when the CV-based modeling of the checkout list has a high confidence level. A checkout list may encounter an exception or error if modeling of the checkout list has low confidence for one or more items, if one or more products is ineligible for automatic entry, if the user is not permitted to or does not have a checkout list, and/or any suitable issue.
  • In particular, the method can include in response to receiving a checkout list at the proxy interface device triggering a user interface output. A user interface output is preferably triggered in response to receiving a checkout list at the proxy interface device. The user interface output could be an audible tone, activation of some display state, graphical representation of the modeled data on a graphical display, or other suitable forms of output.
  • Triggering user interface output can include, If the transmitted checkout list qualifies, outputting a confirmation signal through the user interface output, which functions to communicate a successful checkout list transfer. In some implementations, the output may be generated when a checkout list is received at a proxy interface device. Receiving worker and/or customer confirmation may be requested before finalizing transfer to the checkout station for processing. In other implementations, the user interface output may be triggered when the checkout list is successfully transmitted or delivered to the checkout station.
  • Additionally, triggering the user interface output comprises of, if the checkout list transfer has an exception, outputting an exception signal through the user interface. This functions to signal to a user that there was an issue. In some cases, the issue can be resolved, and this may be presented through the user interface output. For example, an exception may indicate that certain classes of items need to be manually entered. Items such as restricted items like alcohol, difficult to identify products like produce, items sold by weight, and other types of items may trigger exceptions. In other instances, a checkout list may not be usable or available for use and a signal could be triggered indicating this. When not able to resolve the exception, the worker may use that signal to proceed with a manual product entry checkout process.
  • The method additionally can additionally include disassociating a CV-person and a computing device. A CV-person is preferably disassociated when the CV-person loses priority status. In one variation, the priority status may be lost when the human associated with the CV-person leaves a particular region. In another variation, the priority status may be lost when a second human is assigned priority status if for example, if the second human moves to be the closest human. Various heuristics, rules, and detection processes may be used in determining which individual or group of users should be treated as the primary. In some variations, though multiple users may be simultaneously synched with a target computing device. For example, if a group of four people all select items in the store, those individually detected checkout lists can be grouped for checkout by the associated humans all entering a checkout region next to a checkout station.
  • As an exemplary application of the method, a first user will enter the store and select various items as the user walks through the store. The CV monitoring system (or some other sensing system) can track a checkout list of the first user that represents predicted “cart” contents for the user. Here the cart contents may be stored in the cart but could alternatively be store in a basket, held in bag, held in the hand, stuck into pocket. When the first user is done, they can approach a checkout station. Other users may be in front of the first user, and those users may have similar process applied to their checkout experience. In some cases, these other users may have a tracked checkout list automatically entered into the checkout station for expedited checkout, part of the checkout list automatically entered, and/or assisted in any suitable manner.
  • The systems and methods of the embodiments can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions. The instructions can be executed by computer-executable components integrated with the application, applet, host, server, network, website, communication service, communication interface, hardware/firmware/software elements of a user computer or mobile device, wristband, smartphone, or any suitable combination thereof. Other systems and methods of the embodiment can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions. The instructions can be executed by computer-executable components integrated with apparatuses and networks of the type described above. The computer-readable medium can be stored on any suitable computer readable media such as RAMs, ROMs, flash memory, EEPROMs, optical devices (CD or DVD), hard drives, floppy drives, or any suitable device. The computer-executable component can be a processor, but any suitable dedicated hardware device can (alternatively or additionally) execute the instructions.
  • As a person skilled in the art will recognize from the previous detailed description and from the figures and claims, modifications and changes can be made to the embodiments of the invention without departing from the scope of this invention as defined in the following claims.

Claims (20)

We claim:
1. A method comprising:
through a CV monitoring system, detecting a computer vision modeled person and setting a user-record in association with a modeled person, the CV monitoring system being part of a computing platform;
modeling interactions of the modeled person as modeled data associated with the user-record;
detecting the modeled person in proximity to a computing device in the environment and thereby establishing an association of the computing device with the modeled person; and
after establishing an association of the computing device with the modeled person, transmitting at least a part of the modeled data from the computing platform to the computing device.
2. The method of claim 1, wherein modeling interactions of the modeled person in association with the user-record comprises of modeling a checkout list of items selected by the user in the environment; and wherein the modeled data is at least part of the checkout list.
3. The method of claim 2, wherein the computing device is a checkout station device.
4. The method of claim 2, wherein the computing device is a proxy interface device that is communicatively coupled to a checkout station; and further comprising upon receiving the checkout list from the computing platform, relaying an itemized checkout list data to the checkout station.
5. The method of claim 4, wherein the proxy interface device is communicatively coupled with a product entry device; and wherein upon receiving item data from the product entry device, relaying the item data to the checkout station.
6. The method of claim 5, further comprising, at the proxy interface device, upon receiving item data from the product entry device, communicating the item data to the computing platform.
7. The method of claim 4, wherein the proxy interface device is communicatively coupled to the checkout station with a wired connection.
8. The method of claim 4, wherein in response to receiving a checkout list at the proxy interface device triggering a user interface output.
9. The method of claim 8, wherein, triggering the user interface output comprises of, if the checkout list qualifies, outputting a confirmation signal through the user interface output.
10. The method of claim 9, wherein triggering the user interface output comprises of, if the checkout list transfer has an exception, outputting an exception signal through the user interface.
11. The method of claim 2, wherein the modeled data is wirelessly communicated to the proxy interface device.
12. The method of claim 2 further comprising storing a payment mechanism in association with the user-record, wherein the transmitted modeled data is the payment mechanism.
13. The method of claim 12, wherein the computing device is a digital payment transmitter.
14. A system comprising:
a computer vision monitoring platform configured to:
detect a computer vision modeled person associated with a user-record,
generate a checkout list for the user-record,
detect the modeled person in proximity to a target computing device in the environment and thereby establish an association of the target computing device with the modeled person, and
transmit the checkout list to a proxy interface device mapped to the target computing device; and
the proxy interface device communicatively, which is coupled to the computer vision monitoring platform and to the target computing device, and configured to transmit at least a part of the modeled data to the target computing device upon receipt of the modeled data.
15. The system of claim 14, wherein the target computing device is a checkout station.
16. The method of claim 15, wherein the proxy interface device emulates a product entry device.
17. The system of claim 16, wherein, the proxy interface device further comprises a product entry module communicatively coupled to a product entry device; and wherein the proxy interface device is further configured to communicate item data received through to the checkout station.
18. The system of claim 17, wherein the proxy interface device is further configured to communicate item data received through the product entry module to the computing platform.
19. The system of claim 14, wherein proxy interface device further comprises a user feedback system configured to output state of a checkout list.
20. The system of claim 19, wherein the user feedback system comprises of an audio system and graphical display system.
US17/592,287 2017-06-21 2022-02-03 Interfacing with a point of sale system from a computer vision system Pending US20220261812A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US17/592,287 US20220261812A1 (en) 2017-06-21 2022-02-03 Interfacing with a point of sale system from a computer vision system

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US201762523183P 2017-06-21 2017-06-21
US16/015,181 US20190005479A1 (en) 2017-06-21 2018-06-21 Interfacing with a point of sale system from a computer vision system
US17/592,287 US20220261812A1 (en) 2017-06-21 2022-02-03 Interfacing with a point of sale system from a computer vision system

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US16/015,181 Continuation US20190005479A1 (en) 2017-06-21 2018-06-21 Interfacing with a point of sale system from a computer vision system

Publications (1)

Publication Number Publication Date
US20220261812A1 true US20220261812A1 (en) 2022-08-18

Family

ID=64693289

Family Applications (6)

Application Number Title Priority Date Filing Date
US16/015,180 Active 2038-06-26 US10740742B2 (en) 2017-06-21 2018-06-21 Linked observed human activity on video to a user account
US16/015,181 Abandoned US20190005479A1 (en) 2017-06-21 2018-06-21 Interfacing with a point of sale system from a computer vision system
US16/911,311 Active US11288650B2 (en) 2017-06-21 2020-06-24 Linking computer vision interactions with a computer kiosk
US17/592,287 Pending US20220261812A1 (en) 2017-06-21 2022-02-03 Interfacing with a point of sale system from a computer vision system
US17/666,360 Active US11748465B2 (en) 2017-06-21 2022-02-07 Synchronizing computer vision interactions with a computer kiosk
US18/224,456 Pending US20240134950A1 (en) 2017-06-21 2023-07-19 Linking observed human activity on video to a user account

Family Applications Before (3)

Application Number Title Priority Date Filing Date
US16/015,180 Active 2038-06-26 US10740742B2 (en) 2017-06-21 2018-06-21 Linked observed human activity on video to a user account
US16/015,181 Abandoned US20190005479A1 (en) 2017-06-21 2018-06-21 Interfacing with a point of sale system from a computer vision system
US16/911,311 Active US11288650B2 (en) 2017-06-21 2020-06-24 Linking computer vision interactions with a computer kiosk

Family Applications After (2)

Application Number Title Priority Date Filing Date
US17/666,360 Active US11748465B2 (en) 2017-06-21 2022-02-07 Synchronizing computer vision interactions with a computer kiosk
US18/224,456 Pending US20240134950A1 (en) 2017-06-21 2023-07-19 Linking observed human activity on video to a user account

Country Status (6)

Country Link
US (6) US10740742B2 (en)
EP (1) EP3635623A4 (en)
AU (2) AU2018289552B2 (en)
BR (1) BR112019027120A2 (en)
IL (1) IL271528B1 (en)
WO (1) WO2018237210A1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11748465B2 (en) 2017-06-21 2023-09-05 Grabango Co. Synchronizing computer vision interactions with a computer kiosk
US11922390B2 (en) 2018-10-29 2024-03-05 Grabango Co Commerce automation for a fueling station

Families Citing this family (47)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109414119B (en) 2016-05-09 2021-11-16 格拉班谷公司 System and method for computer vision driven applications within an environment
WO2018013439A1 (en) 2016-07-09 2018-01-18 Grabango Co. Remote state following devices
US11019162B2 (en) * 2016-11-16 2021-05-25 Dell Products L.P. System and method for provisioning a user interface for sharing
JP7093783B2 (en) 2017-02-10 2022-06-30 グラバンゴ コーポレイション Systems and methods for a dynamic customer checkout experience in an automated shopping environment
GB2560177A (en) 2017-03-01 2018-09-05 Thirdeye Labs Ltd Training a computational neural network
GB2560387B (en) 2017-03-10 2022-03-09 Standard Cognition Corp Action identification using neural networks
US10778906B2 (en) 2017-05-10 2020-09-15 Grabango Co. Series-configured camera array for efficient deployment
US11232687B2 (en) 2017-08-07 2022-01-25 Standard Cognition, Corp Deep learning-based shopper statuses in a cashier-less store
US10650545B2 (en) 2017-08-07 2020-05-12 Standard Cognition, Corp. Systems and methods to check-in shoppers in a cashier-less store
US11200692B2 (en) 2017-08-07 2021-12-14 Standard Cognition, Corp Systems and methods to check-in shoppers in a cashier-less store
US11250376B2 (en) 2017-08-07 2022-02-15 Standard Cognition, Corp Product correlation analysis using deep learning
US11023850B2 (en) 2017-08-07 2021-06-01 Standard Cognition, Corp. Realtime inventory location management using deep learning
US10474991B2 (en) 2017-08-07 2019-11-12 Standard Cognition, Corp. Deep learning-based store realograms
US10853965B2 (en) 2017-08-07 2020-12-01 Standard Cognition, Corp Directional impression analysis using deep learning
US10474988B2 (en) 2017-08-07 2019-11-12 Standard Cognition, Corp. Predicting inventory events using foreground/background processing
US10445694B2 (en) 2017-08-07 2019-10-15 Standard Cognition, Corp. Realtime inventory tracking using deep learning
US20190079591A1 (en) * 2017-09-14 2019-03-14 Grabango Co. System and method for human gesture processing from video input
US10963704B2 (en) 2017-10-16 2021-03-30 Grabango Co. Multiple-factor verification for vision-based systems
US11481805B2 (en) 2018-01-03 2022-10-25 Grabango Co. Marketing and couponing in a retail environment using computer vision
US11373542B2 (en) 2018-01-29 2022-06-28 Israel Aerospace Industries Ltd. Proximity navigation of unmanned vehicles
JP6548279B1 (en) * 2018-02-28 2019-07-24 Necプラットフォームズ株式会社 Self POS terminal
US11605065B2 (en) * 2018-08-24 2023-03-14 Mastercard International Incorporated Systems and methods for secure remote commerce
US11393213B2 (en) 2018-12-05 2022-07-19 AiFi Inc. Tracking persons in an automated-checkout store
US11443291B2 (en) 2018-12-05 2022-09-13 AiFi Inc. Tracking product items in an automated-checkout store
DE112019006072T5 (en) * 2018-12-05 2021-09-02 Sony Group Corporation Information processing apparatus, information processing system, information processing method and program
US11373160B2 (en) 2018-12-05 2022-06-28 AiFi Inc. Monitoring shopping activities using weight data in a store
US11386306B1 (en) * 2018-12-13 2022-07-12 Amazon Technologies, Inc. Re-identification of agents using image analysis and machine learning
US11029710B2 (en) * 2018-12-31 2021-06-08 Wipro Limited Method and system for real-time tracking of a moving target object
US11245875B2 (en) * 2019-01-15 2022-02-08 Microsoft Technology Licensing, Llc Monitoring activity with depth and multi-spectral camera
CA3131604A1 (en) 2019-03-01 2020-09-10 Grabango Co. Cashier interface for linking customers to virtual data
US10997414B2 (en) * 2019-03-29 2021-05-04 Toshiba Global Commerce Solutions Holdings Corporation Methods and systems providing actions related to recognized objects in video data to administrators of a retail information processing system and related articles of manufacture
US11232575B2 (en) 2019-04-18 2022-01-25 Standard Cognition, Corp Systems and methods for deep learning-based subject persistence
US11928682B2 (en) * 2019-05-15 2024-03-12 Worldpay, Llc Methods and systems for generating a unique signature based on user movements in a three-dimensional space
FR3102872B1 (en) * 2019-11-06 2023-04-14 Carrefour Method and device for automating purchases and payments in a physical merchant site
JP7483365B2 (en) * 2019-12-17 2024-05-15 東芝テック株式会社 Shopper management device, information processing program, information processing method, and shopper management system
JP7370845B2 (en) * 2019-12-17 2023-10-30 東芝テック株式会社 Sales management device and its control program
JP2021096791A (en) * 2019-12-19 2021-06-24 東芝テック株式会社 Transaction processing system
CN115136176A (en) * 2019-12-30 2022-09-30 秀皮克科技有限责任公司 System and method for fast checkout using a portable computer device
US11203370B2 (en) 2020-03-11 2021-12-21 Gatekeeper Systems, Inc. Shopping cart monitoring using computer vision
US11315096B2 (en) * 2020-05-14 2022-04-26 Gurunavi, Inc. Payment support system, payment support method, and non-transitory recording medium
CN115427951A (en) * 2020-05-21 2022-12-02 富士通株式会社 Control method, control program, and information processing apparatus
US11303853B2 (en) 2020-06-26 2022-04-12 Standard Cognition, Corp. Systems and methods for automated design of camera placement and cameras arrangements for autonomous checkout
US11361468B2 (en) 2020-06-26 2022-06-14 Standard Cognition, Corp. Systems and methods for automated recalibration of sensors for autonomous checkout
US11636482B2 (en) * 2020-06-30 2023-04-25 Mastercard International Incorporated Method and system for validation of identity of a user during a digital payment process
EP4020415A1 (en) 2020-12-27 2022-06-29 Bizerba SE & Co. KG Self-checkout store
US11894941B1 (en) 2022-03-18 2024-02-06 Grammarly, Inc. Real-time tone feedback in video conferencing
WO2024047412A1 (en) * 2022-08-29 2024-03-07 Everseen Limited Operation of a self-check out surface area of a retail store

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140081738A1 (en) * 2012-08-16 2014-03-20 International Business Machines Corporation Intelligent point of sale system
US20160110797A1 (en) * 2014-10-15 2016-04-21 Toshiba Global Commerce Solutions Holdings Corporation Method, computer program product, and system for providing a sensor-based environment
US20160109954A1 (en) * 2014-05-16 2016-04-21 Visa International Service Association Gesture Recognition Cloud Command Platform, System, Method, and Apparatus

Family Cites Families (227)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5254853A (en) 1990-02-14 1993-10-19 Stefan Reich Optical sensing device
US5418567A (en) 1993-01-29 1995-05-23 Bayport Controls, Inc. Surveillance camera system
US5502564A (en) 1994-09-13 1996-03-26 Hughes Aircraft Company Substrate thickness measurement using oblique incidence multispectral interferometry
US6837436B2 (en) 1996-09-05 2005-01-04 Symbol Technologies, Inc. Consumer interactive shopping system
US6697103B1 (en) 1998-03-19 2004-02-24 Dennis Sunga Fernandez Integrated network for monitoring remote objects
US6970183B1 (en) 2000-06-14 2005-11-29 E-Watch, Inc. Multimedia surveillance and monitoring system including network configuration
US7107110B2 (en) 2001-03-05 2006-09-12 Microsoft Corporation Audio buffers with audio effects
US20040201754A1 (en) 2001-10-12 2004-10-14 Mcalister Micheal J. Dual camera mounting arrangement for a wide screen imaging system
US8321302B2 (en) 2002-01-23 2012-11-27 Sensormatic Electronics, LLC Inventory management system
US7274803B1 (en) 2002-04-02 2007-09-25 Videomining Corporation Method and system for detecting conscious hand movement patterns and computer-generated visual feedback for facilitating human-computer interaction
US7921036B1 (en) 2002-04-30 2011-04-05 Videomining Corporation Method and system for dynamically targeting content based on automatic demographics and behavior analysis
US20030210340A1 (en) 2002-05-07 2003-11-13 John Frederick Romanowich Camera with a mechanical and electrical interface for couplable engagement with a standard lampholder
US7227976B1 (en) 2002-07-08 2007-06-05 Videomining Corporation Method and system for real-time facial image enhancement
US8351647B2 (en) 2002-07-29 2013-01-08 Videomining Corporation Automatic detection and aggregation of demographics and behavior of people
US7053915B1 (en) 2002-07-30 2006-05-30 Advanced Interfaces, Inc Method and system for enhancing virtual stage experience
US8010402B1 (en) 2002-08-12 2011-08-30 Videomining Corporation Method for augmenting transaction data with visually extracted demographics of people using computer vision
US7225414B1 (en) 2002-09-10 2007-05-29 Videomining Corporation Method and system for virtual touch entertainment
US9711153B2 (en) 2002-09-27 2017-07-18 The Nielsen Company (Us), Llc Activating functions in processing devices using encoded audio and detecting audio signatures
US6996460B1 (en) 2002-10-03 2006-02-07 Advanced Interfaces, Inc. Method and apparatus for providing virtual touch interaction in the drive-thru
US7912246B1 (en) 2002-10-28 2011-03-22 Videomining Corporation Method and system for determining the age category of people based on facial images
US7283650B1 (en) 2002-11-27 2007-10-16 Video Mining Corporation Method and system for printing of automatically captured facial images augmented with promotional content
US7734070B1 (en) 2002-12-31 2010-06-08 Rajeev Sharma Method and system for immersing face images into a video sequence
US20040260513A1 (en) 2003-02-26 2004-12-23 Fitzpatrick Kerien W. Real-time prediction and management of food product demand
US7711155B1 (en) 2003-04-14 2010-05-04 Videomining Corporation Method and system for enhancing three dimensional face modeling using demographic classification
US7590261B1 (en) 2003-07-31 2009-09-15 Videomining Corporation Method and system for event detection by analysis of linear feature occlusion
US7505621B1 (en) 2003-10-24 2009-03-17 Videomining Corporation Demographic classification using image components
US20050096997A1 (en) 2003-10-31 2005-05-05 Vivek Jain Targeting shoppers in an online shopping environment
US7319779B1 (en) 2003-12-08 2008-01-15 Videomining Corporation Classification of humans into multiple age categories from digital images
US7100824B2 (en) 2004-02-27 2006-09-05 Evolution Robotics, Inc. System and methods for merchandise checkout
US7168618B2 (en) 2004-08-12 2007-01-30 International Business Machines Corporation Retail store method and system
US20060036485A1 (en) * 2004-08-13 2006-02-16 International Business Machines Corporation Methods and apparatus for presenting personalized information to consumers in a retail environment
US7646887B2 (en) 2005-01-04 2010-01-12 Evolution Robotics Retail, Inc. Optical flow for object recognition
US9609287B2 (en) 2005-03-02 2017-03-28 En-Gauge, Inc. Remote monitoring
US9036028B2 (en) 2005-09-02 2015-05-19 Sensormatic Electronics, LLC Object tracking and alerts
US20070091177A1 (en) 2005-10-24 2007-04-26 The Regents Of The University Of California Remote unattended camera and computer integrated security system
US20070126871A1 (en) 2005-12-06 2007-06-07 Henninger Paul E Iii Modular surveillance camera system with self-identification capability
WO2007067999A2 (en) 2005-12-09 2007-06-14 Amnis Corporation Extended depth of field imaging for high speed object analysis
US7911482B1 (en) 2006-01-06 2011-03-22 Videomining Corporation Method and system for efficient annotation of object trajectories in image sequences
JP4125328B2 (en) 2006-04-17 2008-07-30 キヤノン株式会社 Electronic device, control method of peripheral device by electronic device, program, and storage medium
US7681790B2 (en) 2006-06-09 2010-03-23 The Container Store Computer supported retail shopping systems and methods
US7930204B1 (en) 2006-07-25 2011-04-19 Videomining Corporation Method and system for narrowcasting based on automatic analysis of customer behavior in a retail store
US7974869B1 (en) 2006-09-20 2011-07-05 Videomining Corporation Method and system for automatically measuring and forecasting the behavioral characterization of customers to help customize programming contents in a media network
US7987111B1 (en) 2006-10-30 2011-07-26 Videomining Corporation Method and system for characterizing physical retail spaces by determining the demographic composition of people in the physical retail spaces utilizing video image analysis
US8380558B1 (en) 2006-12-21 2013-02-19 Videomining Corporation Method and system for analyzing shopping behavior in a store by associating RFID data with video-based behavior and segmentation data
US8189926B2 (en) 2006-12-30 2012-05-29 Videomining Corporation Method and system for automatically analyzing categories in a physical space based on the visual characterization of people
US20080208719A1 (en) 2007-02-28 2008-08-28 Fair Isaac Corporation Expert system for optimization of retail shelf space
US8146811B2 (en) 2007-03-12 2012-04-03 Stoplift, Inc. Cart inspection for suspicious items
US8295597B1 (en) 2007-03-14 2012-10-23 Videomining Corporation Method and system for segmenting people in a physical space based on automatic behavior analysis
US7957565B1 (en) 2007-04-05 2011-06-07 Videomining Corporation Method and system for recognizing employees in a physical space based on automatic behavior analysis
US9565419B2 (en) 2007-04-13 2017-02-07 Ari M. Presler Digital camera system for recording, editing and visualizing images
US7848548B1 (en) 2007-06-11 2010-12-07 Videomining Corporation Method and system for robust demographic classification using pose independent model from sequence of face images
US7909248B1 (en) 2007-08-17 2011-03-22 Evolution Robotics Retail, Inc. Self checkout with visual recognition
US8520906B1 (en) 2007-09-24 2013-08-27 Videomining Corporation Method and system for age estimation based on relative ages of pairwise facial images of people
US10296936B1 (en) 2007-09-26 2019-05-21 Videomining Corporation Method and system for measuring effectiveness of a marketing campaign on digital signage
US20090158309A1 (en) 2007-12-12 2009-06-18 Hankyu Moon Method and system for media audience measurement and spatial extrapolation based on site, display, crowd, and viewership characterization
US20100280956A1 (en) 2007-12-26 2010-11-04 Johnson Controls Technology Company Systems and methods for conducting commerce in a vehicle
US8098888B1 (en) 2008-01-28 2012-01-17 Videomining Corporation Method and system for automatic analysis of the trip of people in a retail space using multiple cameras
KR20100121638A (en) 2008-02-04 2010-11-18 에프피에스 푸드 프로세싱 시스템즈 비.브이. Vision system with software control for detecting dirt and other imperfections on egg surfaces
US20130215116A1 (en) 2008-03-21 2013-08-22 Dressbot, Inc. System and Method for Collaborative Shopping, Business and Entertainment
US8027521B1 (en) 2008-03-25 2011-09-27 Videomining Corporation Method and system for robust human gender recognition using facial feature localization
US8433612B1 (en) 2008-03-27 2013-04-30 Videomining Corporation Method and system for measuring packaging effectiveness using video-based analysis of in-store shopper response
US8009863B1 (en) 2008-06-30 2011-08-30 Videomining Corporation Method and system for analyzing shopping behavior using multiple sensor tracking
US8219438B1 (en) 2008-06-30 2012-07-10 Videomining Corporation Method and system for measuring shopper response to products based on behavior and facial expression
DE202008009834U1 (en) 2008-07-22 2009-12-10 Liebherr-Elektronik Gmbh Camera for use in a digital network
US8448859B2 (en) 2008-09-05 2013-05-28 Datalogic ADC, Inc. System and method for preventing cashier and customer fraud at retail checkout
US8379937B1 (en) 2008-09-29 2013-02-19 Videomining Corporation Method and system for robust human ethnicity recognition using image feature-based probabilistic graphical models
US8577705B1 (en) 2008-12-30 2013-11-05 Videomining Corporation Method and system for rating the role of a product category in the performance of a store area
US8175388B1 (en) 2009-01-30 2012-05-08 Adobe Systems Incorporated Recognizing text at multiple orientations
KR20110131247A (en) 2009-02-27 2011-12-06 파운데이션 프로덕션, 엘엘씨 Headset-based telecommunications platform
US8892469B2 (en) 2009-04-01 2014-11-18 Igt Gaming device security mechanism
US8254633B1 (en) 2009-04-21 2012-08-28 Videomining Corporation Method and system for finding correspondence between face camera views and behavior camera views
US9747497B1 (en) 2009-04-21 2017-08-29 Videomining Corporation Method and system for rating in-store media elements
US8638211B2 (en) 2009-04-30 2014-01-28 Icontrol Networks, Inc. Configurable controller and interface for home SMA, phone and multimedia
WO2010135575A2 (en) 2009-05-20 2010-11-25 Express Imaging Systems, Llc Long-range motion detection for illumination control
US9740977B1 (en) 2009-05-29 2017-08-22 Videomining Corporation Method and system for recognizing the intentions of shoppers in retail aisles based on their trajectories
US8812344B1 (en) 2009-06-29 2014-08-19 Videomining Corporation Method and system for determining the impact of crowding on retail performance
US8325982B1 (en) 2009-07-23 2012-12-04 Videomining Corporation Method and system for detecting and tracking shopping carts from videos
US8412656B1 (en) 2009-08-13 2013-04-02 Videomining Corporation Method and system for building a consumer decision tree in a hierarchical decision tree structure based on in-store behavior analysis
JP5257335B2 (en) 2009-11-24 2013-08-07 オムロン株式会社 Method for displaying measurement effective area in three-dimensional visual sensor and three-dimensional visual sensor
WO2011071542A1 (en) 2009-12-13 2011-06-16 AisleBuyer LLC Systems and methods for purchasing products from a retail establishment using a mobile device
US8803888B2 (en) 2010-06-02 2014-08-12 Microsoft Corporation Recognition system for sharing information
JP5548042B2 (en) 2010-06-23 2014-07-16 ソフトバンクモバイル株式会社 User terminal device and shopping system
WO2012003538A1 (en) 2010-07-06 2012-01-12 James Shaun O'leary A system for electronic transactions
JP2012028015A (en) 2010-07-20 2012-02-09 Toshiba Corp Illumination control system and illumination control method
US8488881B2 (en) 2010-07-27 2013-07-16 International Business Machines Corporation Object segmentation at a self-checkout
US8615254B2 (en) * 2010-08-18 2013-12-24 Nearbuy Systems, Inc. Target localization utilizing wireless and camera sensor fusion
US8652033B2 (en) 2010-09-23 2014-02-18 Karl Storz Endovision, Inc. Video stylet with directable tip
US20120173351A1 (en) * 2010-12-29 2012-07-05 Qthru, Llc Mobile Electronic Shopping
US10474858B2 (en) * 2011-08-30 2019-11-12 Digimarc Corporation Methods of identifying barcoded items by evaluating multiple identification hypotheses, based on data from sensors including inventory sensors and ceiling-mounted cameras
US9367770B2 (en) 2011-08-30 2016-06-14 Digimarc Corporation Methods and arrangements for identifying objects
US9129277B2 (en) 2011-08-30 2015-09-08 Digimarc Corporation Methods and arrangements for identifying objects
WO2013056169A1 (en) 2011-10-14 2013-04-18 Hewett Spencer Thornton Interactive consumer self-service shopping system
US20130284806A1 (en) 2011-10-19 2013-10-31 Ran Margalit Automated purchasing system
US10326921B2 (en) 2011-11-14 2019-06-18 Tseng-Lu Chien Light device has built-in camera and related digital data device's functions
WO2013103912A1 (en) 2012-01-05 2013-07-11 Visa International Service Association Transaction visual capturing apparatuses, methods and systems
US8606645B1 (en) 2012-02-02 2013-12-10 SeeMore Interactive, Inc. Method, medium, and system for an augmented reality retail application
US20150095189A1 (en) 2012-03-16 2015-04-02 In Situ Media Corporation System and method for scanning, tracking and collating customer shopping selections
US9661047B2 (en) 2012-04-30 2017-05-23 Mobilatv Ltd. Method and system for central utilization of remotely generated large media data streams despite network bandwidth limitations
US9892438B1 (en) 2012-05-03 2018-02-13 Stoplift, Inc. Notification system and methods for use in retail environments
WO2013167164A1 (en) 2012-05-07 2013-11-14 Imm Sound S.A. Method and apparatus for layout and format independent 3d audio reproduction
US9147114B2 (en) 2012-06-19 2015-09-29 Honeywell International Inc. Vision based target tracking for constrained environments
US9774459B2 (en) 2012-06-22 2017-09-26 Sensormatic Electronics, LLC Security system and method using wireless adapters and PoE cameras
US9288299B2 (en) 2012-09-14 2016-03-15 Dewmobile, Inc. Method and apparatus for file sharing in a network
US20140082610A1 (en) 2012-09-14 2014-03-20 DewMobile Inc. Mesh network and mesh network node application
US9647906B2 (en) 2012-11-02 2017-05-09 Rockwell Automation Technologies, Inc. Cloud based drive monitoring solution
US20140155022A1 (en) 2012-12-05 2014-06-05 Anil Kandregula Methods and apparatus to monitor usage of mobile devices
US20140188601A1 (en) 2013-01-03 2014-07-03 International Business Machines Corporation Integration between brick-and-mortar establishments and web based establishments
US10062066B2 (en) 2013-01-30 2018-08-28 Walmart Apollo, Llc Systems and methods for retrieving items for a customer at checkout
US20140214564A1 (en) 2013-01-31 2014-07-31 Wal-Mart Stores, Inc. Method to allow two or more mobile devices to contribute items to the same virtual shopping cart in mobile self checkout software
US20140245160A1 (en) 2013-02-22 2014-08-28 Ubiquiti Networks, Inc. Mobile application for monitoring and controlling devices
US10198080B1 (en) 2013-03-11 2019-02-05 Amazon Technologies, Inc. Virtual user interface
US9392675B2 (en) 2013-03-14 2016-07-12 Lutron Electronics Co., Inc. Digital load control system providing power and communication via existing power wiring
US9330413B2 (en) * 2013-03-14 2016-05-03 Sears Brands, L.L.C. Checkout and/or ordering systems and methods
US8915429B2 (en) 2013-03-15 2014-12-23 Ncr Corporation Methods of mobile self-checkout shopping for produce items in a retail grocery store
US9613659B2 (en) 2013-03-15 2017-04-04 Fitbit, Inc. Generating custom audio content for an exercise session
US9098825B2 (en) 2013-03-26 2015-08-04 Leonard Bashkin Storage container with inventory control
US9213803B2 (en) 2013-05-02 2015-12-15 David Rolley System and method for collecting, analyzing and reporting fitness activity data
US9412099B1 (en) 2013-05-09 2016-08-09 Ca, Inc. Automated item recognition for retail checkout systems
US20140363059A1 (en) * 2013-06-07 2014-12-11 Bby Solutions, Inc. Retail customer service interaction system and method
US20140365334A1 (en) 2013-06-07 2014-12-11 Bby Solutions, Inc. Retail customer service interaction system and method
US9329682B2 (en) 2013-06-18 2016-05-03 Microsoft Technology Licensing, Llc Multi-step virtual object selection
US10268983B2 (en) 2013-06-26 2019-04-23 Amazon Technologies, Inc. Detecting item interaction and movement
US10176456B2 (en) * 2013-06-26 2019-01-08 Amazon Technologies, Inc. Transitioning items from a materials handling facility
US10217133B2 (en) 2013-07-19 2019-02-26 Paypal, Inc. Reverse showrooming and merchant-customer engagement system
US10290031B2 (en) * 2013-07-24 2019-05-14 Gregorio Reid Method and system for automated retail checkout using context recognition
US9473747B2 (en) 2013-07-25 2016-10-18 Ncr Corporation Whole store scanner
US20150046213A1 (en) 2013-08-07 2015-02-12 Motorola Solutions, Inc. Method for identifying a shopping group in a store
EP3031206B1 (en) 2013-08-09 2020-01-22 ICN Acquisition, LLC System, method and apparatus for remote monitoring
JP5920299B2 (en) 2013-09-17 2016-05-18 コニカミノルタ株式会社 Image forming apparatus, remote control method, and remote control program
JP6361103B2 (en) 2013-09-17 2018-07-25 株式会社リコー Management device, management system, object management method, and program
US9141931B2 (en) 2013-09-26 2015-09-22 Amazon Technologies, Inc. Inventory distribution method and system
US9984352B2 (en) 2013-09-26 2018-05-29 Amazon Technologies, Inc. Kiosk network in a kiosk management system
US9474934B1 (en) 2013-10-11 2016-10-25 Fit Intuition, LLC Biometric assessment in fitness improvement
US10366445B2 (en) 2013-10-17 2019-07-30 Mashgin Inc. Automated object recognition kiosk for retail checkouts
US9183620B2 (en) 2013-11-21 2015-11-10 International Business Machines Corporation Automated tilt and shift optimization
US20150163411A1 (en) 2013-12-11 2015-06-11 Echostar Technologies, Llc Home Monitoring and Control
WO2015114123A1 (en) 2014-01-30 2015-08-06 Koninklijke Philips N.V. Controlling a lighting system using a mobile terminal
US20150227890A1 (en) 2014-02-07 2015-08-13 Kristin Kaye Bednarek Communications system and smart device apps supporting segmented order distributed distribution system
US9948902B1 (en) 2014-03-07 2018-04-17 Alarm.Com Incorporated Video camera and sensor integration
US20150310601A1 (en) 2014-03-07 2015-10-29 Digimarc Corporation Methods and arrangements for identifying objects
US9120621B1 (en) 2014-03-25 2015-09-01 Amazon Technologies, Inc. Verifying bin content in an automated materials handling facility
US9317785B1 (en) 2014-04-21 2016-04-19 Video Mining Corporation Method and system for determining ethnicity category of facial images based on multi-level primary and auxiliary classifiers
US9918213B2 (en) 2014-05-07 2018-03-13 DewMobile Inc. Discovery and networking of proximate wireless devices by acoustic messaging
US20150373509A1 (en) 2014-06-19 2015-12-24 Dewmobile, Inc. Group gaming platform for mobile devices in proximity
JP5866522B2 (en) 2014-07-08 2016-02-17 パナソニックIpマネジメント株式会社 Facility management support apparatus, facility management support system, and facility management support method
US10129507B2 (en) 2014-07-15 2018-11-13 Toshiba Global Commerce Solutions Holdings Corporation System and method for self-checkout using product images
US9547964B2 (en) 2014-07-24 2017-01-17 Heathco, Llc Integrated home lighting and notification system
EP3009997B1 (en) 2014-10-15 2016-11-23 Axis AB Arrangement for a monitoring camera device
US10157379B2 (en) 2014-11-12 2018-12-18 Toshiba Global Commerce Solutions Holdings Corporation Self checkout with security checks based on categorized items
US9262681B1 (en) 2014-11-19 2016-02-16 Amazon Technologies, Inc. Probabilistic registration of interactions, actions or activities from multiple views
US10594983B2 (en) 2014-12-10 2020-03-17 Robert Bosch Gmbh Integrated camera awareness and wireless sensor system
US10134004B1 (en) 2014-12-23 2018-11-20 Amazon Technologies, Inc. Processing image data from a camera cluster
US10722166B2 (en) 2014-12-30 2020-07-28 Ergoview S.R.L. Method and system for biomechanical analysis of the posture of a cyclist and automatic customized manufacture of bicycle parts
US9990587B2 (en) 2015-01-22 2018-06-05 Preferred Networks, Inc. Machine learning heterogeneous edge device, method, and system
US9412034B1 (en) 2015-01-29 2016-08-09 Qualcomm Incorporated Occlusion handling for computer vision
US9706619B2 (en) 2015-02-16 2017-07-11 Cree, Inc. Lighting fixture with image sensor
US9853730B2 (en) 2015-02-27 2017-12-26 Xicato, Inc. Lighting based authentication of a mobile electronic device
US9270634B1 (en) 2015-03-02 2016-02-23 Dewmobile, Inc. Building a proximate social networking database based on relative distance profiling of two or more operably coupled computers
CA3183763A1 (en) 2015-03-13 2016-09-22 Lutron Electronics Co., Inc. Control device having an illuminated portion controlled in response to an external sensor
US9250712B1 (en) 2015-03-20 2016-02-02 Hand Held Products, Inc. Method and application for scanning a barcode with a smart device while continuously running and displaying an application on the smart device display
US10089520B2 (en) 2015-03-26 2018-10-02 Krishna V Motukuri System for displaying the contents of a refrigerator
US20160289964A1 (en) 2015-04-02 2016-10-06 Shawn Engberg Suspended ceiling
AU2015388775A1 (en) 2015-04-03 2017-10-26 Lucis Technologies Holdings Limited Environmental control system
US10217120B1 (en) 2015-04-21 2019-02-26 Videomining Corporation Method and system for in-store shopper behavior analysis with multi-modal sensor fusion
US10565455B2 (en) * 2015-04-30 2020-02-18 Ants Technology (Hk) Limited Methods and systems for audiovisual communication
US10037592B2 (en) 2015-06-05 2018-07-31 Mindaptiv LLC Digital quaternion logarithm signal processing system and method for images and other data types
KR102658873B1 (en) 2015-06-24 2024-04-17 매직 립, 인코포레이티드 Augmented reality devices, systems and methods for purchasing
US9911290B1 (en) 2015-07-25 2018-03-06 Gary M. Zalewski Wireless coded communication (WCC) devices for tracking retail interactions with goods and association to user accounts
US10318976B2 (en) 2015-07-28 2019-06-11 Walmart Apollo, Llc Methods for determining measurement data of an item
US20190054347A1 (en) 2015-08-18 2019-02-21 Michael Saigh Wearable sports guidance communication system and developers tool kit
US10180469B2 (en) 2015-10-28 2019-01-15 Siemens Healthcare Gmbh Gesture-controlled MR imaging system and method
CN105335509B (en) 2015-10-29 2017-06-30 广州神马移动信息科技有限公司 A kind of method for recommending action message, device and server
US20170161703A1 (en) 2015-12-03 2017-06-08 Wal-Mart Stores, Inc. Smart cart for self-checkout of retail merchandise
US10915910B2 (en) 2015-12-09 2021-02-09 International Business Machines Corporation Passive analysis of shopping behavior in a physical shopping area using shopping carts and shopping trays
US11010910B2 (en) 2015-12-18 2021-05-18 Iris Automation, Inc. Systems and methods for dynamic object tracking using a single camera mounted on a moving object
US10262331B1 (en) 2016-01-29 2019-04-16 Videomining Corporation Cross-channel in-store shopper behavior analysis
WO2017136151A1 (en) 2016-02-02 2017-08-10 Gaming Grids Wearables, Llc Esports fitness and training system
US10832311B2 (en) 2016-02-26 2020-11-10 Imagr Limited Method and medium for shopping in a physical store
WO2017149875A1 (en) 2016-02-29 2017-09-08 ソニー株式会社 Image capture control device, image capture device, and image capture control method
KR20170110824A (en) 2016-03-24 2017-10-12 삼성전자주식회사 Display apparatus and the control method thereof
US10198625B1 (en) 2016-03-26 2019-02-05 Videomining Corporation Association of unique person to a mobile device using repeat face image matching
US10387896B1 (en) 2016-04-27 2019-08-20 Videomining Corporation At-shelf brand strength tracking and decision analytics
WO2017192457A1 (en) 2016-05-02 2017-11-09 Focal Systems, Inc. Expedited checkout system through portable checkout units
CN109414119B (en) 2016-05-09 2021-11-16 格拉班谷公司 System and method for computer vision driven applications within an environment
EP3466047A4 (en) 2016-05-31 2020-07-08 Theia Group, Incorporated System for transmission and digitization of machine telemetry
US10354262B1 (en) 2016-06-02 2019-07-16 Videomining Corporation Brand-switching analysis using longitudinal tracking of at-shelf shopper behavior
US10380814B1 (en) 2016-06-27 2019-08-13 Amazon Technologies, Inc. System for determining entry of user to an automated facility
WO2018013439A1 (en) 2016-07-09 2018-01-18 Grabango Co. Remote state following devices
US10083358B1 (en) 2016-07-26 2018-09-25 Videomining Corporation Association of unique person to point-of-sale transaction data
BR102016019151A2 (en) 2016-08-18 2018-03-06 De Souza Lopes Roberto METHOD AND COMPUTER VEHICLE DISPLAY AND IDENTIFICATION SYSTEM THROUGH CAMERAS APPLIED IN FUEL STATIONS AND CONVENIENCE STORES
US10409548B2 (en) 2016-09-27 2019-09-10 Grabango Co. System and method for differentially locating and modifying audio sources
US10002344B2 (en) 2016-10-17 2018-06-19 Conduent Business Services, Llc System and method for retail store promotional price tag detection
WO2018125712A1 (en) 2016-12-30 2018-07-05 Datalogic Usa, Inc. Self-checkout with three dimensional scanning
US10665051B2 (en) 2017-02-02 2020-05-26 Smartbins Inc. Bulk food integrated scale system
JP7093783B2 (en) 2017-02-10 2022-06-30 グラバンゴ コーポレイション Systems and methods for a dynamic customer checkout experience in an automated shopping environment
US20180240180A1 (en) 2017-02-20 2018-08-23 Grabango Co. Contextually aware customer item entry for autonomous shopping applications
US10458595B2 (en) 2017-02-28 2019-10-29 Cisco Technology, Inc. Smart Power over Ethernet lift
US10997421B2 (en) 2017-03-30 2021-05-04 Hrl Laboratories, Llc Neuromorphic system for real-time visual activity recognition
US10778906B2 (en) 2017-05-10 2020-09-15 Grabango Co. Series-configured camera array for efficient deployment
IL271528B1 (en) 2017-06-21 2024-04-01 Grabango Co Linking observed human activity on video to a user account
CA3072058A1 (en) 2017-08-07 2019-02-14 Standard Cognition, Corp. Predicting inventory events using semantic diffing
US11023850B2 (en) 2017-08-07 2021-06-01 Standard Cognition, Corp. Realtime inventory location management using deep learning
US10474991B2 (en) 2017-08-07 2019-11-12 Standard Cognition, Corp. Deep learning-based store realograms
US10445694B2 (en) 2017-08-07 2019-10-15 Standard Cognition, Corp. Realtime inventory tracking using deep learning
US10650545B2 (en) 2017-08-07 2020-05-12 Standard Cognition, Corp. Systems and methods to check-in shoppers in a cashier-less store
US10127438B1 (en) * 2017-08-07 2018-11-13 Standard Cognition, Corp Predicting inventory events using semantic diffing
US10474988B2 (en) 2017-08-07 2019-11-12 Standard Cognition, Corp. Predicting inventory events using foreground/background processing
US10055853B1 (en) 2017-08-07 2018-08-21 Standard Cognition, Corp Subject identification and tracking using image recognition
US10133933B1 (en) 2017-08-07 2018-11-20 Standard Cognition, Corp Item put and take detection using image recognition
US20190079591A1 (en) 2017-09-14 2019-03-14 Grabango Co. System and method for human gesture processing from video input
US10469768B2 (en) * 2017-10-13 2019-11-05 Fyusion, Inc. Skeleton-based effects and background replacement
US10963704B2 (en) 2017-10-16 2021-03-30 Grabango Co. Multiple-factor verification for vision-based systems
US11481805B2 (en) 2018-01-03 2022-10-25 Grabango Co. Marketing and couponing in a retail environment using computer vision
US20190244161A1 (en) 2018-02-02 2019-08-08 Microsoft Technology Licensing, Llc Inventory control
US20190333039A1 (en) 2018-04-27 2019-10-31 Grabango Co. Produce and bulk good management within an automated shopping environment
US10282720B1 (en) 2018-07-16 2019-05-07 Accel Robotics Corporation Camera-based authorization extension system
US10282852B1 (en) 2018-07-16 2019-05-07 Accel Robotics Corporation Autonomous store tracking system
US11087539B2 (en) 2018-08-21 2021-08-10 Mastercard International Incorporated Systems and methods for generating augmented reality-based profiles
CN112930292A (en) 2018-09-07 2021-06-08 看门人系统公司 Shopping basket monitoring using computer vision and machine learning
CA3117918A1 (en) 2018-10-29 2020-05-07 Grabango Co. Commerce automation for a fueling station
US10347009B1 (en) 2018-11-21 2019-07-09 Juan Ramon Terven Self callbrating camera system
US10943204B2 (en) 2019-01-16 2021-03-09 International Business Machines Corporation Realtime video monitoring applied to reduce customer wait times
US20200265494A1 (en) 2019-02-17 2020-08-20 Grabango Co. Remote sku on-boarding of products for subsequent video identification and sale
CA3131604A1 (en) * 2019-03-01 2020-09-10 Grabango Co. Cashier interface for linking customers to virtual data
US11810067B2 (en) 2019-12-31 2023-11-07 Grabango Co. Digitally managed shelf space marketplace
US11218868B1 (en) 2020-05-18 2022-01-04 NortonLifeLock Inc. Employing beacon messages to restart an application on a mobile device
US20220092664A1 (en) 2020-09-24 2022-03-24 Grabango Co. Optimization of product presentation

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140081738A1 (en) * 2012-08-16 2014-03-20 International Business Machines Corporation Intelligent point of sale system
US20160109954A1 (en) * 2014-05-16 2016-04-21 Visa International Service Association Gesture Recognition Cloud Command Platform, System, Method, and Apparatus
US20160110797A1 (en) * 2014-10-15 2016-04-21 Toshiba Global Commerce Solutions Holdings Corporation Method, computer program product, and system for providing a sensor-based environment

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11748465B2 (en) 2017-06-21 2023-09-05 Grabango Co. Synchronizing computer vision interactions with a computer kiosk
US11922390B2 (en) 2018-10-29 2024-03-05 Grabango Co Commerce automation for a fueling station

Also Published As

Publication number Publication date
AU2023202100A1 (en) 2023-05-04
US20180373928A1 (en) 2018-12-27
US11748465B2 (en) 2023-09-05
AU2018289552B2 (en) 2023-01-05
AU2018289552A1 (en) 2020-01-16
US20240134950A1 (en) 2024-04-25
US20200394636A1 (en) 2020-12-17
IL271528B1 (en) 2024-04-01
WO2018237210A8 (en) 2019-06-13
BR112019027120A2 (en) 2020-07-07
IL271528A (en) 2020-02-27
US11288650B2 (en) 2022-03-29
US20220237621A1 (en) 2022-07-28
EP3635623A4 (en) 2020-10-21
WO2018237210A1 (en) 2018-12-27
EP3635623A1 (en) 2020-04-15
US20190005479A1 (en) 2019-01-03
US10740742B2 (en) 2020-08-11

Similar Documents

Publication Publication Date Title
US20220261812A1 (en) Interfacing with a point of sale system from a computer vision system
CN110462669B (en) Dynamic customer checkout experience within an automated shopping environment
US11257086B2 (en) Automated sensor-based customer identification and authorization systems within a physical environment
US10929829B1 (en) User identification and account access using gait analysis
US20170142589A1 (en) Method for adjusting usage policy and electronic device for supporting the same
US9265450B1 (en) Proximity-based system for object tracking and automatic application initialization
JP7439844B2 (en) Terminal device, information processing device, information output method, information processing method, customer service support method and program
US20160350811A1 (en) Measurements of earth's magnetic field indoors
WO2018165287A1 (en) Order information determination method and apparatus
US11049170B1 (en) Checkout flows for autonomous stores
RU2717957C2 (en) Method and system of user connection with portable device
TWI809044B (en) Store management device and store management method
US10952015B2 (en) Interlinked geo-fencing
US9973897B2 (en) Information processing apparatus, program product, and method
US20190253413A1 (en) Information processing terminal, information processing device, information processing method, information processing system, and program
KR20200132897A (en) Store system, method, and apparatus for processing information of clothes to be tried on
JP2023535908A (en) TOUCHPOINT DEVICE, TOUCHPOINT SYSTEM, TOUCHPOINT METHOD AND STORAGE MEDIUM
KR101777170B1 (en) Method, system and computer-readable recording medium for providing online learnimg information
WO2020227109A1 (en) Device-independent, contextually driven application computing environment
JP2023101451A (en) Experience sharing support program, experience sharing support method, and experience sharing support apparatus
WO2014193519A1 (en) Methods and systems for agnostic payment systems

Legal Events

Date Code Title Description
STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

AS Assignment

Owner name: GRABANGO CO., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GLASER, WILLIAM;VAN OSDOL, BRIAN;SIGNING DATES FROM 20180607 TO 20180621;REEL/FRAME:060150/0806

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

Free format text: NON FINAL ACTION MAILED

AS Assignment

Owner name: GLICKBERG, DANIEL, NEW YORK

Free format text: SECURITY INTEREST;ASSIGNOR:GRABANGO CO.;REEL/FRAME:067611/0150

Effective date: 20240528

AS Assignment

Owner name: FIRST-CITIZEN BANK & TRUST COMPANY, CALIFORNIA

Free format text: SECURITY INTEREST;ASSIGNOR:GRABANGO CO.;REEL/FRAME:067637/0231

Effective date: 20240524