#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define t 5
/* Defining the node structure */
struct nodes
{
double m; // metric//
int s, l; // symbol and level //
struct nodes * ptI, * ptI_plus1, * ptI_minus1;
} ;
typedef struct nodes* node;
node create_node ( int symbol, double weight, int level) {
node temp
= ( node
) malloc ( sizeof ( struct nodes
) ) ; if ( temp == NULL) {
} else {
temp-> s= symbol;
temp-> m= weight;
temp-> l= level;
temp-> ptI = NULL;
temp-> ptI_plus1 = NULL;
temp-> ptI_minus1 = NULL;
/*while (prev->next != NULL) {
prev = prev->next;
}*/
}
return temp;
}
node add_node_i( node hd, int symbol, double weight, int level) {
node temp;
level= level+ 1 ;
temp = create_node( symbol, weight, level) ;
hd-> ptI = temp;
return temp;
}
node add_node_i_plus1( node hd, int symbol, double weight, int level) {
node temp;
level= level+ 1 ;
temp = create_node( symbol, weight, level) ;
hd-> ptI_plus1 = temp;
return temp;
}
node add_node_i_minus1( node hd, int symbol, double weight, int level) {
node temp;
level= level+ 1 ;
temp = create_node( symbol, weight, level) ;
hd-> ptI_minus1 = temp;
return temp;
}
/* Defining the stack structure */
struct stack_node
{
int e;
struct stack_node* nxt;
} ;
typedef struct stack_node* st_nd;
// Initializing the stack
void init_st( st_nd stack_head)
{
printf ( "el co de su madre\n " ) ;
stack_head = NULL;
}
// Entering the elements into stack
st_nd push_st( st_nd stack_head, int data) {
st_nd tmp
= ( st_nd
) malloc ( sizeof ( struct stack_node
) ) ;
if ( tmp
== NULL
) { exit ( 0 ) ; }
tmp-> e= data;
tmp-> nxt = stack_head;
printf ( "tmp->nxt = stack_head %d\n " ,& stack_head
-> e
) ; stack_head = tmp;
printf ( " stack_head=temp %d\n " ,& stack_head
-> e
) ; return stack_head;
}
//Deleting an element from the stack.
st_nd pop_st( st_nd stack_head, int * elemento)
{
st_nd tmp = stack_head;
* elemento = stack_head-> e;
stack_head = stack_head-> nxt;
return stack_head;
}
void display( st_nd stack_head)
{
st_nd current;
current = stack_head;
if ( current!= NULL)
{
do
{
printf ( " TOPE DEL STACK symbol:%d \n " , current
-> e
) ; current = current-> nxt;
}
while ( current!= NULL) ;
}
else
{
printf ( "The Stack is empty\n " ) ; }
}
//sort elements of the stack
void sort_stack( st_nd stack_head, node node1, node node2, node node3) {
//printf("oaaaaaaaaaaaaaaa\n");
if ( node1-> m <= node2-> m && node1-> m <= node3-> m) {
if ( node2-> m <= node3-> m) {
push_st( stack_head, node3-> s) ;
//printf ("simbolotope: %d\n",stack_head->e);
push_st( stack_head, node2-> s) ;
//printf ("simbolotope: %d\n",stack_head->e);
push_st( stack_head, node1-> s) ;
//printf("oaaaaaaaaaaaaaaa\n");
//printf ("simbolotope: %d\n",stack_head->e);
}
else
{ push_st( stack_head, node2-> s) ;
push_st( stack_head, node3-> s) ;
push_st( stack_head, node1-> s) ;
}
}
else if ( node2-> m < node1-> m && node2-> m <= node3-> m) {
if ( node1-> m <= node3-> m) {
push_st( stack_head, node3-> s) ;
push_st( stack_head, node1-> s) ;
push_st( stack_head, node2-> s) ;
}
else {
push_st( stack_head, node1-> s) ;
push_st( stack_head, node3-> s) ;
push_st( stack_head, node2-> s) ;
}
}
else {
if ( node1-> m <= node2-> m) {
push_st( stack_head, node2-> s) ;
push_st( stack_head, node1-> s) ;
push_st( stack_head, node3-> s) ;
//printf ("simbolotope: %d\n",&stack_head->e);
} else {
push_st( stack_head, node1-> s) ;
push_st( stack_head, node2-> s) ;
push_st( stack_head, node3-> s) ;
//printf ("simbolotope: %d\n",&stack_head->e);
}
}
// printf ("simbolotope: %d\n",&stack_head->e);
}
double min_distance( double a, double b, double c) {
double dmin;
if ( a <= b && a <= c) {
dmin= a;
}
else if ( b < a && b <= c) {
dmin= b;
}
else {
dmin= c;
}
return dmin;
}
/*int symbol_min_dist(node node1, node node2, node node3){
int smin;
if(node1->m < node2->m && node1->m < node3->m){
smin=node1->s;
}
else if(node2->m < node1->m && node2->m < node3->m){
smin=node2->s;
}
else{
smin=node3->s;
}
return smin;
}
*/
node head_node( node node1, node node2, node node3) {
node temp;
temp
= ( node
) malloc ( sizeof ( struct nodes
) ) ; if ( temp == NULL) {
}
else {
if ( node1-> m <= node2-> m && node1-> m <= node3-> m) {
temp= node1;
}
else if ( node2-> m < node1-> m && node2-> m <= node3-> m) {
temp= node2;
}
else {
temp= node3;
}
printf ( "New head: m = %lf, s = %d, l = %d\n " , temp
-> m
, temp
-> s
, temp
-> l
) ; return temp;
}
}
int in( double u1, int cmin, int cmax) {
int u0;
u0= rint( u1) ;
if ( u0> cmax)
return cmax;
else
{ if ( u0< cmin)
return cmin;
else
return u0;
}
}
void display_tree ( node head) {
if ( head != NULL)
{
printf ( "m = %lf, s = %d, l = %d\n " , head
-> m
, head
-> s
, head
-> l
) ; display_tree( head-> ptI) ;
display_tree( head-> ptI_plus1) ;
display_tree( head-> ptI_minus1) ;
}
}
//Zig Zag decoder algorithm
void ZZ( double * y, double R[ t] [ t] , int lg, int col, int tr, int k, int * sf) {
//local variables
int i, j;
tr= tr- 1 ; //Matrix index
node root, node1, node2, node3, head;
st_nd st_hd;
double s[ tr] ;
int si[ tr] , si_plus1[ tr] , si_minus1[ tr] ;
double weighti[ tr] , weighti_plus1[ tr] , weighti_minus1[ tr] ;
double aux, d= 0 ;
/*definition cmin and cmax*/
double cmin= 0 , cmax;
switch ( k) {
case 2 :
cmax= 1 ;
break ;
case 3 :
cmax= 3 ;
break ;
case 4 :
cmax= 3 ;
break ;
case 6 :
cmax= 7 ;
break ;
case 8 :
cmax= 15 ;
break ;
default :
}
/* root node and initializing stack */
root = create_node ( 0 , 0 , 0 ) ;
head = root;
init_st( st_hd) ;
printf ( "Root head: m = %lf, s = %d, l = %d\n \n " , head
-> m
, head
-> s
, head
-> l
) ;
//Initializing the cycle
for ( i = tr; i >= 0 ; i-- ) {
int level= i+ 1 ;
printf ( "Level = %d \n " , level
) ; aux= 0 ;
for ( j= i+ 1 ; j<= tr; j++ ) {
printf ( "R[%i][%i] = %lf s[%i] = %lf\n " , i
, j
, R
[ i
] [ j
] , j
, s
[ j
] ) ; aux= R[ i] [ j] * s[ j] + aux;
}
//Calculation of the symbols for each level Si, Si+1 and Si-1
s[ i] = ( y[ i] - aux) / R[ i] [ i] ;
si[ i] = in( s[ i] , cmin, cmax) ;
si_plus1[ i] = si[ i] + 1 ;
si_minus1[ i] = si[ i] - 1 ;
printf ( "s[%d] = %lf, si[%d] = %d, si_plus1[%d] = %d, si_minus1[%d] = %d\n " , i
, s
[ i
] , i
, si
[ i
] , i
, si_plus1
[ i
] , i
, si_minus1
[ i
] ) ;
//Calculation of the accumulated weights for each level Si, Si+1 and Si-1
weighti
[ i
] = fabs ( y
[ i
] - ( R
[ i
] [ i
] * si
[ i
] + aux
) ) + d
; weighti_plus1
[ i
] = fabs ( y
[ i
] - ( R
[ i
] [ i
] * si_plus1
[ i
] + aux
) ) + d
; weighti_minus1
[ i
] = fabs ( y
[ i
] - ( R
[ i
] [ i
] * si_minus1
[ i
] + aux
) ) + d
;
printf ( "wi[%d] = %lf, wi_plus1[%d] = %lf, wi_minus[%d] = %lf\n " , i
, weighti
[ i
] , i
, weighti_plus1
[ i
] , i
, weighti_minus1
[ i
] ) ; //Mimimum weight
d= min_distance( weighti[ i] , weighti_plus1[ i] , weighti_minus1[ i] ) ;
//Adding nodes to the tree
node1= add_node_i ( head, si[ i] , weighti[ i] , i) ;
node2= add_node_i_plus1 ( head, si_plus1[ i] , weighti_plus1[ i] , i) ;
node3= add_node_i_minus1 ( head, si_minus1[ i] , weighti_minus1[ i] , i) ;
printf ( "Node 1: m = %lf, s = %d, l = %d\n " , node1
-> m
, node1
-> s
, node1
-> l
) ; printf ( "Node 2: m = %lf, s = %d, l = %d\n " , node2
-> m
, node2
-> s
, node2
-> l
) ; printf ( "Node 3: m = %lf, s = %d, l = %d\n " , node3
-> m
, node3
-> s
, node3
-> l
) ;
display_tree( root) ;
//push_st(st_hd,node3);
//display(st_hd);
sort_stack( st_hd, node1, node2, node3) ;
head= head_node( node1, node2, node3) ;
sf[ i] = head-> s;
// if(i>0) {pop_st(st_hd,&head);}
}
}
int main ( ) {
int l= 5 , a= 5 , k= 6 , h= t, symbol;
int pt[ t] , i;
double r[ t] [ t] = { { 0.15 , 0.9 , 0.25 , 0.25 , 0.3 } , { 0 , 0.25 , 0.125 , 0.75 , 0.21 } , { 0 , 0 , 0.2 , 0.5 , 0.4 } , { 0 , 0 , 0 , 0.2 , 0.88 } , { 0 , 0 , 0 , 0 , 0.7 } } ;
double y[ t] = { 0.8 , 0.7 , 0.9 , 0.1 , 0.2 } ;
ZZ( y, r, l, a, h, k, pt) ;
for ( i = t- 1 ; i >= 0 ; i-- ) {
symbol= i+ 1 ;
printf ( "simbolo %d=%d\n " , symbol
, pt
[ i
] ) ; }
return 0 ;
}
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#define t 5

