【数学建模】图论模型

文章目录

  • 图的基础理论及networkx简介
    • 图的基本概念
    • 图的表示及Networkx简介
      • 图的表示
      • NetworkX简介
  • 最短路算法及其Python实现
    • 固定起点到其余各点的最短路算法
    • 每对顶点间的最短路算法
      • 最短路应用
  • 最小生成树算法及其networkx实现
    • 基本概念
    • 最小生成树算法
    • 最小生成树应用
  • 匹配问题
  • 最大流最小费用问题
    • 基本概念
    • 最小费用流问题
  • PageRank算法
  • 复杂网络简介
    • 复杂网络概况

图的基础理论及networkx简介

图的基本概念

  1. 无向图和有向图
  2. 简单图和完全图:重边、环、孤立点
  3. 赋权图/网络
  4. 顶点的度
  5. 子图与生成子图
  6. 路与回路、迹、path、圈
  7. 连通图与非连通图

图的表示及Networkx简介

图的表示

考虑简单图

  1. 关联矩阵表示
    image.png

  2. 邻接矩阵表示
    image.png
    对于赋权图而言,邻接矩阵中的数值改为对应边的权值就得到对应的无向/有向赋权图

NetworkX简介

python语言
图论与复杂网络建模工具
内置常用图与复杂网络分析算法

绘图布局
图形布局共五种

  1. circular_layout:顶点在一个圆环上均匀分布;
  2. random_layout:顶点随机分布;
  3. shell_layout:顶点在同心圆上分布;
  4. spring_layout: 用Fruchterman-Reingold算法排列顶点;
  5. spectral_layout:根据图的拉普拉斯特征向量排列顶点

最短路算法及其Python实现

Dijkstra(迪克斯特拉)标号算法和Floyd(弗洛伊德)算法
Dijkstra标号算法只适用于边权是非负的情形
最短路问题也可以归结为一个0-1整数规划模型

固定起点到其余各点的最短路算法

Dijkstra(迪克斯特拉)标号算法
赋权图 G ( V , E , W ) G(V,E,W) G(V,E,W),其中顶点集 V = { v 1 , . . . , v n } V=\{v_1, ..., v_n\} V={v1,...,vn}, 边集 E E E,邻接矩阵 W = ( w i j ) n x n W=(w_{ij})_{n x n} W=(wij)nxn,且 w i j w_{ij} wij满足
image.png
记号确定
d ( u 0 , v 0 ) d(u_0, v_0) d(u0,v0) :顶点 u 0 u_0 u0到顶点 v 0 v_0 v0的最短距离
l ( v ) l(v) l(v):起点 u 0 u_0 u0 v v v的当前路长度
z ( v ) z(v) z(v):顶点 v v v的父顶点标号
S i S_i Si:具有永久标号的顶点集

每对顶点间的最短路算法

Floyd(弗洛伊德)算法
动态规划算法,递推产生矩阵序列 A 1 , A 2 , . . . , A k , . . . , A n A_1, A_2, ..., A_k, ..., A_n A1,A2,...,Ak,...,An,矩阵 A k = ( a k ( i , j ) ) n x n A_k=(a_k(i,j))nxn Ak=(ak(i,j))nxn,第 i i i行第 j j j列元素 a k ( i , j ) a_k(i,j) ak(i,j)表示从顶点 v i v_i vi到顶点 v j v_j vj路径上顶点数不大于 k k k的最短路径长度
迭代公式
image.png

networkx求所有顶点对之间最短路径的函数为
shortest_path(G, source=None, target=None, weight=None, method='dijkstra'),返回值是可迭代类型,其中method可以取值dijkstrabellman-ford

最短路应用

