Source code for nvflare.apis.utils.task_utils

# Copyright (c) 2023, NVIDIA CORPORATION.  All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from nvflare.apis.fl_constant import FilterKey, FLContextKey


[docs]def apply_filters(filters_name, filter_data, fl_ctx, config_filters, task_name, direction): filter_list = [] fl_ctx.set_prop(FLContextKey.FILTER_DIRECTION, direction, private=True, sticky=False) scope_object = fl_ctx.get_prop(FLContextKey.SCOPE_OBJECT) if scope_object: filters = getattr(scope_object, filters_name) if filters: filter_list.extend(filters.get(direction, [])) task_filter_list = config_filters.get(task_name + FilterKey.DELIMITER + direction) if task_filter_list: filter_list.extend(task_filter_list) if filter_list: for f in filter_list: filter_data = f.process(filter_data, fl_ctx) return filter_data