File: psm.c

package info (click to toggle)
symmetrica 2.0-1
  • links: PTS
  • area: main
  • in suites: lenny, squeeze, wheezy
  • size: 3,892 kB
  • ctags: 4,938
  • sloc: ansic: 97,272; makefile: 8
file content (71 lines) | stat: -rw-r--r-- 1,548 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#include "def.h"
#include "macro.h"

INT psm_ende()
{
    return OK;
}

INT psm___(a,b,c,f) OP a,b,c,f;
{
    INT erg = OK;
    CTTTTO(HASHTABLE,INTEGER,PARTITION,SCHUR,"psm___(1)",a);
    CTTTTO(INTEGER,HASHTABLE,PARTITION,MONOMIAL,"psm___(2)",b);
    CTTO(HASHTABLE,MONOMIAL,"psm___(3)",c);

    NYI("psm___");
    ENDR("psm___");
}


INT tsp___faktor();
INT ppm___();

INT plet_schur_monomial(a,b,c) OP a,b,c;
/* AK 111201
*/
{
    INT t=0,erg = OK;
    CTTTTO(HASHTABLE,INTEGER,PARTITION,SCHUR,"plet_schur_monomial(1)",a);
    CTTTTO(INTEGER,HASHTABLE,PARTITION,MONOMIAL,"plet_schur_monomial(2)",b);
    CTTTO(EMPTY,HASHTABLE,MONOMIAL,"plet_schur_monomial(3)",c);
 
    if (S_O_K(c) == EMPTY)
         { t=1; init_hashtable(c); }

    {
    /* via ppm with change of basis */
    OP f = CALLOCOBJECT();
    erg += init_hashtable(f);
    erg += tsp___faktor(a,f,cons_eins);


    CTO(HASHTABLE,"plet_schur_monomial(i1)",f);
    erg += ppm___(f,b,c,cons_eins);
    FREEALL(f);
    }

    if (t==1) t_HASHTABLE_MONOMIAL(c,c);
    ENDR("plet_schur_monomial");
}

INT plet_schur_monomial_new(a,b,c) OP a,b,c;
/* AK 111201
*/
{
    INT t=0,erg = OK;
    CTTTTO(HASHTABLE,INTEGER,PARTITION,SCHUR,"plet_schur_monomial(1)",a);
    CTTTTO(INTEGER,HASHTABLE,PARTITION,MONOMIAL,"plet_schur_monomial(2)",b);
    CTTTO(EMPTY,HASHTABLE,MONOMIAL,"plet_schur_monomial(3)",c);
 
    if (S_O_K(c) == EMPTY)
         { t=1; init_hashtable(c); }
 
    erg += psm___(a,b,c,cons_eins);
 
    if (t==1) t_HASHTABLE_MONOMIAL(c,c);
    ENDR("plet_schur_monomial");
}