Threshold computing in a distributed computing system
First Claim
1. A computing device comprising:
- an interface configured to interface and communicate with a dispersed or distributed storage network (DSN);
memory that stores operational instructions; and
a processing module operably coupled to the interface and to the memory, wherein the processing module, when operable within the computing device based on the operational instructions, is configured to;
determine capability levels of a plurality of other computing devices;
select, based on the capability levels of a plurality of other computing devices, a subset of the plurality of other computing devices to perform a computing task on a data object, wherein the data object is segmented into a plurality of data segments, wherein a data segment of the plurality of data segments is dispersed error encoded in accordance with dispersed error encoding parameters to produce a set of encoded data slices (EDSs), wherein the set of EDSs are distributedly stored among a plurality of storage units (SUs), wherein a decode threshold number of EDSs are needed to recover the data segment, wherein a read threshold number of EDSs provides for reconstruction of the data segment, and wherein a write threshold number of EDSs provides for a successful transfer of the set of EDSs from a first at least one location in the DSN to a second at least one location in the DSN;
determine processing parameters of the data based on a number of the subset of the plurality of other computing devices;
determine task partitioning based on the subset of the plurality of other computing devices, the processing parameters, and a threshold computing parameter;
process the data based on processing parameters to generate data slice groupings;
partition the task based on the task partitioning to generate partial tasks;
transmit the partial tasks and the data slice groupings respectively to the subset of the plurality of other computing devices to be executed respectively by the subset of the plurality of other computing devices to generate a plurality of partial results;
when the decode threshold number of the plurality of partial results is generated by the subset of the plurality of other computing devices and available as indicated by at least the write threshold number of the subset of the plurality of other computing devices, obtain at least the decode threshold number of the plurality of partial results; and
process the at least the decode threshold number of the plurality of partial results to generate a result.
4 Assignments
0 Petitions
Accused Products
Abstract
A computing device includes an interface configured to interface and communicate with a dispersed storage network (DSN), a memory that stores operational instructions, and a processing module operably coupled to the interface and memory such that the processing module, when operable within the computing device based on the operational instructions, is configured to perform various operations. The computing device selects a subset of the other computing devices to perform a computing task on a data object. The computing device determines processing parameters of the data and determines task partitioning. The computing device also processes the data based on processing parameters to generate data slice groupings and partitions the task based on the task partitioning to generate partial tasks. The computing device obtains and processes at least the decode threshold number of the plurality of partial results generated by the subset of the other computing devices to generate a result.
92 Citations
20 Claims
-
1. A computing device comprising:
-
an interface configured to interface and communicate with a dispersed or distributed storage network (DSN); memory that stores operational instructions; and a processing module operably coupled to the interface and to the memory, wherein the processing module, when operable within the computing device based on the operational instructions, is configured to; determine capability levels of a plurality of other computing devices; select, based on the capability levels of a plurality of other computing devices, a subset of the plurality of other computing devices to perform a computing task on a data object, wherein the data object is segmented into a plurality of data segments, wherein a data segment of the plurality of data segments is dispersed error encoded in accordance with dispersed error encoding parameters to produce a set of encoded data slices (EDSs), wherein the set of EDSs are distributedly stored among a plurality of storage units (SUs), wherein a decode threshold number of EDSs are needed to recover the data segment, wherein a read threshold number of EDSs provides for reconstruction of the data segment, and wherein a write threshold number of EDSs provides for a successful transfer of the set of EDSs from a first at least one location in the DSN to a second at least one location in the DSN; determine processing parameters of the data based on a number of the subset of the plurality of other computing devices; determine task partitioning based on the subset of the plurality of other computing devices, the processing parameters, and a threshold computing parameter; process the data based on processing parameters to generate data slice groupings; partition the task based on the task partitioning to generate partial tasks; transmit the partial tasks and the data slice groupings respectively to the subset of the plurality of other computing devices to be executed respectively by the subset of the plurality of other computing devices to generate a plurality of partial results; when the decode threshold number of the plurality of partial results is generated by the subset of the plurality of other computing devices and available as indicated by at least the write threshold number of the subset of the plurality of other computing devices, obtain at least the decode threshold number of the plurality of partial results; and process the at least the decode threshold number of the plurality of partial results to generate a result. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8)
-
-
9. A computing device comprising:
-
an interface configured to interface and communicate with a dispersed or distributed storage network (DSN); memory that stores operational instructions; and a processing module operably coupled to the interface and to the memory, wherein the processing module, when operable within the computing device based on the operational instructions, is configured to; determine capability levels of a plurality of other computing devices; select, based on the capability levels of a plurality of other computing devices, a subset of the plurality of other computing devices to perform a computing task on a data object, wherein the data object is segmented into a plurality of data segments, wherein a data segment of the plurality of data segments is dispersed error encoded in accordance with dispersed error encoding parameters to produce a set of encoded data slices (EDSs), wherein the set of EDSs are distributedly stored among a plurality of storage units (SUs), wherein a decode threshold number of EDSs are needed to recover the data segment, wherein a read threshold number of EDSs provides for reconstruction of the data segment, and wherein a write threshold number of EDSs provides for a successful transfer of the set of EDSs from a first at least one location in the DSN to a second at least one location in the DSN; determine processing parameters of the data based on a number of the subset of the plurality of other computing devices; determine task partitioning based on the subset of the plurality of other computing devices, the processing parameters, and a threshold computing parameter, wherein the threshold computing parameter includes at least one of a decode threshold number of computing devices, a pillar width number of computing devices, or a task redundancy requirement number of computing devices to execute an identical partial task; process the data based on processing parameters to generate data slice groupings; partition the task based on the task partitioning to generate partial tasks; transmit the partial tasks and the data slice groupings respectively to the subset of the plurality of other computing devices to be executed respectively by the subset of the plurality of other computing devices to generate a plurality of partial results; when the decode threshold number of the plurality of partial results is generated by the subset of the plurality of other computing devices and available as indicated by at least the write threshold number of the subset of the plurality of other computing devices, obtain at least the decode threshold number of the plurality of partial results; and decode the at least the decode threshold number of the plurality of partial results to generate a result. - View Dependent Claims (10, 11, 12, 13)
-
-
14. A method for execution by a computing device, the method comprising:
-
determining capability levels of a plurality of other computing devices; selecting, based on the capability levels of a plurality of other computing devices, a subset of the plurality of other computing devices to perform a computing task on a data object, wherein the data object is segmented into a plurality of data segments, wherein a data segment of the plurality of data segments is dispersed error encoded in accordance with dispersed error encoding parameters to produce a set of encoded data slices (EDSs), wherein the set of EDSs are distributedly stored among a plurality of storage units (SUs), wherein a decode threshold number of EDSs are needed to recover the data segment, wherein a read threshold number of EDSs provides for reconstruction of the data segment, and wherein a write threshold number of EDSs provides for a successful transfer of the set of EDSs from a first at least one location in a dispersed or distributed storage network (DSN) to a second at least one location in the DSN; determining processing parameters of the data based on a number of the subset of the plurality of other computing devices; determining task partitioning based on the subset of the plurality of other computing devices, the processing parameters, and a threshold computing parameter; processing the data based on processing parameters to generate data slice groupings; partitioning the task based on the task partitioning to generate partial tasks; transmitting, via an interface configured to interface and communicate with the DSN, the partial tasks and the data slice groupings respectively to the subset of the plurality of other computing devices to be executed respectively by the subset of the plurality of other computing devices to generate a plurality of partial results; when the decode threshold number of the plurality of partial results is generated by the subset of the plurality of other computing devices and available as indicated by at least the write threshold number of the subset of the plurality of other computing devices, obtaining at least the decode threshold number of the plurality of partial results; and processing the at least the decode threshold number of the plurality of partial results to generate a result. - View Dependent Claims (15, 16, 17, 18, 19, 20)
-
Specification