Psat-1 3 4
Psat-1 3 4
Psat-1 3 4
27.1
Basics
Firstly, one needs to set up PSAT environment. Launching the script le initpsat, as follows: >> initpsat will initialize PSAT and display on the Matlab workspace: < P S A T > Copyright (C) 2002-2004 Federico Milano Version 1.3.2 November 2, 2004 PSAT comes with ABSOLUTELY NO WARRANTY; type gnuwarranty for details. This is free software, and you are welcome to redistribute it under certain conditions; type gnulicense for details. Host: Session: Usage: Path: Matlab 7.0.0.19901 (R14) 02-Nov-2004 17:30:23 Command Line /home/fmilano/psatd
Existing workspace variables are not cleared during the initialization, as it happens when launching the PSAT GUI. Clearing the workspace could not be the desired 297
298
behavior as the command line version of PSAT can be used from within user dened routines. However, observe that all user variables which have same names as a PSAT global variables will be overwritten. Refer to Chapter A for the complete list of PSAT global variables. The scope of PSAT global variables will be the scope of the current workspace from where initpsat is called. If initpsat is called from within a user dened function, the scope will be the function workspace and the PSAT global variables will not be available in the Matlab workspace. To set PSAT global variables in the common Matlab workspace, initpsat must be launched form the Matlab command line of from within a script le.1 Initializing the PSAT variables is required only once for each workspace. A Following steps are setting up the data le and launching a PSAT routine. These operations can be done sequentially or at the same time by means of the function runpsat, as follows: >> runpsat( (datafile runpsat(datafile ,data) runpsat( (routine >> runpsat(routine ) or >> runpsat(datafile ,routine ) runpsat( (datafile where datafile is a string containing the data le name, and routine is a string containing the conventional name of the routine to be executed. The data le can be both a PSAT script le or a PSAT Simulink model. In the latter case the extension .mdl is mandatory. The dierence between the two methods is that when calling only the routine the data le name will not be overwritten. The rst method can be used if the data le under study does not change, while the user wants to perform several dierent analysis, as follows: >> >> >> >> runpsat( (datafile runpsat(datafile ,data) runpsat( (routine1 runpsat(routine1 ) runpsat( (routine2 runpsat(routine2 ) runpsat( (routine3 runpsat(routine3 )
The second method can be used if there are several data les under study: >> runpsat(datafile1 ,routine ) >> runpsat(datafile2 ,routine ) >> runpsat(datafile3 ,routine ) In the previous commands it is assumed that the data le is in the current directory (i.e. the one which is returned by the function pwd). To force PSAT to use a directory other than the current one, commands changes as follows: runpsat( (datafile >> runpsat(datafile ,datapath ,data) runpsat( (routine >> runpsat(routine )
1 The
27.1 Basics
299
Table 27.1: String pf cpf snb lib cpfatc sensatc n1cont opf sssa td pmu gams uw
Routine Conventional Names for Command Line Usage. Associated routine power ow analysis continuation power ow analysis direct method for saddle-node bifurcations direct method for limit-induced bifurcations evaluate ATC using CPF analysis evaluate ATC using sensitivity analysis N -1 contingency analysis optimal power ow analysis small signal stability analysis time domain simulation PMU placement OPF analysis through the PSAT-GAMS interface CPF analysis through the PSAT-UWPFLOW interface
or >> runpsat(datafile ,datapath ,routine ) where datapath is the absolute path of the data le. The perturbation le can be set in a similar way as the data le. At this aim, the following commands are equivalent: >> runpsat(pertfile ,pert) >> runpsat(pertfile ,pertpath ,pert) >> runpsat(datafile ,datapath ,pertfile ,pertpath ,routine ) Observe that if setting both the data and the perturbation les, it is necessary to specify as well the absolute paths for both les. The routine names are depicted in Table 27.1. Observe that if runpsat is launched with only one argument, say option, the following notations are equivalent: >> runpsat(option) >> runpsat option Other command line options for runpsat are depicted in Table 27.2. The syntax for the opensys option is the same as the one for data and pert options. If the PSAT variables are not needed anymore, the workspace can be cleared using the command: >> closepsat which will clear only PSAT global structures.
300
Table 27.2: General Options for Command Line Usage. String Associated routine data set data le pert set perturbation le opensys open solved case savesys save current system log write log le of the current session pfrep write current power ow solution eigrep write eigenvalue report le pmurep write PMU placement report le
27.2
Advanced Usage
The standard usage of PSAT through GUIs monopolizes the Matlab environment and makes dicult to include PSAT routine in other Matlab programs and/or including new features to PSAT. These issues will be briey commented in this section. When using PSAT GUIs, PSAT runs as a master program and the user can initialize and launch each internal routine from the main window. Thus each routine is a slave program (see Figure 27.1). Using this architecture, the only way to include a new routine in PSAT is writing a function which interacts with the PSAT GUIs, shares some of the PSAT global structures and properly exchanges information with PSAT. However, users who want to run PSAT routines within their own algorithms generally need to get rid of GUIs. Thus, the best solution would be to use the user dened program as the master and launching PSAT only when needed, as a slave application. In this way the user only needs to know how to pass and get data to and from PSAT. The latter can be easily solved by using PSAT global structures such as DAE, which mostly contains all variables of the current static solution (power ow, last CPF point, OPF), SSSA which contains the last small signal stability analysis solu-
301
Table 27.3: Structures to be modied to change default behavior. Routine Associated structure Power Flow Settings Continuation Power Flow CPF SNB direct method SNB LIB direct method LIB Optimal Power Flow OPF Small Signal Stability Analysis SSSA Time Domain Simulation Settings PMU placement PMU PSAT-GAMS interface GAMS PSAT-UWPFLOW interface UWPFLOW
tion, and Varout which contains the time domain simulation output, the continuation curves or the Pareto set. The structure DAE also contains the current system Jacobian matrices. Refer to Appendix A for details. Passing data and options to PSAT is quite simple if the default behavior is convenient for the current application. Otherwise, one needs to edit the PSAT global structures and set the desired options. Observe that, when using the standard version of PSAT, global structures are edited through the GUIs. Editing global structures from the command line can be a lengthy process, especially if one needs repeating often the same settings. In this case it could be convenient to write a script le where these settings are listed altogether and then launching the script le. Table 27.3 depicts PSAT routines and the associated global structures which dene routine options. A full description of these structures is presented in Appendix A.
27.3
The default behavior of command line usage of PSAT can be adjusted by means of the structure clpsat, which contains a few options, as follows:2 init command line initialization status. It is 1 if PSAT is running with the standard GUI support, 0 otherwise. The value of this eld should not be changed by the user and is initialized when launching PSAT. mesg status of PSAT messages. If the value is 0, no message will be displayed on the Matlab workspace. Default value is 1. Disabling message display will result in a little bit faster operations. refresh if true (default), forces to repeat power ow before running further analysis independently on the power ow status. This implies that the base case
2 In
the following the word true means the value of the variable is 1 and false means 0.
302
solution is used as the initial solution for all routines. refreshsim if true, forces to reload Simulink model before running power ow independently on the Simulink model status. Default is false since in the command line usage it is assumed that the user does not want to or cannot use the Simulink graphical interface. readfile if true (default), forces to read data le before running power ow. If the value is false, the data le is not reloaded, and slack generator, PV generator and PQ load data are reinitialized using their elds store. These data need to be reloaded since they might be modied during PSAT computations. showopf if true, forces to display OPF result on the standard output. Default is false. pq2z if true (default), forces to switch PQ loads to constant impedances before running time domain simulations. viewrep if true, forces to display report les when created. Default is false, i.e. the report le is created silently. For the sake of completeness, a summary of the elds of the clpsat structure is also depicted in Appendix A.
27.4
Example
The following script le gives a simple example of command line usage of PSAT. % initialize PSAT initpsat % do not reload data file clpsat.readfile = 0; % set data file runpsat(d 006 mdl,data) % solve base case power flow runpsat(pf) voltages = DAE.V; % increase base loading by 50% for i = 1:10 PQ.store(:,[4,5]) = (1+i/20)*[0.9, 0.6; 1, 0.7; 0.9, 0.6]; PV.store(:,4) = (1+i/20)*[0.9; 0.6]; runpsat(pf) voltages = [voltages, DAE.V];
27.4 Example
303
end % clear PSAT global variables closepsat disp(voltages) Firstly, PSAT is initialized and the readfile option is set to false. Then the le d 006 mdl is loaded (assuming that the le is in the current directory). Following instructions explain how to solve the base case power ow and a series of power ows with increased loads by means of an embedding algorithm. Finally the PSAT variables are cleared and the bus voltages printed on the workspace, as follows: voltages = Columns 1 through 6 1.0500 1.0500 1.0500 0.9859 0.9685 0.9912 1.0500 1.0500 1.0500 0.9820 0.9633 0.9876 1.0500 1.0500 1.0500 0.9781 0.9579 0.9840 1.0500 1.0500 1.0500 0.9741 0.9525 0.9803 1.0500 1.0500 1.0500 0.9700 0.9469 0.9765 1.0500 1.0500 1.0500 0.9660 0.9413 0.9728
Columns 7 through 11 1.0500 1.0500 1.0500 0.9618 0.9356 0.9689 1.0500 1.0500 1.0500 0.9576 0.9298 0.9650 1.0500 1.0500 1.0500 0.9533 0.9239 0.9611 1.0500 1.0500 1.0500 0.9490 0.9179 0.9571 1.0500 1.0500 1.0500 0.9446 0.9118 0.9531
Observe the usage of the store elds of the PV and PQ components. This allows changing the values of the system loading prole without reloading the data le.