Carl Love

Carl Love

28055 Reputation

25 Badges

13 years, 16 days
Himself
Wayland, Massachusetts, United States
My name was formerly Carl Devore.

MaplePrimes Activity


These are replies submitted by Carl Love

I think that this is a clue to what's happening: There are numerous solutions that are exact duplicates.

invsol:= solve(sol=x+b, y):
nops([invsol]);

                               
16
nops({invsol});
                               
2

@charlie_fcl Are there really any problems? Or do you just get that warning message? A warning is not an error, and it may be innocuous.

@janhardo I don't know the exact relationship between the value of kernelopts(level) and the value that printlevel needs to set to to print at the corresponding level. It would require some experimentation.

@Mathrookie94 @acer Is it possible that the output is being affected by interface(displayprecision) set in an initialization file?

You can check by giving the command

interface(displayprecision)

from a command line. The response should be -1 if it hasn't been altered.

@lcz Note the need for nolist pointed out by @dharr . My Answer should be corrected to

op~(
    1,
    {entries}(
        ListTools:-Classify(
            g-> [seq](op(4, GraphTheory:-CanonicalGraph(g))), graph_list
        ),
        'nolist'
    )
)

 

@dharr Sorry that I forgot the nolist; I often do. I wish it were the default! I will correct my Answer.

And I retract my claim that the help page is incorrect.

And a Vote Up for @dharr!

@dharr Thank you for that example. My procedure for the canonical representative was based on the following paragraph from help page ?CanonicalGraph plus the somewhat obvious fact that there's a bijective correspondence between adjacency matrices and op(4, ...):

  • Owing to graph symmetries, it is possible that CanonicalGraph may return distinct vertex orderings when invoked on two graphs G and H with identical vertex sets and edge sets. The representation is nevertheless canonical in the sense that if G and H are isomorphic, AdjacencyMatrix(CanonicalGraph(G))=AdjacencyMatrix(CanonicalGraph(H)).

Your example shows that this statement is wrong.
 

@dharr When there is a (reasonable) procedure to find a canonical equivalence-class representative, it is far more effcient to use ListTools:-Classify than to use ListTools:-Categorize. The former is O(n) and the latter is O(n^2), where is the number of items being classified,

@lcz To just get the non-isomorphic graphs, use

op~(
    1,
    ({entries}@ListTools:-Classify)(
        g-> [seq](op(4, GraphTheory:-CanonicalGraph(g))), graph_list
    )
)

Although this generates the equivalence classes and then discards all but the first element of each, it is far, far more efficient than your loop. This method is O(n) and the loop is O(n^2), where n = nops(graph_list).

If is a Graph, then V:= op(4,G) is a compact (and far more efficient) representation of G's adjacency matrix A. Specifically, 

  • A = Matrix(numelems(V)$2, (i,j)-> `if`(j in V[i], 1, 0))

Let me know if you understand this.

This vector---which I call the neighbor array---is already computed and stored in every Graph object, whereas adjaceny matrices are generated as needed.

 

 

@Hullzie16 The two-variable-function approach can achieve something much closer to what the OP wants by separating the two variables like this:

F:= a-> x-> a*x:
f:= F(3);

                      
f := x -> 3*x

To use a shooting method in this case, you need known values at the right boundary (x=100), which you try to achieve by guessing initial conditions (D@@2)(f)(0), D(phi)(0), and D(theta)(0). You seem to be guessing values for x=100 rather than x=0.

Also, the differential order of this system is 7, so you need three guesses, not 4.

This Reply is not an attempt to correct the numerous other errors you've made. I just need to know 3 actual values at x=100 or x=infinity to proceed.

Just guessing here: Is it possible that your phone version is licensed and your iPad version is a free download?

@C_R Please let me know whether the issue that you had with my plotting command has been resolved.

@C_R The only change that I made to the OP's code is that display command. For it to work, you need to use it within that original code:

restart;
with(geometry);
with(plots);
_EnvHorizomtalName = 'x';
_EnvVerticalName = 'y';
_local(D);
line(delta, y = 1/3*x - 2, [x, y]);
line(deltap, y = (-1)/4*x + 1, [x, y]);
line(D, y = 3*x - 5, [x, y]);
point(S, 3, 0);
omega := Pi/3;
intersection(P, delta, D);
intersection(Pp, deltap, D);
projection(H, S, delta);
projection(K, S, deltap);
projection(M, S, D);
circle(c1, [H, K, M], 'centername' = O1);
display(
    textplot(
       [
           [coordinates(S)[], "S"], [coordinates(P)[], "P"], [coordinates(H)[], "H"], 
           [coordinates(K)[], "K"], [coordinates(M)[], "M"]
       ], font = [times, bold, 16], align = [above, right]
    ), 
    draw([
        delta(color = blue), deltap(color = blue), D(color = red), c1(color = black),
        S(color = black, symbol = solidcircle, symbolsize = 16),
        P(color = black, symbol = solidcircle, symbolsize = 16)
    ]), 
    scaling = constrained, axes = none, view = [-15 .. 15, -15 .. 15]
);

 

@vv Thank you. Yes, I noticed those separation anomalies. My goal was only to translate the given formulas into concise Maple with altering them mathematically.

First 17 18 19 20 21 22 23 Last Page 19 of 709