ivyResyn.c 5.96 KB
Newer Older
Alan Mishchenko committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
/**CFile****************************************************************

  FileName    [ivyResyn.c]

  SystemName  [ABC: Logic synthesis and verification system.]

  PackageName [And-Inverter Graph package.]

  Synopsis    [AIG rewriting script.]

  Author      [Alan Mishchenko]
  
  Affiliation [UC Berkeley]

  Date        [Ver. 1.0. Started - May 11, 2006.]

  Revision    [$Id: ivyResyn.c,v 1.00 2006/05/11 00:00:00 alanmi Exp $]

***********************************************************************/

#include "ivy.h"

23 24 25
ABC_NAMESPACE_IMPL_START


Alan Mishchenko committed
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
////////////////////////////////////////////////////////////////////////
///                        DECLARATIONS                              ///
////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////
///                     FUNCTION DEFINITIONS                         ///
////////////////////////////////////////////////////////////////////////

/**Function*************************************************************

  Synopsis    [Performs several passes of rewriting on the AIG.]

  Description []
               
  SideEffects []

  SeeAlso     []

***********************************************************************/
Ivy_Man_t * Ivy_ManResyn0( Ivy_Man_t * pMan, int fUpdateLevel, int fVerbose )
{
47
    abctime clk;
Alan Mishchenko committed
48 49 50 51 52
    Ivy_Man_t * pTemp;

if ( fVerbose ) { printf( "Original:\n" ); }
if ( fVerbose ) Ivy_ManPrintStats( pMan );

53
clk = Abc_Clock();
Alan Mishchenko committed
54 55
    pMan = Ivy_ManBalance( pMan, fUpdateLevel );
if ( fVerbose ) { printf( "\n" ); }
56
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
57 58 59
if ( fVerbose ) Ivy_ManPrintStats( pMan );

//    Ivy_ManRewriteAlg( pMan, fUpdateLevel, 0 );
60
clk = Abc_Clock();
Alan Mishchenko committed
61 62
    Ivy_ManRewritePre( pMan, fUpdateLevel, 0, 0 );
if ( fVerbose ) { printf( "\n" ); }
63
if ( fVerbose ) { ABC_PRT( "Rewrite", Abc_Clock() - clk ); }
Alan Mishchenko committed
64 65
if ( fVerbose ) Ivy_ManPrintStats( pMan );

66
clk = Abc_Clock();
Alan Mishchenko committed
67 68 69
    pMan = Ivy_ManBalance( pTemp = pMan, fUpdateLevel );
    Ivy_ManStop( pTemp );
if ( fVerbose ) { printf( "\n" ); }
70
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
if ( fVerbose ) Ivy_ManPrintStats( pMan );
    return pMan;
}