设备更新问题
image.png
image.png
转化为最短路问题
赋权有向图 D = ( V , A , W ) D=(V, A, W) D=(V,A,W),顶点集 V = { v 1 , v 2 , . . . , v 5 } V=\{v_1, v_2, ..., v_5\} V={v1,v2,...,v5} v i v_i vi i = 1 , 2 , 3 , 4 i=1, 2, 3, 4 i=1,2,3,4)表示第 i i i年年初, v 5 v_5 v5表示第4年年末,A为边集,W为邻接矩阵, w i j w_{ij} wij为第 i i i年年初到第 j j j年年初/第 j − 1 j-1 j1年年末所支付的费用,计算公式为
w i j = p i + ∑ i j − 1 a k − r j w_{ij} = p_i+\sum_i^{j-1}a_k-r_j wij=pi+ij1akrj
说明: p i p_i pi为第 i i i年年初机器的购置费用, a k a_k ak为第 k k k年的机器维护费用, r i r_i ri为第 i i i年末机器的出售价格
根据这个公式计算得到邻接矩阵 W W W,并且原问题转化为求解 v 1 v_1 v1 v 5 v_5 v5的费用最短路
image.png

结果
image.png

重心问题/选址问题

image.png

image.png

问题转化:求出各个顶点对之间的最短距离,然后得到某一顶点到其他各个顶点的(最短重量·距离)和最小,这个顶点即为所求

计算结果展示
image.png

最小生成树算法及其networkx实现

基本概念

  1. 树:连通的五圈图
  2. 树的判定定理:n个顶点m条边的图
  3. 生成树、最小生成树

最小生成树算法

Kruskal算法和Prim算法
Kruskal算法
贪心,每次选择权值最小的边加入子图T,并保证不形成环,直到子图中包含 n − 1 n-1 n1条边为止
Prim算法
使用两个集合 P P P Q Q Q,从任意 p ∈ P p \in P pP v ∈ V − P v \in V-P vVP,选择最小权值的边 p v pv pv,将 v v v加入 P P P p v pv pv加入Q,直到 P = V P=V P=V为止
说明:对比Kruskal算法和Prim算法,Kruskal算法是显式地说明了不能在生成子图中出现环,Prim算法则是通过设定选定新边的一个顶点在 P P P集合,一个顶点在 V − P V-P VP集合这样隐式保证的

NetworkX提供接口
T=minimum_spanning_tree(G, weight='weight', algorithm='kruskal')
G为输入图
algorithm的取值有三种字符串:‘kruskal’,‘prim’,或’boruvka’,缺省值为’kruskal’
返回值T为所求得的最小生成树的可迭代对象

示例
image.png

最小生成树应用

image.png

说明:从这个题看出最小生成树和最短路算法的区别,最短路在找的是各个节点到某个节点的最短,而最小生成树在找的是一条通过全部节点的最短路

结果
image.png

匹配问题

image.png

问题转化:赋权图 G = ( V , E , W ^ ) G=(V, E, \hat{W}) G=(V,E,W^) ,顶点集 V = { v 1 , v 2 , . . . , v 10 } V=\{v_1, v_2, ..., v_{10}\} V={v1,v2,...,v10} v 1 , v 2 , . . . , v 5 v_1, v_2, ..., v_5 v1,v2,...,v5表示5个人, v 6 , v 7 , v 8 , v 9 , v 10 v_6, v_7, v_8, v_9, v_{10} v6,v7,v8,v9,v10表示5项工作,邻接矩阵 W ^ \hat{W} W^满足
image.png

代码:

import numpy as np
import networkx as nx
from networkx.algorithms.matching import max_weight_matching
a=np.array([[3,5,5,4,1],[2,2,0,2,2],[2,4,4,1,0],[0,2,2,1,0],[1,2,1,3,3]])
b=np.zeros((10,10)); b[0:5,5:]=a; G=nx.Graph(b)
#返回值为(人员,工作)的集合
s0=max_weight_matching(G)  
s=[sorted(w) for w in s0]
L1=[x[0] for x in s]; L1=np.array(L1)+1  #人员编号
L2=[x[1] for x in s]; L2=np.array(L2)-4  #工作编号
c=a[L1-1,L2-1]  #提取对应的效益
d=c.sum()  #计算总的效益
print("工作分配对应关系为:\n人员编号:",L1)
print("工作编号:", L2); print("总的效益为:",d)

最大流最小费用问题

网络流问题——如何安排使流量最大,即最大流问题,如公路系统中有车辆流、物资调配系统中有物资流、金融系统中有现金流等

基本概念

  1. 有向图 D ( V , A ) D(V, A) D(V,A)、源点 v s v_s vs、汇点 v t v_t vt、弧容量 c ( v i , v j ) ≥ 0 c(v_i, v_j) \geq 0 c(vi,vj)0 、网络流 f ( v i , v j ) f(v_i, v_j) f(vi,vj)
  2. 可行流的条件
  3. 增广路

