Minggu, 18 Juni 2017


Tugas Mandiri Orkom 2 - Program Thread


TUGAS MANDIRI ORGANISASI KOMPUTER DAN SISTEM OPERASI
PROGRAM THREAD


  

Disusun oleh :
Zulfannullah (064001600015)
Devi Febrita Sari H. (064001600020)
Tri Cendekia Dewi (065001600014)
Novenia Tika (065001600015)


TEKNIK INFORMATIKA
FAKULTAS TEKNOLOGI INDUSTRI
UNIVERSITAS TRISAKTI
2017



DESKRIPSI

Membuat program komunikasi antar thread menggunakan Linux versi Ubuntu 64-bit.



KOMPETENSI DASAR

1. Memahami Komunikasi antar Thread dalam sistem operasi Linux Ubuntu 64-bit.
2. Memahami fungsi Komunikasi antar Thread
3. Memahami bahasa pemrograman pada terminal Linux


TUJUAN

Laporan ini dibuat untuk menyelesaikan praktikum sebelas matakuliah Organisasi computer dan Sistem Operasi. Selain itu, hal ini juga beguna sebagai panduan umum penggunaan fungsi thread terminal pada operasi sistem linux.




TEORI PERCOBAAN

      Thread dalam sistem operasi dapat diartikan sebagai sekumpulan perintah (instruksi) yang dapatdilaksanakan (dieksekusi) secara sejajar dengan ulir lainnya, dengan menggunakan cara time slice (ketika satu CPU melakukan perpindahan antara satu ulir ke ulir lainnya) atau multiprocess(ketika ulir-ulir tersebut dilaksanakan oleh CPU yang berbeda dalam satu sistem).

       Ulir sebenarnya mirip dengan proses, tapi cara berbagi sumber daya antara proses dengan ulir sangat berbeda. Multiplethread  dapat dilaksanakan secara sejajar pada sistem komputer. Secaraumum multithreading melakukan time-slicing (sama dengan time-division multipleks), dimana sebuah CPU bekerja pada ulir yang berbeda, di mana suatu kasus ditangani tidak sepenuhnya secara serempak, untuk CPU tunggal pada dasarnya benar-benar melakukan sebuah pekerjaan pada satu waktu. 

       Thread saling berbagi bagian program, bagian data dan sumber daya sistem operasi denganthread lain yang mengacu pada proses yang sama. Thread terdiri atas ID thread, program counter, himpunan register, dan stack. Dengan banyak kontrol thread proses dapat melakukan lebih darisatu pekerjaan pada waktu yang sama.



LAB SETUP

· 1 buah PC.

· Sistem Operasi Linux (Ubuntu 64-bit).



CARA PERCOBAAN

1. Buka terminal pada Linux

2. Buka file yang sudah dibuat dengan cara tulis:
$ nano threadtm.c, tekan enter.

3. Tulis sourcodenya seperti gambar berikut.

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>

/*  
Struktur dibawah ini mengandung informasi yang dibutuhkan untuk mengakses fungsi dotprod untuk mengakses data yang diinputnya dan menaruh outputnya kedalam struktur.
Struktur ini tidak berubah dari bentuk sekuensial. Program ini adalah program thread yang mengeluarkan output dari variabel mutexnya
*/

typedef struct
{
  double      *a;
  double      *b;
  double     sum;
  int     veclen;
} DOTDATA;

/* Mendefinisikan variabel yang bisa diakses secara global atau member variabel dan jg mutex*/

#define NUMTHRDS 10
#define VECLEN 1000
  DOTDATA dotstr;
  pthread_t callThd[NUMTHRDS];
  pthread_mutex_t mutexsum;

/*
Fungsi dotprod diaktifkan ketika thread itu telah dibuat.
Seperti sebelumnya, semuainput untuk rutin ini diperoleh dari struktur dengan tipe DOTDATA dan semua output dari fungsi ini ditulis kedalam struktur ini. Keuntungan dari keluaran ini adalah bagi program multithread: ketika thread dibuat kita melewati satu argumen untuk fungsi yg diaktifkan biasanya argumen ini adalah angka thread. Semua informasi lainnya yang dibutuhkan oleh fungsi diakses dari struktur global.
*/

