forked from MATPOWER/matpower
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmakeSbus.m
79 lines (72 loc) · 2.95 KB
/
makeSbus.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
67
68
69
70
71
72
73
74
75
76
77
78
79
function [Sbus, dSbus_dVm] = makeSbus(baseMVA, bus, gen, mpopt, Vm, Sg)
%MAKESBUS Builds the vector of complex bus power injections.
% SBUS = MAKESBUS(BASEMVA, BUS, GEN)
% SBUS = MAKESBUS(BASEMVA, BUS, GEN, MPOPT, VM)
% SBUS = MAKESBUS(BASEMVA, BUS, GEN, MPOPT, VM, SG)
% returns the vector of complex bus power injections, that is, generation
% minus load. Power is expressed in per unit. If the MPOPT and VM arguments
% are present it evaluates any ZIP loads based on the provided voltage
% magnitude vector. If VM is empty, it assumes nominal voltage. If SG is
% provided, it is a complex ng x 1 vector of generator power injections in
% p.u., and overrides the PG and QG columns in GEN, using GEN only for
% connectivity information.
%
% [SBUS, DSBUS_DVM] = MAKESBUS(BASEMVA, BUS, GEN, MPOPT, VM)
% With two output arguments, it computes the partial derivative of the
% bus injections with respect to voltage magnitude, leaving the first
% return value SBUS empty. If VM is empty, it assumes no voltage dependence
% and returns a sparse zero matrix.
%
% See also MAKEYBUS.
% 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 named indices into bus, gen matrices
[PQ, PV, REF, NONE, BUS_I, BUS_TYPE, PD, QD, GS, BS, BUS_AREA, VM, ...
VA, BASE_KV, ZONE, VMAX, VMIN, LAM_P, LAM_Q, MU_VMAX, MU_VMIN] = idx_bus;
[GEN_BUS, PG, QG, QMAX, QMIN, VG, MBASE, GEN_STATUS, PMAX, PMIN, ...
MU_PMAX, MU_PMIN, MU_QMAX, MU_QMIN, PC1, PC2, QC1MIN, QC1MAX, ...
QC2MIN, QC2MAX, RAMP_AGC, RAMP_10, RAMP_30, RAMP_Q, APF] = idx_gen;
%% default inputs
if nargin < 5
Vm = [];
if nargin < 4
mpopt = [];
end
end
nb = size(bus, 1);
%% get load parameters
Sd = makeSdzip(baseMVA, bus, mpopt);
if nargout == 2
Sbus = [];
if isempty(Vm)
dSbus_dVm = sparse(nb, nb);
else
dSbus_dVm = -(spdiags(Sd.i + 2 * Vm .* Sd.z, 0, nb, nb));
end
else
%% compute per-bus generation in p.u.
on = find(gen(:, GEN_STATUS) > 0); %% which generators are on?
gbus = gen(on, GEN_BUS); %% what buses are they at?
ngon = size(on, 1);
Cg = sparse(gbus, (1:ngon)', 1, nb, ngon); %% connection matrix
%% element i, j is 1 if
%% gen on(j) at bus i is ON
if nargin > 5 && ~isempty(Sg)
Sbusg = Cg * Sg(on);
else
Sbusg = Cg * (gen(on, PG) + 1j * gen(on, QG)) / baseMVA;
end
%% compute per-bus loads in p.u.
if isempty(Vm)
Vm = ones(nb, 1);
end
Sbusd = Sd.p + Sd.i .* Vm + Sd.z .* Vm.^2;
%% form net complex bus power injection vector
%% (power injected by generators + power injected by loads)
Sbus = Sbusg - Sbusd;
end