This disclosure generally relates to mechanisms for secure and reliable communication of information involving cargo distribution terminals, such as in oil and gas distribution terminals or in other product distribution systems. More specifically, this disclosure relates to terminal automation solutions supporting blockchain technology.
Throughout history, the shipment and distribution of goods have been essential. Movement of goods from one location to another often involves the loading or unloading of cargo at distribution terminals, such as warehouses, ports, or storage terminals. The cargo is unloaded from and loaded onto cargo transporting vehicles, such as trucks, trains, and ships.
Due to the frequent arrival and departure of many cargo transporting vehicles and a limited number of cargo bays, some distribution terminals have deployed terminal automation systems. These terminal automation systems are typically designed to manage and schedule the loading and unloading of cargo involving numerous cargo transporting vehicles. However, these terminal automation systems are often implemented using hardware devices and software solutions hosted locally, with no interaction with other terminals.
This disclosure provides terminal automation solutions supporting blockchain technology.
In a first embodiment, a method includes obtaining data associated with at least one of: (i) one or more products stored in or transferred via a first cargo distribution terminal, (ii) one or more actions occurring in the first cargo distribution terminal, and (iii) one or more personnel associated with the first cargo distribution terminal or the one or more products. The method also includes generating an update to a blockchain based on the data and updating a local copy of the blockchain using the update. The method further includes publishing the update to one or more nodes for updating one or more additional copies of the blockchain.
In a second embodiment, an apparatus includes at least one memory configured to store data associated with at least one of: (i) one or more products stored in or transferred via a first cargo distribution terminal, (ii) one or more actions occurring in the first cargo distribution terminal, and (iii) one or more personnel associated with the first cargo distribution terminal or the one or more products. The apparatus also includes at least one processor configured to generate an update to a blockchain based on the data, update a local copy of the blockchain using the update, and publish the update to one or more nodes for updating one or more additional copies of the blockchain.
In a third embodiment, a non-transitory computer readable medium contains instructions that when executed cause at least one processor to obtain data associated with at least one of: (i) one or more products stored in or transferred via a first cargo distribution terminal, (ii) one or more actions occurring in the first cargo distribution terminal, and (iii) one or more personnel associated with the first cargo distribution terminal or the one or more products. The medium also contains instructions that when executed cause the at least one processor to generate an update to a blockchain based on the data, update a local copy of the blockchain using the update, and publish the update to one or more nodes for updating one or more additional copies of the blockchain.
Other technical features may be readily apparent to one skilled in the art from the following figures, descriptions, and claims.
For a more complete understanding of this disclosure, reference is now made to the following description, taken in conjunction with the accompanying drawings, in which:
As noted above, cargo distribution terminals (such as warehouses, ports, or storage terminals) typically receive cargo from and deliver cargo to many cargo transporting vehicles (such as trucks, trains, or ships). Due to frequent arrivals and departures of many cargo transporting vehicles and a limited number of cargo bays, some distribution terminals have deployed terminal automation systems designed to manage and schedule the loading and unloading of cargo. However, terminal automation systems are often implemented using hardware devices and software solutions hosted locally without any interactions with other terminals.
Terminal owners and operators may rely heavily on the trust and transparency built among multiple stakeholders, such as shareholders, terminal owners, terminal operators, carrier companies, and terminal customers. Currently, different stakeholders have different systems and databases at every stage, and there is no automated synchronization happening across these systems. Manual interactions between untrusted parties make the supply chain less efficient and can result in higher operational costs.
As particular examples, it is currently difficult for the owners or operators of multiple distribution terminals to exchange information about truck drivers who enter and exit their terminals in order to drop off or pick up cargo. Product pilferage during transfers in trucks can result in huge losses for customers, but it is difficult for terminal owners or operators to exchange information about drivers who may be engaging in or allowing pilferage. Also, drivers who deviate from standard operating procedures (SOPs) at the gantries of terminals can create safety issues inside the terminals, but it is difficult for owners or operators of some terminals to obtain information identifying improper driver behaviors at other terminals. Further, the inability to track driver or vehicle activities can prevent identification of the drivers' overall performance across different terminals. In addition, the lack of stock reconciliation can reduce transparency to customers, particularly when those customers have products that are stored in comingling tanks (meaning multiple customers' products are stored in the same tank).
In accordance with this disclosure, various techniques are provided for using one or more blockchains to store information used with terminal automation solutions. For example, the blockchains can be used to store information about terminal operations and cargo stored in one or more terminals. The blockchains can also be used to store information about suppliers that provide the cargo, carrier companies that transport the cargo, and customers who receive the cargo. The blockchains can further be used to store information about specific drivers or vehicles used to transport the cargo. Among other things, having this data available in one or more blockchains allows terminals, their customers, and other parties to be connected more reliably and allows them to share useful and valid information across terminals. This helps to establish and increase trust among the various parties involved in cargo distribution operations. It also makes this data easily available for use by any interested party associated with the cargo distribution operations.
As shown in
Except for the first block 102a in the blockchain 100, each block 102 includes a previous hash value 104, which represents a cryptographic hash from the previous block 102 in the blockchain 100. Each block 102 also includes a timestamp 106, which identifies the date and time that the associated block 102 was created. Each block 102 further includes a nonce value 108, which represents a value that is added to the block 102 by the party who created the block 102. The nonce value 108 provides proof to other parties that the party who created the block 102 performed certain cryptographic operations in order to generate a valid block 102, where the other parties can easily verify the validity of the block 102 using the nonce value 108.
In addition, each block 102 includes transaction data, which includes a transaction root hash value 110. The transaction root hash value 110 in each block 102 represents a hash value generated by the party who created that block 102 based on transaction information. In this example, the transaction root hash value 110 in each block 102 can be generated by taking data 112 associated with one or more transactions (such as actual data or metadata describing the transactions) and applying one or more hashing functions using the data 112. This generates one or more hash values 114. Assuming there are multiple hash values 114, one or more additional hashing functions (such as pairwise hashing functions) can be applied to the hash values 114 in order to generate one or more additional hash values 116. An additional hashing function could then be applied to the hash values 116 in order to generate the root hash value 110. The root hash value 110 here represents the “Merkle root” of the data 112. Note that this represents one example of how the transaction root hash value 110 could be generated. In general, the root hash value 110 could be generated in any suitable manner, as long as the root hash value 110 represents a cryptographic hash of most or all of the block 102. As noted above, the transaction associated with each block 102 relates in some way to terminal automation, such as when the block 102 contains data about cargo, smart contracts associated with cargo, and/or drivers or vehicles that transport cargo.
In one aspect of operation, multiple “local” copies of the blockchain 100 are stored and maintained by multiple computing nodes, each of which is accessible by one or more (and typically all) of the parties associated with the blockchain 100. The blockchain 100 therefore functions as a distributed ledger that can be used by multiple parties to obtain or verify information contained in the blocks 102 of the blockchain 100. The parties also generate or use transaction data, and cryptographic operations are performed using the transaction data to create and add new blocks 102 to the blockchain 100. Thus, parties can append new blocks 102 to the blockchain 100 at different computing nodes as new transactions occur, and these blocks 102 are propagated to other computing nodes so that the blockchain 100 can be updated at those nodes. Each new block 102 is linked to a previous block 102 in the blockchain 100 as described above, which helps to prevent someone from illicitly changing data in earlier blocks 102 of the blockchain 100. Approval of a majority of the parties may be required before each new block 102 is added to the blockchain 100.
In the context of terminal automation, blockchains 100 can be used to support various functions. For example, blockchains 100 could be used to store information about cargo passing through or stored at one or more distribution terminals and about people and vehicles used to transport the cargo. Using blockchains 100 as a storage location for information about cargo and people/vehicles can help parties distribute and transport cargo more efficiently. As a particular example, parties could use the contents of one or more blockchains 100 to identify drivers who may be pilfering products being transported on their trucks or allowing it to happen. As another particular example, parties could use the contents of one or more blockchains 100 to identify drivers who engage in misbehaviors that can lead to safety risks and revenue losses to terminals, such as by deviating from standard operating procedures. As yet another particular example, parties could use the contents of one or more blockchains 100 to identify which products stored in one or more terminals belong to which customers, allowing customers to quickly obtain current “on demand” stock availability for the customers' products. Note that these examples are merely meant to illustrate potential ways in which blockchains 100 can be used to support terminal automation functions. Blockchains 100 could be used in any other suitable manner to support terminal automation functions and to share data between multiple parties.
In this way, the blockchain 100 provides a tamper-evident distributed ledger that can be used by multiple parties. This helps to improve the trust among the parties involved in the blockchain 100 over time and eliminates the need to use an intermediary between non-trusting parties. The use of blockchain technology also helps to provide data security and data authenticity. In addition, the use of blockchain technology allows for distributed availability of the data as well as distributed accountability between the parties. The end results from using blockchain technology with terminal automation solutions include reduced operational costs, improved terminal operations, improved speed of business processes, reduced disputes (accuracy improvements), reduced time needed for audits, and availability of real-time stock reconciliation.
In general, any stakeholder associated with cargo being transported or distributed could access and add information to one or more blockchains 100. The following describes examples of the types of stakeholders that could be associated with one or more blockchains 100 in the oil and gas industry. Of course, other or additional stakeholders could be associated with one or more blockchains 100 in the oil and gas industry. Also, the blockchains 100 could be used with any suitable stakeholders in any suitable industries.
In the oil and gas industry, the stakeholders could include shareholders who initially own cargo and who can use at least one blockchain 100 to accurately track shipments, make allocations based on terminal distribution/demand patterns, and generate stock reconciliation reports. Owners of one or more distribution terminals could use at least one blockchain 100 to help reduce or minimize operational costs and increase or maximize revenues while supporting just-in-time (JIT) inventory management using a decentralized information technology (IT) infrastructure. One or more terminal planners could use at least one blockchain 100 to help identify upstream supply patterns and downstream distribution/demand patterns to support JIT inventory management and shareholder allocations/transfer agreements. One or more terminal operators could use at least one blockchain 100 to help digitally identify drivers or other personnel at one or more terminals. One or more governmental authorities could use at least one blockchain 100 during excise taxation procedures, which could help to increase government revenues, provide for tamper-proof auditing and inquiries, and allow penalization of appropriate violations. One or more carrier companies (such as drivers or vehicle providers) could use at least one blockchain 100 to identify their engagement level in one or more terminals and possibly to receive priority during bay allocation at one or more terminals. One or more gas station owners could use at least one blockchain 100 to accurately track incoming cargo shipments and generate stock reconciliation reports, as well as to select one or more carriers or one or more terminals that will be used to provide cargo in the future. One or more end customers (such as gas station customers) could use at least one blockchain 100 to rate gas stations or other vendors with the best service (such as in terms of price, quality, or utilities). Note that these stakeholders and functions are merely examples of how one or more blockchains 100 could be used to support terminal automation functions.
Although
There are various ways to set up a blockchain, including public, private, and consortium blockchains. Public blockchains are typically available to a large number of users and have been used for cryptographic currencies like BitCoin. When close control is needed, a public blockchain is generally not an option. Private blockchains are typically used by individual companies or other organizations. Consortium (or “permissioned”) blockchains can be used when multiple companies or other organizations are involved, such as when hosting blockchain as a service (BAAS), but when public availability of the ledgers is not needed or desired. In
As shown in
Each entity associated with the functional architecture 200 generally operates or has access to its own subnetwork that supports the use of the blockchains 100. Each subnetwork could be formed from a single computing node or multiple computing nodes. Each subnetwork could represent one or more computing nodes owned or operated by the associated entity, or each subnetwork could be implemented virtually (such as in a cloud computing environment) on behalf of the associated entity. The computing nodes here include transaction nodes 206, mining nodes 208, and virtual gateways 210.
Each transaction node 206 generally operates to receive information associated with transactions (such as information related to cargo, smart contracts, drivers, or vehicles) and submit that information to one or more mining nodes 208 for inclusion in one or more suitable blockchains 100. Each mining node 208 generally operates to perform cryptographic operations using the transaction information in order to create new blocks 102 that are added to their local copies of the suitable blockchains 100. Each virtual gateway 210 generally operates to support communications between the various entities over a virtual network 212. Among other things, this allows each mining node 208 to send updates made to its local copy of one or more blockchains 100 to other mining nodes 208, which allows those other mining nodes 208 to update their local copies of the same blockchain(s) 100. Different virtual networks 212 (accessible via a common virtual gateway 210 or different virtual gateways 210) could be used by each entity to support the use of different consortium blockchains.
Each entity can have or use any suitable numbers of transaction nodes 206, mining nodes 208, and virtual gateways 210. In some embodiments, each of the transaction nodes 206, mining nodes 208, and virtual gateways 210 could represent a virtual node or virtual machine that is executed in a computing cloud or on other suitable hardware. In particular embodiments, the transaction nodes 206, mining nodes 208, and virtual gateways 210 could be executed using one or more of MICROSOFT's AZURE, IBM's BLUE MIX, and AMAZON's AWS computing cloud services. This approach allows transaction nodes 206, mining nodes 208, and virtual gateways 210 to be executed and used when needed. However, other approaches could also be used here.
If needed or desired, one or more load balancers 214 could be used to distribute processing loads among the different entities involved in the consortium. This may help to reduce or prevent one entity's actual or virtual computing nodes from being over-burdened while another entity's computing nodes are under-utilized. For example, since different entities may have different numbers of mining nodes 208, entities with more mining nodes 208 may be able to receive and process more requests to add blocks 102 to blockchains 100. In some embodiments, the load balancers 214 may be responsible for passing requests to the transaction nodes 206, so the load balancers 214 could include public Internet Protocol (IP) addresses. The transaction nodes 206 could be accessed using Secure Shell (SSH) or other cryptographic network protocols. This could help to shield the mining nodes 208 so that the mining nodes 208 cannot be accessed remotely.
As described in more detail below, this type of functional architecture 200 can be used by various parties associated with terminal automation. For example, in the oil and gas industry, an oil and gas supply chain can involve numerous parties between the points where oil and gas are extracted from the ground and the points where products are delivered to customers. These parties can include refineries, suppliers, bottling plants, bulk storage terminal operators, governmental and port authorities, bulk distribution terminal operators, pipeline operators, truck/train/ship operators, wholesalers, gas stations, and customers. Different parties can use the functional architecture 200 to create and use blockchains 100 associated with terminal automation, drivers, vehicles, smart contracts, or other information about the supply chain.
As a particular example, part or all of an oil and gas supply chain can be moved to one or more consortium or other blockchains 100, where extraction, refining, terminal owners, and carrier companies could be the stakeholders. The blockchains 100 could then be used to support automated/transparent inventory tracking and exchange, as well as to support auditing. Moreover, smart contracts could be executed automatically based on real-time information, such as by charging customers appropriately based on an input crude oil's quality, taking action when a shareholder's stock moves above or below a specified limit, or automatically executing a comingling contract. In addition, cargo can be moved across terminals based on demand in a specified area. With respect to transfers of cargo out of terminals, the blockchains 100 could be used to track the movements of products from the terminals until reaching end customers and to execute smart contracts when applicable, such as for invoice generation related to custody transfers. Numerous parties could therefore benefit using blockchains 100, among other reasons by avoiding paper-based contracting and by improving the efficiency of supply chain management.
Any suitable blockchain technologies and nodes associated with those blockchain technologies can be used in the functional architecture 200. In some embodiments, for example, the ETHEREUM blockchain as a service can be used. In particular examples, the Nethereum web3 package can be used for blockchain interactions, Metamask can be used for ETHEREUM transfers, VISUAL STUDIO 2015 update 3 can be used for .Net application development, and MICROSOFT SOLIDITY and AZURE tool library integration can be used in VISUAL STUDIO 2015. Note, however, that other implementations are also possible. For instance, there are a number of blockchain technologies associated with cryptocurrencies that could be used (modified or unmodified) in the functional architecture 200.
Moreover, any suitable application or applications could be used by each party to interact with one or more blockchains 100. For example, an application could be used to create smart contracts, such as by using a driver identity, driver mapping, and transaction data, and to compile the smart contracts. Also, distributed applications could be used to connect to blockchains (such as by using Nethereum), unlock appropriate accounts, deploy the smart contracts into the blockchains, and submit transactions/execution of methods in the smart contracts. In addition, an application could be used support blockchain traversal for extracting transaction information (mining) and to display blocks, associated transactions, or other information in an intuitive user interface. Note that the same application could perform all of these functions, or different applications could be used to support different functions.
Although
As shown in
In the example shown in
As noted above, due to the frequent arrival and departure of many cargo vehicles 304 and a limited number of cargo bays 306, some cargo distribution terminal 302a-302n have deployed terminal automation systems 310. The terminal automation systems 310 are typically designed to manage and schedule the loading and unloading of cargo involving numerous cargo vehicles 304. For example, each of the terminal automation systems 310 could generate schedules identifying when different cargo vehicles 304 are allowed to load or unload cargo in a cargo distribution terminal 302a-302n. Each of the terminal automation systems 310 could also track other information, such as information about drivers or vehicles.
If the terminal automation systems 310 are implemented using hardware devices and software solutions hosted locally, there may be little or no interactions between the automation systems 310 of different cargo distribution terminals 302a-302n. The lack of reliable communications between the automation systems 310 of different cargo distribution terminals 302a-302n can make it difficult to deal with a number of issues affecting cargo distribution. For example, cargo distribution terminals 302a-302n often face difficult challenges in dealing with product pilferage by vehicle drivers during the transportation of products from terminals 302a-302n to various destinations. As a particular example, assume that a single truck shipment involves 30,000 liters of fuel. A 0.1% pilferage would amount to 30 liters of lost fuel for that single shipment. A typical terminal might have 500 shipments of fuel per day, which could result in 35,000 liters of fuel loss per day. Monthly losses at this rate could amount to 450,000 liters of fuel, and this problem can be compounded to large annual operational losses across a single terminal or multiple terminals. This can result in huge monetary losses for terminal operators.
As another example, the lack of reliable communications between the automation systems 310 can make it difficult to detect drivers who engage in other misbehaviors that can lead to safety risks and revenue losses to the terminals. For instance, drivers who delay loading or unloading processes by not following appropriate standard operating procedures (SOPs) for a terminal can reduce the throughput of the terminal, such as when every 30 minutes of delay is equivalent to missing one full shipment of product. Incidents involving more critical safety issues could result in the shutdown and downtime of much longer durations in a terminal, resulting in even more significant monetary losses. Drivers and vehicles are often not flagged for such misbehaviors. Even if a particular driver or vehicle is identified for wrongdoing, this awareness is usually limited to a local terminal only and is not passed on to other terminals so that the same set of practices can be avoided.
As yet another example, one or more customers could hold the same type of product in the same tank or different tanks of a terminal. In some cases, customers could also hold products across multiple terminals. Obtaining information regarding stock availability for particular customers can be a challenge, particularly in the case of comingling tanks in the above-mentioned scenarios. Tank readings are normally read at the start of a day/shift, and reconciliations are performed at the close of the day/shift. Obtaining a current “on demand” stock availability for particular customers can be difficult for terminals.
As described in this patent document, the terminal automation systems 310 of different cargo distribution terminals 302a-302n can be configured to use blockchains to support information exchanges between the terminals 302a-302n. Various third-party systems 312a-312m may also be used in the system 300 and support the use of blockchains. The third-party systems 312a-312m could denote data processing systems used by parties associated with cargo or the distribution terminals 302a-302n. Example third-party systems 312a-312m could include computing systems used by governmental entities, product producers, cargo carriers, product distributors, and end customers. In general, any stakeholder associated with cargo being transported or distributed could have an associated third-party system 312. Example third-party systems 310a-310m could also include a computing system that is used by a party hosting or overseeing the use of one or more blockchains, such as a consortium leader 202. As a specific example, a company that is unrelated to the terminals and other third parties could host or oversee the use of one or more blockchains.
Assume that at least one consortium blockchain is used in
Within each computing cloud 314a-314p, the associated party has one or more transaction nodes 316, one or more mining nodes 318, and optionally one or more load balancing nodes 320. While not shown here, the associated party could also have one or more virtual gateways within each computing cloud 314a-314p. These components may be the same as or similar to the corresponding components described above with respect to
If needed, at least one network 324 can be used to couple the computing clouds 314a-314p. The network 324 facilitates communications between various components in the system 300. For example, the network 324 may communicate Internet Protocol (“IP”) packets or other information between network addresses. The network 324 could support communications over any suitable physical or wireless connections. The network 324 may include one or more local area networks (“LANs”), metropolitan area networks (“MANs”), wide area networks (“WANs”), all or a portion of a global network such as the Internet, or any other communication system or systems at one or more locations.
In some embodiments, the leader of a consortium blockchain can connect member subnetworks (the computing clouds 314a-314p in this example) by configuring virtual network settings to connect the members over the network 324. The leader and the other members can then host the transaction nodes 316, which could receive new blockchain content, such as from distributed applications (DAPPs). The transaction nodes 316 can provide the new blockchain content to the mining nodes 318 for insertion into the blockchains 322. In particular embodiments, all transaction nodes 316 could be accessible over a specified port or ports using a secure protocol, such as SSH, and the mining nodes 318 could be shielded so they cannot be accessed remotely.
Blockchains 322 can be used for various purposes in the system 300. This includes end-to-end supply chain optimization using a consortium blockchain for custody transfers. Among other things, blockchains 322 can be used to represent products being loaded, unloaded, and stored in the cargo distribution terminals 302a-302n. This can be done to support the digital tracking of product transfers between various parties, extended stock reconciliation, and integration with payments and receipt generations in real-time. Blockchains 322 could also be associated with drivers or vehicles and used to support digital identity management for vehicles/drivers across different terminals. Blockchains 322 could further be used to support the creation, compilation, and deployment of smart contracts and to track transactions associated with the smart contracts.
As particular examples, the various parties involved in cargo distribution can use blockchains 322 to support a number of functions. For instance, driver/vehicle performance data and digital identities can be shared among the terminals 302a-302n using one or more blockchains 322. This information could then be used to restrict “bad actors” from entering into all of the terminals 302a-302n. This can help to reduce product pilferage, increase safety of the operating environment within the terminals, or ensure delivery of products with a higher grade of accuracy to intended destinations. The use of blockchain technology also helps the terminal operators to know that valid information is being received from other terminal operators. As another example, customers can interact with terminals using blockchains 322 to receive immediate notifications directly from the terminals regarding products being shipped. This helps the customers to make proactive decisions, such as when making new exchange agreements based on their demand and supply variations across terminals.
Although
As shown in
The memory 410 and a persistent storage 412 are examples of storage devices 404, which represent any structure(s) capable of storing and facilitating retrieval of information (such as data, program code, and/or other suitable information on a temporary or permanent basis). The memory 410 may represent a random access memory or any other suitable volatile or non-volatile storage device(s). The persistent storage 412 may contain one or more components or devices supporting longer-term storage of data, such as a read only memory, hard drive, Flash memory, or optical disc.
The communications unit 406 supports communications with other systems or devices. For example, the communications unit 406 could include at least one network interface card or wireless transceiver facilitating communications over at least one wired or wireless network. The communications unit 406 may support communications through any suitable physical or wireless communication link(s).
The I/O unit 408 allows for input and output of data. For example, the I/O unit 408 may provide a connection for user input through a keyboard, mouse, keypad, touchscreen, or other suitable input device. The I/O unit 408 may also send output to a display, printer, or other suitable output device.
Although
As shown in
The graphical user interface 500 also includes one or more sections 512, where each section 512 is associated with a different customer who has received, is receiving, or will be receiving the product stored in the identified tank. In this example, each section 512 identifies a gasoline storage tank at a specific gas station. Each section 512 also includes a button 514 associated with a truck used to deliver the product to that customer. Selection of the button 514 allows a user to view information about the receipt of the product in the associated truck. Each section 512 may optionally include one or more buttons 516 associated with individual pumps associated with the gas station, which could be selected to view information about that specific pump (such as use of the product by that pump). The graphical user interface 500 may further optionally include a section 518 containing one or more buttons that could be selected to view information provided by end users, such as customer reviews of the gas station.
The information used to generate the graphical user interface 500 can be inserted into one or more blockchains 100, 322 by any suitable entity or entities, and that information can then be mined from the blockchain(s) 100, 322 to generate the graphical user interface 500. For example, an owner or operator of a distribution terminal could use a device 400 having a processor 402 that inserts blocks into the blockchain(s) 100, 322 related to the tank, the product stored in the tank, the cargo vehicle(s) that delivered the product in the tank, and the cargo vehicle(s) that shipped the product from the tank. An owner or operator of each gas station could use a device 400 having a processor 402 that inserts blocks into the blockchain(s) 100, 322 related to the receipt and use of the product. A third-party system could include a processor 402 that inserts blocks into the blockchain(s) 100, 322 related to end users.
As shown in
As shown in
The pop-up window 700 here includes a button that allows a user to rate the driver associated with the shipment. This may allow, for example, a user associated with a terminal to provide information about whether the driver deviated from standard operating procedures or caused other problems during loading of cargo onto a vehicle. Selection of this button causes a pop-up window 702 to be displayed over the graphical user interface 500. The pop-up window 702 here includes fields identifying the shipment code and driver for the delivery, which may or may not be auto-populated based on the contents of the pop-up window 700. The pop-up window 702 also includes fields identifying the planned arrival time and actual arrival time of the driver for loading of the cargo. In addition, the pop-up window 702 includes fields identifying whether the driver deviated from standard operating procedures and the total time spent by the driver during the cargo loading. It should be noted that these fields are examples only and that any other or additional fields could be provided to store information about a driver. One or more of these fields could be filled in or edited by a user, and any additions or changes could be included in one or more new blocks added to the appropriate blockchain(s) 100, 322.
As shown in
As can be seen in
As shown in
As shown in
As a result, one or more blockchains 100, 322 could be used for driver or vehicle identity management. Information about each driver stored in the blockchain(s) could include the driver's name and date of birth, driver's license expiration date, carrier company, and any specialty training (like health, safety, and environment or “HSE” training). Multiple terminal owners and carrier companies could be the stakeholders of the blockchains. The blockchains could also optionally be used by one or more governmental entities, such as state or federal transportation departments for license validation or other functions. Driver or vehicle identities can be maintained in the blockchain(s) along with a history of their activities. The history can identify on-time arrivals, their times taken in terminals, theft complaints, fleet management (such as tracking or detour information), and vehicle maintenance details and inspection details. Rating of the drivers could then be generated based on their histories and other information.
The rating information could be used in any suitable manner. For example, terminal owners or operators could incentivize drivers with good driver ratings by placing them in priority queues for picking up or dropping off cargo. Also, terminal owners or operators could blacklist drivers who deviate from standard operating procedures a specified number of times and reject entry of those drivers into the terminals. This can help to promote safer and more effective operations and to protect multiple terminals, even those that have not witnessed unsafe driver behaviors.
Although
As shown in
At least one update to at least one blockchain is generated based on the data at step 1104, and a local copy of the blockchain(s) is updated using the at least one update at step 1106. This could include, for example, the processor 402 executing or implementing the mining node 208 to generate one or more blocks 102 to be added to one or more blockchains 100. This could also include the processor 402 executing or implementing the mining node 208 to insert each new block 102 into the appropriate blockchain 100. Each block 102 could have the form shown in
The steps 1102-1108 could be repeated any number of times by any number of nodes to support the use of at least one blockchain 100 containing terminal automation-related data. Each blockchain 100 could include only several blocks 102 or a large number of blocks 102. Each blockchain 100 could also be used in any suitable manner. For example, one or more blockchains could be accessed in order to obtain data associated with terminal operations or personnel at step 1110, and the data could be used to perform at least one function at step 1112. This could include, for example, a computer system accessing at least one blockchain 100 to obtain information about the products being stored in or distributed from a terminal, such as to perform real-time reconciliation of products. This could also include a computer system accessing at least one blockchain 100 to obtain information about a specific driver or other cargo vehicle operator and using the information to grant/deny terminal access to the vehicle operator. This could further include a computer system accessing at least one blockchain 100 to obtain information and generating one or more graphical user interfaces. Any other or additional actions could occur using one or more blockchains containing information about terminal operations or related personnel.
Although
In some embodiments, various functions described in this patent document are implemented or supported by a computer program that is formed from computer readable program code and that is embodied in a computer readable medium. The phrase “computer readable program code” includes any type of computer code, including source code, object code, and executable code. The phrase “computer readable medium” includes any type of medium capable of being accessed by a computer, such as read only memory (ROM), random access memory (RAM), a hard disk drive, a compact disc (CD), a digital video disc (DVD), or any other type of memory. A “non-transitory” computer readable medium excludes wired, wireless, optical, or other communication links that transport transitory electrical or other signals. A non-transitory computer readable medium includes media where data can be permanently stored and media where data can be stored and later overwritten, such as a rewritable optical disc or an erasable storage device.
It may be advantageous to set forth definitions of certain words and phrases used throughout this patent document. The terms “application” and “program” refer to one or more computer programs, software components, sets of instructions, procedures, functions, objects, classes, instances, related data, or a portion thereof adapted for implementation in a suitable computer code (including source code, object code, or executable code). The term “communicate,” as well as derivatives thereof, encompasses both direct and indirect communication. The terms “include” and “comprise,” as well as derivatives thereof, mean inclusion without limitation. The term “or” is inclusive, meaning and/or. The phrase “associated with,” as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, have a relationship to or with, or the like. The phrase “at least one of,” when used with a list of items, means that different combinations of one or more of the listed items may be used, and only one item in the list may be needed. For example, “at least one of: A, B, and C” includes any of the following combinations: A, B, C, A and B, A and C, B and C, and A and B and C.
The description in the present application should not be read as implying that any particular element, step, or function is an essential or critical element that must be included in the claim scope. The scope of patented subject matter is defined only by the allowed claims. Moreover, none of the claims invokes 35 U.S.C. § 112(f) with respect to any of the appended claims or claim elements unless the exact words “means for” or “step for” are explicitly used in the particular claim, followed by a participle phrase identifying a function. Use of terms such as (but not limited to) “mechanism,” “module,” “device,” “unit,” “component,” “element,” “member,” “apparatus,” “machine,” “system,” “processor,” or “controller” within a claim is understood and intended to refer to structures known to those skilled in the relevant art, as further modified or enhanced by the features of the claims themselves, and is not intended to invoke 35 U.S.C. § 112(f).
While this disclosure has described certain embodiments and generally associated methods, alterations and permutations of these embodiments and methods will be apparent to those skilled in the art. Accordingly, the above description of example embodiments does not define or constrain this disclosure. Other changes, substitutions, and alterations are also possible without departing from the spirit and scope of this disclosure, as defined by the following claims.
This application claims priority under 35 U.S.C. § 119(e) to U.S. Provisional Patent Application No. 62/544,972 filed on Aug. 14, 2017. This provisional application is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62544972 | Aug 2017 | US |