Firstly I assume dt=0.00006 is known and use the following code to draw the curve of il.
{r = 22, l = 2 10^-1, c = 1 10^-4, vi = 24, initvalueil = 0,
initvaluevc = 0, tstart = 0, tend = 0.08, dt = 0.00006};
\[CapitalDelta]vi = 0;
A = {{0, -1/l}, {1/c, -1/(r c)}};
G = Inverse[A];
B = {1/l, 0};
S1 = Inverse[DiagonalMatrix[{1, 1}] - dt*A + 1/2*dt*dt*A . A];
S2 = Inverse[DiagonalMatrix[{1, 1}] - dt*A];
STAR1 = S1 . G . (B*vi + G . B*\[CapitalDelta]vi/dt) -
G . (B*(vi + \[CapitalDelta]vi) + G . B*\[CapitalDelta]vi/dt);
STAR2 = S2 . G . (B*vi + G . B*\[CapitalDelta]vi/dt) -
G . (B*(vi + \[CapitalDelta]vi) + G . B*\[CapitalDelta]vi/dt);
X0 = {0, 0};
X[t_] :=
Simplify[(MatrixPower[S1, i] - MatrixPower[S2, i]) .
X0 + (DiagonalMatrix[{1, 1}] . (DiagonalMatrix[{1, 1}] -
MatrixPower[S1, i]) .
Inverse[DiagonalMatrix[{1, 1}] - S1]) .
STAR1 - (DiagonalMatrix[{1, 1}] . (DiagonalMatrix[{1, 1}] -
MatrixPower[S2, i]) .
Inverse[DiagonalMatrix[{1, 1}] - S2]) . STAR2] /. {i ->
t/dt};
il = X[t][[1]];
Plot[il, {t, 0, 0.08}, AxesLabel -> {"s", "il[t]/A"},
PlotLegends -> {"dt=0.00006"}, PlotStyle -> {Red}, PlotRange -> All]
FindMaximum[il, {t, 0, 0.08}]
The obtained curve is shown in the following figure: From the output results, we can know that the maximum value of il under the constraints of dt and t is 0.0019152.
Then I assigned the value of 0.0019152 to error and solved the value of dt using the following code, but the output result dt is not 0.00006. Why is this? If I want to make dt=0.00006, what instructions should I use or modify my code?
The code is as follows:
{r = 22, l = 2 10^-1, c = 1 10^-4, vi = 24, initvalueil = 0,
initvaluevc = 0, tstart = 0, tend = 0.08, limitdt = 0.0001,
error = 0.0019152};
\[CapitalDelta]vi = 0;
A = {{0, -1/l}, {1/c, -1/(r c)}};
G = Inverse[A];
B = {1/l, 0};
S1 = Inverse[DiagonalMatrix[{1, 1}] - dt*A + 1/2*dt*dt*A . A];
S2 = Inverse[DiagonalMatrix[{1, 1}] - dt*A];
STAR1 = S1 . G . (B*vi + G . B*\[CapitalDelta]vi/dt) -
G . (B*(vi + \[CapitalDelta]vi) + G . B*\[CapitalDelta]vi/dt);
STAR2 = S2 . G . (B*vi + G . B*\[CapitalDelta]vi/dt) -
G . (B*(vi + \[CapitalDelta]vi) + G . B*\[CapitalDelta]vi/dt);
X0 = {0, 0};
X[t_] :=
Simplify[(MatrixPower[S1, i] - MatrixPower[S2, i]) .
X0 + (DiagonalMatrix[{1, 1}] . (DiagonalMatrix[{1, 1}] -
MatrixPower[S1, i]) .
Inverse[DiagonalMatrix[{1, 1}] - S1]) .
STAR1 - (DiagonalMatrix[{1, 1}] . (DiagonalMatrix[{1, 1}] -
MatrixPower[S2, i]) .
Inverse[DiagonalMatrix[{1, 1}] - S2]) . STAR2] /. {i ->
t/dt};
ilerror = X[t][[1]];
condequal = ilerror <= error;
maxil = FindMaximum[{ilerror, condequal, tstart <= t <= tend,
0 <= dt <= limitdt}, {t, dt}]