How to define a piecewise anonymous function

Hello everyone,
the example code
syms x
continuous_function = x^2+x;
matlabFunction(continuous_function,'Vars',x)
gives me the anonymous function
@(x)x+x.^2
I would like a similar result for piecewise functions. However, the code
syms x
piecewise_function = piecewise( 0<x<1, x, 'otherwiseVal', 0 );
matlabFunction(piecewise_function,'Vars',x)
does not work.
Thanks for any help!

 채택된 답변

Star Strider
Star Strider 2019년 5월 31일

11 개 추천

You need to use ‘logical indexing’:
piecewise_function = @(x) (x.^2+x) .* ((0<x) & (x<1));
x = linspace(-1, 2);
figure
plot(x, piecewise_function(x))
producing:
How to define a piecewise anonymous function - 2019 05 31.png

댓글 수: 11

Thank you!
Do I understand you correctly that there is no function that converts
piecewise_function = piecewise( 0<x<1, x^2+x, 'otherwiseVal', 0 );
to
@(x) (x.^2+x) .* ((0<x) & (x<1))
Yes.
This code:
syms x
piecewise_function = piecewise( 0<x<1, x^2+x, 'otherwiseVal', 0 );
matlabFunction(piecewise_function)
throws this error:
Error using symengine
Unable to generate code for piecewise for use in anonymous functions.
(and some others).
The construction I use here appears to be the only way. Various such expressions can be combined in one function to create piecewise functions across various intervals, for example:
piecewise_function = @(x) (x.^2+x) .* ((0<x) & (x<1)) + (x+sqrt(x)).*((x>=1) & (x<1.5));
So all is not lost.
Stephan
Stephan 2019년 5월 31일
Thank you for this useful remark!
As always, my pleasure!
THANK YOU SO MUCH!!!!!!!!!!!! I've been looking for something like this for months!!!
ElPerroVerde — My pleasure!
A Vote would be appreciated!
.
Roy Goodman
Roy Goodman 2025년 10월 29일
How can we modify this to take the value NaN outside the interval [0 1]?
Roy Goodman
Roy Goodman 2025년 10월 29일
MATLAB Copilot returns code that fails!
Torsten
Torsten 2025년 10월 29일
편집: Torsten 2025년 10월 29일
piecewise_function = @(x) (x.^2+x) + 0./((0<=x) & (x<=1));
x = linspace(-1, 2);
figure
plot(x, piecewise_function(x))
syms x
f = piecewise((0<=x) & (x<=1),x.^2+x,nan)
f = 
piecewise_function = matlabFunction(f, 'file', 'test_piecewise.m')
piecewise_function = function_handle with value:
@test_piecewise
dbtype test_piecewise
1 function f = test_piecewise(x) 2 %TEST_PIECEWISE 3 % F = TEST_PIECEWISE(X) 4 5 % This function was generated by the Symbolic Math Toolbox version 25.2. 6 % 29-Oct-2025 22:14:42 7 8 t2 = ((0.0 <= x) & (x <= 1.0)); 9 if ~all(cellfun(@isscalar,{t2})) 10 error(message('symbolic:sym:matlabFunction:ConditionsMustBeScalar')); 11 end 12 if (t2) 13 f = x+x.^2; 14 else 15 f = NaN; 16 end 17 end
x = linspace(-1, 2);
plot(x, arrayfun(piecewise_function, x))
xline([-1 2])
Roy Goodman
Roy Goodman 2025년 10월 30일
Thanks!

댓글을 달려면 로그인하십시오.

추가 답변 (1개)

Walter Roberson
Walter Roberson 2020년 5월 16일

0 개 추천

If you use matlabFunction with 'file' option, then it will convert piecewise() into if/else in the generated code.
Note: because it uses if/else instead of logical indexing, the generated code will not be vectorized on that variable.

카테고리

질문:

2019년 5월 31일

댓글:

2025년 10월 30일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by