System Identification - Frequency Domain
6 ビュー (過去 30 日間)
古いコメントを表示
I am trying to model the transfer function for the plant of a magnetic actuator. The input is in current (A) and output is distance moved x (mm). A sine sweep is run as disturbance and the input output plot looks like this:
data:image/s3,"s3://crabby-images/54673/5467342d25672aa3ae3a24b49d82fe4730c56ba3" alt=""
Since it is a sine sweep, i convert the data into frequency domain as follows:
data:image/s3,"s3://crabby-images/3078e/3078ea31e3bd9aba9730bd8a92760a05a2511449" alt=""
I am trying to identify the transfer function for this frequency domain plot. I use this as an idfrd data. I do manage to find a 6th order transfer function that fits the data. The corresponding code is as follows:
f_data=idfrd(H3c,fc,t_loop,'FrequencyUnit','Hz','Name', 'Openloop Plant', ...
'InputName', 'currrent', 'OutputName', 'xdist',...
'InputUnit', 'A', 'OutputUnit', 'mm');
bode(f_data)
f_data.InterSample = 'zoh';
model_1=tfest(f_data,6)
bode(model_1)
hold on
bode(f_data)
figure()
compare(f_data,model_1)
From this, I get the following match:
data:image/s3,"s3://crabby-images/9ce38/9ce389d146330befeedc2b9c481e78ba18c0a407" alt=""
The problem is, I can't get this back in the time domain. Or atleast, it is becoming unstable in the time domain like follows:
y=sim(model_1,Signal);
plot(t,y)
data:image/s3,"s3://crabby-images/e842e/e842e8d464f8bfb966070306d5c9dea30e3275e2" alt=""
Can anybody give any suggestions as to why this is happening and what to do to make it right?
0 件のコメント
採用された回答
Rajiv Singh
2020 年 7 月 7 日
Make an attempt with stability enforced.
opt = tfestOptions('EnforceStability', true);
model=tfest(f_data,6,opt)
Also, you don't necessarily need to generate FRD representation for frequency domain identification (conversion of time domaoin data to FRD is itself an estimation problem, subject to bias/variance considerations). You could try something like this too:
Time_Domain_Data = iddata(y,t,Ts);
Frequency_Domain_Data = fft(Time_Domain_Data);
model=tfest(Frequency_Domain_Data,6,opt)
3 件のコメント
Rajiv Singh
2020 年 7 月 9 日
The algorithm fits the complex frequency response, not magnitude and phase separately. I can't think of a way of improving phase only while keeping the magnitude curve unchanged, with the exception of rotations induced by delays. If there is a delay present from input to output, try finding out its value (e.g., using impulse or step test, or using delayest) and adding that value to the estimated model. But I doubt that is the case here.. you are probably forcing a stable model on the data from a (seemingly) unstable process.
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Linear Model Identification についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!