最大流问题可写为这样一个线性规划问题
image.png

Ford-Fulkerson算法寻求最大流

使用NetworkX求解网络最大流
image.png

最小费用流问题

标号说明
f i j f_{ij} fij为弧 ( v i , v j ) (v_i, v_j) (vi,vj)上的流量, b i j b_{ij} bij为弧 ( v i , v j ) (v_i, v_j) (vi,vj)上的单位费用, c i j c_{ij} cij为弧 ( v i , v j ) (v_i, v_j) (vi,vj)上的容量,问题转化为下面的线性规划问题
image.png
v = v m a x v=v_{max} v=vmax时,问题有解;当 v > v m a x v > v_{max} v>vmax时,问题无解

使用NetworkX求解问题
image.png

代码:

import numpy as np
import networkx as nx
L=[(1,2,5,3),(1,3,3,6),(2,4,2,8),(3,2,1,2),(3,5,4,2),(4,3,1,1),(4,5,3,4),(4,6,2,10),(5,6,5,2)]
G=nx.DiGraph()
for k in range(len(L)):G.add_edge(L[k][0]-1,L[k][1]-1, capacity=L[k][2], weight=L[k][3])
mincostFlow=nx.max_flow_min_cost(G,0,5)
print("所求流为:",mincostFlow)
mincost=nx.cost_of_flow(G, mincostFlow)
print("最小费用为:", mincost)
flow_mat=np.zeros((6,6),dtype=int)
for i,adj in mincostFlow.items():for j,f in adj.items():flow_mat[i,j]=f
print("最小费用最大流的邻接矩阵为:\n",flow_mat)

PageRank算法

引文分析思想
当网页甲有一个链接指向网页乙,就认为乙获得了甲对它贡献的分值,该值的多少取决于网页甲本身的重要程度,即网页甲的重要性越大,网页乙获得的贡献值就越高。
由于网络中网页链接的相互指向,pagerank分值计算为一个迭代过程,最终网页根据所得分值进行排序

假设
我们在上网时浏览页面并选择下一个页面的过程,与过去浏览过哪些页面无关,而仅依赖于当前所在的页面。
这一选择过程可以认为是一个有限状态、离散时间的随机过程,其状态转移规律用Markov链描述
image.png
说明: a i j a_{ij} aij表示从页面 i i i转移到页面 j j j的概率, 1 − d N \frac{1-d}{N} N1d为随机跳转时到页面 j j j的概率, d b i j r i d \frac{b_{ij}}{r_i} dribij为根据连接进行跳转到页面 j j j的概率

再根据正则Markov的平稳分布,得到各个网页被访问的概率分布,这个概率就被定义为各个网页的PageRank值

image.png

使用NetworkX求解
image.png

复杂网络简介

重点关注复杂网络的统计性质,并使用NetworkX计算

复杂网络概况

复杂网络:具有自组织、自相似、吸引子、小世界、无标度中部分或全部性质的网络
特征:结构复杂、网络进化、连接多样性、动力学复杂性、节点多样性
研究内容:网络的几何性质,网络的形成机制,网络演化的统计规律,网络上的模型性质,以及网络的结构稳定性,网络的演化动力学机制等问题
基本测度:度(degree)及其分布特征,度的相关性,集聚程度及其分布特征,最短距离及其分布特征,介数(betweenness)及其分布特征,连通集团的规模分布

  1. 节点的度和度分布:度分布一般用直方图展示, A 2 A^2 A2的对角元素 a i i 2 a_{ii}^2 aii2即为节点 v i v_i vi的度,平均度 < k > = t r ( A 2 ) / N <k> = tr(A^2)/N <k>=tr(A2)/N
  2. 平均路径长度,网络直径
  3. 聚类系数

image.png

代码:

