Masalah Transportasi Jaringan (2)
Pengenalan Optimisasi Jaringan¶
Masalah Transportasi Jaringan (2)
Tautan Masalah Transportasi Jaringan (1) : https://www.ridwanreza.com/2021/08/masalah-transportasi-jaringan.html
#Install library Mixed Integer Programming sebagai tools yang digunakan dalam workshop ini
!pip install mip #Apabila library mip sudah terinstall, berikan comment (tanda #) sebelum !pip
import mip #memanggil library Mixed Integer Programminh
import numpy as np #memanggil library Numerical Python
Tugas 1¶
Terdapat 4 buah pabrik yang memiliki kapasitas produksi 30,80,10, dan 60
Terdapat 4 orang penjual yang meminta barang sejumlah 10,50,20, dan 80.
- Masalah ini serupa dengan Contoh 1, tetapi tidak ada penjual kelima
Biaya pengiriman barang dari satu pabrik ke penjual bisa berbeda. (terlampir pada matriks C pada gambar)
Tentukan biaya minimum untuk mengirimkan barang !
Formulasi Tugas 1 :¶
Misalkan :
- $x_{i,j}$ merupakan banyaknya barang yang dikirimkan dari pabrik $i$ ke penjual $j$
- $c_{i,j}$ merupakan biaya antar barang yang dikirimkan dari pabrik $i$ ke penjual $j$
dengan $i\in\{0,1,2,3\}$ dan $j\in\{0,1,2,3,4\}$ (indeks pada python dimulai dari nol)
Minimumkan biaya pengantaran : $$f(\mathbb{x})=c_{0,0}x_{0,0}+c_{0,1}x_{0,1}+c_{0,2}x_{0,2}+...+c_{3,4}x_{3,4}$$ $$f(\mathbb{x})=\sum_{j=0}^4\sum_{i=0}^3 c_{i,j}x_{i,j}$$
Kendala 1 - setiap pabrik mengirimkan barang sesuai kapasitas produksinya :
- Pabrik ke-0 produksi sebanyak 30 : $x_{0,0}+x_{0,1}+x_{0,2}+x_{0,3}+x_{0,4}=30$
- Pabrik ke-1 produksi sebanyak 80 : $x_{1,0}+x_{1,1}+x_{1,2}+x_{1,3}+x_{1,4}=80$
- Pabrik ke-2 produksi sebanyak 10 : $x_{2,0}+x_{2,1}+x_{2,2}+x_{2,3}+x_{2,4}=10$
- Pabrik ke-3 produksi sebanyak 60 : $x_{3,0}+x_{3,1}+x_{3,2}+x_{3,3}+x_{3,4}=60$
Kendala 2 - setiap penjual menerima sesuai dengan permintaannya :
- Penjual ke-0 meminta 10 barang : $x_{0,0}+x_{1,0}+x_{2,0}+x_{3,0}=10$
- Penjual ke-1 meminta 50 barang : $x_{0,1}+x_{1,1}+x_{2,1}+x_{3,1}=10$
- Penjual ke-2 meminta 20 barang : $x_{0,2}+x_{1,2}+x_{2,2}+x_{3,2}=10$
- Penjual ke-3 meminta 80 barang : $x_{0,3}+x_{1,3}+x_{2,3}+x_{3,3}=10$
- Penjual ke-4 meminta 20 barang : $x_{0,4}+x_{1,4}+x_{2,4}+x_{3,4}=10$
Formulasi Contoh 1 :¶
Misalkan :
- $x_{i,j}$ merupakan banyaknya barang yang dikirimkan dari pabrik $i$ ke penjual $j$
- $c_{i,j}$ merupakan biaya antar barang yang dikirimkan dari pabrik $i$ ke penjual $j$
dengan $i\in\{0,1,2,3\}$ dan $j\in\{0,1,2,3\}$ (indeks pada python dimulai dari nol)
Minimumkan biaya pengantaran : $$f(\mathbb{x})=c_{0,0}x_{0,0}+c_{0,1}x_{0,1}+c_{0,2}x_{0,2}+...+c_{3,3}x_{3,3}$$ $$f(\mathbb{x})=\sum_{j=0}^4\sum_{i=0}^3 c_{i,j}x_{i,j}$$
Kendala 1 - setiap pabrik mengirimkan barang sesuai kapasitas produksinya :
- Pabrik ke-0 produksi sebanyak 30 : $x_{0,0}+x_{0,1}+x_{0,2}+x_{0,3}=30$
- Pabrik ke-1 produksi sebanyak 80 : $x_{1,0}+x_{1,1}+x_{1,2}+x_{1,3}=80$
- Pabrik ke-2 produksi sebanyak 10 : $x_{2,0}+x_{2,1}+x_{2,2}+x_{2,3}=10$
- Pabrik ke-3 produksi sebanyak 60 : $x_{3,0}+x_{3,1}+x_{3,2}+x_{3,3}=60$
Kendala 2 - setiap penjual menerima sesuai dengan permintaannya :
- Penjual ke-0 meminta 10 barang : $x_{0,0}+x_{1,0}+x_{2,0}+x_{3,0}=10$
- Penjual ke-1 meminta 50 barang : $x_{0,1}+x_{1,1}+x_{2,1}+x_{3,1}=10$
- Penjual ke-2 meminta 20 barang : $x_{0,2}+x_{1,2}+x_{2,2}+x_{3,2}=10$
- Penjual ke-3 meminta 80 barang : $x_{0,3}+x_{1,3}+x_{2,3}+x_{3,3}=10$
#Definisikan matriks cost
cost=np.array([[3,4,6,8],
[2,2,4,5],
[2,2,2,3],
[3,3,2,4]])
m = mip.Model("Tugas 1 Masalah Transportasi")
x = [[m.add_var(var_type=mip.INTEGER) for j in range(4)] for i in range(4)]
#m.objective = mip.minimize( 3*x[0][0]+ 4*x[0][1]+ 6*x[0][2]+ ... )
m.objective = mip.minimize( mip.xsum(cost[i][j]*x[i][j] for i in range(4) for j in range(4) ) )
#barang yang dikirim boleh kurang dari yang diproduksi
m += x[0][0]+x[0][1]+x[0][2]+x[0][3] == 30 # kendala pengiriman dari S0
m += x[1][0]+x[1][1]+x[1][2]+x[1][3] == 80 # kendala pengiriman dari S1
m += x[2][0]+x[2][1]+x[2][2]+x[2][3] == 10 # kendala pengiriman dari S0
m += x[3][0]+x[3][1]+x[3][2]+x[3][3] == 60 # kendala pengiriman dari S1
#penjual 0 hanya butuh 10
m += x[0][0]+x[1][0]+x[2][0]+x[3][0] == 10
#penjual 1 hanya butuh 50
m += x[0][1]+x[1][1]+x[2][1]+x[3][1] == 50
#penjual 2 hanya butuh 50
m += x[0][2]+x[1][2]+x[2][2]+x[3][2] == 20
#penjual 3 hanya butuh 80
m += x[0][3]+x[1][3]+x[2][3]+x[3][3] == 80
m.optimize()
print(m.status)
print('minimum dari f objektif =',m.objective_value)
print('Variabel keputusan : ')
for i in range(4):
for j in range(4):
if(x[i][j].x>=0.5): print("x[",i,",",j,"]=",x[i][j].x,' dan cost[',i,',',j,'] =',cost[i][j])
Kode di atas tidak mengeluarkan hasil karena memang tidak memiliki solusi (solusi infeasible).
Penyebabnya adalah kendala kita meminta banyak barang yang diproduksi harus sama dengan banyak permintaan.
Pada kasus ini permintaan kurang dari produksi, sehingga ada barang yang berlebih.
Salah satu solusinya adalah mengubah kendala menjadi :
Kendala 1 - setiap pabrik mengirimkan barang sesuai kapasitas produksinya :
- Pabrik ke-0 produksi sebanyak 30 : $x_{0,0}+x_{0,1}+x_{0,2}+x_{0,3}\leq 30$
- Pabrik ke-1 produksi sebanyak 80 : $x_{1,0}+x_{1,1}+x_{1,2}+x_{1,3}\leq 80$
- Pabrik ke-2 produksi sebanyak 10 : $x_{2,0}+x_{2,1}+x_{2,2}+x_{2,3}\leq 10$
- Pabrik ke-3 produksi sebanyak 60 : $x_{3,0}+x_{3,1}+x_{3,2}+x_{3,3}\leq 60$
Artinya barang yang kirimkan boleh kurang dari yang diminta
#Definisikan matriks cost
cost=np.array([[3,4,6,8],
[2,2,4,5],
[2,2,2,3],
[3,3,2,4]])
m = mip.Model("Tugas 1 Masalah Transportasi")
x = [[m.add_var(var_type=mip.INTEGER) for j in range(4)] for i in range(4)]
#m.objective = mip.minimize( 3*x[0][0]+ 4*x[0][1]+ 6*x[0][2]+ ... )
m.objective = mip.minimize( mip.xsum(cost[i][j]*x[i][j] for i in range(4) for j in range(4) ) )
#barang yang dikirim boleh kurang dari yang diproduksi
m += x[0][0]+x[0][1]+x[0][2]+x[0][3] <= 30 # kendala pengiriman dari S0
m += x[1][0]+x[1][1]+x[1][2]+x[1][3] <= 80 # kendala pengiriman dari S1
m += x[2][0]+x[2][1]+x[2][2]+x[2][3] <= 10 # kendala pengiriman dari S2
m += x[3][0]+x[3][1]+x[3][2]+x[3][3] <= 60 # kendala pengiriman dari S3
#penjual 0 hanya butuh 10
m += x[0][0]+x[1][0]+x[2][0]+x[3][0] == 10
#penjual 1 hanya butuh 50
m += x[0][1]+x[1][1]+x[2][1]+x[3][1] == 50
#penjual 2 hanya butuh 50
m += x[0][2]+x[1][2]+x[2][2]+x[3][2] == 20
#penjual 3 hanya butuh 80
m += x[0][3]+x[1][3]+x[2][3]+x[3][3] == 80
m.optimize()
print(m.status)
print('minimum dari f objektif =',m.objective_value)
print('Variabel keputusan : ')
for i in range(4):
for j in range(4):
if(x[i][j].x>=0.5): print("x[",i,",",j,"]=",x[i][j].x,' dan cost[',i,',',j,'] =',cost[i][j])
Salah satu solusi lain adalah menambahkan titik dummy yang berfungsi sebagai tempat "menyimpan"/"membuang" kelebihan produksi, yaitu 20 barang.
Artinya masalah kembali ke Contoh 1. Misalkan penjual 4 adalah "menyimpan"/"membuang" kelebihan produksi. dengan biaya pengantaran 0 (kita bisa mengubah sesuai dengan kondisi)
#Definisikan matriks cost
cost=np.array([[3,4,6,8,0],
[2,2,4,5,0],
[2,2,2,3,0],
[3,3,2,4,0]])
m = mip.Model("Tugas 1 Masalah Transportasi")
x = [[m.add_var(var_type=mip.INTEGER) for j in range(5)] for i in range(4)]
#m.objective = mip.minimize( 3*x[0][0]+ 4*x[0][1]+ 6*x[0][2]+ ... )
m.objective = mip.minimize( mip.xsum(cost[i][j]*x[i][j] for i in range(4) for j in range(5) ) )
#barang yang dikirim sama dengan kapasitas produksi
m += x[0][0]+x[0][1]+x[0][2]+x[0][3]+x[0][4] == 30 # kendala pengiriman dari S0
m += x[1][0]+x[1][1]+x[1][2]+x[1][3]+x[1][4] == 80 # kendala pengiriman dari S1
m += x[2][0]+x[2][1]+x[2][2]+x[2][3]+x[2][4] == 10 # kendala pengiriman dari S2
m += x[3][0]+x[3][1]+x[3][2]+x[3][3]+x[3][4] == 60 # kendala pengiriman dari S3
#penjual 0 hanya butuh 10
m += x[0][0]+x[1][0]+x[2][0]+x[3][0] == 10
#penjual 1 hanya butuh 50
m += x[0][1]+x[1][1]+x[2][1]+x[3][1] == 50
#penjual 2 hanya butuh 50
m += x[0][2]+x[1][2]+x[2][2]+x[3][2] == 20
#penjual 3 hanya butuh 80
m += x[0][3]+x[1][3]+x[2][3]+x[3][3] == 80
#penjual 4 hanya butuh 20
m += x[0][4]+x[1][4]+x[2][4]+x[3][4] == 20
#penjual 2 ingin menerima minimal 3 barang dari pabrik 1
m += x[1][2] >= 3
#pabrik 0 tidak memiliki akses mengirimkan barang ke penjual 0
m += x[0][0] == 0
m.optimize()
print(m.status)
print('minimum dari f objektif =',m.objective_value)
print('Variabel keputusan : ')
for i in range(4):
for j in range(5):
if(x[i][j].x>=0.5): print("x[",i,",",j,"]=",x[i][j].x,' dan cost[',i,',',j,'] =',cost[i][j])
Ada yang mau didiskusikan?
Silahkan hubungi Ridwan
Comments
Post a Comment