Bac nao biet cach tao khoi moi trong matlab su dung S-Function Builder xin chi cho em voi. Em co bai tap :tao khoi PID trong S-Function Builder,cac bac giup em, em dang can gap lam, doi on cac bac nhieu!
Thông báo
Collapse
No announcement yet.
Giup em tao khoi moi trong Matlab su dung S-Function Builder
Collapse
X
-
S-function builder là công cụ giúp người dùng có thể tạo S-function một cách tự động thông qua việc đưa vào tên khối, tham số, đầu vào-ra, viết một số hàm cần thiết để tạo một S-Function. Ngoài ra bạn cũng có thể tạo bằng tay bằng cách lập trình dạng mex-file để tạo các khối mới tuỳ ý thích. Bạn có thể tham khảo chi tiết trong phần help của matlab, ở đây có rất nhiều ví dụ về cách tạo ra một S-functionViet Nguyen
AC2/K47-hut
-
Con viec thiet ke bo PID nhu ban noi, ta hoan toan co the dung khoi Subsystem. Sau day la chi tiet cach lam khoi PID thuc te bang cach dung Subsystem:
Viet Nguyen
AC2/K47-hut
Comment
-
Làm với Subsystem cũng đơn giản thôi. Bác xem thử xem nha:Nguyên văn bởi viettuan224 Xem bài viếtSao em không xem được hướng dẫn của bác vậy.Giúp em đi!Attached FilesViet Nguyen
AC2/K47-hut
Comment
-
Sau đây mình sẽ hướng dẫn bạn tạo một S-function cho bộ điều khiển PID. So sánh kết quả thu được so với cách tạo bằng subsystem.
- Đây là mã mà mình viết cho realPID:
Code:/*================================ Ham S-function mo ta dong hoc cua khau PID thuc te===========================*/ #define S_FUNCTION_NAME realPID #define S_FUNCTION_LEVEL 2 #include <math.h> #include "simstruc.h" #include "mat.h" #define U(element) (*uPtrs[element]) // con tro toi cong vao /*Dinh nghia cac tham so cua khoi*/ #define Kp mxGetPr(ssGetSFcnParam(S,0)) // tham so thu nhat #define Ki mxGetPr(ssGetSFcnParam(S,1)) // tham so thu hai #define Kd mxGetPr(ssGetSFcnParam(S,2)) // tham so thu ba #define ANFA mxGetPr(ssGetSFcnParam(S,3)) // tham so thu tu /*khoi tao kich co cho khoi*/ static void mdlInitializeSizes(SimStruct *S){ int ninputs=1; // be rong tin hieu cong vao int noutputs=1;// be rong tin hieu cong ra int nstates=2; // so trang thai lien tuc cua khoi ssSetNumSFcnParams( S, 4); // thiet lap so tham so cho khoi if (ssGetNumSFcnParams(S) != ssGetSFcnParamsCount(S)) { return;// neu so tham so nguoi dung dua vao ma khong bang voi yeu cau thi thoat ngay } ssSetNumContStates( S, nstates); // thiet lap so trang thai lien tuc ssSetNumDiscStates( S, 0); // thiet lap so trang thai gian doan if (!ssSetNumInputPorts(S, 1)){ return;// neu khong thiet lap duoc so cong vao la 1 thi thoat ngay } ssSetInputPortWidth(S, 0, ninputs); // thiet lap be rong tin hieu cong vao ssSetInputPortDirectFeedThrough(S, 0, 1); // thiet lap trang thai co xuyen xuot if (!ssSetNumOutputPorts(S, 1)){ return;// neu khong thiet lap duoc so cong ra la 1 thi thoat ngay } ssSetOutputPortWidth(S, 0, noutputs); // thiet lap be rong tin hieu cong ra ssSetNumSampleTimes( S, 1); // thiet lap so thoi gian trich mau ssSetNumRWork( S, 0); /* number of real work vector elements */ ssSetNumIWork( S, 0); /* number of integer work vector elements */ ssSetNumPWork( S, 0); /* number of pointer work vector elements */ ssSetNumModes( S, 0); ssSetNumNonsampledZCs( S, 0); /* Take care when specifying exception free code - see sfuntmpl.doc */ ssSetOptions(S, SS_OPTION_EXCEPTION_FREE_CODE); } /* ham khoi tao thoi gian*/ static void mdlInitializeSampleTimes(SimStruct *S){ ssSetSampleTime(S, 0, CONTINUOUS_SAMPLE_TIME); ssSetOffsetTime(S, 0, 0.0); } /*khoi tao dieu kien ban dau*/ #define MDL_INITIALIZE_CONDITIONS static void mdlInitializeConditions(SimStruct *S){ int i,nstates=2; real_T *x0 = ssGetContStates(S); for(i=0;i<nstates;i++){ x0[i] = 0; } } /*tinh toan dau ra*/ static void mdlOutputs(SimStruct *S, int tid){ real_T *y=ssGetOutputPortRealSignal(S,0); real_T *x=ssGetContStates(S); InputRealPtrsType uPtrs = ssGetInputPortRealSignalPtrs(S,0); double kp,ki,kd,anfa; kp=Kp[0]; ki=Ki[0]; kd=Kd[0]; anfa=ANFA[0]; y[0]=ki/anfa*x[0]+(ki-kd/anfa/anfa-kp/anfa)*x[1]+(kd/anfa+kp)*U(0); } /*tinh dao ham*/ #define MDL_DERIVATIVES static void mdlDerivatives(SimStruct *S){ real_T *dx = ssGetdX(S); real_T *x = ssGetContStates(S); InputRealPtrsType uPtrs = ssGetInputPortRealSignalPtrs(S,0); double anfa=ANFA[0]; dx[0]=x[1]; dx[1]= -1/anfa*x[1]+U(0); } /*ket thuc*/ static void mdlTerminate(SimStruct *S){ } /*ma o cuoi moi S-function luon nhu sau*/ #ifdef MATLAB_MEX_FILE /* Is this being compiled as a MEX-file? */ #include "simulink.c" /* mex-file interface mechanism */ #else #include "cg_sfun.h" /* Code generation registration func */ #endifViet Nguyen
AC2/K47-hut
Comment
-
Công việc tiếp theo là dịch file realPID.c ra dạng .dll
Bước 1:
Chọn trình biêm dịch bằng lệnh: >>mex -setup
Khi đó matlab sẽ hiển thị ra các trình biên dịch có trong máy của bạn, chỉ cần chọn 1 trình biên dịch và bấm enter là OK
Bước 2:
Dịch file realPID.c ra dạng .dll bằng lệnh: >>mex realPID.c
(lưu ý trước khi dịch bạn copy file vào thư mục work của Matlab, hoặc một thư mục bất kì nhưng phải chỉ đường dẫn thư mục đó cho matlab nhé: >>cd 'đường dẫn của thu mục')
Bước 3:
Sau khi dịch xong rồi ta tiến hành mô phỏng, lôi các khối cần thiết trong simulink ra nhé: subsystem,...
Sau đây mình up lên toàn bộ quá trình làm để ai quan tâm thì theo dõi nhé:Viet Nguyen
AC2/K47-hut
Comment
-
Ok nếu có gì mình làm được liên quan đến lĩnh vực này thì sẽ post lên nhé. Nhân đây mình có bài toán này cho bạn đây, bạn có thể làm nó như bước đi ban đầu trong lĩnh vực thiết kế S-Function nhé:
- Mô hình hoá cho bình mức một vào một ra bằng phương pháp lý thuyết
- có điều kiện thì kiểm chứng bằng thực nghiệm nhé
- tiến hành lập trình trên S-Function
- tiến hành mô phỏng
- thiết kế điều khiển
Gợi ý cho bạn là: đối tượng bình mức mà mình cho dưới đây có dạng hàm truyền là khâu quán tính tích phân: G(s)=K/s/(1+Ts). Khi ra được như thế này rồi thì việc lập trình là hoàn toàn đơn giản.
Chúc thành công!
Last edited by hero_ac; 09-05-2007, 18:21.Viet Nguyen
AC2/K47-hut
Comment
-
Bạn nào muốn tìm hiểu về cách dùng S-Function thì đọc tài liệu nè nè. Rất tốt cho người mới bắt đầu làm quen với S-Function.Nguyên văn bởi viettuan224 Xem bài viếtBac nao biet cach tao khoi moi trong matlab su dung S-Function Builder xin chi cho em voi. Em co bai tap :tao khoi PID trong S-Function Builder,cac bac giup em, em dang can gap lam, doi on cac bac nhieu!
Comment
-
Bạn nào muốn tìm hiểu về cách dùng S-Function thì đọc tài liệu nè nè. Rất tốt cho người mới bắt đầu làm quen với S-Function.Nguyên văn bởi viettuan224 Xem bài viếtBac nao biet cach tao khoi moi trong matlab su dung S-Function Builder xin chi cho em voi. Em co bai tap :tao khoi PID trong S-Function Builder,cac bac giup em, em dang can gap lam, doi on cac bac nhieu!
MatlabTutorialPart5
Mình upload lên ko được. Mọi người tự down nhé
Dễ lắm.Hi
Comment
-
chao bạn tuanbs
cái này đơn giảnNguyên văn bởi tuanbs Xem bài viếte muốn tạo khối subsystem có bốn đầu vào KP, KI, KD và e thì làm thế nào ạ
bước 1: tạo một model mới bằng Simulink model
bước 2: trong thư viện Simulink block ạn tìm khối Sussystem và input ,output kéo ra thả ngoài mạn hình -> đặt tên lại các khối
bước 3: copy các khối input và output đã tạo -> kích đúp vào khối Sussystem -> past vào bên trong
bước 4: ra ngoài khối Sussystem và nối dây vào
hoàn thành
bạn có thể tự do thiết kế tuy thích
có gì không hiểu cứ liên lạc với mình
tdquang@nippon-seiki.co.jp
Comment
Bài viết mới nhất
Collapse
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi vi van phamHôn nhân của tôi dường như có bàn tay sắp đặt của ông tơ, bà nguyệt. Bà xả nói tôi viết hồi ký duyên số này. Tôi đã viết vào tập 100 trang học sinh. Sau 50 năm lật tới, lật lui xem quyển hối ký có nơi rách nát. Tôi viết lại bằng AI, giọng đọc VBBe, ca sĩ hát là là Synthesizer V.
...-
Channel: Tâm tình dân kỹ thuật
Hôm qua, 14:18 -
-
Trả lời cho Công thức tính định luật kirchhoffbởi nguyendinhvanCông thức này chắc là để áp dụng cho UAV để bắn máy bay F15....
-
Channel: Hỗ trợ học tập
14-05-2026, 21:17 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92GIỚI THIỆU CA KHÚC VỀ CHA MẸ:
Nặng Nghĩa Mẹ Cha
Sáng tác: Hoàng Đình Thường
Giọng hát: AI
Công cha cao tựa như Thái Sơn
Nghĩa mẹ sâu nước biếc xanh trong
Mong con khôn lớn đời hạnh phúc
Mẹ cha...-
Channel: Tâm tình dân kỹ thuật
12-05-2026, 16:22 -
-
bởi afrendlyCảm ơn bạn. Mình hỏi để thợ có thể tham khảo thôi chứ không đủ kiển thức để sửa, mà cũng không có đồ nghề, mua đồ nghề quá tiền máy. Gọi nhiều lần mà thợ hẹn mãi chưa có tới ấy bạn. Mình muốn sửa được chứ bỏ thì uống, nhưng sợ là được mỗi người thợ mà lại không sửa nổi....
-
Channel: Điện tử gia dụng
11-05-2026, 00:34 -
-
bởi mèomướpDạ nó bị tắc ẩm hoặc rò thiếu gas hoặc lốc yếu hoặc van tiết lưu có vấn đề hoặc tất cả những nguyên nhân trên ạ. Chú ko chuyên về mảng này thì bán đi, giành thời gian trồng rau sạch đem ra chợ bán lấy tiền mua tủ mới ạ. Còn...
-
Channel: Điện tử gia dụng
10-05-2026, 17:01 -
-
bởi afrendlyXin chào mọi người. Mình lại có vấn đề về đồ điện cần nhờ mọi người hỗ trợ giúp. Mình có tủ lạnh Sharp dùng cũng lâu rồi. Trước có bị kém lạnh, không đông đá thì có thợ họ mang về, sục đường ga gì đó hết 900k và đã dùng...
-
Channel: Điện tử gia dụng
10-05-2026, 16:53 -
-
bởi dinhthuong92Đấy, cái tôi thắc mắc là chỗ màu hồng ấy bạn, để áp vào cao chứ không bị sụt gần bằng áp pin thì rất cần cuộc cảm để làm điều đó. Tuy nhiên, trong công thức bác thớt dẫn không thấy mặt L, và một vài mạch MPPT tôi đã kiểm...
-
Channel: Nguồn!
09-05-2026, 10:01 -
-
bởi mèomướpDạ mạch sạc là 1 cục nguồn, nó sẽ điều chỉnh công suất đầu ra để có tổng trở bằng nội trở của pin ạ. Và cái cách nó chỉnh công suất đầu ra sẽ là dạng buck, boot. Đều cần đến cuộn cảm ạ. Tất nhiên chú thích thì có thể dùng dạng tuyến tính transistor để bù trừ nhưng mà nó đốt năng lượng vô ích ạ...
-
Channel: Nguồn!
08-05-2026, 16:26 -
-
bởi dinhthuong92Tng trở R của tải (gồm pin và mạch sạc) trong công thức đó rõ ràng khống có L xuất hiện. Nếu tính các dây dẫn thì rất nhỏ, bỏ qua. Vì nội trở pin là rất nhỏ, có thể nói luôn lớn hơn nội trở solar, nên mạch MPPT sẽ hầu như luôn tính...
-
Channel: Nguồn!
08-05-2026, 11:00 -

Comment