|
|
(12 intermediate revisions by the same user not shown) |
Line 1: |
Line 1: |
− | {| class="wikitable" style="float:right; margin-left: 10px;"
| |
− | !colspan="2"|Profile
| |
− | |-
| |
− | |colspan="2"|[[File:Rezky.jpg|250px|Center]]
| |
− | |-
| |
− | |'''Nama Lengkap'''
| |
− | |Rezky Alfian Fatra
| |
− | |-
| |
− | |'''NPM'''
| |
− | |1906379043
| |
− | |-
| |
− | |style="vertical-align:top;"|'''Jurusan'''
| |
− | |Teknik Mesin
| |
− | |-
| |
− | |colspan="2" style="text-align:center;width:200px;"|
| |
− | |}
| |
| | | |
− |
| |
− | '''Rezky Alfian Fatra''' (lahir di Jakarta, 13 November 2000; umur 20 tahun) adalah seorang mahasiswa yang mengambil jurusan Teknik Mesin di Universitas Indonesia angkatan 2019. Selain menjalankan tugas utama menjadi seorang mahasiswa, '''Rezky''' juga dikenal aktif berkontribusi di Lembaga Dakwah Kampus,khususnya di IMM yang memberikan wawasan berupa ilmu keagamaan kepada mahasiswa Departemen Teknik Mesin.Salah satu hal yang dilakukan oleh Rezky adalah dengan membuat program kerja yang menjadi wadah bagi mahasiswa Departemen Teknik Mesin untuk meningkatkan wawasan maupun kemampuan keagamaanya.
| |
− |
| |
− | __TOC__
| |
− |
| |
− | == Aktivitas ==
| |
− |
| |
− | Rezky Alfian Fatra atau panggilan akrabnya adalah Ekky adalah seorang mahasiswa yang aktif dalam melakukan kontribusi semenjak SMA, khususnya dalam bidang dakwah agar bisa memberikan manfaat bagi orang banyak.Ini terbukti dengan banyaknya organisasi rohani islam yang pernah ia jalani
| |
− |
| |
− | Sangat besar harapan saya agar terus bisa berkontribusi memberikan kebaikan yang bisa bermanfaat dan berguna bagi orang banyak, seperti yang pernah disabdakan oleh Nabi Muhammad SAW : "Sebaik-baiknya manusia adalah manusia yang bermanfaat untuk orang lain."
| |
− |
| |
− | Dalam aktivitasnya menjadi seorang pendakwah yang memberikan manfaat bagi orang banyak, Rezky juga tidak lupa untuk terus menambah ilmunya dengan mengikuti kajian keagamaan yang diselenggarakan oleh Manazil Ilmi Insani (Meninggikan Ilmu Manusia)
| |
− | *https://www.youtube.com/channel/UCv_8XF7jxSQ27uhbAo_039w
| |
− |
| |
− |
| |
− |
| |
− | == Metode Numerik ==
| |
− |
| |
− | Metode numerik merupakan sebuah metode yang digunakan untuk menyelesaikan persoalan dimana perhitungan yang dilakukan secara analitik sudah sulit atau bahkan tidak bisa untuk dilakukan.Metode numerik ini berawal dari sebuah pemikiran bahwa permasalahan dapat diselesaikan dengan menggunakan pendekatan-pendekatan yang dapat dipertanggungjawabkan dengan metode analitik.Dengan menggunakan metode numerik, kita bisa mendapatkan hasil yang cepat dan tepat (meskipun dengan menggunakan pendekatan).
| |
− |
| |
− | Pada kelas Metode Numerik-02 semester ganjil 2020/2021, dari awal perkuliahan sampai UTS diisi oleh Bapak Dr. Ir. Engkos A. Kosasih, M.T.
| |
− | Dimana pada pertemuan yang telah dilakukan telah membahas materi seperti:
| |
− |
| |
− | *Pseudocode
| |
− | *Sistem Persamaan
| |
− | *Turunan Numerik
| |
− | *Metode Newton Rhapson, Secant, dan Bisection
| |
− | *Regresi Linear
| |
− | *Interpolasi
| |
− |
| |
− | Setelah UTS pembelajaran diisi oleh Bapak Dr. Ir. Ahmad Indra Siswantara
| |
− |
| |
− | == Pertemuan Perkuliahan ==
| |
− |
| |
− | === Pertemuan Pertama (Rabu, 11 November 2020) ===
| |
− |
| |
− | Pada pertemuan pertama yang diisi oleh Bapak Dr. Ir. Ahmad Indra Siswantara. Mahasiswa dijelaskan mengenai esensi atau tujuan pembelajaran metode numerik, yaitu:
| |
− |
| |
− | 1. Memahami konsep-konsep dan prinsip-prinsip dasar dalam metode numerik seperti:Persamaan algoritma, aljabar, pencocokan kurva, persamaan diferensial parsial, dan lainnya
| |
− |
| |
− | 2. Mengerti dan mampu menerapkan pemahaman atau aplikasi terhadap konsep metode numerik
| |
− |
| |
− | 3. Mampu menerapkan metode numerik dalam hal terkait persoalan keteknikan
| |
− |
| |
− | 4. Mendapat added value (nilai tambah)/adab sehingga mahasiswa menjadi orang yang memiliki budi pekerti yang baik
| |
− |
| |
− | Selain empat poin yang telah disebutkan, Mahasiswa juga mendapatkan pelajaran terkait penggunaan aplikasi OpenModelica. Dimana Mahasiswa dijelaskan dengan sangat sistematis mengenai penggunaan sederhana OpenModelica.Bahkan Bapak Dr. Ir. Ahmad Indra Siswantara juga menjelaskan bahwa komputer memiliki limit atau batasan yang tidak dapat dilampauinya.Pada misalnya saja komputer tidak mampu menentukan nilai 1/0 yang hanya Tuhan yang tahu nilainya. Pelajaran atau hikmah yang dapat diambil dari kasus ini adalah manusia haruslah beriman dengan Rabb-Nya dan jangan pernah melupakan Tuhan yang mengetahui dan berkuasa atas segala sesuatu.
| |
− |
| |
− | Tugas minggu pertama
| |
− | [[File:Rezky Alfian Fatra Video1.mp4|720px|center]]
| |
− |
| |
− | === Pertemuan Kedua (Rabu, 18 November 2020) ===
| |
− | Pada pertemuan minggu ke-2, beberapa mahasiswa dimintai untuk mempresentasikan hasil tugas yang diberikan pada minggu pertama.Selain itu, pada pertemuan kali ini, Bapak Dr. Ir. Ahmad Indra Siswantara juga mengajari mahasiswa mengenai fitur class dan function.Alasan Bapak Dr. Ir. Ahmad Indra Siswantara memilih untuk menggunakan open modelica, yaitu karena aplikasi ini lebih mudah untuk digunakan (tidak butuh spesifikasi yang tinggi) dan bisa digunakan secara gratis oleh mahasiswa.
| |
− |
| |
− | Untuk tugas minggu ke dua, mahasiswa diminta untuk mempelajari lagi open modelica dan melakukan sistem panggil class dan function.Berikut tugas saya dengan menggunakan contoh soal Aljabar Linier dengan ordo 4x4
| |
− |
| |
− | [[File:Rezky Alfian Fatra Video2.mp4|720px|center]]
| |
− |
| |
− | === Pertemuan Ketiga (Rabu, 25 November 2020) ===
| |
− |
| |
− | '''Tugas 3'''
| |
− | *Berikut adalah soal untuk tugas kali ini:
| |
− | *Penyelesaian:
| |
− | [[File:Soal Trusses 2 Rezky.jpg|480px|thumb|Soal Trusses]]
| |
− |
| |
− | '''Persamaan'''
| |
− |
| |
− | class Trusses_Tugas3_RezkyAlfianFatra
| |
− |
| |
− | parameter Integer N=8; //Global matrice = 2*points connected
| |
− | parameter Real A=0.001; //Area m2
| |
− | parameter Real E=200e9; //Pa
| |
− | Real G[N,N]; //global
| |
− | Real Ginitial[N,N]; //global
| |
− | Real Sol[N]; //global dispplacement
| |
− | Real X[N]={0,0,-1035.2762,-3863.7033,0,0,-1035.2762,-3863.7033};
| |
− | Real R[N]; //global reaction force
| |
− | Real SolMat[N,1];
| |
− | Real XMat[N,1];
| |
− |
| |
− | //boundary condition
| |
− | Integer b1=1;
| |
− | Integer b2=3;
| |
− |
| |
− | //truss 1
| |
− | parameter Real X1=0; //degree between truss
| |
− | Real k1=A*E/1;
| |
− | Real K1[4,4]; //stiffness matrice
| |
− | Integer p1a=1;
| |
− | Integer p1b=2;
| |
− | Real G1[N,N];
| |
− |
| |
− | //truss 2
| |
− | parameter Real X2=0; //degree between truss
| |
− | Real k2=A*E/1;
| |
− | Real K2[4,4]; //stiffness matrice
| |
− | Integer p2a=2;
| |
− | Integer p2b=3;
| |
− | Real G2[N,N];
| |
− |
| |
− | //truss 3
| |
− | parameter Real X3=90; //degree between truss
| |
− | Real k3=A*E/1.25;
| |
− | Real K3[4,4]; //stiffness matrice
| |
− | Integer p3a=2;
| |
− | Integer p3b=4;
| |
− | Real G3[N,N];
| |
− |
| |
− | //truss 4
| |
− | parameter Real X4=90+38.6598; //degree between truss
| |
− | Real k4=A*E/1.6;
| |
− | Real K4[4,4]; //stiffness matrice
| |
− | Integer p4a=1;
| |
− | Integer p4b=4;
| |
− | Real G4[N,N];
| |
− |
| |
− | //truss 5
| |
− | parameter Real X5=90-38.6598; //degree between truss
| |
− | Real k5=A*E/1.6;
| |
− | Real K5[4,4]; //stiffness matrice
| |
− | Integer p5a=3;
| |
− | Integer p5b=4;
| |
− | Real G5[N,N];
| |
− |
| |
− | /*
| |
− | for each truss, please ensure pXa is lower then pXb (X represents truss element number)
| |
− | */
| |
− |
| |
− | algorithm
| |
− |
| |
− | //creating global matrice
| |
− | K1:=Stiffness_Matrices(X1);
| |
− | G1:=k1*Local_Global(K1,N,p1a,p1b);
| |
− |
| |
− | K2:=Stiffness_Matrices(X2);
| |
− | G2:=k2*Local_Global(K2,N,p2a,p2b);
| |
− |
| |
− | K3:=Stiffness_Matrices(X3);
| |
− | G3:=k3*Local_Global(K3,N,p3a,p3b);
| |
− |
| |
− | K4:=Stiffness_Matrices(X4);
| |
− | G4:=k4*Local_Global(K4,N,p4a,p4b);
| |
− |
| |
− | K5:=Stiffness_Matrices(X5);
| |
− | G5:=k5*Local_Global(K5,N,p5a,p5b);
| |
− |
| |
− | G:=G1+G2+G3+G4+G5;
| |
− | Ginitial:=G;
| |
− |
| |
− | //implementing boundary condition
| |
− | for i in 1:N loop
| |
− | G[2*b1-1,i]:=0;
| |
− | G[2*b1,i]:=0;
| |
− | G[2*b2-1,i]:=0;
| |
− | G[2*b2,i]:=0;
| |
− | end for;
| |
− |
| |
− | G[2*b1-1,2*b1-1]:=1;
| |
− | G[2*b1,2*b1]:=1;
| |
− | G[2*b2-1,2*b2-1]:=1;
| |
− | G[2*b2,2*b2]:=1;
| |
− |
| |
− | //solving displacement
| |
− | Sol:=Gauss_Jordan(N,G,X);
| |
− |
| |
− | //solving reaction force
| |
− | SolMat:=matrix(Sol);
| |
− | XMat:=matrix(X);
| |
− | R:=Reaction_Trusses(N,Ginitial,SolMat,XMat);
| |
− |
| |
− | end Trusses_Tugas3_RezkyAlfianFatra;
| |
− |
| |
− | '''Grafik Displacement'''
| |
− | [[File:Grafik Displacement Rezky.jpg|480px|Center]]
| |
− |
| |
− |
| |
− | '''Grafik Reaction Forces'''
| |
− | [[File:Trusses 2 Reactiion Rezky.jpg|480px|Center]]
| |
− |
| |
− |
| |
− |
| |
− | '''Fungsi Panggil'''
| |
− | {| class="wikitable"
| |
− | |-
| |
− | | style='border-style: none none solid solid;' |
| |
− | ''Matrice Transformation''
| |
− |
| |
− | function Stiffness_Matrices
| |
− | input Real A;
| |
− | Real Y;
| |
− | output Real X[4,4];
| |
− | Real float_error = 10e-10;
| |
− |
| |
− | final constant Real pi=2*Modelica.Math.asin(1.0);
| |
− |
| |
− | algorithm
| |
− |
| |
− | Y:=A/180*pi;
| |
− |
| |
− | X:=[(Modelica.Math.cos(Y))^2,Modelica.Math.cos(Y)*Modelica.Math.sin(Y),-(Modelica.Math.cos(Y))^2,-Modelica.Math.cos(Y)*Modelica.Math.sin(Y);
| |
− |
| |
− | Modelica.Math.cos(Y)*Modelica.Math.sin(Y),(Modelica.Math.sin(Y))^2,-Modelica.Math.cos(Y)*Modelica.Math.sin(Y),-(Modelica.Math.sin(Y))^2;
| |
− |
| |
− | -(Modelica.Math.cos(Y))^2,-Modelica.Math.cos(Y)*Modelica.Math.sin(Y),(Modelica.Math.cos(Y))^2,Modelica.Math.cos(Y)*Modelica.Math.sin(Y);
| |
− |
| |
− | -Modelica.Math.cos(Y)*Modelica.Math.sin(Y),-(Modelica.Math.sin(Y))^2,Modelica.Math.cos(Y)*Modelica.Math.sin(Y),(Modelica.Math.sin(Y))^2];
| |
− |
| |
− | for i in 1:4 loop
| |
− | for j in 1:4 loop
| |
− | if abs(X[i,j]) <= float_error then
| |
− | X[i,j] := 0;
| |
− | end if;
| |
− | end for;
| |
− | end for;
| |
− |
| |
− | end Stiffness_Matrices;
| |
− |
| |
− | | style="width: 20cm;"|
| |
− | ''Global Element Matrice''
| |
− |
| |
− | function Local_Global
| |
− | input Real Y[4,4];
| |
− | input Integer B;
| |
− | input Integer p1;
| |
− | input Integer p2;
| |
− | output Real G[B,B];
| |
− |
| |
− | algorithm
| |
− |
| |
− | for i in 1:B loop
| |
− | for j in 1:B loop
| |
− | G[i,j]:=0;
| |
− | end for;
| |
− | end for;
| |
− |
| |
− | G[2*p1,2*p1]:=Y[2,2];
| |
− | G[2*p1-1,2*p1-1]:=Y[1,1];
| |
− | G[2*p1,2*p1-1]:=Y[2,1];
| |
− | G[2*p1-1,2*p1]:=Y[1,2];
| |
− |
| |
− | G[2*p2,2*p2]:=Y[4,4];
| |
− | G[2*p2-1,2*p2-1]:=Y[3,3];
| |
− | G[2*p2,2*p2-1]:=Y[4,3];
| |
− | G[2*p2-1,2*p2]:=Y[3,4];
| |
− |
| |
− | G[2*p2,2*p1]:=Y[4,2];
| |
− | G[2*p2-1,2*p1-1]:=Y[3,1];
| |
− | G[2*p2,2*p1-1]:=Y[4,1];
| |
− | G[2*p2-1,2*p1]:=Y[3,2];
| |
− |
| |
− | G[2*p1,2*p2]:=Y[2,4];
| |
− | G[2*p1-1,2*p2-1]:=Y[1,3];
| |
− | G[2*p1,2*p2-1]:=Y[2,3];
| |
− | G[2*p1-1,2*p2]:=Y[1,4];
| |
− |
| |
− | end Local_Global;
| |
− |
| |
− | | style="width: 20cm;"|
| |
− | ''Reaction Matrice Equation''
| |
− |
| |
− | function Reaction_Trusses
| |
− | input Integer N;
| |
− | input Real A[N,N];
| |
− | input Real B[N,1];
| |
− | input Real C[N,1];
| |
− | Real X[N,1];
| |
− | output Real Sol[N];
| |
− | Real float_error = 10e-10;
| |
− |
| |
− | algorithm
| |
− | X:=A*B-C;
| |
− |
| |
− | for i in 1:N loop
| |
− | if abs(X[i,1]) <= float_error then
| |
− | X[i,1] := 0;
| |
− | end if;
| |
− | end for;
| |
− |
| |
− | for i in 1:N loop
| |
− | Sol[i]:=X[i,1];
| |
− | end for;
| |
− |
| |
− | end Reaction_Trusses;
| |
− |
| |
− | |}
| |
− |
| |
− | '''Gauss Jordan'''
| |
− | {| class="wikitable"
| |
− | |-
| |
− | | style='border-style: none none solid solid;' |
| |
− |
| |
− | function Gauss_Jordan
| |
− | input Integer N;
| |
− | input Real A[N,N];
| |
− | input Real B[N];
| |
− | output Real X[N];
| |
− | Real float_error = 10e-10;
| |
− |
| |
− | algorithm
| |
− | X:=Modelica.Math.Matrices.solve(A,B);
| |
− |
| |
− | for i in 1:N loop
| |
− | if abs(X[i]) <= float_error then
| |
− | X[i] := 0;
| |
− | end if;
| |
− | end for;
| |
− |
| |
− | end Gauss_Jordan;
| |
− |
| |
− | |}
| |
− |
| |
− | === Pertemuan Keempat (Rabu, 02 Desember 2020) ===
| |
− | [[File:Flowchart Rezky.jpg|480px|center]]
| |
− |
| |
− | ===Tugas 4===
| |
− | Pr No 8
| |
− | kami diminta untuk menyelesaikan permasalahan 3D dengan membuat class diagram, flowchart, dan penyelesaiannya dengan openmodelica
| |
− | [[File:Prno8.png|720px|center]]
| |
− | Pertama saya membuat class diagram
| |
− | [[File:PR8 RezkyA.jpeg|400px|center]]
| |
− | Kemudian saya membuat flowchart
| |
− | [[File:Pr8bag2 Rezky.jpeg|400px|center]]
| |
− |
| |
− | Setelah itu, saya membuat Free Body Diagram (FBD) untuk mencari data-data yang diperlukan pada persoalan ini.Data tersbut berupa node, modulus elastisitas, luas, sudut, dan panjang dari setiap batang.Karena pada kasus ini merupakan permasalahan 3D (3 Dimensi), maka sudut akan berada pada arah X, Y, dan Z.Rumus untuk mencari panjang batang, bisa kita dapatkan di buku.Untuk gaya eksternal yang ada, kita dapat melihatnya dari gambar yang hanya berada di node 1 arah sumbu y.Kemudian setelah itu, data-data yang ada kita ubah menjadi bentuk matriks agar bisa diselesaikan dengan menggunakan openmodelica
| |
− | [[File:Pr8bag3 Rezky.jpeg|400px|center]]
| |
− |
| |
− | Untuk mendapatkan nilai K dapat menggunakan rumus K=AE/L.Setelah mendapatkan nilai K pada setiap batang, nilai tersebut digunakan untuk membuat matriks K elemental (Ke) pada setiap batang
| |
− | [[File:MatriksKekakuanElemen Rezky.png|600px|center]]
| |
− |
| |
− | Kemudian matriks 6x6 tersebut akan dibuat menjadi matrks 12x12 sesuai dengan jumlah batang yang ada (3)*jumlah node (4).Ini disebut dengan matriks kekakuan global (Kg)
| |
− | [[File:MatriksKekakuanGlobal Rezky.png|600px|center]]
| |
− |
| |
− | Selanjutnya matriks kekakuan pada setiap batang dijumlahkan agar mendapatkan matriks kekakuan global total
| |
− | [[File:JumlahMatriksKekakuanGlobal Rezky.png|600px|center]]
| |
− |
| |
− | Setelah itu, boundary diterapkan pada matriks kekakuan global total.Pada kasus yang ini, node 2, node 3, dan node 4 merupakan pinned. Sehingga U2X=U2Y=U2Z=U3X=U3Y=U3Z=U4X=U4Y=U4Z=0.
| |
− | [[File:BatasKekakuanMatriksGlobal Rezky.png|600px|center]]
| |
− |
| |
− | Untuk mencari nilai U atau nilai displacement lainnya menggunakan Eliminasi Gauss Jordan dengan menggunakan persamaan XU=F. Dengan X adalah matriks K global yang sudah menerapkan boundary (KgB) dan F didefinisikan sebagai eksternal load
| |
− | [[File:GaussJordan Rezky.png|600px|center]]
| |
− |
| |
− | Sedangkan untuk mencari reaction force dapat menggunakan persamaan R=Kg*U-F
| |
− | [[File:ReactionForce Rezky.png|600px|center]]
| |
− |
| |
− | Function-function tersebut akan dipanggil ke dalam sebuah class untuk penyelesaiannya. Pada class juga akan diinput data-data yang telah dicari pada langkah pertama
| |
− | [[File:Tugas8 RezkyAlfian.png|600px|center]]
| |
− |
| |
− | Sehingga, setelah disimulate, kita akan mendapatkan nilai displacement (U)
| |
− | [[File:NilaiU Rezky.png|200px|center]]
| |
− |
| |
− | dan Nilai R
| |
− | [[File:NilaiR Rezky.png|200px|center]]
| |
− |
| |
− | Berikut video penjelasannya
| |
− | [[File:Video RezkyAlfian No8.mp4|720px|center]]
| |
− |
| |
− | === Pertemuan Keenam ===
| |
− | Sistem optimasi
| |
− | dalam sebuah sistem fluida ada yang berupa zat cair seperti aliran darah, dan juga ada yang berupa gas seperti sistem pernapasan.Yang ditampilkan pada grafik dibawah ini adalah sebuah karakteristik dari sistem dan komponen.
| |
− | sistem fluida tidak hanya perpipaan, tapi juga mesin kerja berupa pompa dan tenaga, ada valve, dan juga ada pipa belok.Sistem fluida, aliran air dimasukan dari yang tediri pompa, pipa, pipa belok (T,L) valve.Pada setiap komponen memiliki tujuan yang sama, yaitu mengalirkan air dari sebuah tempat ke tempat yang kita tuju.Sistem tersebut adalah pompa, dengan menggunakan sistem pendukung, memberikan tenaga pada pompa
| |
− |
| |
− | [[File:Grafikfluid.jpeg|720px|center]]
| |
− |
| |
− | *Yang melengkung pada grafik tersebut adalah efisiensi
| |
− | *Sumbu datar adalah jumlah aliran yang diantarkan
| |
− | *Sumbu y adalah efisiensi dari pompa
| |
− | *Garis hijau merupakan tenaga air yang keluar dari pompa
| |
− | *Pada saat jumlah air yang dikeluarkan tekanan akan turun dan breakhouse power akan naik
| |
− | *Pada efisiensi, makin tinggi kapasitasnya maka efisiensinya akan naik. Terdapat juga titik maksimum dan kemudan setelah itu efisiensi akan menurun
| |
− | *Untuk efisiensi pada sistem, mempertimbangkan heatloss pada kondisi tertentu
| |
− |
| |
− | Pembahasan berikutnya mengenai metode Bracket Optimization Using Golden Ratio Method yang dijelaskan oleh bu Chandra.Jika ingin menyelesaikan suatu permasalahan dengan menggunakan cara optimasi, kita harus paham terlebih dahulu mengenai materinya
| |
− |
| |
− | [[File:Bracktergraph.png|500px|center]]
| |
− | *Menentukan dan mengetahui batasan titik awal terendah (xL) dan tertinggi (xH)
| |
− | *Mendapatkan nilai x1 dan x2 dari golden ratio (d)
| |
− | *Menentukan xL dan xH berdasarkan nilai batasan maksimum dan minimal baru
| |
− | *Mendapatkan nilai x1 dan x2 baru
| |
− |
| |
− | Jika dalam soal diketahui untuk menyelesaikan persamaan y=2sinx-x^2/10,kemudian fungsi ini dimasukkan ke dalam openmodelica, kemudian fungsi tersebut akan dipanggil
| |
− | [[File:Rezky Metnum.png|720px|center]]
| |
− |
| |
− | Setelah di cek dan tidak terjadi masalah dalam simulate openmodelica, dapat dibuat model yang akan memanggil fungsi tersebut
| |
− |
| |
− | [[File:Brackopt.png|720px|center]]
| |
− |
| |
− | == Progress Tugas Besar ==
| |
− | Tugas besar yang diberikan kemarin untuk kelas metnum 02 dan 03 adalah menghitung dengan menggunnakan optimasi untuk rangka batang:
| |
− | [[File:600px-Soaltubes.jpeg|720px|center]]
| |
− | suatu rangka batang yang telah dibentuk seperti gambar diatas, dengan spesifikasi sebagai berikut:
| |
− | [[File:Soaltubes2.jpeg|720px|center]]
| |
− | Diharapkan dari persoalan di atas dapat mendesain rangka batang dengan harga yang terjangkau dan optimal.
| |
− |
| |
− | Faktor atau variabel bebasnya meliputi : Harga, Material yang digunakan, dan cross section
| |
− |
| |
− | Dari soal yang diberikan, mahasiswa diharuskan mendesign rangka pada batang dengan harga yang terjangkau dan optimal
| |
− |
| |
− | Pada tugas besar ini, kami diberikan sebuah tugas untuk melakukan perhitungan pemilihan material dan luas penampang pada trusses yang akan digunakan untuk membuat sebuah konstruksi pada gambar di bawah ini:
| |
− | [[File:Tugas Besar Metnum Geometri Jos.jpg|center]]
| |
− |
| |
− | Asumsi yang digunakan untuk melakukan perhitungan ini antara lain:
| |
− | *Beban akan terdistribusi hanya pada node (karena bersifat trusses).
| |
− | *Safety factor minimal bernilai 2.
| |
− | *Batas displacement 0,001 m sebelum terjadinya buckling (pada truss paling atas).
| |
− | *Ketinggian trusses untuk setiap lantai sama yaitu 0,6 m.
| |
− |
| |
− | Untuk jenis material yang sama:
| |
− | #Mencari harga untuk 6 ukuran batang dengan material yang sama yaitu dengan menggunakan SS304.
| |
− | #Mengitung nilai safety factor yang digunakan pada 6 ukuran batang.
| |
− | #Membuat rasio antara safety factor dengan harga total batang.
| |
− | #Membuat persamaan antara rasio (safe/harga) dengan area dengan menggunakan metode curve fitting.
| |
− | #Melakukan optimasi menggunakan metode golden section.
| |
− |
| |
− | Untuk area penampang yang sama:
| |
− | #Mencari harga untuk 4 jenis material dengan area penampang yang sama, yaitu 171 mm^2.
| |
− | #Mengitung nilai safety factor pada 4 jenis batang.
| |
− | #Membuat rasio antara safety factor dengan harga total.
| |
− | #Membuat persamaan antara rasio (safe/harga) dengan jenis material dengan metode curve fitting.
| |
− | #Melakukan optimasi menggunakan metode golden section.
| |
− |
| |
− | '''Coding yang digunakan'''
| |
− | ----
| |
− | *Untuk perhitungan displacement, reaction force, stress, dan safety factor:
| |
− | model Trusses_3D_Tugas_Besar_Safety
| |
− |
| |
− | //define initial variable
| |
− | parameter Integer Points=size(P,1); //Number of Points
| |
− | parameter Integer Trusses=size(C,1); //Number of Trusses
| |
− | parameter Real Yield=689e6; //Yield Strength (Pa)
| |
− | parameter Real Area=0.000224; //Area L Profile (Dimension=0.03, Thickness=0,004) (m2)
| |
− | parameter Real Elas=206.7e9; //Elasticity SS 304 (Pa)
| |
− |
| |
− | //define connection
| |
− | parameter Integer C[:,2]=[1,5;
| |
− | 2,6;
| |
− | 3,7;
| |
− | 4,8;
| |
− | 5,6; //1st floor
| |
− | 6,7; //1st floor
| |
− | 7,8; //1st floor
| |
− | 5,8; //1st floor
| |
− | 5,9;
| |
− | 6,10;
| |
− | 7,11;
| |
− | 8,12;
| |
− | 9,10; //2nd floor
| |
− | 10,11;//2nd floor
| |
− | 11,12;//2nd floor
| |
− | 9,12; //2nd floor
| |
− | 9,13;
| |
− | 10,14;
| |
− | 11,15;
| |
− | 12,16;
| |
− | 13,14;//3rd floor
| |
− | 14,15;//3rd floor
| |
− | 15,16;//3rd floor
| |
− | 13,16];//3rd floor
| |
− |
| |
− | //define coordinates (please put orderly)
| |
− | parameter Real P[:,6]=[0.3,-0.375,0,1,1,1; //1
| |
− | -0.3,-0.375,0,1,1,1; //2
| |
− | -0.3,0.375,0,1,1,1; //3
| |
− | 0.3,0.375,0,1,1,1; //4
| |
− |
| |
− | 0.3,-0.375,0.6,0,0,0; //5
| |
− | -0.3,-0.375,0.6,0,0,0; //6
| |
− | -0.3,0.375,0.6,0,0,0; //7
| |
− | 0.3,0.375,0.6,0,0,0; //8
| |
− |
| |
− | 0.3,-0.375,1.2,0,0,0; //9
| |
− | -0.3,-0.375,1.2,0,0,0; //10
| |
− | -0.3,0.375,1.2,0,0,0; //11
| |
− | 0.3,0.375,1.2,0,0,0; //12
| |
− |
| |
− | 0.3,-0.375,1.8,0,0,0; //13
| |
− | -0.3,-0.375,1.8,0,0,0; //14
| |
− | -0.3,0.375,1.8,0,0,0; //15
| |
− | 0.3,0.375,1.8,0,0,0]; //16
| |
− |
| |
− | //define external force (please put orderly)
| |
− | parameter Real F[Points*3]={0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,0,
| |
− | 0,0,-500,
| |
− | 0,0,-1000,
| |
− | 0,0,-1000,
| |
− | 0,0,-500};
| |
− |
| |
− | //solution
| |
− | Real displacement[N], reaction[N];
| |
− | Real check[3];
| |
− |
| |
− | Real stress1[Trusses];
| |
− | Real safety[Trusses];
| |
− | Real dis[3];
| |
− | Real Str[3];
| |
− |
| |
− | protected
| |
− | parameter Integer N=3*Points;
| |
− | Real q1[3], q2[3], g[N,N], G[N,N], G_star[N,N], id[N,N]=identity(N), cx, cy, cz, L, X[3,3];
| |
− | Real err=10e-10, ers=10e-4;
| |
− |
| |
− | algorithm
| |
− | //Creating Global Matrix
| |
− | G:=id;
| |
− | for i in 1:Trusses loop
| |
− | for j in 1:3 loop
| |
− | q1[j]:=P[C[i,1],j];
| |
− | q2[j]:=P[C[i,2],j];
| |
− | end for;
| |
− |
| |
− | //Solving Matrix
| |
− | L:=Modelica.Math.Vectors.length(q2-q1);
| |
− | cx:=(q2[1]-q1[1])/L;
| |
− | cy:=(q2[2]-q1[2])/L;
| |
− | cz:=(q2[3]-q1[3])/L;
| |
− | X:=(Area*Elas/L)*[cx^2,cx*cy,cx*cz;
| |
− | cy*cx,cy^2,cy*cz;
| |
− | cz*cx,cz*cy,cz^2];
| |
− |
| |
− | //Transforming to global matrix
| |
− | g:=zeros(N,N);
| |
− | for m,n in 1:3 loop
| |
− | g[3*(C[i,1]-1)+m,3*(C[i,1]-1)+n]:=X[m,n];
| |
− | g[3*(C[i,2]-1)+m,3*(C[i,2]-1)+n]:=X[m,n];
| |
− | g[3*(C[i,2]-1)+m,3*(C[i,1]-1)+n]:=-X[m,n];
| |
− | g[3*(C[i,1]-1)+m,3*(C[i,2]-1)+n]:=-X[m,n];
| |
− | end for;
| |
− |
| |
− | G_star:=G+g;
| |
− | G:=G_star;
| |
− | end for;
| |
− |
| |
− | //Implementing boundary
| |
− | for x in 1:Points loop
| |
− | if P[x,4] <> 0 then
| |
− | for a in 1:Points*3 loop
| |
− | G[(x*3)-2,a]:=0;
| |
− | G[(x*3)-2,(x*3)-2]:=1;
| |
− | end for;
| |
− | end if;
| |
− | if P[x,5] <> 0 then
| |
− | for a in 1:Points*3 loop
| |
− | G[(x*3)-1,a]:=0;
| |
− | G[(x*3)-1,(x*3)-1]:=1;
| |
− | end for;
| |
− | end if;
| |
− | if P[x,6] <> 0 then
| |
− | for a in 1:Points*3 loop
| |
− | G[x*3,a]:=0;
| |
− | G[x*3,x*3]:=1;
| |
− | end for;
| |
− | end if;
| |
− | end for;
| |
− |
| |
− | //Solving displacement
| |
− | displacement:=Modelica.Math.Matrices.solve(G,F);
| |
− |
| |
− | //Solving reaction
| |
− | reaction:=(G_star*displacement)-F;
| |
− |
| |
− | //Eliminating float error
| |
− | for i in 1:N loop
| |
− | reaction[i]:=if abs(reaction[i])<=err then 0 else reaction[i];
| |
− | displacement[i]:=if abs(displacement[i])<=err then 0 else displacement[i];
| |
− | end for;
| |
− |
| |
− | //Checking Force
| |
− | check[1]:=sum({reaction[i] for i in (1:3:(N-2))})+sum({F[i] for i in (1:3:(N-2))});
| |
− | check[2]:=sum({reaction[i] for i in (2:3:(N-1))})+sum({F[i] for i in (2:3:(N-1))});
| |
− | check[3]:=sum({reaction[i] for i in (3:3:N)})+sum({F[i] for i in (3:3:N)});
| |
− |
| |
− | for i in 1:3 loop
| |
− | check[i] := if abs(check[i])<=ers then 0 else check[i];
| |
− | end for;
| |
− |
| |
− | //Calculating stress in each truss
| |
− | for i in 1:Trusses loop
| |
− | for j in 1:3 loop
| |
− | q1[j]:=P[C[i,1],j];
| |
− | q2[j]:=P[C[i,2],j];
| |
− | dis[j]:=abs(displacement[3*(C[i,1]-1)+j]-displacement[3*(C[i,2]-1)+j]);
| |
− | end for;
| |
− |
| |
− | //Solving Matrix
| |
− | L:=Modelica.Math.Vectors.length(q2-q1);
| |
− | cx:=(q2[1]-q1[1])/L;
| |
− | cy:=(q2[2]-q1[2])/L;
| |
− | cz:=(q2[3]-q1[3])/L;
| |
− | X:=(Elas/L)*[cx^2,cx*cy,cx*cz;
| |
− | cy*cx,cy^2,cy*cz;
| |
− | cz*cx,cz*cy,cz^2];
| |
− |
| |
− | Str:=(X*dis);
| |
− | stress1[i]:=Modelica.Math.Vectors.length(Str);
| |
− | end for;
| |
− |
| |
− | //Safety factor
| |
− | for i in 1:Trusses loop
| |
− | if stress1[i]>0 then
| |
− | safety[i]:=Yield/stress1[i];
| |
− | else
| |
− | safety[i]:=0;
| |
− | end if;
| |
− | end for;
| |
− |
| |
− | end Trusses_3D_Tugas_Besar_Safety;
| |
− |
| |
− | |}
| |
− |
| |
− | {| class="wikitable"
| |
− | |-
| |
− | | style='border-style: none none solid solid;' |
| |
− |
| |
− | model Opt_Parabolic
| |
− |
| |
− | parameter Real g1=0; //initial guess
| |
− | parameter Real g2=1; //initial guess
| |
− | parameter Real g3=4; //initial guess
| |
− | parameter Integer N=5; // maximum iteration
| |
− | parameter Real es=0.0001; // maximum error
| |
− |
| |
− | Real x1, x2, x3, xopt, xp[N], ea[N];
| |
− | //Real xl, xm, xu;
| |
− | Real fx1, fx2, fx3, fx, A[4], A_star[4];
| |
− | algorithm
| |
− | x1:=g1;
| |
− | x2:=g2;
| |
− | x3:=g3;
| |
− |
| |
− | for i in 1:N loop
| |
− | fx1:=Func_Optimization(x1);
| |
− | fx2:=Func_Optimization(x2);
| |
− | fx3:=Func_Optimization(x3);
| |
− |
| |
− | xp[i]:=(fx1*(x2^2-x3^2)+fx2*(x3^2-x1^2)+fx3*(x1^2-x2^2))/(2*fx1*(x2-x3)+2*fx2*(x3-x1)+2*fx3*(x1-x2));
| |
− | xopt:=xp[i];
| |
− | fx:=Func_Optimization(xp[i]);
| |
− | A:={x1,x2,x3,xp[i]};
| |
− | A_star:=Modelica.Math.Vectors.sort(A);
| |
− |
| |
− | if xp[i]>x2 then
| |
− | x1:=A_star[2];
| |
− | x2:=A_star[3];
| |
− | x3:=A_star[4];
| |
− | else
| |
− | x1:=A_star[1];
| |
− | x2:=A_star[2];
| |
− | x3:=A_star[3];
| |
− | end if;
| |
− | end for;
| |
− |
| |
− | ea[1]:=1;
| |
− | for i in 2:N loop
| |
− | ea[i]:=abs(1-xp[i-1]/xp[i]);
| |
− | if ea[i]<es then
| |
− | break;
| |
− | end if;
| |
− | end for;
| |
− |
| |
− | end Opt_Parabolic;
| |
− |
| |
− | |}
| |
− |
| |
− | {| class="wikitable"
| |
− | |-
| |
− | | style='border-style: none none solid solid;' |
| |
− |
| |
− | model Opt_Gold
| |
− |
| |
− | parameter Real xlo=0;
| |
− | parameter Real xhi=4;
| |
− | parameter Integer N=8; // maximum iteration
| |
− | parameter Real es=0.0001; // maximum error
| |
− |
| |
− | Real f1[N], f2[N], x1[N], x2[N], ea[N];
| |
− | Real xopt, fx;
| |
− | protected
| |
− | Real d, xl, xu, xint, R=(5^(1/2)-1)/2;
| |
− |
| |
− | algorithm
| |
− | xl := xlo;
| |
− | xu := xhi;
| |
− |
| |
− | for i in 1:N loop
| |
− | d:= R*(xu-xl);
| |
− | x1[i]:=xl+d;
| |
− | x2[i]:=xu-d;
| |
− | f1[i]:=Func_Optimization(x1[i]);
| |
− | f2[i]:=Func_Optimization(x2[i]);
| |
− | xint:=xu-xl;
| |
− |
| |
− | if f1[i]>f2[i] then
| |
− | xl:=x2[i];
| |
− | xopt:=x1[i];
| |
− | fx:=f1[i];
| |
− | else
| |
− | xu:=x1[i];
| |
− | xopt:=x2[i];
| |
− | fx:=f2[i];
| |
− | end if;
| |
− |
| |
− | ea[i]:=(1-R)*abs((xint)/xopt);
| |
− | if ea[i]<es then
| |
− | break;
| |
− | end if;
| |
− | end for;
| |
− |
| |
− | end Opt_Gold;
| |
− |
| |
− | |}
| |
− |
| |
− | |}
| |
− |
| |
− | {| class="wikitable"
| |
− | |-
| |
− | | style='border-style: none none solid solid;' |
| |
− |
| |
− | function Curve_Fitting
| |
− |
| |
− | input Real X[:];
| |
− | input Real Y[size(X,1)];
| |
− | input Integer order=2;
| |
− | output Real Coe[order+1];
| |
− |
| |
− | protected
| |
− | Real Z[size(X,1),order+1];
| |
− | Real ZTr[order+1,size(X,1)];
| |
− | Real A[order+1,order+1];
| |
− | Real B[order+1];
| |
− |
| |
− | algorithm
| |
− |
| |
− | for i in 1:size(X,1) loop
| |
− | for j in 1:(order+1) loop
| |
− | Z[i,j]:=X[i]^(order+1-j);
| |
− | end for;
| |
− | end for;
| |
− | ZTr:=transpose(Z);
| |
− |
| |
− | A:=ZTr*Z;
| |
− | B:=ZTr*Y;
| |
− | Coe:=Modelica.Math.Matrices.solve(A,B);
| |
− | //Coe:=fill(2,size(Coe,1));
| |
− |
| |
− | end Curve_Fitting;
| |
− |
| |
− |
| |
− | |}
| |