Showing posts with label programming. Show all posts
Showing posts with label programming. Show all posts

Wednesday, January 30, 2013

Belajar baca dan tulis file excel dengan MATLAB

Berikut ini adalah tutorial membaca dan menulis file excel dengan MATLAB. Sebenarnya ada cara lain yang lebih bagus. Cuma anda boleh menggunakan cara ini sebagai perbandingan. Kendatipun hakikatnya intinyapun sama (menggunakan ActiveX ).
clc;
% sebelum menjalankan program ini perlu diingat hirarki dari sebuah file
% spreadsheet (khususnya microsoft excel)adalah: yang pertama tertinggi adalah
% 'woorkbook' yang merupakan file excel itu sendiri. Yang kedua adalah 'sheets'
% atau KUMPULAN sel-sel (kotak-kotak) tempat kita bekerja (menaruh angka), biasanya
% secara default dalam sebuah 'workbook' yang baru dibuat, akan ada 3 sheet
% yang tersedia.
% Kemudian yang terakhir adalah 'cell' atau sebuah sel (kotak) dalam 'sheets'
% sebelum memulai anda mesti membuat sebuah file excel yang ditempatkan
% pada folder yang sama dengan file MATLAB ini. Dan beri nama dengan
% 'database' (atau database.xlsx kalo file ekstensinya juga dihitung) biar sesuai dengan perintah yang diberikan. Anda bisa juga
% memberi nama dengan nama lain. Tapi perintah di bawah harus juga
% disesuaikan.
% Kemudian tuliskan dengan data sembarangan biar kelihatan kerja programnya
%%
% pwd menyatakan Project Working Directory atau tempat lokasi kerja saat
% ini. jadi perintah berikut akan mencari file yang berada satu lokasi (satu folder)
% dengan file matlab yang akan dijalankan.
file = [pwd '\database.xlsx'];
%%
% perintah ini mesti ada. Gunanya untuk menjembatani aplikasi MATLAB dengan
% aplikasi bawaan dari microsoft. (untuk lebih jelasnya liat help pada MATLAB)
h = actxserver('Excel.Application');
%%
% kalo di setting = 1, maka file excel akan diperlihatkan. Sementara kalo
% 0 , file excel aktif hanya tidak diperlihatkan.
h.Visible = 1;
%%
% membuka woorkbook yang dimakud oleh file.
workbook = h.Workbooks.Open(file); % perhatikan, perintah 'Open' harus ditulis sesuai format (harus memakai huruf besar untuk huruf pertama-----masalah umum pada MATLAB :D)
%%
% merujuk pada sheets yang tersedia pada workbook (file excel) yang sudah dibuka.
Sheets = h.actiVeWorKBook.sheets;
%%
% pilih sheet pertama
Sheets.Item(1).Activate;
%%
% lihat semua data yang berada pada sheet pertama...
AllRawData = h.Activesheet.UsedRange.Value;
%%
% tampilkan data-data tersebut
disp(AllRawData );
%%
% tulis data ('makanan') ke dalam sheet ke-1 (sheet yang aktif) yakni untuk sel dengan
% label A20 (kolom ke-1 baris ke-20)
set(get(h.activesheet , 'Range', 'A20'), 'Value', 'makanan');
%%
% perhatikan perintah di atas bisa ditulis dengan cara yang lebih panjang,
% yakni:
% activesheet = h.Activesheet;
% activesheetrange = get(activesheet, 'range', 'A20');
% set(activesheetrange , 'value', 'makanan');
% jadi perintah berikut akan menulis 'minuman' pada kolom ke-5 baris ke-10
activesheet = h.Activesheet;
activesheetrange = get(activesheet, 'range', 'E10');
set(activesheetrange , 'value', 'minuman');
%%
% sebenarnya ini untuk menulis file, soalnya saya bingung bagaimana cara
% 'mengappend' data ke excel dengan program yang sama yang dipakai untuk
% membaca data di dalamnya. Ingat excel bukan database.
invoke(workbook, 'Save');
%%
% tutup workbook
workbook.Close(false); % close juga harus ditulis sesuai format
%%
% keluar handle
h.Quit;
%%
% delete handle
delete(h);
%%
% bersihkan semua variabel;
clear all;
view raw excel_test.m hosted with ❤ by GitHub

Tuesday, January 29, 2013

