The present disclosure relates to distributed ledgers for information technology asset management, and more specifically to management of a distributed ledger across information technology assets using rotating master-slave relationships, cryptocurrencies, and/or blockchains.
As part of the Internet of Things (IoT), the ability for devices to communicate with one another and with other computing systems continues to increase. For example, users can control smart thermostats, smart lighting, smart speakers, etc., all using smartphones, computers, tablets, or other networked devices. However, while these IoT devices can communicate with one another, such communications lack information which can be used to determine when the IoT devices are beginning to fail or need maintenance. Moreover, tracking this information over time, across facilities, or even across devices as devices are replaced, can result in network and system inefficiencies.
Disclosed are systems, methods, and non-transitory computer-readable storage media for using a distributed ledger to track and manage information technology fixture assets. An exemplary method for performing concepts according to this disclosure can include: receiving, at a first device in a plurality of devices connected via a network, metadata associated with a second device in the plurality of devices, wherein each device in the plurality of devices requires connection to the network for full operational capability; comparing, via a processor on the first device, the metadata to at least a portion of a distributed ledger, to yield a comparison, the distributed ledger comprising a blockchain, wherein: the first device stores at least the portion of the distributed ledger; an entirety of the distributed ledger is stored across the plurality of devices; the comparing compares the metadata to previously stored first metrics of the first device which were stored in the distributed ledger; and the comparing further compares the metadata to previously stored other metrics of other devices in the plurality of devices which were stored in the distributed ledger; identifying, via the processor and based on the comparison, a distinction in the metadata and at least one of the first metrics and the other metrics stored in the distributed ledger; generating, via the processor and based on the distinction, a modification to the distributed ledger, the modification comprising a new block added to the blockchain; transmitting, to at least one other device in the plurality of devices, the modification; generating, via the processor and based on the distinction, a work order for the first device; initiating, via the processor, payment for the work order using a cryptocurrency wallet associated with the first device.
An exemplary system configured according to this disclosure can include: receiving, at a first device in a plurality of devices connected via a network, metadata associated with a second device in the plurality of devices, wherein each device in the plurality of devices requires connection to the network for full operational capability; comparing, on the first device, the metadata to at least a portion of a distributed ledger, to yield a comparison, wherein: the first device stores at least the portion of the distributed ledger; an entirety of the distributed ledger is stored across the plurality of devices; the comparing compares the metadata to previously stored first metrics of the first device which were stored in the distributed ledger; and the comparing further compares the metadata to previously stored other metrics of other devices in the plurality of devices which were stored in the distributed ledger; identifying, based on the comparison, a distinction in the metadata and at least one of the first metrics and the other metrics stored in the distributed ledger; generating, based on the distinction, a modification to the distributed ledger; and transmitting, to at least one other device in the plurality of devices, the modification.
An exemplary non-transitory computer-readable storage medium configured according to this disclosure can have instructions stored which, when executed by a computing device, cause the computing device to perform operations which include: receiving, at a first device in a plurality of devices connected via a network, metadata associated with a second device in the plurality of devices, wherein each device in the plurality of devices requires connection to the network for full operational capability; comparing, on the first device, the metadata to at least a portion of a distributed ledger, to yield a comparison, wherein: the first device stores at least the portion of the distributed ledger; an entirety of the distributed ledger is stored across the plurality of devices; the comparing compares the metadata to previously stored first metrics of the first device which were stored in the distributed ledger; and the comparing further compares the metadata to previously stored other metrics of other devices in the plurality of devices which were stored in the distributed ledger; identifying, based on the comparison, a distinction in the metadata and at least one of the first metrics and the other metrics stored in the distributed ledger; generating, based on the distinction, a modification to the distributed ledger; and transmitting, to at least one other device in the plurality of devices, the modification.
Additional features and advantages of the disclosure will be set forth in the description which follows, and in part will be obvious from the description, or can be learned by practice of the herein disclosed principles. The features and advantages of the disclosure can be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the disclosure will become more fully apparent from the following description and appended claims, or can be learned by the practice of the principles set forth herein.
Various embodiments of the disclosure are described in detail below. While specific implementations are described, it should be understood that this is done for illustration purposes only. Other components and configurations may be used without parting from the spirit and scope of the disclosure.
The present disclosure addresses a distributed ledger system which can be used to track and manage information technology assets using rotating master-slave relationships, cryptocurrencies, and/or blockchains. Exemplary, non-limiting information technology assets can include cash registers, ATMs (Automated Teller Machines), MC40s or other mobile inventory management devices, computers, electronic scales, kiosks, signature pads, etc. Each of these devices are not fully operational without connection to a network (such as the Internet). For example, modern cash registers transmit information about which items were purchased and the amounts received to a server or other computing device, which requires a network connection. Likewise, MC40s or other mobile computer support tools transmit and receive data (such as inventory or pricing data) using a network connection.
Information technology assets configured according to this disclosure may connect to a network, such as the Internet, or may communicate directly with other information technology assets to form a mesh network. A distributed ledger is maintained among the information technology assets, with information about the various assets being recorded in the distributed ledger. This recording of new data/updating of the distributed ledger can, for example, begin at the asset having data which needs to be added to the ledger. That asset can periodically, or as needed, identify data to be added to the ledger, update the portion of the ledger stored on the asset, then forward the modified/updated ledger to the other information technology assets which share the distributed ledger. For example, every hour information about how much electricity is being consumed by a cash register can be added to the distributed ledger which is shared with an electronic scale and a mobile inventory device. After the cash register makes the addition to the portion of the distributed ledger associated with the cash register, the cash register can forward/transmit the updated portion to the electronic scale, the mobile inventory device, and any other assets which share the distributed ledger.
In such configurations, each individual asset can be configured to process its respective data and make determinations based on the data. For example, if a processor associated with an ATM compares the electricity consumption for dispersing cash is exceeding a known limit and determines that human assistance is required, the ATM can generate a notification to request human assistance. However, other assets may also be configured to analyze data associated with the shelf and act upon those determinations. For example, the ATM may record the electricity being used to disperse cash by updating the distributed ledger, then transmit the updated distributed ledger to the other assets. One of those other assets which receive the updated distributed ledger may be a MC40 being used for inventory management. The MC40 can analyze the updated distributed ledger, identify that the electricity exceeds a threshold value, and generate a notification to humans in the vicinity.
In some combinations, rather than each asset modifying portions of the distributed ledger, then forwarding the modified portion to one or more additional assets, the assets can instead be arranged in a master-slave configuration. In this configuration, certain assets (“masters”) receive data from the assets identified as “slaves.” The master can then determine if the data received from the slave needs to be added to the distributed ledger, and if so can make the addition to the distributed ledger and propagate the update to the appropriate assets. This makes the computer system and network more efficient by reducing network traffic and freeing up the system to handle other task more quickly.
For example, in a retail location there may be a dozen cash registers as well as security cameras watching parts of the store. While in some configurations each cash register and camera may be configured to add data to the distributed ledger, in other configurations a single cash register from the dozen cash registers may be selected as the master asset. Each remaining cash register and/or security camera then transmits data which is specific to that device to the master cash register. Exemplary data transmitted and received can include data such as current pulled, average temperature, number of door openings (for cash registers or ATMs), duration of door openings, disk space available, and/or metadata (data which describes other data). In the cases of periodic transmission, the master asset can then determine if the data received is of sufficient importance to add the data to the distributed ledger. However, in some cases, the individual assets do not transmit data unless the information meets a threshold level of importance indicating the data needs to be acted upon or needs to be recorded, and in those cases the master asset would immediately take actions based on the reception of the other asset's data.
In some configurations, selection of the master asset from among various assets can be based on the type of assets available, the processing capacity of those assets, the location of the asset, and/or the connection bandwidth the master asset has to the network (or an access point for the network). This selection can be based on those factors increasing the speed and/or efficiency in transmitting updated ledgers to the other assets and/or the speed in communicating with other facets of the network. If one or more of those factors change, the asset identified as the master asset may change. For example, in a group of assets including a security camera, a cash register, an ATM, and a kiosk, the kiosk may have the best communication capacity for communicating with the other three assets, and the kiosk is therefore made the master node for the group. However, when the kiosk is moved it may lose that communication superiority, at which time the group of assets may select a distinct asset to be the master asset.
In some configurations, the individual assets or a master asset can relay the data received to a central computing system (such as a server) which analyzes the data and generates alerts based on the data received from the various asserts. That is, depending on the configuration, the analysis of asset behavior can be done by the asset itself, another asset within a group of assets, a master asset, or other device such as a server. In the case of a server, if a cash register begins to draw current significantly higher (above a threshold amount) than other cash registers in a group of cash registers, or more current than previously drawn by that asset, the server may generate a maintenance request (or even trigger an end-of-life determination) for the cash register. Determining how much current was previously drawn by a given unit, or the average current drawn by other units, can be determined by accessing the distributed ledger. In the case of the server, the server may have a distinct database storing the data in conjunction with the distributed ledger.
When units is replaced, due to the distributed ledger being partitioned across multiple assets, with every piece of data being duplicated across multiple locations, the replacement asset can receive the portion of the data which was previously stored on the removed/replaced asset. Using the allocated data, the system can determine if the replacement asset is functioning in an improved manner compared to the replaced asset, become integrated into the group of assets, as well as identify future problems for the individual asset.
The form of the distributed ledger can vary between configurations. For example, in some configurations, encryption or data security may be critical and therefore used to protect the data transmissions/storage. In other configurations, the need to verify the source of the data or the veracity of transactions may be paramount, in which case a blockchain can be part of the distributed ledger. Specifically, the blockchain can be used to contain new pieces of data/metadata in new blocks being added to an existing blockchain, and these new blocks can be created upon determining that certain predefined conditions have been met. The new block can then be transmitted/communicated to the other assets in the group for verification of the block's veracity. The other assets in the group of assets can verify the new block based on encryption, identifications, etc., included in the block. Upon verification, the new block can be added to the blockchain, and the updated distributed ledger (which includes the updated blockchain) can be distributed amongst the group.
Requests, notifications, additions to the distributed ledger blockchain, etc., can all require a payment associated with the asset producing the data. Such actions can vary in cost based on what is required. In some cases this can be a payment using a fictional “allowance” of credits or other metric, thereby allowing the system to track the frequency and/or levels of actions being taken by the assets. In other cases, the payment can be a literal payment, requiring a payment in a currency such as the U.S. dollar, the European Euro, etc. The payment may also be made using various cryptocurrencies, such as Bitcoin or Ethereum. In either case, each asset may have an individualized account or wallet linked to the remaining amount of available currency/cryptocurrency available for the asset to make requests. When the amount of funds in the account or wallet reach a threshold amount (such as when the funds are running low), a notification can be generated indicating that the asset needs more funds allocated to it. In some cases, however, the notification may indicate that the asset has used all of its allocated funds and is due to be replaced.
As time progresses, the system can iteratively improve based on past data. This machine learning process takes specific data associated with the assets, compares that data to the frequency of the actions taken, and makes modifications to the processes performed by the assets based on that comparison. For example, if the system determines that a certain class of asset, or an asset at a specific geographic location, provides the best communication efficiency for the system (based on the data rates, bit-error rates, bandwidth, etc.), the system can defer repeated testing to identify a master asset, instead selecting the master asset based on previously identified parameters (and reducing the frequency of verifying that decision as the most efficient). As another example, the system can compare the data associated with various sensors (such as current or voltage levels), and based on specific values determine likelihoods of component failure within the respective assets. While generating notifications for humans the system can then include those likelihoods. Alternatively, if the system has identified a modification which reduces the likelihood of the particular component failure indicated by asset data, the system can automatically initiate that modification.
The group of information technology assets 102-112 can communicate with one another via the network 114. In addition, the group of information technology assets 102-112 can share information using a distributed ledger, where each individual asset within the group of information technology assets 102-112 contains either (1) an entirety of the distributed ledger, or (2) a portion of the distributed ledger. The distributed ledger can function as a database of information, such that each individual asset can look up information about historical behavior, thresholds, etc., as needed.
In an example, a number of assets 306, 308, 310 are in communication with the access point 302. The communication may take place over one or connections with the access point 304 for each asset 306, 308, 310. Various physical parameters that reflect the strength or throughput of the connection are determined. The assets 306, 308, 310 determine which of the assets should be the connection point to the access point. The authority to make this determination and/or to use one of the assets as the connection may be set forth in a smart contract implemented on blockchain. The smart contract may set forth the terms of determination and the authority for the selected asset to act on behalf of the other assets. The determination of the asset (node) to make the connection to the access point may be adaptive and based on physical data regarding signal strength, upload and download speeds, and other physical parameters.
In this example, asset “2” 404 transmits 422 data (or metadata) to asset “1” 402. Asset “1” 402 analyzes the data and determines that the newly received data needs to be added to the distributed ledger. In a distributed ledger which uses blockchain, this can require generation of a new block to be added to the blockchain, whereas in non-blockchain ledgers this can require generation of a new portion of the distributed ledger. In this example, asset “1” 402 generates a new portion of data “F” 424, which is then transmitted 426 and distributed as needed to the other assets in the group of assets 402-410. As illustrated, asset “2” 404 receives part “F” 424 from asset “1” 402, then stores “F” 428 in memory specific to asset “2” 404. Asset “2” 404 also forwards 430 part “F” to asset “5” 410, which then also stores part “F” 432.
After the process illustrated in
The first device can then identify, via the processor and based on the comparison, a distinction in the metadata and at least one of the first metrics and the other metrics stored in the distributed ledger (614). The first device can also generate, via the processor and based on the distinction, a modification to the distributed ledger, the modification comprising a new block added to the blockchain (616). The first device can transmit, to at least one other device in the plurality of devices, the modification (618) and generate, via the processor and based on the distinction, a work order for the first device (620). Also, the first device can initiate, via the processor, payment for the work order using a cryptocurrency wallet associated with the first device (622).
In some configurations, the first device can be selected from among the plurality of devices to receive the metadata and perform operations based on a higher relative throughput of data than other devices in the plurality of devices, the other devices including the second device. The higher relative throughput of data can include transmitting and receiving data associated with the distributed ledger to at least one of a central computer and a network access point and/or transmitting and receiving data associated with the distributed ledger to the other devices in the plurality of devices.
In some configurations, the primary function of each respective device in the plurality of devices can include one or more of completing sales, electronic weighing, automated telling, dispersing goods, receiving signatures, communicating with a network, and managing inventory.
Non-limiting examples of the metadata can include sensor data from a sensor in the second device, the sensor data comprising one of voltage data of the second device, current data of the second device, efficiency of the second device in performing the primary function, and efficiency of the second device in communications with the plurality of devices.
In some configurations, the new block can be verified as valid by other devices in the plurality of devices.
In some configurations, the metadata may be received on a periodic basis.
With reference to
The system bus 710 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. A basic input/output (BIOS) stored in ROM 740 or the like, may provide the basic routine that helps to transfer information between elements within the computing device 700, such as during start-up. The computing device 700 further includes storage devices 760 such as a hard disk drive, a magnetic disk drive, an optical disk drive, tape drive or the like. The storage device 760 can include software modules 762, 764, 766 for controlling the processor 720. Other hardware or software modules are contemplated. The storage device 760 is connected to the system bus 710 by a drive interface. The drives and the associated computer-readable storage media provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for the computing device 700. In one aspect, a hardware module that performs a particular function includes the software component stored in a tangible computer-readable storage medium in connection with the necessary hardware components, such as the processor 720, bus 710, display 770, and so forth, to carry out the function. In another aspect, the system can use a processor and computer-readable storage medium to store instructions which, when executed by the processor, cause the processor to perform a method or other specific actions. The basic components and appropriate variations are contemplated depending on the type of device, such as whether the device 700 is a small, handheld computing device, a desktop computer, or a computer server.
Although the exemplary embodiment described herein employs the hard disk 760, other types of computer-readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, digital versatile disks, cartridges, random access memories (RAMs) 750, and read-only memory (ROM) 740, may also be used in the exemplary operating environment. Tangible computer-readable storage media, computer-readable storage devices, or computer-readable memory devices, expressly exclude media such as transitory waves, energy, carrier signals, electromagnetic waves, and signals per se.
To enable user interaction with the computing device 700, an input device 790 represents any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. An output device 770 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems enable a user to provide multiple types of input to communicate with the computing device 700. The communications interface 780 generally governs and manages the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed.
The steps outlined herein are exemplary and can be implemented in any combination thereof, including combinations that exclude, add, or modify certain steps. In addition, the examples and configurations described may be combined as necessary provided
Use of language such as “at least one of X, Y, and Z” or “at least one or more of X, Y, or Z” are intended to convey a single item (just X, or just Y, or just Z) or multiple items (i.e., {X and Y}, {Y and Z}, or {X, Y, and Z}). “At least one of” is not intended to convey a requirement that each possible item must be present.
The various embodiments described above are provided by way of illustration only and should not be construed to limit the scope of the disclosure. Various modifications and changes may be made to the principles described herein without following the example embodiments and applications illustrated and described herein, and without departing from the spirit and scope of the disclosure.
The present application claims priority to U.S. Provisional Application No. 62/715,346, filed Aug. 7, 2018, the contents of which are incorporated herein in their entirety.
Number | Date | Country | |
---|---|---|---|
62715346 | Aug 2018 | US |