Book description
Learn the essential skills for building an authentic federated learning system with Python and take your machine learning applications to the next level
Key Features
- Design distributed systems that can be applied to real-world federated learning applications at scale
- Discover multiple aggregation schemes applicable to various ML settings and applications
- Develop a federated learning system that can be tested in distributed machine learning settings
Book Description
Federated learning (FL) is a paradigm-shifting technology in AI that enables and accelerates machine learning (ML), allowing you to work on private data. It has become a must-have solution for most enterprise industries, making it a critical part of your learning journey. This book helps you get to grips with the building blocks of FL and how the systems work and interact with each other using solid coding examples.
FL is more than just aggregating collected ML models and bringing them back to the distributed agents. This book teaches you about all the essential basics of FL and shows you how to design distributed systems and learning mechanisms carefully so as to synchronize the dispersed learning processes and synthesize the locally trained ML models in a consistent manner. This way, you'll be able to create a sustainable and resilient FL system that can constantly function in real-world operations. This book goes further than simply outlining FL's conceptual framework or theory, as is the case with the majority of research-related literature.
By the end of this book, you'll have an in-depth understanding of the FL system design and implementation basics and be able to create an FL system and applications that can be deployed to various local and cloud environments.
What you will learn
- Discover the challenges related to centralized big data ML that we currently face along with their solutions
- Understand the theoretical and conceptual basics of FL
- Acquire design and architecting skills to build an FL system
- Explore the actual implementation of FL servers and clients
- Find out how to integrate FL into your own ML application
- Understand various aggregation mechanisms for diverse ML scenarios
- Discover popular use cases and future trends in FL
Who this book is for
This book is for machine learning engineers, data scientists, and artificial intelligence (AI) enthusiasts who want to learn about creating machine learning applications empowered by federated learning. You'll need basic knowledge of Python programming and machine learning concepts to get started with this book.
Table of contents
- Federated Learning with Python
- Acknowledgments
- Contributors
- About the authors
- About the reviewer
- Preface
- Part 1 Federated Learning – Conceptual Foundations
- Chapter 1: Challenges in Big Data and Traditional AI
- Chapter 2: What Is Federated Learning?
-
Chapter 3: Workings of the Federated Learning System
- FL system architecture
-
Understanding the FL system flow – from initialization to continuous operation
- Initialization of the database, aggregator, and agent
- Initial model upload process by initial agent
- Overall FL cycle and process of the FL system
- Synchronous and asynchronous FL
- The aggregator-side FL cycle and process
- The agent-side local retraining cycle and process
- Model interpretation based on deviation from baseline outputs
- Basics of model aggregation
- Furthering scalability with horizontal design
- Summary
- Further reading
- Part 2 The Design and Implementation of the Federated Learning System
-
Chapter 4: Federated Learning Server Implementation with Python
- Technical requirements
- Main software components of the aggregator and database
-
Implementing FL server-side functionalities
- Importing libraries for the FL server
- Defining the FL Server class
- Initializing the FL server
- Registration function of agents
- The server for handling messages from local agents
- The global model synthesis routine
- Functions to send the global models to the agents
- Functions to push the local and global models to the database
- Maintaining models for aggregation with the state manager
- Aggregating local models
- Running the FL server
- Implementing and running the database server
- Potential enhancements to the FL server
- Summary
- Chapter 5: Federated Learning Client-Side Implementation
- Chapter 6: Running the Federated Learning System and Analyzing the Results
- Chapter 7: Model Aggregation
- Part 3 Moving Toward the Production of Federated Learning Applications
- Chapter 8: Introducing Existing Federated Learning Frameworks
- Chapter 9: Case Studies with Key Use Cases of Federated Learning Applications
- Chapter 10: Future Trends and Developments
-
Appendix: Exploring Internal Libraries
- Technical requirements
- Overview of the internal libraries for the FL system
- Enumeration classes for implementing the FL system
- Understanding communication handler functionalities
- Understanding the data structure handler class
- Understanding helper and supporting libraries
- Messengers to generate communication payloads
- Summary
- Index
- Other Books You May Enjoy
Product information
- Title: Federated Learning with Python
- Author(s):
- Release date: October 2022
- Publisher(s): Packt Publishing
- ISBN: 9781803247106
You might also like
book
Distributed Machine Learning with Python
Build and deploy an efficient data processing pipeline for machine learning model training in an elastic, …
book
Interpretable Machine Learning with Python - Second Edition
A deep dive into the key aspects and challenges of machine learning interpretability using a comprehensive …
book
Practical Data Science with Python
Learn to effectively manage data and execute data science projects from start to finish using Python …
book
Data Visualization with Python and JavaScript, 2nd Edition
How do you turn raw, unprocessed, or malformed data into dynamic, interactive web visualizations? In this …