www.pudn.com > hhu_pfcp.rar > ext2int.m
function [i2e, bus, gen, branch, areas] = ext2int(bus, gen, branch, areas)
%EXT2INT Converts external to internal bus numbering.
% [i2e, bus, gen, branch, areas] = ext2int(bus, gen, branch, areas) converts
% external bus numbers (possibly non-consecutive) to consecutive internal
% bus numbers which start at 1.
% May be called as [i2e, bus, gen, branch] = ext2int(bus, gen, branch) if
% area data is not available/needed.
% MATPOWER
% $Id: ext2int.m,v 1.8 2005/10/14 16:47:32 ray Exp $
% by Ray Zimmerman, PSERC Cornell
% Copyright (c) 1996-2004 by Power System Engineering Research Center (PSERC)
% See http://www.pserc.cornell.edu/matpower/ for more info.
%% define names for columns to data 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;
[F_BUS, T_BUS, BR_R, BR_X, BR_B, RATE_A, RATE_B, RATE_C, ...
TAP, SHIFT, BR_STATUS, PF, QF, PT, QT, MU_SF, MU_ST, ...
ANGMIN, ANGMAX, MU_ANGMIN, MU_ANGMAX] = idx_brch;
[AREA_I, PRICE_REF_BUS] = idx_area;
i2e = bus(:, BUS_I);
e2i = zeros(max(i2e), 1);
e2i(i2e) = [1:size(bus, 1)]';
bus(:, BUS_I) = e2i( bus(:, BUS_I) );
gen(:, GEN_BUS) = e2i( gen(:, GEN_BUS) );
branch(:, F_BUS) = e2i( branch(:, F_BUS) );
branch(:, T_BUS) = e2i( branch(:, T_BUS) );
if nargin > 3 & nargout > 4
if ~isempty(areas)
areas(:, PRICE_REF_BUS) = e2i( areas(:, PRICE_REF_BUS) );
end
end
return;