data:image/s3,"s3://crabby-images/71ce4/71ce4d24ce7d364b0d33a78fd582a882911dc16e" alt="Matlab symbolic toolbox constant"
data:image/s3,"s3://crabby-images/ab8eb/ab8eba8f98c040f94f5ab7bbf549d2631d1b4d98" alt="matlab symbolic toolbox constant matlab symbolic toolbox constant"
data:image/s3,"s3://crabby-images/aa492/aa4929af497e3625ae715b733a34260faa9a5593" alt="matlab symbolic toolbox constant matlab symbolic toolbox constant"
The Symbolic work-around being to declare the variables as Symbolic Arrays to generate the individual elements of the arrays and allow for a one-to-one substitution: > w = sym('w',) While fully conforming dimensional substitutions will work just fine: > subs(f,) % All 3x3Īnd all of this derives from the Symbolic Variables themselves being treated as scalars. G = mupadmex('symobj::fullsubs',F.s,X2,Y2) New arrays must have the same dimensions or must be scalars. Even direct specification of the substitution with cell arrays throws the error: > wnum = However, when the new arrays being substituted do no match size in every dimension (as is the case here with the coefficient matrix being rectangular versus the column vector), a dimension mismatch will more than likely occur in the engine. So the expression undergoing substitution needs to play nice with element-wise application and expansion upon substitution. All constant terms in s are replaced with the constant times a vector or matrix of all 1s. If old is a scalar, and new is a vector or matrix, then subs(s,old,new) replaces all instances of old in s with new, performing all operations elementwise. The Symbolic Toolbox operates from the standpoint that Symbolic Variables are scalars and any operation or expression in which they are present uses element-wise semantics.
data:image/s3,"s3://crabby-images/71ce4/71ce4d24ce7d364b0d33a78fd582a882911dc16e" alt="Matlab symbolic toolbox constant"