nvflare.app_common.psi.dh_psi.dh_psi_workflow module

class DhPSIWorkFlow(bloom_filter_fpr: float = 1e-11)[source]

Bases: PSIWorkflow

Init FLComponent.

The FLComponent is the base class of all FL Components. (executors, controllers, responders, filters, aggregators, and widgets are all FLComponents)

FLComponents have the capability to handle and fire events and contain various methods for logging.

backward_pass(ordered_clients: list, intersect_site: SiteSize) dict[source]
calculate_intersections(response_msg) Dict[str, int][source]
check_final_intersection_sizes(intersect_site: SiteSize)[source]
check_processed_sites(last_site: SiteSize, processed_sites: Dict[str, int])[source]
create_requests(site_setup_msgs) Dict[str, str][source]
finalize(fl_ctx: FLContext)[source]
forward_pass(ordered_sites: List[SiteSize], processed: Dict[str, int]) SiteSize[source]
static get_ordered_sites(results: Dict[str, DXO])[source]
get_updated_site_sizes(ordered_sites)[source]
initialize(fl_ctx: FLContext, **kwargs)[source]
log_pass_time_taken()[source]
pairwise_intersect(ordered_sites: List[SiteSize], response_msg: Dict[str, str])[source]
pairwise_requests(ordered_sites: List[SiteSize], setup_msgs: Dict[str, str])[source]
pairwise_responses(ordered_sites: List[SiteSize], request_msgs: Dict[str, str])[source]
pairwise_setup(ordered_sites: List[SiteSize])[source]
parallel_backward_pass(ordered_clients: list, intersect_site: SiteSize)[source]
parallel_forward_pass(target_sites, processed: dict)[source]
post_process(abort_signal: Signal)[source]
pre_process(abort_signal: Signal) bool[source]
prepare_setup_messages(s: SiteSize, other_site_sizes: Set[int]) Dict[str, str][source]
prepare_sites(abort_signal)[source]
process_requests(s: SiteSize, request_msgs: Dict[str, str]) Dict[str, str][source]
run(abort_signal: Signal)[source]
class SiteSize(name, size)[source]

Bases: tuple

Create new instance of SiteSize(name, size)

name: str

Alias for field number 0

size: int

Alias for field number 1