/* Defining the node structure */

    struct nodes
    {
        double m; // metric//
        int s,l;  // symbol and level  //       
        struct nodes *ptI, *ptI_plus1, *ptI_minus1;
    };

typedef struct nodes* node;

node create_node (int symbol, double weight, int level){

  node temp = (node) malloc(sizeof(struct nodes));
    if (temp == NULL) {
      exit(0);
    } else {
      temp->s=symbol;
      temp->m=weight;
      temp->l=level;
      temp->ptI = NULL;
      temp->ptI_plus1 = NULL;
      temp->ptI_minus1 = NULL;
      
      /*while (prev->next != NULL) {
    prev = prev->next;
        }*/
    }
    return temp;
}

node add_node_i( node hd, int symbol, double weight, int level) {
 
    node temp;
    level=level+1;
    temp = create_node(symbol, weight, level);
    
    hd->ptI = temp;
    
    return temp; 
}

node add_node_i_plus1( node hd, int symbol, double weight, int level) {
    node temp;
    level=level+1;
    temp = create_node(symbol, weight, level);

    hd->ptI_plus1 = temp;
    
    return temp; 
}

node add_node_i_minus1( node hd, int symbol, double weight, int level) {
    node temp;
    level=level+1;
    temp = create_node(symbol, weight, level);

    hd->ptI_minus1 = temp;
    
    return temp; 
}


