forked from sandialabs/MATLAB_PV_LIB
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpvl_SAMLibraryReader_CECModules.m
214 lines (182 loc) · 9.59 KB
/
pvl_SAMLibraryReader_CECModules.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
function [CECModuleDB, ModuleNames] = pvl_SAMLibraryReader_CECModules(varargin)
% PVL_SAMLIBRARYREADER_CECMODULES Open a System Advisor Model (SAM) CEC module library
%
% Syntax
% [CECModuleDB, ModuleNames] = pvl_SAMLibraryReader_CECModules()
% [CECModuleDB, ModuleNames] = pvl_SAMLibraryReader_CECModules(LibraryFile)
%
% Description
% pvl_SAMLibraryReader_CECModules reads a System Advisor Model (SAM) [1]
% library of CEC modules. CECModuleDB is a vector of structures which
% describe each module in the SAM library, one element per module in the
% SAM library. ModuleNames is a cell column vector of the names of each
% module in the CEC Library, thus ModuleNames{n} is the same as
% CECModuleDB(n).name.
%
% Input Parameters:
% LibraryFile - An optional input string to select which SAM library to
% read. If omitted, a user dialog box will prompt the user to browse and
% select a module library. Note that if LibraryFile is input to the
% function, the standard MATLAB precedence order applies.
%
% Output:
% CECModuleDB - The parameters in the SAM module library. CECModuleDB is
% a column vector of size [NumberOfLibraryEntries, 1], where each element
% is a struct with the following fields. These fields may be described in
% more detail in the SAM documentation.
% name - Name of the module entry in the library
% t_noct - Nominal Operating Cell Temperature (NOCT) in degrees C of
% the module
% a_c - Module area in m^2
% Ns - Number of series cells within the module
% i_sc_ref - Short circuit current under reference conditions
% v_oc_ref - Open circuit voltage under reference conditions
% i_mp_ref - Maximum power current under reference condtions
% v_mp_ref - Maximum power voltage under reference conditions
% alpha_sc - Short circuit current temperature coefficient in A/C
% beta_oc - Open circuit voltage tempereature coefficient in V/C
% a_ref - modified diode ideality factor parameter at
% reference conditions (units of eV), a_ref can be calculated from the
% usual diode ideality factor (n), number of cells in series (Ns),
% and cell temperature (Tcell) per equation (2) in [2].
% IL_ref - Light-generated current (or photocurrent)
% in amperes at reference conditions. This value is referred to
% as Iph in some literature.
% I0_ref - diode reverse saturation current in amperes,
% under reference conditions.
% Rs_ref - series resistance under reference conditions (ohms)
% Rsh_ref - shunt resistance under reference conditions (ohms)
% adjust - Adjustment percentage to allow measured power temperature
% coefficient to match reported power temperature coefficient [3].
% gamma_r - Power temperature coefficient in %/C.
% source - String describing the type of cells used in the module.
% LibraryType - Library type as listed in the header information of
% the SAM library file.
% LibraryName - Library name as listed in the header information of
% the SAM library file.
%
% ModuleNames - A cell array of size [NumberOfLibraryEntries, 1] with the
% names of the modules in the SAM library.
%
%
% Notes:
% If this function detects that the selected input library is not of
% type "CECModule", it will display a warning to the command window and
% continue to try and read the library.
%
% The PV_LIB team would also like to thank the SAM team for maintaining
% the CEC module parameter library and allowing for interaction with the
% library files.
%
% Sources:
%
% [1] System Advisor Model web page. https://sam.nrel.gov.
%
% [2] W. De Soto et al., "Improvement and validation of a model for
% photovoltaic array performance", Solar Energy, vol 80, pp. 78-88,
% 2006.
%
% [3] A. Dobos, "An Improved Coefficient Calculator for the California
% Energy Commission 6 Parameter Photovoltaic Module Model", Journal of
% Solar Energy Engineering, vol 134, 2012.
%
% See also
% PVL_SINGLEDIODE PVL_CALCPARAMS_DESOTO
% PVL_SAMLIBRARYREADER_SNLINVERTERS
%% Parse the input data
p = inputParser;
p.addOptional('LibraryFile', 0, @(x) ischar(x));
p.parse(varargin{:})
%% Enter Library structure basics
LibraryHeaderLines = 3; % Number of header lines before beginning data
LinesPerEntry = 19; % include line delimiters such as "!"
NonexistantCharacter = char(172); % A character which is NOT found within the library
% Create the empty structure which will hold all module data
emptyStruct = struct('name',[] , 't_noct', [] , 'a_c', [], 'Ns', [], 'i_sc_ref', [], ...
'v_oc_ref', [], 'i_mp_ref', [], 'v_mp_ref', [], 'alpha_sc', [], 'beta_oc', [], ...
'a_ref', [], 'IL_ref', [], 'I0_ref', [], 'Rs_ref', [], 'Rsh_ref', [], ...
'adjust', [], 'gamma_r', [], 'source', [], 'LibraryType', [], 'LibraryName', []);
defaultchecker = {'LibraryFile'};
if any(strcmp(defaultchecker,p.UsingDefaults))
%% Ask user to get SAM library file
[FileName, FilePath, FilterIndex] = ...
uigetfile('*.samlib', 'Select a CEC Module Library with .samlib extension.', 'MultiSelect', 'off');
if FilterIndex ==0
error('No .samlib file selected, exiting Library Reader')
end
FilePathandName = [FilePath FileName];
else
FilePathandName = p.Results.LibraryFile;
end
%% Open the file and read in the header and data separately
FileID = fopen(FilePathandName);
HeaderDataIn = textscan(FileID, '%s', LibraryHeaderLines, 'Delimiter', NonexistantCharacter);
RawDataIn = textscan(FileID, '%s', 'Delimiter', NonexistantCharacter);%, 'HeaderLines', LibraryHeaderLines);
fclose(FileID);
HeaderDataIn = HeaderDataIn{1};
RawDataIn = RawDataIn{1};
%% Parse out the library name, library type, and number of entries from the header information
% This goes with every entry
LibraryName = textscan(char(HeaderDataIn(1)), '%*8s %s', 'Delimiter', NonexistantCharacter);
LibraryName = LibraryName{1};
% This goes with every entry
LibraryType = textscan(char(HeaderDataIn(2)), '%*s %s', 'Delimiter', ' ', 'MultipleDelimsAsOne', 1);
LibraryType = LibraryType{1};
if ~(strcmp(LibraryType, 'CECModule'))
warning(['A System Advisor Model (SAM) library which is NOT '...
'of type "CECModule" has been selected as input to ' ...
'pvl_SAMLibraryReader_CECModules. Your data may not be correct.']);
end
NumberOfEntries = textscan(char(HeaderDataIn(3)), '%*s %f', 'Delimiter', ' ', 'MultipleDelimsAsOne', 1);
NumberOfEntries = NumberOfEntries{1};
% Create vector of structures which will hold the database information
CECdatabase(1:NumberOfEntries) = emptyStruct;
CECdatabase = CECdatabase(:);
%% Step through each entry and extract the information from each entry into the structures
for cntr1 = 1:NumberOfEntries
EntryRequested = cntr1;
Base = (EntryRequested-1) * LinesPerEntry; % The line before the name of an entry is the "base" line
% Extract information from the requested entry
% Requires that the name field be as follows "entry NAMEOFENTRY"
name = textscan(char(RawDataIn(Base+1)), '%*6s %s', 'Delimiter', NonexistantCharacter);
CECdatabase(EntryRequested).name = (name{1});
t_noct = textscan(char(RawDataIn(Base+2)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).t_noct = t_noct{1};
a_c = textscan(char(RawDataIn(Base+3)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).a_c = a_c{1};
n_s = textscan(char(RawDataIn(Base+4)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).Ns = n_s{1};
i_sc_ref = textscan(char(RawDataIn(Base+5)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).i_sc_ref = i_sc_ref{1};
v_oc_ref = textscan(char(RawDataIn(Base+6)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).v_oc_ref = v_oc_ref{1};
i_mp_ref = textscan(char(RawDataIn(Base+7)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).i_mp_ref = i_mp_ref{1};
v_mp_ref = textscan(char(RawDataIn(Base+8)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).v_mp_ref = v_mp_ref{1};
alpha_sc = textscan(char(RawDataIn(Base+9)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).alpha_sc = alpha_sc{1};
beta_oc = textscan(char(RawDataIn(Base+10)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).beta_oc = beta_oc{1};
a_ref = textscan(char(RawDataIn(Base+11)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).a_ref = a_ref{1};
i_l_ref = textscan(char(RawDataIn(Base+12)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).IL_ref = i_l_ref{1};
i_o_ref = textscan(char(RawDataIn(Base+13)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).I0_ref = i_o_ref{1};
r_s = textscan(char(RawDataIn(Base+14)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).Rs_ref = r_s{1};
r_sh_ref = textscan(char(RawDataIn(Base+15)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).Rsh_ref = r_sh_ref{1};
adjust = textscan(char(RawDataIn(Base+16)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).adjust = adjust{1};
gamma_r = textscan(char(RawDataIn(Base+17)), '%*s %f', 'Delimiter', '=');
CECdatabase(EntryRequested).gamma_r = gamma_r{1};
source = textscan(char(RawDataIn(Base+18)), '%*s %s', 'Delimiter', '=');
CECdatabase(EntryRequested).source = (source{1});
CECdatabase(EntryRequested).LibraryName = LibraryName;
CECdatabase(EntryRequested).LibraryType = LibraryType;
end
%% Write the information from the CEC Library to the output variables.
CECModuleDB = CECdatabase;
ModuleNames = [CECModuleDB.name]';