forked from MATPOWER/matpower
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdIbr_dV.m
66 lines (62 loc) · 2.4 KB
/
dIbr_dV.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
function [dIf_dVa, dIf_dVm, dIt_dVa, dIt_dVm, If, It] = dIbr_dV(branch, Yf, Yt, V)
%DIBR_DV Computes partial derivatives of branch currents w.r.t. voltage.
% [DIF_DVA, DIF_DVM, DIT_DVA, DIT_DVM, IF, IT] = DIBR_DV(BRANCH, YF, YT, V)
% returns four matrices containing partial derivatives of the complex
% branch currents at "from" and "to" ends of each branch w.r.t voltage
% magnitude and voltage angle respectively (for all buses). If YF is a
% sparse matrix, the partial derivative matrices will be as well. Optionally
% returns vectors containing the currents themselves. The following
% explains the expressions used to form the matrices:
%
% If = Yf * V;
%
% Partials of V, Vf & If w.r.t. voltage angles
% dV/dVa = j * diag(V)
% dVf/dVa = sparse(1:nl, f, j * V(f)) = j * sparse(1:nl, f, V(f))
% dIf/dVa = Yf * dV/dVa = Yf * j * diag(V)
%
% Partials of V, Vf & If w.r.t. voltage magnitudes
% dV/dVm = diag(V./abs(V))
% dVf/dVm = sparse(1:nl, f, V(f)./abs(V(f))
% dIf/dVm = Yf * dV/dVm = Yf * diag(V./abs(V))
%
% Derivations for "to" bus are similar.
%
% Example:
% [Ybus, Yf, Yt] = makeYbus(baseMVA, bus, branch);
% [dIf_dVa, dIf_dVm, dIt_dVa, dIt_dVm, If, It] = ...
% dIbr_dV(branch, Yf, Yt, V);
%
% For more details on the derivations behind the derivative code used
% in MATPOWER information, see:
%
% [TN2] R. D. Zimmerman, "AC Power Flows, Generalized OPF Costs and
% their Derivatives using Complex Matrix Notation", MATPOWER
% Technical Note 2, February 2010.
% http://www.pserc.cornell.edu/matpower/TN2-OPF-Derivatives.pdf
% MATPOWER
% Copyright (c) 1996-2016, Power Systems Engineering Research Center (PSERC)
% by Ray Zimmerman, PSERC Cornell
%
% This file is part of MATPOWER.
% Covered by the 3-clause BSD License (see LICENSE file for details).
% See http://www.pserc.cornell.edu/matpower/ for more info.
%% define
nb = length(V);
Vnorm = V ./ abs(V);
if issparse(Yf) %% sparse version (if Yf is sparse)
diagV = sparse(1:nb, 1:nb, V, nb, nb);
diagVnorm = sparse(1:nb, 1:nb, Vnorm, nb, nb);
else %% dense version
diagV = diag(V);
diagVnorm = diag(Vnorm);
end
dIf_dVa = Yf * 1j * diagV;
dIf_dVm = Yf * diagVnorm;
dIt_dVa = Yt * 1j * diagV;
dIt_dVm = Yt * diagVnorm;
%% compute currents
if nargout > 4
If = Yf * V;
It = Yt * V;
end