/* Defining the stack structure */

struct stack_node
{
    int e;
    struct stack_node* nxt;
};

typedef struct stack_node* st_nd;


// Initializing the stack
void init_st(st_nd stack_head)
{
    printf("el co de su madre\n");

    stack_head = NULL;
}

// Entering the elements into stack

st_nd push_st(st_nd stack_head,int data){
  
  st_nd tmp = (st_nd)malloc(sizeof(struct stack_node));
 
  if(tmp == NULL) {exit(0);}
  
  tmp->e=data;
  printf("%d\n",tmp->e);
  tmp->nxt = stack_head;

  printf("tmp->nxt = stack_head %d\n",&stack_head->e);
  stack_head = tmp;   
  printf(" stack_head=temp %d\n",&stack_head->e);
  return stack_head;
}

//Deleting an element from the stack.

st_nd pop_st(st_nd stack_head,int *elemento)
{
    st_nd tmp = stack_head;
    *elemento = stack_head->e;
    stack_head = stack_head->nxt;
    free(tmp);
    return stack_head;
}

void display(st_nd stack_head)
{
    st_nd current;
    
    current = stack_head;
    if(current!= NULL)
    {
        printf("Stack: ");
        do
        {
            printf(" TOPE DEL STACK  symbol:%d  \n",current->e);
            current = current->nxt;
        }
        while (current!= NULL);
        printf("\n");
    }
    else
    {
        printf("The Stack is empty\n");
    }
 
}  

 