import numpy as np
import networkx as nx
L=[(1,2),(1,3),(2,3),(2,4),(2,5),(3,5),(4,5),(4,6)]
G=nx.Graph()   #构造无向图
G.add_nodes_from(range(1,7))  #添加顶点集
G.add_edges_from(L)
D=nx.diameter(G)  #求网络直径
LH=nx.average_shortest_path_length(G) #求平均路径长度
Ci=nx.clustering(G)   #求各顶点的聚类系数
C=nx.average_clustering(G)  #求整个网络的聚类系数
print("网络直径为:",D,"\n平均路径长度为:",LH)
print("各顶点的聚类系数为:")
for index,value in enumerate(Ci.values()):print("(顶点v{:d}: {:.4f});".format(index+1,value),end=' ')
print("\n整个网络的聚类系数为:{:.4f}".format(C))

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/242520.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt5.15.2中加入图片资源

系列文章目录 文章目录 系列文章目录前言一、加入图片资源二、代码 前言 以前用的Qt5.15.2之前的版本&#xff0c;QtCreator默认的工程文件是*.pro&#xff0c;现在用5.15.2创建工程默认的工程文件是CMameList.txt,当然在创建项目时&#xff0c;仍然可以使用pro工程文件用QtCr…

13.浮动面板(PaletteSet)

愿你出走半生,归来仍是少年&#xff01; 环境&#xff1a;.NET FrameWork4.5、ObjectArx 2016 64bit、Entity Framework 6. 在CAD中进行通用组件开发或常驻界面的控件开发时&#xff0c;可使用PaletteSet作为停靠面板&#xff0c;然后将自己的空间放入其中。 1.示例 SearchRe…

web terminal - 如何在mac os上运行gotty

gotty可以让你使用web terminal的方式与环境进行交互&#xff0c;实现终端效果 假设你已经配置好了go环境&#xff0c;首先使用go get github.com/yudai/gotty命令获取可执行文件&#xff0c;默认会安装在$GOPATH/bin这个目录下&#xff0c;注意如果你的go版本比较高&#xff…

小程序系列--10.小程序WXS 脚本

一、概述 1. 什么是 wxs&#xff1f; WXS&#xff08;WeiXin Script&#xff09;是小程序独有的一套脚本语言&#xff0c;结合 WXML&#xff0c;可以构建出页面的结构。 2. wxs 的应用场景 wxml 中无法调用在页面的 .js 中定义的函数&#xff0c;但是&#xff0c;wxml 中可…

Ceph应用

目录 1.资源池Pool管理 创建一个Pool资源池 查看集群Pool信息 查看资源池副本的数量 查看PG和PGP数量 修改pg_num和pgp_num的数量 修改Pool副本数量 删除Pool资源池 2.创建CephFS文件系统MDS接口 服务端操作(192.168.88.22) 1.在管理节点创建 mds 服务 2.查看各个节…

JUC并发编程知识点总结

JMM Java内存模型规定所有的变量都存储在主内存中&#xff0c;包括实例变量&#xff0c;静态变量&#xff0c;但是不包括局部变量和方法参数。每个线程都有自己的工作内存&#xff0c;线程的工作内存保存了该线程用到的变量和主内存的副本拷贝&#xff0c;线程对变量的操作都在…

智篆商业土豆老师:引领电商运营新潮流

智篆商业的土豆老师不仅是电商运营的专家&#xff0c;更是引领电商运营新潮流的先锋。他时刻关注电商行业的发展动态&#xff0c;深入研究新兴技术和市场趋势&#xff0c;不断探索电商运营的新模式和新思路。 土豆老师认为&#xff0c;未来的电商运营将更加注重个性化和精细化…

初始RabbitMQ(入门篇)

消息队列(MQ) 本质上就是一个队列,一个先进先出的队列,队列中存放的内容是message(消息),是一种跨进程的通信机制,用于上下游传递消息, 为什么使用MQ: 削峰填谷: MQ可以很好的做一个缓冲机制,例如在一个系统中有A和B两个应用,A是接收用户的请求的,然后A调用B进行处理. 这时…

微信中这些黑科技不知道,白用微信这么多年,速来学,春节假期很有用,第1季:【#】字诀。

微信中这些黑科技不知道&#xff0c;白用微信这么多年&#xff0c;速来学&#xff0c;春节假期很有用&#xff0c;第1季&#xff1a;【#】字诀。 大家好&#xff01;我是老码农。 今天分享的主题&#xff1a;微信中的黑科技。微信这款软件不用过多介绍&#xff0c;聊天、看朋…

