One technical field of the present disclosure is digital electronic payment systems that process card purchases. Another technical field is online, real-time computer-implemented procurement systems that process requisitions, purchase orders, invoices, orders and the like.
The approaches described in this section are approaches that could be pursued, but not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated, it should not be assumed that any of the approaches described in this section qualify as prior art merely by virtue of their inclusion in this section.
Electronic procurement systems typically use computers to enforce an electronic document processing workflow in which a transaction begins with a requisition or purchase order transmitted from buyer to supplier, the supplier confirms the order, the supplier ships or delivers the goods or services, the supplier transmits an invoice, and the buyer electronically pays the invoice. While this process enforces a measure of control—the supplier isn't paid until the goods ship and an invoice is generated—it also requires the buyer to undertake the added steps of reviewing and paying an invoice long after the requisition or purchase order is created. In some situations, such as high-volume buying, this step becomes a source of delay and work that is perceived to be unnecessary. It requires extensive use of computers to retrieve and display documents, transmit e-mail messages or place phone calls to gather missing data, resolve problems, or send approvals and payment instructions.
Furthermore, when payment is by card, the traditional process requires reconciling card charge statements against invoices, purchase orders and requisitions. Typically, this is performed by manual review of online records and is labor-intensive and costly.
Moreover, traditional card payment reconciliation normally does not permit the buyer to determine the vendor that received payment. Often the vendor is represented only as the issuing bank of the card. This is because each card transaction results in a journal entry by the issuing bank rather than by the actual vendor.
All these issues result in needless use of network transmission bandwidth, memory and CPU cycles to create documents, transmit messages and perform reconciliation steps. The process is inefficient and there is a clear need for a way to reduce the use of these computing resources and save time in processing transactions via computer.
The appended claims may serve as a summary of the invention.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
Embodiments are described herein in sections according to the following outline:
1.0 GENERAL OVERVIEW
2.0 STRUCTURAL OVERVIEW
3.0 PROCEDURAL OVERVIEW
4.0 GRAPHICAL USER INTERFACE IMPLEMENTATIONS
5.0 BENEFITS OF CERTAIN EMBODIMENTS
6.0 HARDWARE OVERVIEW
7.0 OTHER ASPECTS OF DISCLOSURE
1.0 General Overview
In an embodiment, a programmed computer-implemented method allows enterprises to pay transactions using a virtual credit card at the time of an approved purchase order. The approach maintains corporate controls relating to requisitions and purchase orders. Furthermore, by computer input, users can add controls on virtual cards such as total spend limit or category or suppliers that can charge the virtual card number. The disclosed process eliminates the need for electronic invoicing.
The disclosed techniques also automate the accounting and reconciliation of virtual credit card charges. A particular line item in a card statement, representing a particular charge event, is automatically reconciled to the correct purchase order. Embodiments provide a triple linkage of POs (purchase orders) to charges as they happen to credit card statements, which typically are generated monthly.
The disclosed techniques also allow adding vendor level visibility to credit card transactions. Each charge represented in a card statement can be associated with the supplier that is identified in a corresponding PO. Therefore, a computer graphical user interface (GUI) can show vendor identification at any time, whereas most buyers are not able to see the true vendor in spend data on a credit card charge, as the vendor is typically just represented as the issuing bank.
In an embodiment, a computer-implemented method for improving computer processing efficiency, comprises associating, using a procurement computing device, purchase order data with virtual card data prior to transmitting the purchase order data, over a computer network, to a first external computing device. The method further comprises, in response to receiving, at an end of a first periodic interval, a first information feed over the computer network, performing a first routine, wherein the first routine comprises: processing, using the procurement computing device, the first information feed to generate charge data relating to a first event that occurred during the first periodic interval and is associated with the virtual card data, and electronically storing the charge data in a digital repository accessible by the procurement computing device, associating, using the procurement computing device, the charge data with the purchase order data. The method further comprises, in response to receiving, at an end of a second periodic interval that is longer than the first periodic interval, a second information feed over the computer network, performing a second routine, wherein the second routine comprises, processing, using the procurement computing device, the second information feed to generate statement data associated with at least the virtual card data, associating, using the procurement computing device, the statement data representing the first event with the charge data stored in the digital repository.
In an embodiment, the disclosed techniques result in use of fewer computational resources including fewer network messages, less memory and fewer CPU cycles, for all the reasons set forth in the preceding paragraphs.
Other features, aspects and embodiments will become apparent from the disclosure as a whole including the drawings and claims.
2.0 Structural Overview
In the example of
The server computer 102 may be implemented using a server-class computer or other computers having one or more processor cores, co-processors, or other computers. The server computer 102 may be a physical server computer and/or a virtual server instance stored in a data center, such as through cloud computing.
The server computer 102 may be programmed or configured to store transaction data and analyze the transaction data in order to generate recommendations. The server computer 102 may be coupled to a data repository 106 that is configured for storing past transaction data 104, requisition data 110, PO data 112, virtual card data 113, charge data 115, and statement data 116. The server computer 102 may additionally receive information that is not specific to individual transactions, such as public contact information of suppliers, website URLs for suppliers, and catalogue information for suppliers.
The transactional data 104 may be used to generate recommendations, such as supplier improvement recommendations. The transactional data 104 includes data regarding transactions through one or more software platforms. The transactional data 104 includes data regarding past transactions and data generated from the past transactions. The transaction data 104 may include any of a buyer identifier, a supplier identifier, a buyer generated tag, product information, pricing information, a billing code, location data, a rating for a supplier of the transaction, event data, and any other data associated with the transactions. While transactions are generally described in terms of supplying of goods, a transaction may additionally comprise the purchase of services and/or a combination of goods and services.
Past transactions may include transaction data between a plurality of buyers and a plurality of suppliers. The past transactions may include a supplier ID which identifies the supplier in the transaction, a buyer ID which identifies the buyer in the transaction, an item ID which identifies at least one item purchased in the transaction, and additional transaction details. Additional transaction details may include additional data regarding the transaction, such as a tag for the transaction, a billing code for the purchaser, a number of items purchased, a price per unit of the items, identifiers of one or more other suppliers that bid against the supplier of the transaction, contact information for the supplier, and other transaction details.
In an embodiment, the server computer 102 may additionally store data separate from the transactions that are related to the transactions. For example, the server computer 102 may store supplier profiles that identify suppliers, contact information for the suppliers, win rate for the suppliers, past transactions of the suppliers, categorization data that categorizes items associated with transactions, discount threshold data, and any other data determined or generated by procurement management instructions 103, charge management instructions 107 and payment processing instructions 105 as further described.
Requisition data 110 comprises digitally stored data representing procurement requisitions. PO data 112 comprises digitally stored data representing purchase orders. Virtual card data 113 comprises digitally stored data representing a payment card. Charge data 115 comprises digitally stored data representing one or more charges to the payment card. Statement data 116 comprises digitally stored data representing payment card statements of completed charge transactions. Any such data may include data regarding buyer purchases from suppliers such as cost of items or commodities, quantity, and any subset of transaction data 104 related to buyer acquisitions of items or commodities.
In an embodiment, the server computer 102 is programmed with procurement management instructions 103, charge management instructions 107, and payment instructions 105. Other sets of instructions may be included to form a complete system such as an operating system, utility libraries, a presentation layer, database interface layer and so forth. In an embodiment, the procurement management instructions 103 are programmed to implement a digital electronic procurement management system that can accept requisition data, enforce workflows to transition requisitions to POs, transmit POs to suppliers, and manage supplier-buyer interaction via computer. A commercial example of an online e-procurement system that could be used is Coupa Enterprise, commercially available from Coupa Software Incorporated of San Mateo, Calif.
In an embodiment, the charge management instructions 107 are programmed for associating virtual card data with purchase orders, transmitting virtual card data for use in transactions, allocating charges to accounting events, interfacing with the payment processing instructions to manage charge creation and statement creation, and other functions as further described herein. The charge management instructions 107 may be integrated with the procurement management instructions 103 as part of a single e-procurement system, in some embodiments.
In an embodiment, the payment processing instructions 105 are programmed for generating virtual payment cards, transmitting virtual card data, processing card transaction files, processing statement files, creating and updating charge objects, creating and updating statement objects, and interfacing the procurement management instructions 103 and a virtual card issuer 124. In some embodiments, in keeping with sound software engineering principles of modularity and separation of function, the payment instructions 105 are implemented as a logically separate program, process or library in relation to the procurement management instructions 103.
Computer executable instructions described herein may be in machine executable code in the instruction set of a CPU and may have been compiled based upon source code written in JAVA, C, C++, OBJECTIVE-C, or any other human-readable programming language or environment, alone or in combination with scripts in JAVASCRIPT, other scripting languages and other programming source text. In another embodiment, the programmed instructions also may represent one or more files or projects of source code that are digitally stored in a mass storage device such as non-volatile RAM or disk storage, in the systems of
The computing devices such as the buyer computer 114 and supplier computers 116, 118, 120 may comprise a desktop computer, laptop computer, tablet computer, smartphone, or any other type of computing device that allows access to the server 102. The buyer computer 112 may be associated with one or more buyers. Each supplier computer 116, 118, 120 may be associated with one or more suppliers.
A virtual card issuer 124 may be coupled to network 122 for purposes of interacting with the server computer 102 through an application programming interface (API) or other programmatic mechanism. In general, the virtual card issuer 124 typically is an entity independent of the entity that owns, operates or manages the server computer 102 and is programmed to issue virtual payment card numbers and securely process payment transactions. A commercial example of a virtual card issuer 124 is Conferma Ltd. of Cheshire, United Kingdom.
3.0 Procedural Overview
In general,
Creating and digitally storing programmatic charge objects as supplier charges occur to virtual payment cards is a key innovation of the present disclosure. In response to receiving a daily transaction file from a virtual card issuer 124, the payment layer of an e-procurement system creates and stores a charge object to represent each supplier charge identified in the transaction file and associates the charge objects with existing POs or requisitions. This programmatic step permits later processing the credit card issuer's full monthly statement file and matching statement lines with charges and POs when the statement file arrives at the close of a revolving charge accounting period. Individual charges can be transmitted logically higher to ERP systems or accounting systems for journaling, without manual intervention. Consequently, the reconciliation of buyer credit card statements is fully automated, which has not been possible in prior approaches.
For purposes of describing a clear example, in
Referring first to the upper-left corner of
In response, the virtual card issuer 124 internally creates a virtual payment card, typically represented by a unique card number and other metadata such as date of creation, credit limit, owner or user and other values. At step 1.3, the virtual card issuer 124 sends a reply message indicating that a new virtual payment card was successfully created. In response, at step 1.4, the e-procurement payment layer transmits a message logically upward in the e-procurement system indicating that the virtual payment card was successfully created. At step 1.5, metadata for the virtual payment card is associated or linked, via a pointer or other reference, to the purchase order.
At step 2, a copy of the purchase order, or data derived from the purchase order, is electronically transmitted to a supplier computer 116, 118, 120 of the supplier identified in the PO. This message effectively instructs the supplier to deliver the goods and services identified in the PO. Steps involved with actual manufacture, supply or delivery are outside the scope of this disclosure.
At step 3.1, the e-procurement system instructs the payment layer to transmit virtual card details to the supplier. At step 3.2, the payment layer requests the virtual card issuer 124 to transmit virtual card details to the supplier.
At step 3.3, the virtual card issuer 124 initiates transmission of a virtual card number to the supplier. Data stored at the virtual card issuer 124 specifies, for each supplier, whether card numbers are transmitted directly to the supplier or not. As indicated in the test labeled “card # go to supplier?” if such data permits transmitting a card number to the supplier, then at a first branch of step 3.4, the virtual card number for the buyer's specified virtual payment card is transmitted to the supplier. If the test is negative, then at a second branch of step 3.4, the card number is emailed or otherwise transmitted to the requester associated with the e-procurement system who prepared the original requisition. The requester then is responsible to provide card payment details to the supplier by other means, such as email, other secure data transfer, telefax or telephone.
At this point in the process, a PO has been created, a virtual payment card has been created that is associated with a bank account of the enterprise that is using the e-procurement system, and which the supplier can later charge to receive payment for goods or services, and the payment card details have been transmitted to the supplier. Consequently, the system has created and transmitted all data necessary for the supplier to be paid, and associated payment card data with the PO.
Assume at this point that the supplier properly ships goods or supplies services. At step 4.1, the supplier's accounts receivable department, or other authorized party, charges the card number that was received via step 3.4. The charge is effective to pay the supplier for the goods and services. The charge is processed through the virtual card issuer 124 and details of the charge enter a transaction file, which may be a comma-separated-values (CSV) data file, or any other form of data storage.
At step 4.2, the virtual card issuer 124 transmits the transaction file to the payment layer, with a message requesting the payment layer to process the transaction file or specifying that the transaction file is being delivered.
At step 4.3, the payment layer creates a charge object. The charge object is a programmatic object that is digitally created in memory using object-oriented programming and execution techniques. The charge object comprises data representing a particular card charge transaction as occurred at step 4.1 and reported at step 4.2.
At step 4.4, the payment layer notifies the e-procurement system that the charge object has been created and provides a copy, link or reference to the charge object. At step 4.5, the e-procurement system associates the charge object with the purchase order that was previously created. At step 4.6, the e-procurement system initiates a charge allocation operation, which at step 6.1 may comprise a callback to an enterprise resource planning (ERP) system or other external accounting system, to allocate the charge to the PO in a journal entry.
Steps 4.1, 4.2, 4.3, 4.4, 4.5, and 4.6 may be repeated any number of times within a card statement period with respect to different POs or charges of the same supplier or different suppliers. Each individual card charge that a supplier initiates to pay itself for goods or services associated with a PO results in executing the process of steps 4.1, 4.2, 4.3, 4.4, 4.5, and 4.6.
Upon the close of a revolving charge accounting period, typically monthly, the virtual card issuer 124 automatically generates and transmits a statement file to the payment layer at step 5.1. The statement file comprises digital records of each charge transaction that occurred for a particular card(s) in the preceding accounting period.
At step 5.2, the payment layer processes the file and creates a statement object. The statement object is a programmatic object that is digitally created in memory using object-oriented programming and execution techniques. The statement object comprises data representing the statement file that was created at step 5.1 and processed at step 5.2.
At step 5.3, the payment layer transmits a notification to the e-procurement system signaling that a statement object was created and providing a copy, link or reference to the statement object. At step 5.4, the e-procurement system is programmed to match data in the statement object to charge objects that are stored in memory and/or the data repository 106. At step 6.2, the e-procurement system initiates a statement reconciliation operation, which at step 6.1 may comprise a callback to an enterprise resource planning (ERP) system or other external accounting system, to allocate or associate statement line items to journal entries in the ERP system.
The method 300 begins at step 305, in which a procurement computing device associates purchase order data with virtual card data prior to transmitting the purchase order data, over a computer network, to a first external computing device. In an embodiment, the association of the purchase order data with the virtual card data prior to the purchase order data being transmitted to the first external computing device facilitates elimination of subsequent transmission, over the computer network, of any invoice data relating to the purchase order data after the transmission of the purchase order data to the first external computing device. An example first external computing device is a supplier computing device.
The purchase order data is created from a purchase requisition that has been approved by the procurement computing device and is stored in a digital repository accessible by the procurement computing device. In an embodiment, the creation of the purchase order data triggers a request to generate a virtual card. In an embodiment, the virtual card is generated by an entity independent from the entity that owns, operates or manages the procurement computing device. In an embodiment, this independent entity is a virtual card issuer that owns, operates, or manages a card issuer computing device. The virtual card is associated with a unique card number and includes metadata such as date of creation, credit limit, owner or user and other values. In an embodiment, some values may be controls provided by the owner or user prior to the generation of the virtual card, as conditions to prevent improper use of the unique card number. The procurement computing device stores at least the metadata relating to the virtual card as the virtual card data and associates or links the purchase order data with the virtual card data. In an embodiment, the virtual card data may become invalid under the conditions specified by the owner or user.
At step 310, in response to receiving, at an end of a first periodic interval, a first information feed over the computer network, the procurement computing device performs a first subroutine. In an embodiment, the card issuer computing device generates and transmits to the procurement computing device the first information feed on, for example, a daily basis. In an embodiment, the first information feed includes a transaction file, which may be a comma-separated-values data file, or any other form of data storage, which includes information relating to charge transactions.
Referring now to
At step 330, the procurement computing device associates the charge data with the purchase order data stored in the digital repository. In an embodiment, the procurement computing device may transmit the charge data relating to the first event to a second computing device. An example second external computing device is an enterprise resource planning (ERP) computing device or an accounting computing device configured to allocate the charge data to the purchase order data in a journal entry.
Referring back to
Referring now to
At step 360, the procurement computing device associates the statement data representing the first event with the charge data stored in the digital repository. This association results in an automatic reconciliation of the statement data representing the first event to the purchase order data. The automatic reconciliation may be based on a triple link of the purchase order data to the charge data to the statement data representing the first event. In an embodiment, the procurement computing device may transmit at least the statement data representing the first event to the second external computing device to allocate the statement data to the journal entry. In an embodiment, the frequency of transmission of the charge data to the second external computing device is greater than the frequency of transmission of statement data to the second external computing device.
In an embodiment, the method 300 facilitates elimination of subsequent transmission, over the computer network, of any invoice data relating to the purchase order data. For example, the supplier computing device receives all data necessary for the supplier to be paid prior to delivery of goods or service. In an embodiment, the data necessary for the supplier to be paid are received at or about the time the supplier computing device receives the purchase order data. The supplier may then later charge to receive payment of goods or services without generating an invoice that would otherwise be generated after delivery of goods or services in prior approaches.
In an embodiment, the charge data generated by the procurement computing device includes a sufficient amount of information for the ERP computing device or the accounting computing device to create necessary journal entries. The charge data thus may comprise a portion but not all of data from a typical invoice. As such, the charge data is less complex than the invoice data.
4.0 Graphical User Interface Implementations
5.0 Benefits of Certain Embodiments
Using these techniques, a programmed computer-implemented method allows enterprises to pay transactions using a virtual credit card at the time of an approved purchase order. The approach maintains corporate controls relating to requisitions and purchase orders. Furthermore, by computer input, users can add controls on virtual cards such as total spend limit or category or suppliers that can charge the virtual card number. The disclosed process eliminates the need for electronic invoicing. The disclosed techniques also automate the accounting and reconciliation of virtual credit card charges. A particular line item in a card statement, representing a particular charge event, is automatically reconciled to the correct purchase order. Embodiments provide a triple linkage of POs to charges as they happen to credit card statements, which typically are generated monthly. The disclosed techniques also allow adding vendor level visibility to credit card transactions. Each charge represented in a card statement can be associated with the supplier that is identified in a corresponding PO. Therefore, a computer graphical user interface (GUI) can show vendor identification at any time, whereas most buyers are not able to see the true vendor in spend data on a credit card charge, as the vendor is typically just represented as the issuing bank. Consequently, the disclosed techniques result in use of fewer computational resources including fewer network messages, less memory and fewer CPU cycles, for all the reasons set forth in the preceding paragraphs.
6.0 Hardware Overview
According to one embodiment, the techniques described herein are implemented by at least one computing device. The techniques may be implemented in whole or in part using a combination of at least one server computer and/or other computing devices that are coupled using a network, such as a packet data network. The computing devices may be hard-wired to perform the techniques or may include digital electronic devices such as at least one application-specific integrated circuit (ASIC) or field programmable gate array (FPGA) that is persistently programmed to perform the techniques, or may include at least one general purpose hardware processor programmed to perform the techniques pursuant to program instructions in firmware, memory, other storage, or a combination. Such computing devices may also combine custom hard-wired logic, ASICs, or FPGAs with custom programming to accomplish the described techniques. The computing devices may be server computers, workstations, personal computers, portable computer systems, handheld devices, mobile computing devices, wearable devices, body mounted or implantable devices, smartphones, smart appliances, internetworking devices, autonomous or semi-autonomous devices such as robots or unmanned ground or aerial vehicles, any other electronic device that incorporates hard-wired and/or program logic to implement the described techniques, one or more virtual computing machines or instances in a data center, and/or a network of server computers and/or personal computers.
Computer system 800 includes an input/output (I/O) subsystem 802 which may include a bus and/or other communication mechanism(s) for communicating information and/or instructions between the components of the computer system 800 over electronic signal paths. The I/O subsystem 802 may include an I/O controller, a memory controller and at least one I/O port. The electronic signal paths are represented schematically in the drawings, for example as lines, unidirectional arrows, or bidirectional arrows.
At least one hardware processor 804 is coupled to I/O subsystem 802 for processing information and instructions. Hardware processor 804 may include, for example, a general-purpose microprocessor or microcontroller and/or a special-purpose microprocessor such as an embedded system or a graphics processing unit (GPU) or a digital signal processor or ARM processor. Processor 804 may comprise an integrated arithmetic logic unit (ALU) or may be coupled to a separate ALU.
Computer system 800 includes one or more units of memory 806, such as a main memory, which is coupled to I/O subsystem 802 for electronically digitally storing data and instructions to be executed by processor 804. Memory 806 may include volatile memory such as various forms of random-access memory (RAM) or other dynamic storage device. Memory 806 also may be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 804. Such instructions, when stored in non-transitory computer-readable storage media accessible to processor 804, can render computer system 800 into a special-purpose machine that is customized to perform the operations specified in the instructions.
Computer system 800 further includes non-volatile memory such as read only memory (ROM) 808 or other static storage device coupled to I/O subsystem 802 for storing information and instructions for processor 804. The ROM 808 may include various forms of programmable ROM (PROM) such as erasable PROM (EPROM) or electrically erasable PROM (EEPROM). A unit of persistent storage 810 may include various forms of non-volatile RAM (NVRAM), such as FLASH memory, or solid-state storage, magnetic disk or optical disk such as CD-ROM or DVD-ROM and may be coupled to I/O subsystem 802 for storing information and instructions. Storage 810 is an example of a non-transitory computer-readable medium that may be used to store instructions and data which when executed by the processor 804 cause performing computer-implemented methods to execute the techniques herein.
The instructions in memory 806, ROM 808 or storage 810 may comprise one or more sets of instructions that are organized as modules, methods, objects, functions, routines, or calls. The instructions may be organized as one or more computer programs, operating system services, or application programs including mobile apps. The instructions may comprise an operating system and/or system software; one or more libraries to support multimedia, programming or other functions; data protocol instructions or stacks to implement TCP/IP, HTTP or other communication protocols; file format processing instructions to parse or render files coded using HTML, XML, JPEG, MPEG or PNG; user interface instructions to render or interpret commands for a graphical user interface (GUI), command-line interface or text user interface; application software such as an office suite, internet access applications, design and manufacturing applications, graphics applications, audio applications, software engineering applications, educational applications, games or miscellaneous applications. The instructions may implement a web server, web application server or web client. The instructions may be organized as a presentation layer, application layer and data storage layer such as a relational database system using structured query language (SQL) or no SQL, an object store, a graph database, a flat file system or other data storage.
Computer system 800 may be coupled via I/O subsystem 802 to at least one output device 812. In one embodiment, output device 812 is a digital computer display. Examples of a display that may be used in various embodiments include a touch screen display or a light-emitting diode (LED) display or a liquid crystal display (LCD) or an e-paper display. Computer system 800 may include other type(s) of output devices 812, alternatively or in addition to a display device. Examples of other output devices 812 include printers, ticket printers, plotters, projectors, sound cards or video cards, speakers, buzzers or piezoelectric devices or other audible devices, lamps or LED or LCD indicators, haptic devices, actuators or servos.
At least one input device 814 is coupled to I/O subsystem 802 for communicating signals, data, command selections or gestures to processor 804. Examples of input devices 814 include touch screens, microphones, still and video digital cameras, alphanumeric and other keys, keypads, keyboards, graphics tablets, image scanners, joysticks, clocks, switches, buttons, dials, slides, and/or various types of sensors such as force sensors, motion sensors, heat sensors, accelerometers, gyroscopes, and inertial measurement unit (IMU) sensors and/or various types of transceivers such as wireless, such as cellular or Wi-Fi, radio frequency (RF) or infrared (IR) transceivers and Global Positioning System (GPS) transceivers.
Another type of input device is a control device 816, which may perform cursor control or other automated control functions such as navigation in a graphical interface on a display screen, alternatively or in addition to input functions. Control device 816 may be a touchpad, a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 804 and for controlling cursor movement on display 812. The input device may have at least two degrees of freedom in two axes, a first axis (for example, x) and a second axis (for example, y), that allows the device to specify positions in a plane. Another type of input device is a wired, wireless, or optical control device such as a joystick, wand, console, steering wheel, pedal, gearshift mechanism or other type of control device. An input device 814 may include a combination of multiple different input devices, such as a video camera and a depth sensor.
In another embodiment, computer system 800 may comprise an internet of things (IoT) device in which one or more of the output device 812, input device 814, and control device 816 are omitted. Or, in such an embodiment, the input device 814 may comprise one or more cameras, motion detectors, thermometers, microphones, seismic detectors, other sensors or detectors, measurement devices or encoders and the output device 812 may comprise a special-purpose display such as a single-line LED or LCD display, one or more indicators, a display panel, a meter, a valve, a solenoid, an actuator or a servo.
When computer system 800 is a mobile computing device, input device 814 may comprise a global positioning system (GPS) receiver coupled to a GPS module that is capable of triangulating to a plurality of GPS satellites, determining and generating geo-location or position data such as latitude-longitude values for a geophysical location of the computer system 800. Output device 812 may include hardware, software, firmware and interfaces for generating position reporting packets, notifications, pulse or heartbeat signals, or other recurring data transmissions that specify a position of the computer system 800, alone or in combination with other application-specific data, directed toward host 824 or server 830.
Computer system 800 may implement the techniques described herein using customized hard-wired logic, at least one ASIC or FPGA, firmware and/or program instructions or logic which when loaded and used or executed in combination with the computer system causes or programs the computer system to operate as a special-purpose machine. According to one embodiment, the techniques herein are performed by computer system 800 in response to processor 804 executing at least one sequence of at least one instruction contained in main memory 806. Such instructions may be read into main memory 806 from another storage medium, such as storage 810. Execution of the sequences of instructions contained in main memory 806 causes processor 804 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions.
The term “storage media” as used herein refers to any non-transitory media that store data and/or instructions that cause a machine to operation in a specific fashion. Such storage media may comprise non-volatile media and/or volatile media. Non-volatile media includes, for example, optical or magnetic disks, such as storage 810. Volatile media includes dynamic memory, such as memory 806. Common forms of storage media include, for example, a hard disk, solid state drive, flash drive, magnetic data storage medium, any optical or physical data storage medium, memory chip, or the like.
Storage media is distinct from but may be used in conjunction with transmission media. Transmission media participates in transferring information between storage media. For example, transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise a bus of I/O subsystem 802. Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
Various forms of media may be involved in carrying at least one sequence of at least one instruction to processor 804 for execution. For example, the instructions may initially be carried on a magnetic disk or solid-state drive of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a communication link such as a fiber optic or coaxial cable or telephone line using a modem. A modem or router local to computer system 800 can receive the data on the communication link and convert the data to a format that can be read by computer system 800. For instance, a receiver such as a radio frequency antenna or an infrared detector can receive the data carried in a wireless or optical signal and appropriate circuitry can provide the data to I/O subsystem 802 such as place the data on a bus. I/O subsystem 802 carries the data to memory 806, from which processor 804 retrieves and executes the instructions. The instructions received by memory 806 may optionally be stored on storage 810 either before or after execution by processor 804.
Computer system 800 also includes a communication interface 818 coupled to bus 802. Communication interface 818 provides a two-way data communication coupling to network link(s) 820 that are directly or indirectly connected to at least one communication networks, such as a network 822 or a public or private cloud on the Internet. For example, communication interface 818 may be an Ethernet networking interface, integrated-services digital network (ISDN) card, cable modem, satellite modem, or a modem to provide a data communication connection to a corresponding type of communications line, for example an Ethernet cable or a metal cable of any kind or a fiber-optic line or a telephone line. Network 822 broadly represents a local area network (LAN), wide-area network (WAN), campus network, internetwork or any combination thereof. Communication interface 818 may comprise a LAN card to provide a data communication connection to a compatible LAN, or a cellular radiotelephone interface that is wired to send or receive cellular data according to cellular radiotelephone wireless networking standards, or a satellite radio interface that is wired to send or receive digital data according to satellite wireless networking standards. In any such implementation, communication interface 818 sends and receives electrical, electromagnetic or optical signals over signal paths that carry digital data streams representing various types of information.
Network link 820 typically provides electrical, electromagnetic, or optical data communication directly or through at least one network to other data devices, using, for example, satellite, cellular, Wi-Fi, or BLUETOOTH technology. For example, network link 820 may provide a connection through a network 822 to a host computer 824.
Furthermore, network link 820 may provide a connection through network 822 or to other computing devices via internetworking devices and/or computers that are operated by an Internet Service Provider (ISP) 826. ISP 826 provides data communication services through a world-wide packet data communication network represented as internet 828. A server computer 830 may be coupled to internet 828. Server 830 broadly represents any computer, data center, virtual machine or virtual computing instance with or without a hypervisor, or computer executing a containerized program system such as DOCKER or KUBERNETES. Server 830 may represent an electronic digital service that is implemented using more than one computer or instance and that is accessed and used by transmitting web services requests, uniform resource locator (URL) strings with parameters in HTTP payloads, API calls, app services calls, or other service calls. Computer system 800 and server 830 may form elements of a distributed computing system that includes other computers, a processing cluster, server farm or other organization of computers that cooperate to perform tasks or execute applications or services. Server 830 may comprise one or more sets of instructions that are organized as modules, methods, objects, functions, routines, or calls. The instructions may be organized as one or more computer programs, operating system services, or application programs including mobile apps. The instructions may comprise an operating system and/or system software; one or more libraries to support multimedia, programming or other functions; data protocol instructions or stacks to implement TCP/IP, HTTP or other communication protocols; file format processing instructions to parse or render files coded using HTML, XML, JPEG, MPEG or PNG; user interface instructions to render or interpret commands for a graphical user interface (GUI), command-line interface or text user interface; application software such as an office suite, internet access applications, design and manufacturing applications, graphics applications, audio applications, software engineering applications, educational applications, games or miscellaneous applications. Server 830 may comprise a web application server that hosts a presentation layer, application layer and data storage layer such as a relational database system using structured query language (SQL) or no SQL, an object store, a graph database, a flat file system or other data storage.
Computer system 800 can send messages and receive data and instructions, including program code, through the network(s), network link 820 and communication interface 818. In the Internet example, a server 830 might transmit a requested code for an application program through Internet 828, ISP 826, local network 822 and communication interface 818. The received code may be executed by processor 804 as it is received, and/or stored in storage 810, or other non-volatile storage for later execution.
The execution of instructions as described in this section may implement a process in the form of an instance of a computer program that is being executed, and consisting of program code and its current activity. Depending on the operating system (OS), a process may be made up of multiple threads of execution that execute instructions concurrently. In this context, a computer program is a passive collection of instructions, while a process may be the actual execution of those instructions. Several processes may be associated with the same program; for example, opening up several instances of the same program often means more than one process is being executed. Multitasking may be implemented to allow multiple processes to share processor 804. While each processor 804 or core of the processor executes a single task at a time, computer system 800 may be programmed to implement multitasking to allow each processor to switch between tasks that are being executed without having to wait for each task to finish. In an embodiment, switches may be performed when tasks perform input/output operations, when a task indicates that it can be switched, or on hardware interrupts. Time-sharing may be implemented to allow fast response for interactive user applications by rapidly performing context switches to provide the appearance of concurrent execution of multiple processes simultaneously. In an embodiment, for security and reliability, an operating system may prevent direct communication between independent processes, providing strictly mediated and controlled inter-process communication functionality.
7.0 Other Aspects of Disclosure
In the foregoing specification, embodiments of the invention have been described with reference to numerous specific details that may vary from implementation to implementation. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. The sole and exclusive indicator of the scope of the invention, and what is intended by the applicants to be the scope of the invention, is the literal and equivalent scope of the set of claims that issue from this application, in the specific form in which such claims issue, including any subsequent correction.
Any definitions expressly set forth herein for terms contained in such claims shall govern the meaning of such terms as used in the claims. Hence, no limitation, element, property, feature, advantage or attribute that is not expressly recited in a claim should limit the scope of such claim in any way. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
As used herein the terms “include” and “comprise” (and variations of those terms, such as “including”, “includes”, “comprising”, “comprises”, “comprised” and the like) are intended to be inclusive and are not intended to exclude further features, components, integers or steps.
Various operations have been described using flowcharts. In certain cases, the functionality/processing of a given flowchart step may be performed in different ways to that described and/or by different systems or system modules. Furthermore, in some cases a given operation depicted by a flowchart may be divided into multiple operations and/or multiple flowchart operations may be combined into a single operation. Furthermore, in certain cases the order of operations as depicted in a flowchart and described may be able to be changed without departing from the scope of the present disclosure.
It will be understood that the embodiments disclosed and defined in this specification extends to all alternative combinations of two or more of the individual features mentioned or evident from the text or drawings. All of these different combinations constitute various alternative aspects of the embodiments.
This application claims the benefit under 35 U.S.C. § 119(e) of provisional application 62/667,053, filed May 4, 2018, the entire contents of which is hereby incorporated by reference as if fully set forth herein.
Number | Name | Date | Kind |
---|---|---|---|
6941285 | Sarcanin | Sep 2005 | B2 |
7500598 | Davis | Mar 2009 | B2 |
9292871 | Isaacson | Mar 2016 | B2 |
10580070 | Keithley | Mar 2020 | B2 |
20050177507 | Bandych | Aug 2005 | A1 |
20100094735 | Reynolds | Apr 2010 | A1 |
20100174556 | Wilkins | Jul 2010 | A1 |
20120221421 | Hammad | Aug 2012 | A1 |
Number | Date | Country | |
---|---|---|---|
62667053 | May 2018 | US |