//sort elements of the stack

void sort_stack(st_nd stack_head, node node1, node node2, node node3){

   //printf("oaaaaaaaaaaaaaaa\n");  
    
    if(node1->m <= node2->m && node1->m <= node3->m){
        
          if(node2->m <= node3->m){
          push_st(stack_head,node3->s);
          //printf ("simbolotope: %d\n",stack_head->e);
          push_st(stack_head,node2->s);
          //printf ("simbolotope: %d\n",stack_head->e);
          push_st(stack_head,node1->s);
          printf ("up to down 123\n");
          //printf("oaaaaaaaaaaaaaaa\n");
          //printf ("simbolotope: %d\n",stack_head->e);
            }
        else
          {push_st(stack_head,node2->s);
          push_st(stack_head,node3->s);
          push_st(stack_head,node1->s);
          printf ("up to down 132\n");
            }
    }
    else if(node2->m < node1->m && node2->m <= node3->m){
       
          if(node1->m <= node3->m){
          push_st(stack_head,node3->s);
          push_st(stack_head,node1->s);
          push_st(stack_head,node2->s);
          printf ("up to down 213\n");
          }
          else{
          push_st(stack_head,node1->s);
          push_st(stack_head,node3->s);
          push_st(stack_head,node2->s);
          printf ("up to down 231\n");
          }   
    }
    else{     
          if(node1->m <= node2->m){
          push_st(stack_head,node2->s);
          push_st(stack_head,node1->s);
          push_st(stack_head,node3->s);
          printf ("up to down 312\n");
          printf("oaaaaaaaaaaaaaaa\n");
          //printf ("simbolotope: %d\n",&stack_head->e);
          }else{
          push_st(stack_head,node1->s);
          push_st(stack_head,node2->s);
          push_st(stack_head,node3->s);
          printf ("up to down 321\n");
          printf("oaaaaaaaaaaaaaaa\n");
          //printf ("simbolotope: %d\n",&stack_head->e);
    } 
  
  }
  
 // printf ("simbolotope: %d\n",&stack_head->e);
  
}


double min_distance(double a, double b, double c){
  double dmin;
  if(a <= b && a <= c){
    dmin=a;
  }
  else if(b < a && b <= c){
    dmin=b;
  }
  else{
    dmin=c;
  }
  return dmin;
}

/*int symbol_min_dist(node node1, node node2, node node3){
  int smin;

  if(node1->m < node2->m && node1->m < node3->m){
    smin=node1->s;
  }
  else if(node2->m < node1->m && node2->m < node3->m){
    smin=node2->s;
  }
  else{
    smin=node3->s;
  }
  
  return smin;
}
 */ 

