国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python使用遺傳算法解決最大流問題

2020-01-04 16:02:03
字體:
來源:轉載
供稿:網友

本文為大家分享了Python遺傳算法解決最大流問題,供大家參考,具體內容如下

Generate_matrix

def Generate_matrix(x,y): import numpy as np import random return np.ceil(np.array([random.random()*10 for i in range(x*y)]).reshape(x,y))

Max_road

def Max_road(A,degree,start): import random import numpy as np import copy def change(M,number,start): # number 控制變異程度 start 控制變異量   x , y = M.shape  for i in range(start,x):   Line = zip(range(len(M[i])),M[i])   index_0 = [t[0] for t in Line if t[1]==0] # 獲取 0 所對應的下標       index_1 = [t[0] for t in Line if t[1]==1] # 獲取 1 所對應的下標   M[i][random.sample(index_0,number)[0]]=1 # 隨機改變序列中 number 個值 0->1   M[i][random.sample(index_1,number)[0]]=0 # 隨機改變序列中 number 個值 1->0  return M x,y = A.shape n=x generation = y #初始化一個有 n 中情況的解決方案矩陣 init_solve = np.zeros([n,x+y-2])  init=[1]*(x-1)+[0]*(y-1) for i in range(n) :  random.shuffle(init)  init_solve[i,:] = init # 1 表示向下走 0 表示向右走  solve = copy.copy(init_solve) for loop in range(generation):  Sum = [A[0,0]]*n # 用于記錄每一種方案的總流量  for i in range(n):   j=0;k=0;   for m in solve[i,:]:    if m==1:     k=k+1    else:     j=j+1       Sum[i] = Sum[i] + A[k,j]  Sum_index = zip(range(len(Sum)),Sum)  sort_sum_index = sorted(Sum_index,key = lambda d : d[1] , reverse =True) # 將 方案 按照流量總和排序  Max = sort_sum_index[0][1] # 最大流量  #print Max  solve_index_half = [a[0] for a in sort_sum_index[:n/2]] # 保留排序后方案的一半  solve = np.concatenate([solve[solve_index_half],solve[solve_index_half]]) # 將保留的一半方案 進行復制 ,復制部分用于變異  change(solve,int((x+y-2)*degree)+1 ,start) # 變異 return solve[0] , Max

Draw_road

def Draw_road(road,A): import pylab as plt import seaborn seaborn.set() x , y =A.shape  # 將下移和右移映射到繪圖坐標上 Road = [(1,x)] # 初始坐標 j=1;k=x; for m in road:  if m==1:   k=k-1  else:   j=j+1  Road.append((j,k)) # print Road for i in range(len(road)):    plt.plot([Road[i][0],Road[i+1][0]],[Road[i][1],Road[i+1][1]])

實際運行的例子

In [119]: A = Generate_matrix(4,6)In [120]: AOut[120]: array([[ 10., 1., 7., 10., 8., 8.],  [ 4., 8., 8., 4., 8., 2.],  [ 9., 8., 8., 3., 9., 8.],  [ 7., 2., 5., 9., 3., 8.]])In [121]: road , M=Max_road(A,0.1,2)In [122]: Draw_road(road,A)

Python,遺傳算法,最大流

較大規模的情況

In [105]: A = Generate_matrix(40,60)In [106]: road , M=Max_road(A,0.1,4)In [107]: roadOut[107]: array([ 0., 0., 0., 1., 1., 0., 0., 0., 0., 0., 0., 0., 0.,  1., 0., 0., 0., 1., 0., 0., 1., 0., 1., 1., 1., 1.,  1., 0., 0., 0., 0., 0., 1., 0., 0., 1., 0., 0., 0.,  1., 0., 0., 0., 1., 0., 1., 0., 0., 1., 0., 0., 1.,  0., 0., 0., 1., 0., 0., 1., 1., 1., 1., 0., 0., 0.,  0., 0., 0., 1., 0., 1., 1., 1., 1., 0., 1., 0., 1.,  1., 1., 0., 1., 0., 1., 0., 1., 0., 1., 0., 0., 1.,  0., 1., 0., 0., 1., 0., 1.])In [108]: Draw_road(road,A)

Python,遺傳算法,最大流

In [109]: A = generate_Matrix(100,200)In [110]: road , M=Max_road(A,0.1,10)In [111]: draw_road(road,A)

Python,遺傳算法,最大流

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 孝感市| 千阳县| 喀喇| 定陶县| 航空| 惠州市| 宕昌县| 唐河县| 河曲县| 吉木乃县| 太和县| 吉安县| 永修县| 泌阳县| 慈利县| 陇南市| 巩留县| 泗水县| 玉溪市| 清徐县| 疏附县| 青岛市| 宝应县| 江都市| 留坝县| 杭锦后旗| 张家口市| 锡林浩特市| 当雄县| 新安县| 云龙县| 林周县| 兴仁县| 岢岚县| 萝北县| 腾冲县| 黄梅县| 肥乡县| 台中市| 威宁| 邳州市|