void *dotprod(void *arg)
{

/* Mendefinisikan dan menggunakan local variabel demi kemudahan*/

  int i, start, end, len ;
  long offset;
  double mysum, *x, *y;
  offset = (long)arg;
    
  len = dotstr.veclen;
  start = offset*len;
  end   = start + len;
  x = dotstr.a;
  y = dotstr.b;

/*
Perform the dot product and assign result
to the appropriate variable in the structure.
*/
  mysum = 0;
  for (i=start; i<end ; i++)
   {
     mysum += (x[i] * y[i]);
   }

/*
Lock a mutex prior to updating the value in the shared
structure, and unlock it upon updating.
*/
  pthread_mutex_lock (&mutexsum);
  dotstr.sum += mysum;
  printf("Thread bagian %ld melakukan %d untuk %d=\nJumlah=%f\nTotal=%f\n\n",offset,start,end,mysum,dotstr.sum);
  pthread_mutex_unlock (&mutexsum);

  pthread_exit((void*) 0);
}

/*
The main program creates threads which do all the work and then
print out result upon completion. Before creating the threads,
The input data is created. Since all threads update a shared structure, we
need a mutex for mutual exclusion. The main thread needs to wait for
all threads to complete, it waits for each one of the threads. We specify
a thread attribute value that allow the main thread to join with the
threads it creates. Note also that we free up handles  when they are
no longer needed.
*/

int main (int argc, char *argv[])
{
long i;
double *a, *b;
void *status;
pthread_attr_t attr;

/* Assign storage and initialize values */

a = (double*) malloc (NUMTHRDS*VECLEN*sizeof(double));
b = (double*) malloc (NUMTHRDS*VECLEN*sizeof(double));
for (i=0; i<VECLEN*NUMTHRDS; i++) {
 a[i]=1;
 b[i]=a[i];
 }

dotstr.veclen = VECLEN;
dotstr.a = a;
dotstr.b = b;
dotstr.sum=0;

pthread_mutex_init(&mutexsum, NULL);
        
/* Buat thread untuk melakukan dotprodak */
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);

for(i=0;i<NUMTHRDS;i++)
 {
 /* Setiap thread bekerja dalam himpunan data yang berbedaEach thread works on a different set of data.
  * Offsetnya dispesifikasikan oleh 'i'. Ukuran datanya tiap thread diindikasikan oleh VECLEN
  */
  pthread_create(&callThd[i], &attr, dotprod, (void *)i);
  }

pthread_attr_destroy(&attr);
/* Tunggu thread lainnya*/

for(i=0;i<NUMTHRDS;i++) {
 pthread_join(callThd[i], &status);
 }
/* Setelah bergabung, print output hasilnya dan bersihkan.*/

printf ("Sum =  %f \n", dotstr.sum);
free (a);
free (b);
pthread_mutex_destroy(&mutexsum);
pthread_exit(NULL);
}


4. Keluar dari editor dan save.
5. Compile file threadtm.c dengan cara ketik:
$ gcc threadtm.c -o threadtm2orkom.c -lpthread, tekan enter.

6. Jalankan threadtm2orkom.c dengan mengetikkan:

$ ./threaddd.c, lalu tekan enter.



7. Lihat outputnya.


8. Selesai


DATA PERCOBAAN


KESIMPULAN
          Thread adalah unit dasar dari utilitas CPU. Di dalamnya terdapat ID thread, program counter, register, dan stack. Dan saling berbagi dengan thread lain dalam proses yang sama. dengan apa yang kita kerjakan diatas, maka anda telah berhasil menjalankan Komunikasi antar Thread.

0 komentar:

Posting Komentar

Social Profiles

Twitter Facebook Google Plus LinkedIn RSS Feed Email Pinterest

Teknik Informatika

Teknik Informatika

UNIVERSITAS TRISAKTI


Popular Posts

Categories

Total Tayangan Halaman

Diberdayakan oleh Blogger.

BTemplates.com

Blogroll

Homer Simpson

About

Copyright © N.E.W | Powered by Blogger
Design by Lizard Themes | Blogger Theme by Lasantha - PremiumBloggerTemplates.com