⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 case2off.m

📁 该程序是计算最优潮流的matlab工具箱。可以很好的求解目标函数不同的最优潮流问题。
💻 M
字号:
function [q, p] = case2off(gen, gencost)%CASE2OFF  Creates quantity & price offers from gen & gencost.%   [q, p] = case2off(gen, gencost) creates quantity and price offers%   from case variables gen & gencost.%   MATPOWER%   $Id: case2off.m,v 1.5 2005/01/21 20:44:17 ray Exp $%   by Ray Zimmerman, PSERC Cornell%   Copyright (c) 1996-2005 by Power System Engineering Research Center (PSERC)%   See http://www.pserc.cornell.edu/matpower/ for more info.%% define named indices into data matrices[GEN_BUS, PG, QG, QMAX, QMIN, VG, MBASE, ...    GEN_STATUS, PMAX, PMIN, MU_PMAX, MU_PMIN, MU_QMAX, MU_QMIN] = idx_gen;[PW_LINEAR, POLYNOMIAL, MODEL, STARTUP, SHUTDOWN, N, COST] = idx_cost;%% do conversionoldgencost = gencost;i_poly = find(gencost(:, MODEL) == POLYNOMIAL);npts = 6;                   %% 6 points => 5 blocks%% convert polynomials to piece-wise linear by evaluating at zero and then%% at evenly spaced points between Pmin and Pmaxif any(i_poly)    [m, n] = size(gencost(i_poly, :));                              %% size of piece being changed    gencost(i_poly, MODEL) = PW_LINEAR * ones(m, 1);                %% change cost model    gencost(i_poly, COST:n) = zeros(size(gencost(i_poly, COST:n))); %% zero out old data    gencost(i_poly, N) = npts * ones(m, 1);                         %% change number of data points        for i = 1:m        ig = i_poly(i);     %% index to gen        Pmin = gen(ig, PMIN);        Pmax = gen(ig, PMAX);        if Pmin == 0            step = (Pmax - Pmin) / (npts - 1);            xx = [Pmin:step:Pmax];        else            step = (Pmax - Pmin) / (npts - 2);            xx = [0 Pmin:step:Pmax];        end        yy = totcost(oldgencost(ig, :), xx);        gencost(ig,     COST:2:(COST + 2*(npts-1)    )) = xx;        gencost(ig, (COST+1):2:(COST + 2*(npts-1) + 1)) = yy;    endendn = max(gencost(:, N));xx = gencost(:,     COST:2:( COST + 2*n - 1 ));yy = gencost(:, (COST+1):2:( COST + 2*n     ));i1 = 1:(n-1);i2 = 2:n;q = xx(:, i2) - xx(:, i1);p = ( yy(:, i2) - yy(:, i1) ) ./ q;return;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -