Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
timer SALE ENDS IN
0 Days
:
00 Hours
:
00 Minutes
:
00 Seconds
Modern Graph Theory Algorithms with Python
Modern Graph Theory Algorithms with Python

Modern Graph Theory Algorithms with Python : Harness the power of graph algorithms and real-world network applications using Python

Arrow left icon
Profile Icon Colleen M. Farrelly Profile Icon Franck Kalala Mutombo
Arrow right icon
$9.99 $35.99
Full star icon Full star icon Full star icon Full star icon Half star icon 4.6 (7 Ratings)
eBook Jun 2024 290 pages 1st Edition
eBook
$9.99 $35.99
Paperback
$44.99
Subscription
Free Trial
Renews at $19.99p/m
Arrow left icon
Profile Icon Colleen M. Farrelly Profile Icon Franck Kalala Mutombo
Arrow right icon
$9.99 $35.99
Full star icon Full star icon Full star icon Full star icon Half star icon 4.6 (7 Ratings)
eBook Jun 2024 290 pages 1st Edition
eBook
$9.99 $35.99
Paperback
$44.99
Subscription
Free Trial
Renews at $19.99p/m
eBook
$9.99 $35.99
Paperback
$44.99
Subscription
Free Trial
Renews at $19.99p/m

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
Product feature icon AI Assistant (beta) to help accelerate your learning
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Table of content icon View table of contents Preview book icon Preview Book

Modern Graph Theory Algorithms with Python

What is a Network?

This chapter introduces the basics of graph theory and its applications in network science. Network science is not a commonly taught area of data science, but many problems can be framed through a network science perspective. Network-based algorithms often scale better than other machine learning algorithms, making them ideal for analyzing datasets with many variables, exploring spatial datasets with many locations represented, or spotting trends in high-dimensional time series data. Later chapters will delve more deeply into the topics with hands-on examples.

In this chapter, we will define terms that will be used throughout the book, explore some common uses of network science in analyzing social relationship data, and introduce two Python packages that will be used in subsequent chapters. After finishing this chapter, you’ll start to recognize data science problems that can be formulated as network science problems and how to represent them visually...

Technical requirements

We have very few technical requirements or assumptions for this chapter. If you have not installed Python, you are encouraged to do so, as we will be using Python regularly—specifically, the Jupyter Notebooks that are installed with the Anaconda version of Python installation. If you have difficulty with installation, support can be found on Stack Overflow. The code for each chapter can be found under this GitHub link: https://github.com/PacktPublishing/Modern-Graph-Theory-Algorithms-with-Python.

Introduction to graph theory and networks

Social connections are fundamental to society, including family ties, shared roles in communities, trading relationships, and many more. Social networks—from MySpace to Twitter to TikTok—have played a larger and larger role in marketing, job-hunting, and information sharing in the last decades. Software systems might even be built between engineers scattered across the globe collaborating on platforms such as GitHub or Slack to coordinate efforts from teams in Kenya, India, and Australia who have never met.

A branch of data science called network science studies these relationships between individuals, groups, and even societies within social networks using algorithms and statistical methods originating in a field of math called graph theory. Graph theory studies pairwise relationships between objects. Graph objects (including people, towns, ideas, points in time, and many more types of objects to study) are represented in...

Examples of real-world social networks

Real-world networks are often more complicated than the examples we’ve considered. Let’s consider some nuances in social media networks. In the simplest forms, a social network contains mutual connections between friends at a single point in time. However, some friends may interact more often on the social media platform than others; they may comment on posts, reshare content, and message each other frequently. Weighted networks assign numerical values to edges in a network according to some measurement of relationship strength or frequency of interactions.

