Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

HomologicalShiftIdeals - A Macaulay2 package for computing the homological shift ideals of a monomial ideal of a polynomial ring #3474

Open
wants to merge 21 commits into
base: development
Choose a base branch
from

Conversation

Antonino-Ficarra
Copy link

@Antonino-Ficarra Antonino-Ficarra commented Sep 12, 2024

A Macaulay2 package for computing the homological shift ideals of a monomial ideal of a polynomial ring

@d-torrance d-torrance changed the base branch from master to development September 12, 2024 10:33
@d-torrance
Copy link
Member

Thanks for your contribution!

Both new package files should have the .m2 file extension.

@Antonino-Ficarra
Copy link
Author

Thanks for your contribution!

Both new package files should have the .m2 file extension.

Ok, sorry. I added the ".m2" extension.

Copy link
Author

@Antonino-Ficarra Antonino-Ficarra left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I forgot a semicolon

Copy link
Author

@Antonino-Ficarra Antonino-Ficarra left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I forgot some semicolons

@d-torrance
Copy link
Member

Those semicolons don't really matter. The only time when you definitely need semicolons is when a function body contains multiple statements:

f = x -> (
  statement1;
  statement2;
  statement3;
  statement4)

The other time is when you want to suppress the output when interacting directly with Macaulay2.

L=append(L,mdeg);
);
R:=newRing(S,Degrees=>L);
f:=map(R,S);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is the same map that was constructed for toMultidegree, but you're applying it to an ideal instead of a ring element. Perhaps you could extract this code into a helper function that both methods could call? (DRY principle when programming -- don't repeat yourself!)

Copy link
Author

@Antonino-Ficarra Antonino-Ficarra left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed a small error

@d-torrance
Copy link
Member

There was a conflict with =distributed-packages since another package was recently added, so I fixed that and force-pushed. I also added MatchingPowers to that file since it was missing.

@d-torrance
Copy link
Member

There are still a number of examples that are producing errors:

-- -*- M2-comint -*- hash: 2495905948357533320

i1 : S = QQ[x_1..x_4];

i2 : I = ideal(x_1*x_2,x_3^2,x_4^2);

o2 : Ideal of S

i3 : matchingPower(I,2)
stdio:3:13:(3): error: expected ideals for the same ring
-- -*- M2-comint -*- hash: 11433797791073189326

i1 : S = QQ[x_1..x_4];

i2 : I = ideal(x_1*x_2,x_3^2,x_4^2);

o2 : Ideal of S

i3 : J = ideal(x_1*x_3,x_2);

o3 : Ideal of S

i4 : matchingProduct(I,J)
stdio:4:15:(3): error: expected ideals for the same ring
-- -*- M2-comint -*- hash: 4326397003292871051

i1 : S = QQ[x_1..x_4];

i2 : I = ideal(x_1*x_2,x_3^2,x_4^2);

o2 : Ideal of S

i3 : monomialGrade I
stdio:3:13:(3): error: expected ideals for the same ring
-- -*- M2-comint -*- hash: 4326397004548556957

i1 : S = QQ[x_1..x_4];

i2 : I = ideal(x_1*x_2,x_3^2,x_4^2);

o2 : Ideal of S

i3 : gFunction I
stdio:3:9:(3): error: expected ideals for the same ring
-- -*- M2-comint -*- hash: 4025997899046634755

i1 : S = QQ[x_1..x_5];

i2 : I = ideal(x_1,x_2,x_3,x_4)*ideal(x_3,x_4,x_5);

o2 : Ideal of S

i3 : admissibleOrder I

                   2                     2
o3 = {x x , x x , x , x x , x x , x x , x , x x , x x , x x , x x }
       1 3   2 3   3   1 4   2 4   3 4   4   1 5   2 5   3 5   4 5

o3 : List

i4 : S = QQ[x,y];

i5 : I = ideal(x^2,y^2);

o5 : Ideal of S

i6 : admissibleOrder I
stdio:6:15:(3): error: the ideal does not have linear quotients

@d-torrance
Copy link
Member

@Antonino-Ficarra: Have you had a chance to look at the examples that are failing?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants