2008. 5. 9. 13:43ㆍWork
Solution to the Ball & Beam Problem Using PID Control
The open-loop transfer function of the plant for the ball and beam experiment is given below:
- Settling time less than 3 seconds
- Overshoot less than 5%
To see the derivation of the equations for this problem refer to the ball and beam modeling page.
Closed-loop Representation
The block diagram for this example with a controller and unity feedback of the ball's position is shown below:
data:image/s3,"s3://crabby-images/5ef2a/5ef2ad3ca05a41bdd1db508e99f6aad8c3aff0ed" alt="사용자 삽입 이미지"
Recall, that the transfer function for a PID controller is:
data:image/s3,"s3://crabby-images/6729a/6729abbc162c534835549e17fd1152b244e49ad6" alt="사용자 삽입 이미지"
Proportional Control
The closed-loop transfer function for proportional control with a proportional gain (kp) equal to 100, can be modeled by copying the following lines of Matlab code into an m-file (or a '.m' file located in the same directory as Matlab)
.....m = 0.111;
.....R = 0.015;
.....g = -9.8;
.....L = 1.0;
.....d = 0.03;
.....J = 9.99e-6;
.....K = (m*g*d)/(L*(J/R^2+m)); %simplifies input
.....num = [-K];
.....den = [1 0 0];
.....kp = 1;
.....numP = kp*num;
.....[numc, denc] = cloop(numP, den)
You numerator and denominator should be:
.....numc =.....
..... 0 0 0.2100
.....denc =
..... 1.0000 0 0.2100
Now, we can model the system's response to a step input of 0.25 m. Add the following line of code to your m-file and run it:
.....step(0.25*numc,denc)
You should get the following output:
data:image/s3,"s3://crabby-images/7d43e/7d43e33cd5aad4aadd3bb54219c55d6848c3fb11" alt="사용자 삽입 이미지"
Proportional-Derivative Control
Now, we will add a derivative term to the controller. Copy the following lines of code to an m-file and run it to view the system's response to this control method.
.....m = 0.111;
.....R = 0.015;
.....g = -9.8;
.....L = 1.0;
.....d = 0.03;
.....J = 9.99e-6;
.....K = (m*g*d)/(L*(J/R^2+m)); %simplifies input
.....num = [-K];
.....den = [1 0 0];
.....kp = 10;
.....kd = 10;
.....numPD = [kd kp];
.....numh = conv(num, numPD);
.....[numc, denc] = cloop(numh, den);
.....t=0:0.01:5;
.....step(0.25*numc,denc,t)
Your plot should be similar to the following:
data:image/s3,"s3://crabby-images/70f33/70f3398336f9ede2caae1624de975139aa4d6233" alt="사용자 삽입 이미지"
data:image/s3,"s3://crabby-images/9049c/9049cc23dae5f4b45dcaebc6e68864b8f1926497" alt="사용자 삽입 이미지"
data:image/s3,"s3://crabby-images/9ed8f/9ed8f339fbfc176c842745d757e548bcd223ef78" alt="사용자 삽입 이미지"
'Work' 카테고리의 다른 글
Ball & Beam Control - Frequency Response (0) | 2008.05.09 |
---|---|
Ball & Beam Control - Root Locus (0) | 2008.05.09 |
Ball & Beam Control - Modeling (0) | 2008.05.09 |
SDHC/microSD 메모리카드에 관한 자료 (0) | 2008.05.07 |
Canon S3 IS 메뉴얼 (2) | 2008.05.07 |