node head_node(node node1,node node2,node node3){
  node temp;
  temp = (node) malloc(sizeof(struct nodes));
  if (temp == NULL) {
      exit(0);
    } 
    else {
    if(node1->m <= node2->m && node1->m <= node3->m){
    temp=node1;
    }
    else if(node2->m < node1->m && node2->m <= node3->m){
    temp=node2;
    }
    else{
    temp=node3;
    }
  
  printf("New head: m = %lf, s = %d, l = %d\n",temp->m, temp->s, temp->l);
  return temp;
}
}

int in(double u1,int cmin,int cmax){ 
  int u0;
  u0=rint(u1);
  if (u0>cmax)
     return cmax;
  else
      {if(u0<cmin)
           return cmin;
       else
           return u0;
      }
}

void display_tree (node head){ 
      if (head != NULL)
    { 
      printf("m = %lf, s = %d, l = %d\n", head->m, head->s,head->l);
      display_tree(head->ptI);
      display_tree(head->ptI_plus1);
      display_tree(head->ptI_minus1);
    } 
}

//Zig Zag decoder algorithm
void  ZZ(double *y,double R[t][t],int lg,int col, int tr, int k, int* sf){

//local variables  
  int i,j; 
  tr=tr-1;   //Matrix index
  node root,node1,node2,node3,head;
  st_nd st_hd;
  double s[tr];
  int si[tr],si_plus1[tr],si_minus1[tr];
  double weighti[tr],weighti_plus1[tr],weighti_minus1[tr];
  double aux,d=0;

     
   /*definition cmin and cmax*/
    double cmin=0,cmax;
    switch (k){
      case 2:
        cmax=1;
      break;
      case 3:
        cmax=3;
      break;
      case 4:
        cmax=3;
      break;
      case 6:
        cmax=7;
      break;
      case 8:
        cmax=15;
      break;
      default:
      printf("incorrect k\n");
    }
  
  
  /* root node and initializing stack */
  root = create_node (0,0,0);
  head = root;
  init_st(st_hd);
  printf("Root head: m = %lf, s = %d, l = %d\n\n",head->m, head->s, head->l);

//Initializing the cycle
  for(i = tr;i >=0 ;i--){
    int level=i+1;
    printf("Level = %d \n",level);   
    aux=0;

      for(j=i+1;j<=tr;j++){
        printf("R[%i][%i] = %lf  s[%i] = %lf\n", i,j,R[i][j], j,s[j]);
        aux=R[i][j]*s[j]+aux;
      }
        //Calculation of the symbols for each level Si, Si+1 and Si-1
        printf("aux = %lf\n", aux);
        s[i]=(y[i]-aux)/R[i][i];
        si[i]=in(s[i],cmin,cmax);
        si_plus1[i]=si[i]+1;
        si_minus1[i]=si[i]-1;

        printf("s[%d] = %lf, si[%d] = %d, si_plus1[%d] = %d, si_minus1[%d] = %d\n", i, s[i], i, si[i], i,si_plus1[i],i,si_minus1[i]);

        //Calculation of the accumulated weights for each level Si, Si+1 and Si-1
        weighti[i]=fabs(y[i]-(R[i][i]*si[i]+aux))+d;
        weighti_plus1[i]=fabs(y[i]-(R[i][i]*si_plus1[i]+aux))+d;
        weighti_minus1[i]=fabs(y[i]-(R[i][i]*si_minus1[i]+aux))+d;

        printf("wi[%d] = %lf, wi_plus1[%d] = %lf, wi_minus[%d] = %lf\n",i,weighti[i], i , weighti_plus1[i], i, weighti_minus1[i]);
        //Mimimum weight
        d=min_distance(weighti[i], weighti_plus1[i], weighti_minus1[i]);

        printf("d min = %lf\n",d);

        //Adding nodes to the tree
        node1= add_node_i (head, si[i],weighti[i],i);
        node2=add_node_i_plus1 (head,si_plus1[i],weighti_plus1[i],i);
        node3=add_node_i_minus1 (head,si_minus1[i],weighti_minus1[i],i);

        printf("Node 1: m = %lf, s = %d, l = %d\n", node1->m, node1->s, node1->l);
        printf("Node 2: m = %lf, s = %d, l = %d\n", node2->m, node2->s, node2->l);
        printf("Node 3: m = %lf, s = %d, l = %d\n", node3->m, node3->s, node3->l);
        
        printf ("TREE:\n");
        display_tree(root);

        //push_st(st_hd,node3);

        //display(st_hd);
        sort_stack(st_hd,node1, node2, node3);
        head=head_node(node1,node2,node3);

    sf[i] = head->s; 
   // if(i>0) {pop_st(st_hd,&head);}

  printf("\n\n"); 
  }
}

