M2 icon indicating copy to clipboard operation
M2 copied to clipboard

Bizarre crash involving local symbol and computing basis in parallel

Open mahrud opened this issue 1 year ago • 2 comments

I accidentally made a typo in a random piece of code I wrote, and I can't understand the ensuing crash. To replicate, put this in a file and run from "needs" until the end.

await = method(Dispatch => Thing)
await Thing := identity
await BasicList := L -> apply(L, await)
await Task := await @@ taskResult

async = method(Dispatch => Thing)
async Function := f -> (x -> schedule(f, x))

repeat = (n, R) -> (
    if n == 1 then return n;
    r := {repeat(n//2, R), repeat(n//2, R)};
    basis(10, ideal vars R);
    t) --                                <-- here is my typo!
repeat = async repeat

end--
restart
needs "parallel.m2"

R = ZZ/101[x_0..x_10]
elapsedTime await repeat(allowableThreads*2, R)

Note the typo I made, the t should have been an r. Here is what I got on a 1.24.05 binary:

i1 : needs "parallel.m2"

i2 : 
     R = ZZ/101[x_0..x_10]

o2 = R

o2 : PolynomialRing

i3 : elapsedTime await repeat(allowableThreads*2, R)
 -- 0.38629 seconds elapsed

o3 = t

o3 : Symbol

i4 : /home/linuxbrew/.linuxbrew/share/Macaulay2/Core/expressions.m2:675:47:(1):[21]: error: unknown engine error
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/expressions.m2:675:47:(1):[21]: error: unknown engine error
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/expressions.m2:675:47:(1):[21]: error: unknown engine error
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:262:10:(1):[19]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:262:10:(1):[19]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:262:10:(1):[19]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:625:51:(1):[18]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:625:51:(1):[18]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:625:51:(1):[18]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:639:23:(1):[17]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:639:23:(1):[17]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:639:23:(1):[17]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:638:26:(1):[16]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:638:26:(1):[16]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:638:26:(1):[16]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[15]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[15]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[14]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[15]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[14]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[13]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[14]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:631:83:(1):[12]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[13]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[13]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[11]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:631:83:(1):[12]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:631:83:(1):[12]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[10]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[11]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[11]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[10]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[9]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[10]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:226:10:(1):[8]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[9]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:40:8:(1):[9]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:144:73:(1):[7]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:226:10:(1):[8]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:226:10:(1):[8]: --back trace--/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:144:73:(1):[7]: --back trace--

/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[6]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[6]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:144:73:(1):[7]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:17:8:(1):[5]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:17:8:(1):[5]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[6]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:149:72:(1):[4]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:149:72:(1):[4]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[3]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:17:8:(1):[5]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[3]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:17:8:(1):[2]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/basis.m2:149:72:(1):[4]: --back trace--
parallel.m2:12:5:(3):[1]: --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:17:8:(1):[2]: --back trace--
parallel.m2:10:28:(3): --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/methods.m2:154:80:(1):[3]: --back trace--
parallel.m2:12:5:(3):[1]: --back trace--
parallel.m2:10:28:(3): --back trace--
/home/linuxbrew/.linuxbrew/share/Macaulay2/Core/option.m2:17:8:(1):[2]: --back trace--
parallel.m2:12:5:(3):[1]: --back trace--
parallel.m2:10:28:(3): --back trace--

If I fix the t to r then I don't get this error. It also doesn't happen if the first input to repeat is at most a little above allowableThreads.

What on earth is happening?

mahrud avatar Aug 26 '24 19:08 mahrud

@d-torrance is there a way to retrieve all current active tasks, or a way to cancel everything still running?

mahrud avatar Sep 04 '24 12:09 mahrud

I don't believe so. That would be very nice to have!

d-torrance avatar Sep 04 '24 14:09 d-torrance

I was just playing around with this again and somehow the code went into an infinite loop with this warning:

      (t, r) = toSequence elapsedTiming await repeat(8, R)
GC_debug_free: found previously deallocated (?) object at 0x7f8a26171e80 in or near object at 0x7f8a26171e90(<smashed>, appr. sz= 137)

mahrud avatar Feb 09 '25 07:02 mahrud