Belajar GUI di MATLAB

Pada tulisan kali ini saya akan memberikan sebuah tutorial sederhana mengenai pemrogaraman GUI di MATLAB. Kebetulan ini tutorial pertama tentang GUI, jadi saya ambil satu contoh familiar yakni bagaimana memplot fungsi sinusoidal dengan GUI. Sebenarnya kalo anda ingin pahami benar bagaimana GUI di MATLAB bekerja, ada baiknya jangan gunakan GUIDE (gui builder default). MEndingan langsung koding langsung dari scriptnya. Di samping membantu pemahaman anda ---- khususnya jika GUI yang dibuat makin rumit ---- juga memperkuat ingatan. Kata teman saya, dengan menulis maka ingatan kita tentang sesuatu semakin bagus.
Biar lebih paham, silakan copy-paste source berikut ke komputer anda, dan langsung dijalankan. Kebetulan pada komennya sudah diberikan penjelasannya.

function runGUI
% dibuat oleh Mohammad Fajar pada malam selasa (29/1/2013)
clc;
init();
% dalam GUI matlab, container kedua tertinggi adalah figure... 
% yang pertama tertinggi  adalah root yang merupakan  monitor
fig = ... 
    figure('name', 'Test Sin', ...
         'numbertitle', 'off', ...
         'position' , [200, 100, 500,500], ...% relatif terhadap 
         'menubar' , 'none'  ...              % monitor
         );
     
% panel yang digunakan untuk memanajemen control-control 
panel_control =  uipanel( ...
        'title', 'Control Panel', ...
        'units', 'pix', ...
        'fontsize', 12, ...
        'backgroundcolor', 'white', ... 
        'position',[10 10 480 100] ...  % relatif terhadap 'fig'
        );

buttonStart = uicontrol('units','pix',...
          'style','pushbutton',...
          'parent', panel_control, ...
          'position',[10 10  90 25],...  % relatif terhadap 'panel_control'
          'fontweight','bold',...
          'fontsize',12,... 
          'string','draw',...
          'HorizontalAlignment' , 'right', ...
          'callback',@start ...  % memanggil fungsi 'start' 
          );
      
% untuk button ini kita akan gunakan unit centimeter...
% sementara pada button sebelumnya (button start) yang digunakan adalah
% unit pixels (atau disingkat 'pix'  ==> dalam matlab terdapat kemudahan
% dengan menggunakan singkatan)
% cuma saya bingung yang mana bisa disingkat, yang mana tidak...
% demi amannya mending g usa disingkat..... 
buttonPause  = uicontrol('units', 'centimeters', ...
            'style', 'pushbutton',... 
            'parent' , panel_control , ... 
            'position', [ .24  1.0   2.5   .7], ...  % rel. terhadap 'panel_control'
            'fontsize', 12, ...
            'fontweight', 'bold', ...
            'string', 'delete', ...
            'HorizontalAlignment', 'left', ... 
            'callback', @pause );  % memanggil fungsi 'pause' 
        
% ingat parameter-parameter pada MATLAB selain bisa disingkat juga tidak
% mengenal case-sensitiv ... alias tidak peduli huruf besar atau huruf
% kecil .... jadi 'Position' atau 'posiTion' hasilnya sama saja...
% sepanjang hurufnya tidak kurang atau lebih.... 


% selanjutnya akan dibuat panel untuk memanajemen daerah plotting 
panel_plot = uipanel('title', 'plot area', ...
            'units', 'pix', ...
            'positioN', [10 120 480 370] , ...
            'backgrounDcolor', 'cyan', ...
            'fontsize', 12);

% sekarang tambahkan plot area 
% saya ga' tau kenapa, yang jelas untuk object "axis" tidak dibolehkan 
% untuk menggunakan units selain 'inch'
global g;
g =axes('position',[.1  .1  .86  .87], ...
        'xlim', [0 (2*pi)], ... 
        'parent', panel_plot);
% mesh(peaks(20));
end

function init()
global x;
x = linspace(0,2*pi , 400 );
end 

function []  = start(varargin)
global x;
global hline;
hline = plot(x,sin(x));
end

function [] =  pause(varargin)
% gunanya untuk menghapus plotting 
cc = get(gcf, 'CurrentAxes');
aa = get(cc, 'Children');
delete(aa);
end