机器人电机综述 — 电机分类、舵机、步进与伺服、物理性质和伺服控制系统

电机综述 图片与部分素材来自知乎大佬不看后悔&#xff01;最全的电机分类&#xff0c;看这一篇就够了&#xff01; - 知乎 (zhihu.com)&#xff0c;本文只是把机器人中常用的电机知识提炼了一下 1 按照结构和工作原理划分 1. 同步电机 ​ 电机的转速与定子磁场的转速相同步…

springboot113健身房管理系统

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的健身房管理系统 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取…

stm32 FOC 电机介绍

今年开始学习foc控制无刷电机&#xff0c;这几天把所学整理一下&#xff0c;记录一下知识内容。 前言: 为什么要学习FOC? 1.电机控制是自动化控制领域重要一环。 2.目前直流无刷电机应用越来越广泛&#xff0c;如无人机、机械臂、云台、仿生机器人等等。 需要什么基础&…

设计模式-资源库模式

设计模式专栏 模式介绍模式特点应用场景资源库模式与关系型数据库的区别代码示例Java实现资源库模式Python实现资源库模式 资源库模式在spring中的应用 模式介绍 资源库模式是一种架构模式&#xff0c;介于领域层与数据映射层&#xff08;数据访问层&#xff09;之间。它的存在…

Ansible常用模块

目录 实验前准备Ansible部署安装ansible配置主机清单配置密钥对验证 常用模块commond模块shell模块cron模块user模块group模块copy模块file模块ping模块yum模块service/systemd模块script模块setup模块 遇到的问题sshpass卡住 实验前准备 Ansible管理机&#xff1a;192.168.18…

【新书推荐】Web3.0应用开发实战(从Web 2.0到Web 3.0)

第一部分 Flask简介 第1章 安装 1.1 创建应用目录 1.2 虚拟环境 1.2.1 创建虚拟环境 1.2.2 使用虚拟环境 1.3 使用pip安装Python包 1.4 使用pipregs输出包 1.5 使用requirements.txt 1.6 使用pipenv管理包 第2章 应用的基本结构 2.1 网页显示过程 2.2 初始化 2.3 路由和视图函数…

Jmeter的文件参数化:CSV数据文件设置和_CSVRead函数

一、CSV数据文件设置 1、简介 CSV数据文件配置&#xff08;CSV Data Set Config&#xff09;可以将CSV文件中数据读入自定义变量中 Jmeter中CSV数据文件配置的界面如下图所示&#xff1a; 其中&#xff1a; &#xff08;1&#xff09;文件编码 文件的编码格式&#xff0c;与所…

Element-UI 多个el-upload组件自定义上传,不用上传url,并且携带自定义传参(文件序号)

1. 需求&#xff1a; 有多个&#xff08;不确定具体数量&#xff09;的upload组件&#xff0c;每个都需要单独上传获取文件&#xff08;JS File类型&#xff09;&#xff0c;不需要action上传到指定url&#xff0c;自定义上传动作和http操作。而且因为不确定组件数量&#xff0…

【计算机网络】TCP握手与挥手:三步奏和四步曲

这里写目录标题 前言三次握手四次挥手三次握手和四次挥手的作用TCP三次握手的作用建立连接防止已失效的连接请求建立连接防止重复连接 TCP四次挥手的作用&#xff1a;安全关闭连接避免数据丢失避免半开连接 总结&#xff1a; 总结 前言 TCP&#xff08;传输控制协议&#xff09…

Mac M1 Parallels CentOS7.9 Deploy Typecho

一、创建名称空间 kubectl create ns prod二、创建PV & PVC vim local-pv1.yamlapiVersion: v1 kind: PersistentVolume metadata:name: local-pv-1 spec:capacity:storage: 1GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: RetainstorageClassName: loca…

【Python】模块

&#x1f6a9; WRITE IN FRONT &#x1f6a9; &#x1f50e; 介绍&#xff1a;"謓泽"正在路上朝着"攻城狮"方向"前进四" &#x1f50e;&#x1f3c5; 荣誉&#xff1a;2021|2022年度博客之星物联网与嵌入式开发TOP5|TOP4、2021|2222年获评…