/**Function*************************************************************

  Synopsis    [Performs several passes of rewriting on the AIG.]

  Description []
               
  SideEffects []

  SeeAlso     []

***********************************************************************/
Ivy_Man_t * Ivy_ManResyn( Ivy_Man_t * pMan, int fUpdateLevel, int fVerbose )
{
88
    abctime clk;
Alan Mishchenko committed
89 90 91 92 93
    Ivy_Man_t * pTemp;

if ( fVerbose ) { printf( "Original:\n" ); }
if ( fVerbose ) Ivy_ManPrintStats( pMan );

94
clk = Abc_Clock();
Alan Mishchenko committed
95 96
    pMan = Ivy_ManBalance( pMan, fUpdateLevel );
if ( fVerbose ) { printf( "\n" ); }
97
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
98 99 100
if ( fVerbose ) Ivy_ManPrintStats( pMan );

//    Ivy_ManRewriteAlg( pMan, fUpdateLevel, 0 );
101
clk = Abc_Clock();
Alan Mishchenko committed
102 103
    Ivy_ManRewritePre( pMan, fUpdateLevel, 0, 0 );
if ( fVerbose ) { printf( "\n" ); }
104
if ( fVerbose ) { ABC_PRT( "Rewrite", Abc_Clock() - clk ); }
Alan Mishchenko committed
105 106
if ( fVerbose ) Ivy_ManPrintStats( pMan );

107
clk = Abc_Clock();
Alan Mishchenko committed
108 109 110
    pMan = Ivy_ManBalance( pTemp = pMan, fUpdateLevel );
    Ivy_ManStop( pTemp );
if ( fVerbose ) { printf( "\n" ); }
111
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
112 113 114
if ( fVerbose ) Ivy_ManPrintStats( pMan );

//    Ivy_ManRewriteAlg( pMan, fUpdateLevel, 1 );
115
clk = Abc_Clock();
Alan Mishchenko committed
116 117
    Ivy_ManRewritePre( pMan, fUpdateLevel, 1, 0 );
if ( fVerbose ) { printf( "\n" ); }
118
if ( fVerbose ) { ABC_PRT( "Rewrite", Abc_Clock() - clk ); }
Alan Mishchenko committed
119 120
if ( fVerbose ) Ivy_ManPrintStats( pMan );

121
clk = Abc_Clock();
Alan Mishchenko committed
122 123 124
    pMan = Ivy_ManBalance( pTemp = pMan, fUpdateLevel );
    Ivy_ManStop( pTemp );
if ( fVerbose ) { printf( "\n" ); }
125
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
126 127 128
if ( fVerbose ) Ivy_ManPrintStats( pMan );

//    Ivy_ManRewriteAlg( pMan, fUpdateLevel, 1 );
129
clk = Abc_Clock();
Alan Mishchenko committed
130 131
    Ivy_ManRewritePre( pMan, fUpdateLevel, 1, 0 );
if ( fVerbose ) { printf( "\n" ); }
132
if ( fVerbose ) { ABC_PRT( "Rewrite", Abc_Clock() - clk ); }
Alan Mishchenko committed
133 134
if ( fVerbose ) Ivy_ManPrintStats( pMan );

135
clk = Abc_Clock();
Alan Mishchenko committed
136 137 138
    pMan = Ivy_ManBalance( pTemp = pMan, fUpdateLevel );
    Ivy_ManStop( pTemp );
if ( fVerbose ) { printf( "\n" ); }
139
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156
if ( fVerbose ) Ivy_ManPrintStats( pMan );
    return pMan;
}

/**Function*************************************************************

  Synopsis    [Performs several passes of rewriting on the AIG.]

  Description []
               
  SideEffects []

  SeeAlso     []

***********************************************************************/
Ivy_Man_t * Ivy_ManRwsat( Ivy_Man_t * pMan, int fVerbose )
{
157
    abctime clk;
Alan Mishchenko committed
158 159 160 161 162
    Ivy_Man_t * pTemp;

if ( fVerbose ) { printf( "Original:\n" ); }
if ( fVerbose ) Ivy_ManPrintStats( pMan );

163
clk = Abc_Clock();
Alan Mishchenko committed
164 165
    Ivy_ManRewritePre( pMan, 0, 0, 0 );
if ( fVerbose ) { printf( "\n" ); }
166
if ( fVerbose ) { ABC_PRT( "Rewrite", Abc_Clock() - clk ); }
Alan Mishchenko committed
167 168
if ( fVerbose ) Ivy_ManPrintStats( pMan );

169
clk = Abc_Clock();
Alan Mishchenko committed
170 171 172 173
    pMan = Ivy_ManBalance( pTemp = pMan, 0 );
//    pMan = Ivy_ManDup( pTemp = pMan );
    Ivy_ManStop( pTemp );
if ( fVerbose ) { printf( "\n" ); }
174
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
175 176 177
if ( fVerbose ) Ivy_ManPrintStats( pMan );

/*
178
clk = Abc_Clock();
Alan Mishchenko committed
179 180
    Ivy_ManRewritePre( pMan, 0, 0, 0 );
if ( fVerbose ) { printf( "\n" ); }
181
if ( fVerbose ) { ABC_PRT( "Rewrite", Abc_Clock() - clk ); }
Alan Mishchenko committed
182 183
if ( fVerbose ) Ivy_ManPrintStats( pMan );

184
clk = Abc_Clock();
Alan Mishchenko committed
185 186 187
    pMan = Ivy_ManBalance( pTemp = pMan, 0 );
    Ivy_ManStop( pTemp );
if ( fVerbose ) { printf( "\n" ); }
188
if ( fVerbose ) { ABC_PRT( "Balance", Abc_Clock() - clk ); }
Alan Mishchenko committed
189 190 191 192 193 194 195 196 197 198 199
if ( fVerbose ) Ivy_ManPrintStats( pMan );
*/
    return pMan;
}


////////////////////////////////////////////////////////////////////////
///                       END OF FILE                                ///
////////////////////////////////////////////////////////////////////////


200 201
ABC_NAMESPACE_IMPL_END