sursumCorda

1264 Reputation

15 Badges

2 years, 326 days

MaplePrimes Activity


These are answers submitted by sursumCorda

I do not remember where the “De” came from, yet it does work: 

expr := y(3) + y(8) + 5*(D@@2)(y)(4) + Pi + 3*exp(2) + 77*D(y)(0) + 1/(D@@4)(y)(7):
indets(expr, And('De', constant));
           {D(y)(0), (D@@2)(y)(4), (D@@4)(y)(7)}

The restriction on the dependent variable is omitted here, but you may filter manually (or programmatically) later. 

Here is a quick approach: 

f := (p::posint, n::posint) -> upperbound(select(x -> {x[]} subset {0, 1, 4, 6, 8, 9}, `combstruct/allstructs/Partition/allpartk`(n, p, 0))):
f(3, 8);
 = 
                               3

@nm I find a workaround that does not rely upon the `series` operation:

PDETools:-Solve(
  subs(exp(t) = u, exp(I*t) = v, expand(convert(eq, exp))), 
  trial_solution_constants, 'independentof' = {t, u, v});
 = 
 /                           -7         1          -2         1  
{ A[1] = 0, A[2] = 0, A[3] = --, A[4] = --, A[5] = --, A[6] = -, 
 \                           25         25         5          5  

         3                               3\ 
  A[7] = --, A[8] = 0, A[9] = 0, A[10] = - }
         16                              8/ 


You can type “a%\/b” in 2-D math. 

I stumbled upon the following (hacky) workaround: 

patmatch(ToInert(S[a], 'include' = {'_Inert_TABLEREF'}), 
 ToInert(S['b'::name], 'include' = {'_Inert_TABLEREF'}), 'la');
 = 
                              true

la;
 = 
                            [b = a]

However, a better approach is to use `typematch`: 

typematch(S[a], S['b'::name], 'la');
 = 
                              true

la;
 = 
                            [b = a]

The advantage of using typematch is that typematch(S[a1, a2], specindex('b'::name, S), 'la'); also works, while patmatch(…S[a1, a2]…, …S['b'::seq(name)]…, 'la'); is not supported (at least for now). 

I think that this is because, for an non-atomic expression expr, “select(func, expr, …)” is treated as “(op(0, expr)@op)(select(func, [op](expr), …))”. 

There should be a space character before the dollar character: 

`~`[`*`](k, ` $`, A);
 = 
                              k A

For details, see space-dollarsign

> V := Vector[column](3, [0.5863730366, 0.1171249270, 0.2965020364]):
> LinearAlgebra:-DiagonalMatrix(V);
                                    [0.5863730366         0               0      ]
                                    [                                            ]
                                    [     0          0.1171249270         0      ]
                                    [                                            ]
                                    [     0               0          0.2965020364]

The following code also seems to work: 

restart;
L := [3, 4, x, x^2, x^3, sin(x), 1/x^4]:
eval(map(tablelook, L, compiletable([x**n::'nonunit'(anything) = n, x::anything = ''NULL''])));
 = 
                           [2, 3, -4]

eval(map(tablelook, L, compiletable([x**n::'nonunit'(anything) = n])), FAIL = NULL); # alternative
 = 
                           [2, 3, -4]

Note that despite the name “compiletable”, it has nothing to do with the code compilation.

In accordance with Maple's official documentation,

the regular expression accepted by StringTools is based on the POSIX 1003.2 standard for extended modern regular expressions.

However, according to this comparison chart, the POSIX ERE syntax supports neither lookaround nor conditionals. As a result, it is impossible to use lookaround assertions or conditional operators in StringTools:-RegSplit. A possible workaround is to use Python's re module with the help of the Maple Python package. (Incidentally, by today’s standard, the POSIX ERE flavor seems rather bare-bones.) 
Note 1. ERE is an acronym for the Extended Regular Expressions.
Note 2. Lookahead and lookbehind are collectively called “look-around”.

