This does help, thanks!  I have some questions though. Again I'm a
total computer programming novice so I don't understand the code you
have written.  How would I add the extra conditions to what you have
written?  I will be looking forward  to hearing about the multiset
partition support you are working on.  I understand the syntax for
adding assumptions but from what you have written I'm not sure what
variable (?) I would use in an assumption.
thanks
sonny

On Dec 14, 5:09 pm, "Mike Hansen" <mhan...@gmail.com> wrote:
> Hello,
>
> On Sun, Dec 14, 2008 at 4:04 PM, green351 <mmamashra...@gmail.com> wrote:
>
> > Hi,
> > This is my first time emailing with a question and my first time
> > trying to use Sage (I'm a complete programming dunce).  I'm trying to
> > do the following:
> > Given the tuple (p,q) in Z x Z and integer n I need to count the
> > number of integer-tuple solutions to the following
> > (p,q)=(a_1,b_1)+...+(a_n,b_n) subject to the following conditions
> > - (a_i,b_i) \neq (a_j,b_j) for i, j different
> > - a_i, b_i >= -1
> > - a_i+b_i > 0
>
> What you're trying to count is the number of multiset partitions.  I
> haven't written any code to do this in Sage, but I've been meaning
> too. So now is a good time to start :-)
>
> For an interesting reference on this is Knuth's Art of Computer
> Programming Volume 4, Fascicle 3 (b).  Using the formula found 
> inhttp://www.emis.de/journals/HOA/IJMMS/22/1213.pdf, we get the
> following bit of Sage code
>
> @cached_function
> def p(*n):
>     r = len(n)
>     s = sum(n)
>     if s == 0:
>         return 1
>     result = 0
>     for k in range(1, s+1):
>         for l in IntegerVectors(k, r, outer=n):
>             nml = tuple(a-b for a,b in zip(n,l))
>             g = gcd(l)
>             result += sigma(g)/g*sum(l)*p(*nml)
>     return result / s
>
> You call it just like p(a,b).  We can duplicate Table A-1 in the Knuth 
> fascicle:
>
> sage: [ [p(i,j) for j in range(7)] for i in range(6)]
>
> [[1, 1, 2, 3, 5, 7, 11],
>  [1, 2, 4, 7, 12, 19, 30],
>  [2, 4, 9, 16, 29, 47, 77],
>  [3, 7, 16, 31, 57, 97, 162],
>  [5, 12, 29, 57, 109, 189, 323],
>  [7, 19, 47, 97, 189, 339, 589]]
>
> We can also get the specific values cited in the paper with the formula:
>
> sage: p(10,5)
> 3804
> sage: p(9,8)
> 13715
> sage: p(10,8)
> 21893
> sage: p(4,1,1)
> 38
>
> We can also use this to count the number of distinct factorizations of
> an integer.  For example, we can write 12 as 12*1, 6*2, 4*3, or 3*2*2.
>
> sage: p(*[exponent for prime,exponent in factor(12)])
> 4
>
> I'll try to add native support for multiset partitions here into Sage
> in the near future.
>
> Hope that helps,
>
> --Mike
--~--~---------~--~----~------------~-------~--~----~
To post to this group, send email to sage-support@googlegroups.com
To unsubscribe from this group, send email to 
sage-support-unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/sage-support
URLs: http://www.sagemath.org
-~----------~----~----~----~------~----~------~--~---

Reply via email to