Using z-transform to solve the capacitor current, but I don't know where I went wrong.
2 ビュー (過去 30 日間)
古いコメントを表示
Take the simplest capacitive current as an example,
,C is capacitance.
data:image/s3,"s3://crabby-images/48751/48751644f03c0fa7d7e330a9d8b0583b3bc00989" alt=""
The corresponding transfer function is data:image/s3,"s3://crabby-images/ad40d/ad40da06ab89d5137b3d7e40f5a2ebaba786b61d" alt=""
data:image/s3,"s3://crabby-images/ad40d/ad40da06ab89d5137b3d7e40f5a2ebaba786b61d" alt=""
Applying bilinear transformation data:image/s3,"s3://crabby-images/a667c/a667cdbbb4eccaacceb5c58d6d34996b9d12cad3" alt=""
data:image/s3,"s3://crabby-images/a667c/a667cdbbb4eccaacceb5c58d6d34996b9d12cad3" alt=""
data:image/s3,"s3://crabby-images/4fe0e/4fe0ec6da830cba9a6ec57918ba692c6e2581c9c" alt=""
data:image/s3,"s3://crabby-images/32bee/32beeecfd3f304ec5bd82198c05a226011a7268e" alt=""
data:image/s3,"s3://crabby-images/a65eb/a65eb3ac51b130af20bf0d32314632185431d937" alt=""
The inverse transformation yields
data:image/s3,"s3://crabby-images/7d832/7d8322da02b63ed3016d2c5b5694d00136f71a9b" alt=""
Assuming the voltage input is known
,
is calculation step
data:image/s3,"s3://crabby-images/2b7dc/2b7dc45b9c0c0a8e0c481f4f30773c110d4d0a25" alt=""
data:image/s3,"s3://crabby-images/afc56/afc5651a292940fde47a9ca0d3fd5ed2ba62cf85" alt=""
Since index values in matlab start from 1,
.
data:image/s3,"s3://crabby-images/e9e95/e9e959d771aac4503997fe52e8948c7f3d116f6f" alt=""
%%%%%%%%%%%%%%%
deltat=1e-3; %calculation step
T=50e-6; %sampling time
C=100e-3; %capacitance
t=0:deltat:1;
k=2/T;
i=[];
i(1)=0;
u=sin(2*pi*50*t);
for n=1:1000
i(n+1)=C*k*u(n+1)-C*k*u(n)-i(n);
end
plot(t,i)
%%%%%%%%%%%%%%%
data:image/s3,"s3://crabby-images/be0de/be0de059c44d511b94a72d5c47a6e7e5472269a5" alt=""
The code resulted is this,quite different from simulink result.
data:image/s3,"s3://crabby-images/43d74/43d7459fe47f4c4c84041e19d274aa4eb8414213" alt=""
The questions I want to ask are:
1, Where is the formula derivation wrong?
2, If I want to change the index value to start from 0, how can I change the code without any error?
0 件のコメント
回答 (1 件)
Shishir Reddy
2024 年 8 月 30 日
Hi xin
When dealing with discrete data, plotting directly will inherently produce a step-like appearance. If the objective is to accurately reflect the continuous-time behaviour of the system, numerical integration methods should be considered that simulate continuous-time behaviour.
For a capacitor, the relationship between current i(t) and voltage u(t) is given by the differential equation: i(t) = C* (du/dt).
To solve a differential equation numerically, MATLAB's built-in numerical solvers like ode45, which are designed to handle ordinary differential equations (ODEs) can be used.
For detailed information regarding the ode45 solver, kindly refer the following documentation. https://www.mathworks.com/help/matlab/ref/ode45.html
This can be implemented as follows.
C = 100e-3;
T = 0.5;
f = 50;
u = @(t) sin(2 * pi * f * t);
differentialEquation = @(t, i) C * (2 * pi * f * cos(2 * pi * f * t)); % dy/dt = C * du/dt = C * (du/dt)
i0 = 0; % Initial condition for the current
tspan = [0 T];
[t, i] = ode45(differentialEquation, tspan, i0); % Solving the differential equation using ode45
plot(t, i);
title('Capacitive Current (Continuous-Time Simulation)');
xlabel('Time (s)');
ylabel('Current (A)');
ylim([-0.1 0.1])
By using ode45, the continuous-time behaviour of the capacitor can be simulated without manually discretizing the system, resulting in a smooth and accurate representation of the current.
I hope this helps.
0 件のコメント
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!