Let’s return to our hackathon network and weight our edges based on the average number of conversations per day of the hackathon between different team members. Perhaps Machiko is coordinating the business use case of the technology and does not interact much with Ayanda, the backend engineer, but needs to make sure the front end is intuitive (Greta’s team position...

Other type of networks

So far, we’ve mainly considered social networks. However, objects and their relationships can be defined on a much broader range of problems. Network science provides useful tools for understanding spatial data. For instance, consider a region with several small island towns connected by a series of bridges that allow goods and people to travel from region to region. During an epidemic, it might be useful to know which routes to close to minimize the spread of disease from one town to another. However, cutting off routes entirely would leave some areas without necessary supplies, such as food or medicine. Tools we’ll consider in later chapters can help regions plan the optimal routing of goods and minimize the potential spread of an epidemic.

We might also consider a map of stores, each with differing sale volumes of citrus fruit. Stores could be connected into a network based on shared management across stores, based on similarity of citrus...

Advanced use cases of network science

The tools of network science extend beyond social networks, spatial data, and temporal data. Deep learning models are ubiquitous in data science today, solving problems in computer vision, natural language processing, time series forecasting, and generative artificial intelligence. Large language models (LLMs) and text-to-image generators rely on a type of deep learning architecture called transformer models, feed-forward neural networks that find patterns in data by embedding input data, tuning attention weights, and decoding the data with respect to the outcome. These models can have billions or even trillions of parameters to tune across many connected layers. When combined with pre-trained contrastive language-image pre-training (CLIP) models, transformer models such as DALL-E can even generate realistic images based on text input. For instance, inputting hyperdetailed photorealistic king cobra, background desert market into NightCafe’...

Summary

In this chapter, we explored different types of networks, introduced two network packages in Python, examined different theoretical models of network growth and their limitations, and considered several examples of networks not based on social relationships. We also touched on some more advanced topics in network science today, including network applications to deep learning, network classification, and ontology mapping. In the next chapter, we’ll dive deeper into igraph and NetworkX with practical network examples.

References

Aganze, E., Kusinza, R., & Bukavu, D. R. (2020). The current state of fake news in the DR Congo and social impacts. Global Journal of Computer Science and Technology.

Aric A. Hagberg, Daniel A. Schult and Pieter J. Swart “Exploring network structure, dynamics, and function using NetworkX”. In Proceedings of the 7th Python in Science Conference (SciPy2008), Gäel Varoquaux, Travis Vaught, and Jarrod Millman (Eds), (Pasadena, CA USA), pp. 11–15, Aug 20

Berge, C. (2001, January 1). The Theory of Graphs. Courier Corporation.

BRANDES, U., ROBINS, G., McCRANIE, A., & WASSERMAN, S. (2013, April). What is network science? Network Science, 1(1), 1–15.

Csárdi G., Nepusz T. The igraph software package for complex network research. InterJournal Complex Systems, 1695, 2006.

Ducruet, C., & Beauguitte, L. (2014). Spatial science and network science: review and outcomes of a complex relationship. Networks and Spatial Economics...

Left arrow icon Right arrow icon
Download code icon Download Code

Key benefits

  • Learn how to wrangle different types of datasets and analytics problems into networks
  • Leverage graph theoretic algorithms to analyze data efficiently
  • Apply the skills you gain to solve a variety of problems through case studies in Python
  • Purchase of the print or Kindle book includes a free PDF eBook

Description

We are living in the age of big data, and scalable solutions are a necessity. Network science leverages the power of graph theory and flexible data structures to analyze big data at scale. This book guides you through the basics of network science, showing you how to wrangle different types of data (such as spatial and time series data) into network structures. You’ll be introduced to core tools from network science to analyze real-world case studies in Python. As you progress, you’ll find out how to predict fake news spread, track pricing patterns in local markets, forecast stock market crashes, and stop an epidemic spread. Later, you’ll learn about advanced techniques in network science, such as creating and querying graph databases, classifying datasets with graph neural networks (GNNs), and mining educational pathways for insights into student success. Case studies in the book will provide you with end-to-end examples of implementing what you learn in each chapter. By the end of this book, you’ll be well-equipped to wrangle your own datasets into network science problems and scale solutions with Python.

Who is this book for?

If you’re a researcher or industry professional analyzing data and are curious about network science approaches to data, this book is for you. To get the most out of the book, basic knowledge of Python, including pandas and NumPy, as well as some experience working with datasets is required. This book is also ideal for anyone interested in network science and learning how graph algorithms are used to solve science and engineering problems. R programmers may also find this book helpful as many algorithms also have R implementations.

What you will learn

  • Transform different data types, such as spatial data, into network formats
  • Explore common network science tools in Python
  • Discover how geometry impacts spreading processes on networks
  • Implement machine learning algorithms on network data features
  • Build and query graph databases
  • Explore new frontiers in network science such as quantum algorithms

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Jun 07, 2024
Length: 290 pages
Edition : 1st
Language : English
ISBN-13 : 9781805120179
Category :
Languages :
Concepts :

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
Product feature icon AI Assistant (beta) to help accelerate your learning
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Product Details

Publication date : Jun 07, 2024
Length: 290 pages
Edition : 1st
Language : English
ISBN-13 : 9781805120179
Category :
Languages :
Concepts :

Packt Subscriptions

See our plans and pricing
Modal Close icon
$19.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
$199.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just $5 each
Feature tick icon Exclusive print discounts
$279.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just $5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total $ 136.97
Mastering PyTorch
$51.99
Modern Graph Theory Algorithms with Python
$44.99
Mastering Transformers
$39.99
Total $ 136.97 Stars icon
Banner background image

Table of Contents

20 Chapters
Part 1:Introduction to Graphs and Networks with Examples Chevron down icon Chevron up icon
Chapter 1: What is a Network? Chevron down icon Chevron up icon
Chapter 2: Wrangling Data into Networks with NetworkX and igraph Chevron down icon Chevron up icon
Part 2: Spatial Data Applications Chevron down icon Chevron up icon
Chapter 3: Demographic Data Chevron down icon Chevron up icon
Chapter 4: Transportation Data Chevron down icon Chevron up icon
Chapter 5: Ecological Data Chevron down icon Chevron up icon
Part 3: Temporal Data Applications Chevron down icon Chevron up icon
Chapter 6: Stock Market Data Chevron down icon Chevron up icon
Chapter 7: Goods Prices/Sales Data Chevron down icon Chevron up icon
Chapter 8: Dynamic Social Networks Chevron down icon Chevron up icon
Part 4: Advanced Applications Chevron down icon Chevron up icon
Chapter 9: Machine Learning for Networks Chevron down icon Chevron up icon
Chapter 10: Pathway Mining Chevron down icon Chevron up icon
Chapter 11: Mapping Language Families – an Ontological Approach Chevron down icon Chevron up icon
Chapter 12: Graph Databases Chevron down icon Chevron up icon
Chapter 13: Putting It All Together Chevron down icon Chevron up icon
Chapter 14: New Frontiers Chevron down icon Chevron up icon
Index Chevron down icon Chevron up icon
Other Books You May Enjoy Chevron down icon Chevron up icon

Customer reviews

Top Reviews
Rating distribution
Full star icon Full star icon Full star icon Full star icon Half star icon 4.6
(7 Ratings)
5 star 57.1%
4 star 42.9%
3 star 0%
2 star 0%
1 star 0%
Filter icon Filter
Top Reviews

Filter reviews by




ivan Jun 30, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
I found Colleen Farrelly and Frank Mutombo’s book on Modern Graph Theory Algorithms with Python to be a highly engaging and relevant read, especially for those interested in graph theory, Python programming, and machine learning. It is nicely written and easy to follow, with a strong beginning and finish. The first chapter explains core graph theory concepts. The book then culminates with a chapter dedicated to new applications of network science, which I found to be relevant information to share with readers. The readers have 12 additional chapters to learn how graph theory can solve various industry challenges, from ecological to clinical, financial, and spatial. Throughout the entire book, you will find well-defined coding examples. These gems show you cleverly how to implement graph-based algorithms using Python. In this sense, the book is pleasant to the reader since it wants you to succeed. An additional benefit this book offers to readers is that it gives you enough context and valuable explanations to incorporate new graph-based learning techniques in your daily work.This is the kind of book I will take off the shelf to look at whenever I need a refresher or inspiration on how to do something the right way. I gladly recommend it.
Amazon Verified review Amazon
Amazon Customer Jul 13, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
"Modern Graph Theory with Python" is an essential guide for researchers and industry professionals diving into network science to analyze big data at scale. The book covers a wide range of topics, starting from transforming different data types into network structures to implementing advanced techniques like graph neural networks and graph databases using Python.Readers will learn how to leverage network science tools to tackle real-world problems such as predicting fake news spread, forecasting stock market crashes, and analyzing educational pathways for student success. The book provides comprehensive case studies that demonstrate end-to-end examples of applying network science concepts in Python.With a focus on practical applications, this book equips readers with the skills to wrangle datasets into network science problems and scale solutions effectively using Python. It is recommended for those with basic Python knowledge, including pandas and NumPy, as well as some experience working with datasets.Overall, "Modern Graph Theory with Python" is a valuable resource for anyone interested in network science and its applications in solving data analysis challenges in various fields. From understanding the basics of networks to exploring new frontiers in the field, this book provides a comprehensive and hands-on approach to mastering graph theory with Python.
Amazon Verified review Amazon
Quincy H Aug 07, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
There are many great tutorials, online workflows, books, and other supporting content that can introduce you to concepts in data science and help you navigate difficult topics.Of these resources, I could not more highly recommend the work by Colleen M. Farrelly and Franck Kalala Mutombo - “Modern Graph Theory Algorithms with Python”.Have you ever wondered how social media platforms suggest friends to connect with? Or what goes into predicting stock prices? Or maybe even why some spoken and written languages seem easier to learn than others?This book provides answers to those questions - and much more!Colleen and Franck expertly interweave an engaging, culturally diverse, and inclusive narrative with high quality illustrations and step-by-step instructions for applying the discussed concepts to your own data.The Python code is presented clearly and provides a foundational introduction to newcomers as well as more advanced concepts for those adept in programing languages.I highly recommend this book! Go check it out!
Amazon Verified review Amazon
A.Y. Jun 18, 2024
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Since its inception in 1730’s by Leonhard Euler, graph theory has found a wide range of applications in the study and analysis of networks arising in logistics, engineering, finance, energy, linguistics, social sciences, biology, and many more.This book, in my view, is a successful attempt to showcase many such applications through real-life examples and leveraging Python for network data analysis (e.g. using packages like NetworkX and igraph). The book offers a practical view of the tools, techniques, and models used in network analysis without getting into too much theory, distinguishing itself from classic graph theory texts. It covers use cases involving social and demographic data, transportation and network flow models, spectral clustering, spatiotemporal data, and SIR-diffusion models. In addition, the book includes chapters on graph machine learning, causal pathways and Bayesian networks, and quantum network science algorithms with a forward-looking perspective.Overall, I found the book easy to navigate, readable, and a great introduction to the study and analysis of network data using Python. The book will serve well both the beginner data scientist, as well as more advanced readers interested in such practical applications. One minor criticism is the abundant use of AI-generated cartoons as a part of the storytelling which I found occasionally distracting and at odds with otherwise python-generated displays, but that is my taste and entirely subjective!
Amazon Verified review Amazon
Manu Aug 02, 2024
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
I recently had the pleasure of diving into "Modern Graph Theory Algorithms with Python" by Colleen M. Farrelly and Franck Kalala Mutombo, and I must say, it’s a valuable read, especially for those of us coming from non-CS backgrounds.The book provides a survey of basic Graph Theory algorithms, making it accessible and informative. What truly stood out to me were the varied use cases of graphs outlined throughout the chapters. Each chapter follows a use case by use case approach, introducing relevant graph algorithms along with practical code examples to tackle the problems.One aspect I particularly enjoyed was the focus on spatio-temporal data use cases, which offered a fascinating perspective on the application of graph theory in real-world scenarios.However, I did find the book a bit too basic for my taste. While it excels at explaining the use cases, it doesn’t delve deeply into the intricacies of the techniques. For those looking for an in-depth exploration, this might feel a bit lacking.Nevertheless, it serves as an excellent introductory book for anyone looking to step into the world of graphs.
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

How do I buy and download an eBook? Chevron down icon Chevron up icon

Where there is an eBook version of a title available, you can buy it from the book details for that title. Add either the standalone eBook or the eBook and print book bundle to your shopping cart. Your eBook will show in your cart as a product on its own. After completing checkout and payment in the normal way, you will receive your receipt on the screen containing a link to a personalised PDF download file. This link will remain active for 30 days. You can download backup copies of the file by logging in to your account at any time.

If you already have Adobe reader installed, then clicking on the link will download and open the PDF file directly. If you don't, then save the PDF file on your machine and download the Reader to view it.

Please Note: Packt eBooks are non-returnable and non-refundable.

Packt eBook and Licensing When you buy an eBook from Packt Publishing, completing your purchase means you accept the terms of our licence agreement. Please read the full text of the agreement. In it we have tried to balance the need for the ebook to be usable for you the reader with our needs to protect the rights of us as Publishers and of our authors. In summary, the agreement says:

  • You may make copies of your eBook for your own use onto any machine
  • You may not pass copies of the eBook on to anyone else
How can I make a purchase on your website? Chevron down icon Chevron up icon

If you want to purchase a video course, eBook or Bundle (Print+eBook) please follow below steps:

  1. Register on our website using your email address and the password.
  2. Search for the title by name or ISBN using the search option.
  3. Select the title you want to purchase.
  4. Choose the format you wish to purchase the title in; if you order the Print Book, you get a free eBook copy of the same title. 
  5. Proceed with the checkout process (payment to be made using Credit Card, Debit Cart, or PayPal)
Where can I access support around an eBook? Chevron down icon Chevron up icon
  • If you experience a problem with using or installing Adobe Reader, the contact Adobe directly.
  • To view the errata for the book, see www.packtpub.com/support and view the pages for the title you have.
  • To view your account details or to download a new copy of the book go to www.packtpub.com/account
  • To contact us directly if a problem is not resolved, use www.packtpub.com/contact-us
What eBook formats do Packt support? Chevron down icon Chevron up icon

Our eBooks are currently available in a variety of formats such as PDF and ePubs. In the future, this may well change with trends and development in technology, but please note that our PDFs are not Adobe eBook Reader format, which has greater restrictions on security.

You will need to use Adobe Reader v9 or later in order to read Packt's PDF eBooks.

What are the benefits of eBooks? Chevron down icon Chevron up icon
  • You can get the information you need immediately
  • You can easily take them with you on a laptop
  • You can download them an unlimited number of times
  • You can print them out
  • They are copy-paste enabled
  • They are searchable
  • There is no password protection
  • They are lower price than print
  • They save resources and space
What is an eBook? Chevron down icon Chevron up icon

Packt eBooks are a complete electronic version of the print edition, available in PDF and ePub formats. Every piece of content down to the page numbering is the same. Because we save the costs of printing and shipping the book to you, we are able to offer eBooks at a lower cost than print editions.

When you have purchased an eBook, simply login to your account and click on the link in Your Download Area. We recommend you saving the file to your hard drive before opening it.

For optimal viewing of our eBooks, we recommend you download and install the free Adobe Reader version 9.