A supply chain is an entire system of producing and delivering a final product, from the sourcing of various components and sub-components to the final delivery of the product. Efficient information sharing among different suppliers in a supply chain is essential for the proper functioning of the supply chain. Specifically, efficient information sharing may help a supplier to mitigate disruptions occurring far down in the supply chain from the supplier. Such disruptions may be caused by geopolitical tensions, pandemics, or global geo-economic uncertainty.
This Summary is provided to introduce a selection of concepts in a simplified form that is further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
According to aspects of the disclosure, a non-transitory computer-readable medium is provided that stores one or more processor-executable instructions which, when executed, by one or more processors cause the one or more processors to perform the operations of: storing, in a ledger of a blockchain system, a transaction record containing information associated with a first purchase that is made in a supply chain, the supply chain including a plurality of suppliers, the first purchase being made by a first one of the plurality of suppliers from a second one of the plurality of suppliers, the transaction record containing a plurality of data items associated with the first purchase; and storing, in the ledger of the blockchain system, a logic for enforcing one or more data access policies, the logic being configured to control access to at least one of the plurality of data items in the transaction record by any given one of the plurality of suppliers based on a respective tier in the supply chain to which the given supplier belongs, wherein the blockchain system is configured to: (i) receive, from a third one of the plurality of suppliers, a request for any given one of the plurality of data items and (ii) generate a response to the request based on a tier in the supply chain of the third supplier, the response being generated, at least in part, by executing the logic.
According to aspects of the disclosure, a method is provided comprising: one or more processors configured to perform the operations of: storing, in a ledger of a blockchain system, a transaction record containing information associated with a first purchase that is made in a supply chain, the supply chain including a plurality of suppliers, the first purchase being made by a first one of the plurality of suppliers from a second one of the plurality of suppliers, the transaction record containing a plurality of data items associated with the first purchase; and storing, in the ledger of the blockchain system, a logic for enforcing one or more data access policies, the logic being configured to control access to at least one of the plurality of data items in the transaction record by any given one of the plurality of suppliers based on a respective tier in the supply chain to which the given supplier belongs, wherein the blockchain system is configured to: (i) receive, from a third one of the plurality of suppliers, a request for any given one of the plurality of data items and (ii) generate a response to the request based on a tier in the supply chain of the third supplier, the response being generated, at least in part, by executing the logic.
According to aspects of the disclosure, a non-transitory computer-readable medium is provided that stores one or more processor-executable instructions which, when executed, by one or more processors cause the one or more processors to perform the operations of: storing, in a ledger of a blockchain system, a transaction record containing information associated with a first purchase that is made in a supply chain, the supply chain including a plurality of suppliers, the first purchase being made by a first one of the plurality of suppliers from a second one of the plurality of suppliers, the transaction record containing a plurality of data items associated with the first purchase; and storing, in the ledger of the blockchain system, a logic for enforcing one or more data access policies, the logic being configured to control access to at least one of the plurality of data items in the transaction record by any given one of the plurality of suppliers based on a respective tier in the supply chain to which the given supplier belongs, wherein the blockchain system is configured to: (i) receive, from a third one of the plurality of suppliers, a request for any given one of the plurality of data items and (ii) generate a response to the request based on a tier in the supply chain of the third supplier, the response being generated, at least in part, by executing the logic.
Other aspects, features, and advantages of the claimed invention will become more fully apparent from the following detailed description, the appended claims, and the accompanying drawings in which like reference numerals identify similar or identical elements. Reference numerals that are introduced in the specification in association with a drawing figure may be repeated in one or more subsequent figures without additional description in the specification in order to provide context for other features.
According to the present disclosure, a multi-tier supply chain management system is provided. The system enables the sharing of data among suppliers from different tiers of a supply chain. The system intelligently integrates a supply-chain tier model in its operations. Specifically, the system shares various types of information with different suppliers in the supply chain based on the tier of the suppliers. Examples of information that is shared include information about a supplier that is party to a specific transaction, the capacity of a supplier to produce a part that is subject to the transaction, the cost of the part, information about the quality of the part, or information about various compliance policies that are implemented by the supplier with respect to the part. The multi-tier supply chain management system enables comprehensive end-to-end traceability of materials within a supply chain, as well as a secure sharing of transaction information between suppliers from non-consecutive tiers of the supply chain.
The transaction record 100 may include a plurality of access restriction settings. Each access restriction setting may include a number, a string, or an alphanumerical string that specifies access permissions for a particular data item (or group of data items). Each of the access restriction settings may identify one or more of: (i) a specific supplier (or customer) that is permitted to view a given data item that is associated with the access restriction setting, (ii) a specific tier in the supply chain whose constituent suppliers are permitted to view the given data item, (iii) a specific supplier (or customer) that is not permitted to view the given data item, (iv) a specific tier in the supply chain whose constituent suppliers are not permitted to view the given data item. In other words, each of the access restriction settings may include: (i) a supplier identifier that uniquely identifies the supplier among a plurality of suppliers and/or (ii) a tier identifier that uniquely identifies a tier in the supply chain 200 among a plurality of tiers in the supply chain 200. According to the present example, access restriction setting 103 is associated with data item 102; access restriction setting 105 is associated with data item 104; access restriction setting 107 is associated with data item 106; access restriction setting 109 is associated with data item 108; access restriction setting 111 is associated with data item 110; and access restriction setting 113 is associated with data item 112. Although the access restriction settings are depicted as being integrated into the transaction record 100, alternative implementations are possible in which they are provided separately from the transaction record 100.
Although in the present example the transaction record 100 is associated with a specific transaction, alternative implementations are possible in which the transaction record is not associated with any specific transaction. Irrespective of whether the transaction record 100 is associated with a particular transaction, the transaction record may also include information that is not specific to any individual transaction, such as information about a supplier's capacity, datasheets from parts that are provided by the supplier, information about the compliance of the manufacturer with various standards and policies.
Supplier 202-1 may receive parts #7 and #8 from suppliers 203-1 and 203-2, respectively, and assemble part #3 from parts #7 and #8. Supplier 202-2 may receive parts #9 and #10 from suppliers 203-3 and 203-4, respectively, and assemble part #4 from parts #9 and #10. Supplier 202-3 may receive parts #11 and #12 from suppliers 203-5 and 203-6, respectively, and assemble part #5 from parts #11 and #12. Supplier 202-4 may receive parts #13 and #14 from suppliers 203-7 and 203-8, respectively, and assemble part #6 from parts #13 and #14. Supplier 201-1 may receive parts #3 and #4 from suppliers 202-1 and 202-2, respectively, and assemble part #1 from parts #3 and #4. Supplier 201-2 may receive parts #5 and #6 from suppliers 202-3 and 202-4, respectively, and assemble part #2 from parts #5 and #6. Manufacturer 210 may receive parts #1 and #2 from suppliers 201-1 and 201-2 respectively, and assemble those parts into a finished product. Customer 220 may purchase the finished product from manufacturer 210.
The operation of the supply chain 200 may depend on different transactions between individual suppliers in the supply chain 200. For each transaction, a respective transaction record may be stored in the ledger 320 of the blockchain system 280 (shown in
As used throughout the disclosure, the term “tier of a supplier” refers to how far removed a supplier is from a finished product that is produced by a supply chain. For example, a tier-0 supplier may be the supplier that produces the finished product (e.g., manufacturer 210 in the example of
By definition, any transaction in a supply chain necessarily takes place between suppliers from consecutive tiers in the supply chain (hereinafter “a purchaser” and “a seller”). Some of the information about the transaction may be desired to be shared with other suppliers in the supply chain, while other information regarding the transaction may be desired to be kept secret from everyone in the supply chain, except for the supplier and the seller. Consider a transaction between a tier-1 supplier and a tier-2 supplier of a supply. Price information associated with the transaction may be desired to be kept confidential from a tier-0 supplier of the supply chain, whereas information about any delays in executing the transaction may be desired to be shared with the tier-0 supplier. As is discussed further below, a blockchain system 280 is provided, which enables the selective sharing of information with different suppliers in a supply chain based on the respective tiers of the suppliers in the supply chain. The operation of the blockchain system 280 is discussed further below with respect to
Each of the computing devices 272 may be the same or similar to the computing device 800, which is discussed further below with respect to
The blockchain system 280 may include any suitable type of cryptographically auditable platform that is configured to provide secure access to information associated with transactions in a supply chain. The blockchain system 280 may include any suitable type of blockchain system, such as a public blockchain, a private blockchain, or a hybrid blockchain system. According to the present example, the blockchain system 280 is implemented as a peer-to-peer network including the computing devices 272. Although in the present example the computing devices 272 are configured to operate as nodes in the blockchain system 280, alternative implementations are possible in which the computing devices 272 are external to the blockchain system 280.
The authentication database 273 may include a database for authenticating the credentials of entities that attempt to retrieve or store information in the ledger of the blockchain system 280. The external data store 274 may include one or more computing devices that are configured to store information. The tier data store 275 may include one or more computing devices that identify the topology of the supply chain 200. In some implementations, the tier data store 275 may store one or more data structures that identify all (or at least some) of the suppliers that are part of the supply chain 200, as well as the respective tiers of the suppliers. For any of the suppliers in the supply chain 200, the one or more data structures may store an identifier of the supplier and an indication of the respective tier of the supplier in the supply chain 200.
The ledger 320 may be further configured to store entity definitions 342. Each of the entity definitions 342 may correspond to a different supplier in the supply chain 200 or to a respective customer. In some implementations, for each of the suppliers in the supply chain 200, a different entity definition 342 may be provided that contains an identifier of the supplier and an indication of a tier in the supply chain 200 to which the supplier belongs. In some implementations, for any customer in the supply chain 200, a different entity definition may be provided that includes an identifier of the customer along with an indication that the entity definition belongs to a customer (rather than a supplier). Each of the entity definitions 342 may be implemented as a standalone data structure or as a portion of a larger data structure.
The ledger 320 may be further configured to store a plurality of public/private key pairs 341. Each pair 341 may correspond to a different supplier in the supply chain 200 and include a public encryption key that belongs to the supplier and a private encryption key that belongs to the supplier. The private key in each pair 341 may be one that is accessible only from within the blockchain system 280. For example, the private key in each pair 341 may be accessible only by smart contract logic that is executed by the blockchain system 280. As another example, the public key of any supplier in the supply chain 200 may be known to other suppliers in the supply chain 200, whereas the private key of any supplier in the supply chain 200 may be hidden from all other suppliers in the supply chain 200.
The ledger 320 may be further configured to store one or more smart contracts 331, one or more smart contracts 332, and one or more smart contracts 333. Each of the smart contracts 331, 332, and 333 may include logic that is executed by nodes in the blockchain system 280, by using a consensus-building mechanism of the blockchain system 280.
The smart contract(s) 331 may include logic that is configured to search (or otherwise examine) the entity definitions 342 to determine the role (e.g., the tier) in the supply chain 200 of a particular entity (e.g., a particular supplier). For example, the logic may receive as input an identifier of a supplier and return an indication of the tier of the supplier. As another example, the logic may receive as input an identifier of an entity (e.g., a customer or a supplier) and return an indication of whether the entity is a supplier or customer. As yet another example, the logic may be configured to receive a request to generate a new entity definition 342 and execute the request by creating the new entity definition 342. The request may include an identifier of a supplier and an indication of the supplier's tier in the supply chain 200. As used throughout the disclosure, the term “logic” may refer to electronic circuitry and/or one or more processor-executable instructions that cause at least one processor to perform an action when they are executed by the processor.
The smart contract(s) 332 may include logic for setting or retrieving access restriction settings for different data items in the transaction records 243, 242, and 250. For example, the logic may be configured to receive a request including (i) an identifier of a data item, (ii) an identifier of a transaction or transaction record which the data item is part of (or associated with), and (iii) an identifier of a supplier (or another entity) that is attempting to retrieve the data item. In response to the request, the logic may return an indication of whether the supplier (or other entity) is permitted to view the data item. As another example, the logic may be configured to receive a request including (i) an identifier of a data item, (ii) an identifier of a transaction or transaction record which the data item is part of (or associated with), and (iii) an identifier of a tier in the supply chain 200. In response to the request, the logic may return an indication of whether the suppliers that are part of the tier are authorized to view the data item. As another example, the logic may be configured to receive a request to grant or deny (to a supplier/entity or to a tier in the supply chain 200) permission to view a data item. In response to the request, the logic may modify the access restriction setting that is associated with the data item.
The smart contract(s) 333 may include logic for instantiating any of the transaction records 243, 242, and 250. The logic may also be configured to store or retrieve data from any of the transaction records. In some implementations, the logic may be configured to perform at least a process 600A or a process 600B, both of which are discussed further below with respect to
The tier assembly component 335 may be configured to generate the entity definitions 342. The tier assembly component 335 may be implemented by using smart contracts and/or other logic. The tier-assembly component 335 may include the access management smart contract(s) 332 (or portion thereof) and/or other logic. In some implementations, the tier assembly component 335 may be configured to perform a process 700, which is discussed further below with respect to
The transaction component 334 may be configured to generate the transaction records 243, 242, and 250. The transaction component 334 may include the data management smart contract(s) 333 (or portion thereof) and/or other logic. The transaction component 334 may specify a metadata model for the transaction records, and provide methods and routines that regulate data access rights, permission policies, and data encryption. In some implementations, the collaboration component 336 may be configured to execute processes 600A and 600B, which are discussed further below with respect to
The collaboration component 336 may be configured to enforce data access policies that apply to different data items in a transaction record. The collaboration component 336 may include the access policy management smart contract(s) 332 (or portion thereof), the tier validation smart contract(s) 331 (or portion thereof), and/or other logic. The collaboration component 336 may be configured to perform processes 500A and 500B, which are discussed further below with respect to
The collaboration component 336 may be configured to receive (through component 338) supplier data from different facilities and suppliers, store the supplier data in the ledger 320 along with corresponding metadata, and send the supplier data to another supplier who has gained permission from the data owner. Specifically, the collaboration component 336 may provide the following Application Programming Interfaces (APIs): (1) Submit Data, (2) Set Data Permission, and (3) Retrieve Data.
Executing the Submit Data API may cause the collaboration component 336 to interact with the transaction component 334 to generate a transaction data record for a particular transaction (if the record has not already been created), and store supplier data in the transaction record. In some implementations, the Submit Data API may process supplier data (e.g., by adding metadata to it) and call the transaction component 334 to record the processed supplier data to the ledger 320. The Submit Data API may also store an encrypted version of the supplier data to the external data store 274.
Executing the Set Data Permission API may cause the collaboration component 336 to change access restriction settings for different supplier data items. In some implementations, the Set Data Permission API may interact with the transaction component 334 to develop access restriction policies and methods.
Executing the Retrieve Data API may cause the collaboration component 336 to retrieve data from any of the transaction records 243, 242, and 250 and provide the retrieved data to the entity that invoked the Retrieve Data API. The Retrieve Data API may call smart contracts in the transaction component 334 to retrieve encrypted supplier data from the ledger 320, verify encrypted supplier data authenticity, and decrypt the encrypted data to obtain the original data. The authenticity of decrypted data may be verified by decrypting the encrypted data with a private key corresponding to the owner of the data (i.e., the supplier who stored the data in the ledger 320).
The multi-party access component 338 may provide an interface (to external clients) for accessing the services of the blockchain system 280. The component 338 may be configured the verify the identity of a supplier and cooperate with the collaboration component 336 to execute an action that is requested by the supplier (if the supplier's identity has been authenticated successfully). The multi-party access component 338 may be configured to perform a process 400, which is discussed further below with respect to
At step 402, the multi-party access component 338 receives a request to perform an action. The action may include storing supplier data in the ledger 320, retrieving supplier data from the ledger 320, setting access restrictions for supplier data, and or any other suitable type of action. The request may be received from one of the suppliers or customers in the supply chain 200. The request may include one or more parameters. For example, when the request is to store supplier data, the one or more parameters may include the supplier data. As another example, when the request is to set (or change) one or more access restriction settings, the one or more parameters may include the new values of the access restriction settings. As noted, the request may be received from any of the suppliers 201, 202, 203, the manufacturer 210 or the customer 220. Under the nomenclature of the present disclosure, the entity from which the request is received is also referred to as “the maker of the request.”
At step 404, the multiparty-access component attempts to authenticate the maker of the request. Authenticating the maker of the request may include authenticating credentials that are provided together with or separately from the request. The credentials may be authenticated by using the authentication database 273.
At step 406, the multi-party access component 338 determines if the authentication is successful. If the authentication is not successful, the process 400 proceeds to step 408. Otherwise, if the authentication is successful, the process 400 proceeds to step 410.
At step 408, the multiparty-access component 338 returns a response rejecting the request. The response may be returned to the maker of the request.
At step 410, the multi-party access component 338 forwards the request to the collaboration component 336. Forwarding the request to the collaboration component 336 may include providing the collaboration component 336 with one or more of (i) an indication of the action that is desired to be performed, (ii) one or more parameters of the request, and/or (iii) an indication that the supplier has been authenticated successfully.
At step 412, the multi-party access component 338 receives, from the collaboration component 336, a response to the request that is transmitted at step 410.
At step 414, the multi-party access component 338 forwards the response to the maker of the request.
At step 502, the collaboration component 336 receives a request to store supplier data in the ledger 320. The request may be received from the multi-party access component 338. The request may include supplier data that is desired to be stored in the blockchain system 280. The received request may be the one that is transmitted at step 410 of the process 400.
At step 504, the collaboration component 336 processes the supplier data to produce processed supplier data. Processing the supplier data may include converting the supplier data to a standardized metadata format. For example, the supplier data (receive at step 502) may be a status update for a transaction. The status update may include the following raw supplier data: “123/expected delivery=6/6/2022.” Upon receiving the status update, the collaboration component 336 may convert the raw supplier data to the following standardized supplier data “transaction_id=123; order_shipped=true; eta=6/6/2022”. The standardized supplier data may follow a standard metadata model. The raw supplier data may follow a metadata model that is specific to the supplier which submitted the raw supplier data. Different suppliers that interact with the blockchain system 280 may use different metadata models for recording information. Converting supplier data to the standardized metadata model may ensure that all data stored in the transaction records 243, 242, and 250 has the same format.
At step 506, the collaboration component 336 transmits to the transaction component 334 a request to store the processed (e.g., standardized) supplier data (generated at step 504).
At step 508, the collaboration component 336 sets one or more access restrictions for the supplier data. For any (or each) data item in the processed supplier data (generated at step 504), the collaboration component 336 may set the value of a respective access restriction setting. The value may be set by executing the access policy management smart contract(s) 332.
At step 510, the collaboration component 336 may provide portions of the processed supplier data to third suppliers. The supplier data may be data associated with a specific transaction between a first supplier and a second supplier (e.g., a purchaser and a seller, etc.). Both the first supplier and the second supplier may be part of the supply chain 200. A third supplier is another supplier in the supply chain 200 that is neither the first supplier nor the second supplier. The third supplier may or may not be from a different tier of the supplier chain 200 than the first supplier and/or the second supplier. Specifically, at step 510, for each (or any) data item in the processed supplier data, the collaboration component 336 may (i) identify an access restriction setting for the data item, (ii) identify one or more suppliers that are permitted to view the data item based on the access restriction setting, and (iii) instruct the multi-party access component 338 to provide the data item to the suppliers which are permitted to view the data item. In instances in which the access restriction setting for a data item indicates that an entire tier in the supply chain 200 is permitted to view the data item, the data item may be disseminated by the collaboration component 336 to all suppliers in the tier. For example, the collaboration component 336 may instruct the multi-party access component 338 to provide the data item to all of the suppliers in the tier.
In some implementations, at step 524, the collaboration component 336 may execute the smart contract(s) 331 to determine the tier in the supply chain 200 of the maker of the request (e.g., a supplier from which the initial request is received at step 402). Afterwards, the collaboration component 336 may execute the smart contract(s) 332 to determine if the tier of the maker of the request is authorized to view the data item that is requested. For example, the collaboration component 336 may submit to the smart contract(s) 332 an indication of the tier of the maker of the request (as well as an identifier of the requested data item and a corresponding transaction/transaction record). In response, the collaboration component 336 may receive a response indicating whether all members of the tier are authorized to view the requested data item. If the requested data item is made available to all members of the tier of the maker of the request, the collaboration component 336 may determine that the maker of the request is authorized to retrieve the data item. Otherwise, the collaboration component 336 may determine that the maker of the request is not authorized to obtain the data item. In some respects, executing the smart contract 331 allows the collaboration component 336 to use a consensus-building mechanism of the blockchain system 280 to verify the tier of the maker of the request. In some respects, executing the smart contract 332 allows the collaboration component 336 to use a consensus-building mechanism of the blockchain system 280 to verify the access permissions for the data item. The terms “access permission”, “access restriction”, and “access policy” are used interchangeably throughout the disclosure.
Referring to
Processor 802 may be implemented by one or more programmable processors executing one or more computer programs to perform the functions of the system. As used herein, the term “processor” describes an electronic circuit that performs a function, an operation, or a sequence of operations. The function, operation, or sequence of operations may be hard-coded into the electronic circuit or soft coded by way of instructions held in a memory device. A “processor” may perform the function, operation, or sequence of operations using digital values or using analog signals. In some embodiments, the “processor” can be embodied in an application-specific integrated circuit (ASIC). In some embodiments, the “processor” may be embodied in a microprocessor with associated program memory. In some embodiments, the “processor” may be embodied in a discrete electronic circuit. The “processor” may be analog, digital or mixed-signal. In some embodiments, the “processor” may be one or more physical processors or one or more “virtual” (e.g., remotely located or “cloud”) processors.
The term “or” is intended to mean an inclusive “or” rather than an exclusive “or”. That is, unless specified otherwise, or clear from context, “X employs A or B” is intended to mean any of the natural inclusive permutations. That is, if X employs A; X employs B; or X employs both A and B, then “X employs A or B” is satisfied under any of the foregoing instances. In addition, the articles “a” and “an” as used in this application and the appended claims should generally be construed to mean “one or more” unless specified otherwise or clear from context to be directed to a singular form.
To the extent directional terms are used in the specification and claims (e.g., upper, lower, parallel, perpendicular, etc.), these terms are merely intended to assist in describing and claiming the invention and are not intended to limit the claims in any way. Such terms do not require exactness (e.g., exact perpendicularity or exact parallelism, etc.), but instead it is intended that normal tolerances and ranges apply. Similarly, unless explicitly stated otherwise, each numerical value and range should be interpreted as being approximate as if the word “about”, “substantially” or “approximately” preceded the value of the value or range.
Moreover, the terms “system,” “component,” “module,” “interface,”, “model” or the like are generally intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a controller and the controller can be a component. One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers.
Although the subject matter described herein may be described in the context of illustrative implementations to process one or more computing application features/operations for a computing application having user-interactive components the subject matter is not limited to these particular embodiments. Rather, the techniques described herein can be applied to any suitable type of user-interactive component execution management methods, systems, platforms, and/or apparatus.
While the exemplary embodiments have been described with respect to processes of circuits, including possible implementation as a single integrated circuit, a multi-chip module, a single card, or a multi-card circuit pack, the described embodiments are not so limited. As would be apparent to one skilled in the art, various functions of circuit elements may also be implemented as processing blocks in a software program. Such software may be employed in, for example, a digital signal processor, micro-controller, or general-purpose computer.
Some embodiments might be implemented in the form of methods and apparatuses for practicing those methods. Described embodiments might also be implemented in the form of program code embodied in tangible media, such as magnetic recording media, optical recording media, solid-state memory, floppy diskettes, CD-ROMs, hard drives, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the claimed invention. Described embodiments might also be implemented in the form of program code, for example, whether stored in a storage medium, loaded into and/or executed by a machine, or transmitted over some transmission medium or carrier, such as over electrical wiring or cabling, through fiber optics, or via electromagnetic radiation, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the claimed invention. When implemented on a general-purpose processor, the program code segments combine with the processor to provide a unique device that operates analogously to specific logic circuits. Described embodiments might also be implemented in the form of a bitstream or other sequence of signal values electrically or optically transmitted through a medium, stored magnetic-field variations in a magnetic recording medium, etc., generated using a method and/or an apparatus of the claimed invention.
It should be understood that the steps of the exemplary methods set forth herein are not necessarily required to be performed in the order described, and the order of the steps of such methods should be understood to be merely exemplary. Likewise, additional steps may be included in such methods, and certain steps may be omitted or combined, in methods consistent with various embodiments.
Also, for purposes of this description, the terms “couple,” “coupling,” “coupled,” “connect,” “connecting,” or “connected” refer to any manner known in the art or later developed in which energy is allowed to be transferred between two or more elements, and the interposition of one or more additional elements is contemplated, although not required. Conversely, the terms “directly coupled,” “directly connected,” etc., imply the absence of such additional elements.
As used herein in reference to an element and a standard, the term “compatible” means that the element communicates with other elements in a manner wholly or partially specified by the standard, and would be recognized by other elements as sufficiently capable of communicating with the other elements in the manner specified by the standard. The compatible element does not need to operate internally in a manner specified by the standard.
It will be further understood that various changes in the details, materials, and arrangements of the parts which have been described and illustrated in order to explain the nature of the claimed invention might be made by those skilled in the art without departing from the scope of the following claims.