Although neither succinct nor elegant, the following approach appears closer to using pattern matching

L := combinat:-permute([1, 2, 3, 4]):
`?()`~(
  overload([setattribute(
     eval((a::seq(Non(2)), b::2, 
        c::seq(Non(3)), d::3) -> [a, b, c, d, 
        _rest]), 'overload(callseq_only)'), 
     () -> NULL]), L);
 = 
   [[1, 2, 3, 4], [1, 2, 4, 3], [1, 4, 2, 3], [2, 1, 3, 4], 

     [2, 1, 4, 3], [2, 3, 1, 4], [2, 3, 4, 1], [2, 4, 1, 3], 

     [2, 4, 3, 1], [4, 1, 2, 3], [4, 2, 1, 3], [4, 2, 3, 1]]


I think it impossible to use patmatch (as well as other pattern-based functions like applyrule, define, and tablelook) since there is no exprseq type (even if an expression sequence is of type sequential) in Maple and accordingly the Maple pattern matcher cannot handle variable numbers of expressions (and it does not allow pattern objects in which particular forms repeated arbitrary times either…). 

Another opinion is to use Statistics:-Tally

convert~(Statistics:-Tally(L), list);
 = 
       

If you just want future input to be in document mode by default (so existing cells remain unchanged), you can simply open the file in a text editor (like Notepad) and change the fifth line and the sixth line from 

<View-Properties presentation="false" autoexpanding_sections="true" UserProfileName="Maple Default Profile" NumericFormat-ApplyInteger="true" NumericFormat-ApplyRational="true" NumericFormat-ApplyExponent="false" editable="true">
</View-Properties>

 to 

<View-Properties presentation="true" autoexpanding_sections="true" UserProfileName="Maple Default Profile" NumericFormat-ApplyInteger="true" NumericFormat-ApplyRational="true" NumericFormat-ApplyExponent="false" editable="true">
</View-Properties> 

Besides, the remaining options may be deleted, then Maple will use the default settings for this file. As an example, you can also change them to: 

<View-Properties presentation="true"></View-Properties> 

By the way, to further convert existing content from worksheet mode into document mode, one has to manually edit some other code. For instance, the following text 

<Group labelreference="L1" drawlabel="true" applyint="true" applyrational="true" applyexponent="false">
    ……something omitted……
</Group>

should be converted into 

<Presentation-Block>
<Group view="presentation" inline-output="false" labelreference="L1" drawlabel="true" applyint="true" applyrational="true" applyexponent="false"><!--Attributes “hide-input”, “hide-output”, “inline-output”, “redirect-target”, etc. all appear optional. -->
    ……something omitted……
</Group></Presentation-Block> 

Note that these are undocumented, so there is no guarantee that they will always work …. 
However, it is relatively easy to convert an existing document in document mode to worksheet mode in Maple: just save it in the Maple Classic Worksheet (.mws) format. 

Here is a somewhat inefficient approach: 

e1 := a/sqrt(tan(x+c__1)^2+1):
(_ -> simplify(ifelse(type(_, atomic), _, map(thisproc, _)), trig))(e1);
 = 
                     

But the advantage is that there is no need to understand the structure of the expression beforehand.

There exist at least two approaches, 

e1 := a/sqrt(tan(x + c__1)**2 + 1):
convert(e1, exp, 'simplifier' = rcurry(simplify, trig, exp)@normal, 'evaluate');
 = 
                     convert(simplify(convert(a/sqrt(tan(x + c__1)^2 + 1), 'sincos'), sqrt, constant), 'sectan')

simplify(simplify(convert(e1, 'sincos'), constant, sqrt), trig);
 = 
                     convert(convert(a/sqrt(tan(x + c__1)^2 + 1), exp, 'simplifier' = evala@rcurry(simplify, trig, exp)@normal), sec)

even though neither of them looks elegant …. (By the way, I believe it should be a BUG that the output of simplify(e1, trig); remains unchanged.) 

1 2 3 4 5 6 Page 1 of 6