Rev | Line | |
---|
[37] | 1 | function x = setnonlinearvariables(p,x) |
---|
| 2 | |
---|
| 3 | for i = 1:length(p.nonlinear) |
---|
| 4 | [row,pos,vals] = find(p.monomtable(p.nonlinear(i),:)); |
---|
| 5 | x(p.nonlinear(i)) = prod((x(pos)').^(vals)); |
---|
| 6 | end |
---|
| 7 | |
---|
| 8 | xevaled = x;%eros(1,length(p.c)); |
---|
| 9 | %xevaled(p.variabletype == 0) = x; |
---|
| 10 | if ~isempty(p.evalVariables) |
---|
| 11 | % Experimental support for arbitrary functions |
---|
| 12 | if ~isempty(p.evalMap) |
---|
| 13 | for i = 1:length(p.evalMap) |
---|
| 14 | arguments = {p.evalMap{i}.fcn,xevaled(p.evalMap{i}.variableIndex)}; |
---|
| 15 | arguments = {arguments{:},p.evalMap{i}.arg{2:end-1}}; |
---|
| 16 | xevaled(p.evalVariables(i)) = feval(arguments{:}); |
---|
| 17 | end |
---|
| 18 | end |
---|
| 19 | end |
---|
| 20 | |
---|
| 21 | x = xevaled(:); |
---|
| 22 | % for i = 1:length(p.nonlinear) |
---|
| 23 | % [row,pos,vals] = find(p.monomtable(p.nonlinear(i),:)); |
---|
| 24 | % x(p.nonlinear(i)) = prod((x(pos)').^(vals)); |
---|
| 25 | % end |
---|
Note: See
TracBrowser
for help on using the repository browser.