int main (){

  int l=5, a=5,k=6, h=t, symbol;
  int pt[t],i;
  double r[t][t]={{0.15,0.9,0.25,0.25,0.3},{0,0.25,0.125,0.75,0.21},{0,0,0.2,0.5,0.4},{0,0,0,0.2,0.88},{0,0,0,0,0.7}};
  double y[t]={0.8,0.7,0.9,0.1,0.2};
  

  ZZ(y,r,l,a, h, k,pt);

  for ( i = t-1; i >= 0; i-- ) {
  symbol=i+1;
  printf( "simbolo %d=%d\n",symbol,pt[i]);
  }

   return 0;
}

stdout
el co de su madre
Root head: m = 0.000000, s = 0, l = 0
Level = 5
aux = 0.000000
s[4] = 0.285714, si[4] = 0, si_plus1[4] = 1, si_minus1[4] = -1
wi[4] = 0.200000, wi_plus1[4] = 0.500000, wi_minus[4] = 0.900000
d min = 0.200000
Node 1: m = 0.200000, s = 0, l = 5
Node 2: m = 0.500000, s = 1, l = 5
Node 3: m = 0.900000, s = -1, l = 5
TREE:
m = 0.000000, s = 0, l = 0
m = 0.200000, s = 0, l = 5
m = 0.500000, s = 1, l = 5
m = 0.900000, s = -1, l = 5
-1
tmp->nxt = stack_head 0
stack_head=temp 1044476128
1
tmp->nxt = stack_head 0
stack_head=temp 1044476160
0
tmp->nxt = stack_head 0
stack_head=temp 1044476192
up to down 123
New head: m = 0.200000, s = 0, l = 5
Level = 4
R[3][4] = 0.880000 s[4] = 0.285714
aux = 0.251429
s[3] = -0.757143, si[3] = 0, si_plus1[3] = 1, si_minus1[3] = -1
wi[3] = 0.351429, wi_plus1[3] = 0.551429, wi_minus[3] = 0.248571
d min = 0.248571
Node 1: m = 0.351429, s = 0, l = 4
Node 2: m = 0.551429, s = 1, l = 4
Node 3: m = 0.248571, s = -1, l = 4
TREE:
m = 0.000000, s = 0, l = 0
m = 0.200000, s = 0, l = 5
m = 0.351429, s = 0, l = 4
m = 0.551429, s = 1, l = 4
m = 0.248571, s = -1, l = 4
m = 0.500000, s = 1, l = 5
m = 0.900000, s = -1, l = 5
1
tmp->nxt = stack_head 0
stack_head=temp 1044476416
0
tmp->nxt = stack_head 0
stack_head=temp 1044476448
-1
tmp->nxt = stack_head 0
stack_head=temp 1044476480
up to down 312
oaaaaaaaaaaaaaaa
New head: m = 0.248571, s = -1, l = 4
Level = 3
R[2][3] = 0.500000 s[3] = -0.757143
R[2][4] = 0.400000 s[4] = 0.285714
aux = -0.264286
s[2] = 5.821429, si[2] = 6, si_plus1[2] = 7, si_minus1[2] = 5
wi[2] = 0.284286, wi_plus1[2] = 0.484286, wi_minus[2] = 0.412857
d min = 0.284286
Node 1: m = 0.284286, s = 6, l = 3
Node 2: m = 0.484286, s = 7, l = 3
Node 3: m = 0.412857, s = 5, l = 3
TREE:
m = 0.000000, s = 0, l = 0
m = 0.200000, s = 0, l = 5
m = 0.351429, s = 0, l = 4
m = 0.551429, s = 1, l = 4
m = 0.248571, s = -1, l = 4
m = 0.284286, s = 6, l = 3
m = 0.484286, s = 7, l = 3
m = 0.412857, s = 5, l = 3
m = 0.500000, s = 1, l = 5
m = 0.900000, s = -1, l = 5
7
tmp->nxt = stack_head 0
stack_head=temp 1044476704
5
tmp->nxt = stack_head 0
stack_head=temp 1044476736
6
tmp->nxt = stack_head 0
stack_head=temp 1044476768
up to down 132
New head: m = 0.284286, s = 6, l = 3
Level = 2
R[1][2] = 0.125000 s[2] = 5.821429
R[1][3] = 0.750000 s[3] = -0.757143
R[1][4] = 0.210000 s[4] = 0.285714
aux = 0.219821
s[1] = 1.920714, si[1] = 2, si_plus1[1] = 3, si_minus1[1] = 1
wi[1] = 0.304107, wi_plus1[1] = 0.554107, wi_minus[1] = 0.514464
d min = 0.304107
Node 1: m = 0.304107, s = 2, l = 2
Node 2: m = 0.554107, s = 3, l = 2
Node 3: m = 0.514464, s = 1, l = 2
TREE:
m = 0.000000, s = 0, l = 0
m = 0.200000, s = 0, l = 5
m = 0.351429, s = 0, l = 4
m = 0.551429, s = 1, l = 4
m = 0.248571, s = -1, l = 4
m = 0.284286, s = 6, l = 3
m = 0.304107, s = 2, l = 2
m = 0.554107, s = 3, l = 2
m = 0.514464, s = 1, l = 2
m = 0.484286, s = 7, l = 3
m = 0.412857, s = 5, l = 3
m = 0.500000, s = 1, l = 5
m = 0.900000, s = -1, l = 5
3
tmp->nxt = stack_head 0
stack_head=temp 1044476992
1
tmp->nxt = stack_head 0
stack_head=temp 1044477024
2
tmp->nxt = stack_head 0
stack_head=temp 1044477056
up to down 132
New head: m = 0.304107, s = 2, l = 2
Level = 1
R[0][1] = 0.900000 s[1] = 1.920714
R[0][2] = 0.250000 s[2] = 5.821429
R[0][3] = 0.250000 s[3] = -0.757143
R[0][4] = 0.300000 s[4] = 0.285714
aux = 3.080429
s[0] = -15.202857, si[0] = 0, si_plus1[0] = 1, si_minus1[0] = -1
wi[0] = 2.584536, wi_plus1[0] = 2.734536, wi_minus[0] = 2.434536
d min = 2.434536
Node 1: m = 2.584536, s = 0, l = 1
Node 2: m = 2.734536, s = 1, l = 1
Node 3: m = 2.434536, s = -1, l = 1
TREE:
m = 0.000000, s = 0, l = 0
m = 0.200000, s = 0, l = 5
m = 0.351429, s = 0, l = 4
m = 0.551429, s = 1, l = 4
m = 0.248571, s = -1, l = 4
m = 0.284286, s = 6, l = 3
m = 0.304107, s = 2, l = 2
m = 2.584536, s = 0, l = 1
m = 2.734536, s = 1, l = 1
m = 2.434536, s = -1, l = 1
m = 0.554107, s = 3, l = 2
m = 0.514464, s = 1, l = 2
m = 0.484286, s = 7, l = 3
m = 0.412857, s = 5, l = 3
m = 0.500000, s = 1, l = 5
m = 0.900000, s = -1, l = 5
1
tmp->nxt = stack_head 0
stack_head=temp 1044477280
0
tmp->nxt = stack_head 0
stack_head=temp 1044477312
-1
tmp->nxt = stack_head 0
stack_head=temp 1044477344
up to down 312
oaaaaaaaaaaaaaaa
New head: m = 2.434536, s = -1, l = 1
simbolo 5=0
simbolo 4=-1
simbolo 3=6
simbolo 2=2
simbolo 1=-1