-
Notifications
You must be signed in to change notification settings - Fork 2
/
pdeset.m
144 lines (128 loc) · 3.92 KB
/
pdeset.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
function varargout = pdeset(varargin)
%PDESET Set options for pde15s
% PDESET('NAME1',VALUE1,'NAME2',VALUE2,...) creates options for the
% Chebfun pde15s routine. It acts as a gateway to odeset for the usual
% ode options for use in advancing through time, in addition to some new
% options.
%
% OPTIONS = PDESET(OLDOPTS,'NAME1',VALUE1,...) alters an existing options
% structure OLDOPTS.
%
% PDESET PROPERTIES (In addition to ODESET properties)
%
% Eps - Tolerance to use in solving the PDE [ positive scalar {1e-6} ].
%
% N - Turn off spacial adaptivity. [{NaN} | positive integer ]
% Use a fixed spacial grid of size N. If N is NaN, then the automatic
% procedure is used.
%
% Plot - Plot the solution at the end of every time chunk. [ {on} | off ]
% Turning this off can improve speed considerably.
%
% HoldPlot - Hold the plots after each chunk. [ on | {off} ]
%
% YLim - Fix the limits of the Y axis if plotting. [ 2x1 vector | {NaN} ]
% If Ylim is NaN then the imits are determined automatically.
%
% PlotStyle - Change the plotting options. [ string | ''-'' ].
%
% PDEflag - Specify which entries correspond to time derivatives.
% [ vector of logicals {true} ].
%
% Jacobian - set whether Chebfun should use AD functionality to determine
% the Jacobian function automatically, or allow ode15s to compute it
% numerically with odenumjac. [{'auto'}, 'none']
% Copyright 2011 by The University of Oxford and The Chebfun Developers.
% See http://www.maths.ox.ac.uk/chebfun/ for Chebfun information.
names = ['Eps '
'N '
'Plot '
'HoldPlot '
'YLim '
'PlotStyle'
'PDEflag '];
m = size(names,1);
shortnames = cell(m,1);
for k = 1:m
shortnames{k} = strtrim(names(k,:));
end
% initialise
opts = {};
pdeopts = {};
if nargin == 0,
if nargout == 0
odeset;
fprintf(' Eps: [ positive scalar {1e-6} ]\n')
fprintf(' N: [ {NaN} | positive integer ]\n')
fprintf(' Plot: [ {on} | off ]\n')
fprintf(' HoldPlot: [ on | {off} ]\n')
fprintf(' YLim: [ 2x1 vector | {NaN} ]\n')
fprintf(' PlotStyle: [ string | ''-'']\n')
fprintf(' PDEflag: [ vector of logicals {true} ]\n')
else
% Get the ode opts
opts = odeset;
% Add empty pde opts
for j = 1:m
opts.(shortnames{j}) = [];
end
varargout{1} = opts;
end
return
end
% Is an odeset / pdeset structure being passed?
if isstruct(varargin{1})
opts = varargin{1};
varargin(1) = [];
end
% Remember the old pdeopt values
for k = 1:m
namek = shortnames{k};
if isfield(opts,namek)
pdeopts = [ pdeopts {namek, opts.(namek)}];
end
end
% Parse the remaining input and update pdeopts entries
k = 1;
while k < length(varargin)
if ~any(strcmpi(fieldnames(odeset),varargin{k}))
if strcmpi(varargin{k},'Plot') || strcmpi(varargin{k},'HoldPlot')
varargin{k+1} = onoff(varargin{k+1});
end
pdeopts = [pdeopts varargin(k:k+1)];
varargin(k:k+1) = [];
else
k = k+2;
end
end
% Get the ode opts
opts = odeset(opts,varargin{:});
% Add empty pde opts
for j = 1:m
opts.(shortnames{j}) = [];
end
% Attach the pde opts
for k = 1:2:length(pdeopts)
for j = 1:m
if strcmpi(pdeopts{k},shortnames{j})
opts.(shortnames{j}) = pdeopts{k+1};
break
end
if j == m
error('CHEBFUN:pdeset:UnknownOption',['Unrecognized property name ',pdeopts{k},'.'])
end
end
end
if isfield(opts,'Mass') && ~isempty(opts.Mass) && ~isa(opts.Mass,'chebop')
error('CHEBFUN:pdeset:Mass','Mass matrix must be a chebop.');
end
varargout{1} = opts;
function foo = onoff(foo)
% Convert logical values of 'on' or 'off'
if ~ischar(foo)
if logical(foo)
foo = 'on';
else
foo = 'off';
end
end