Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
abc
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
abc
Commits
ae0f03f4
Commit
ae0f03f4
authored
Jun 10, 2022
by
Alan Mishchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Adding command to check resub problem solution.
parent
3241a595
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
169 additions
and
0 deletions
+169
-0
abclib.dsp
+4
-0
src/aig/gia/giaResub6.c
+0
-0
src/aig/gia/giaSupps.c
+104
-0
src/aig/gia/module.make
+1
-0
src/base/abci/abc.c
+60
-0
No files found.
abclib.dsp
View file @
ae0f03f4
...
@@ -5155,6 +5155,10 @@ SOURCE=.\src\aig\gia\giaResub3.c
...
@@ -5155,6 +5155,10 @@ SOURCE=.\src\aig\gia\giaResub3.c
# End Source File
# End Source File
# Begin Source File
# Begin Source File
SOURCE=.\src\aig\gia\giaResub6.c
# End Source File
# Begin Source File
SOURCE=.\src\aig\gia\giaRetime.c
SOURCE=.\src\aig\gia\giaRetime.c
# End Source File
# End Source File
# Begin Source File
# Begin Source File
...
...
src/aig/gia/giaResub6.c
0 → 100644
View file @
ae0f03f4
This diff is collapsed.
Click to expand it.
src/aig/gia/giaSupps.c
View file @
ae0f03f4
...
@@ -138,6 +138,7 @@ int Supp_DeriveLines( Supp_Man_t * p )
...
@@ -138,6 +138,7 @@ int Supp_DeriveLines( Supp_Man_t * p )
{
{
int
n
,
i
,
iObj
,
nWords
=
p
->
nWords
;
int
n
,
i
,
iObj
,
nWords
=
p
->
nWords
;
int
nDivWords
=
Abc_Bit6WordNum
(
Vec_IntSize
(
p
->
vCands
)
);
int
nDivWords
=
Abc_Bit6WordNum
(
Vec_IntSize
(
p
->
vCands
)
);
//Vec_IntPrint( p->vCands );
for
(
n
=
0
;
n
<
2
;
n
++
)
for
(
n
=
0
;
n
<
2
;
n
++
)
{
{
p
->
vDivs
[
n
]
=
Vec_WrdStart
(
64
*
nWords
*
nDivWords
);
p
->
vDivs
[
n
]
=
Vec_WrdStart
(
64
*
nWords
*
nDivWords
);
...
@@ -656,6 +657,79 @@ int Supp_ManReconstruct( Supp_Man_t * p, int fVerbose )
...
@@ -656,6 +657,79 @@ int Supp_ManReconstruct( Supp_Man_t * p, int fVerbose )
return
Supp_ManRandomSolution
(
p
,
iSet
,
fVerbose
);
return
Supp_ManRandomSolution
(
p
,
iSet
,
fVerbose
);
}
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
int
s_Counter
=
0
;
void
Supp_DeriveDumpSims
(
FILE
*
pFile
,
Vec_Wrd_t
*
vDivs
,
int
nWords
)
{
int
i
,
k
,
nDivs
=
Vec_WrdSize
(
vDivs
)
/
nWords
;
for
(
i
=
0
;
i
<
nDivs
;
i
++
)
{
word
*
pSim
=
Vec_WrdEntryP
(
vDivs
,
i
*
nWords
);
for
(
k
=
0
;
k
<
64
*
nWords
;
k
++
)
fprintf
(
pFile
,
"%c"
,
'0'
+
Abc_TtGetBit
(
pSim
,
k
)
);
fprintf
(
pFile
,
"
\n
"
);
}
}
void
Supp_DeriveDumpProb
(
Vec_Wrd_t
*
vIsfs
,
Vec_Wrd_t
*
vDivs
,
int
nWords
)
{
char
Buffer
[
100
];
int
nDivs
=
Vec_WrdSize
(
vDivs
)
/
nWords
;
int
RetValue
=
sprintf
(
Buffer
,
"case01_%02d.resub"
,
s_Counter
);
FILE
*
pFile
=
fopen
(
Buffer
,
"wb"
);
if
(
pFile
==
NULL
)
printf
(
"Cannot open output file.
\n
"
);
fprintf
(
pFile
,
"resyn %d %d %d %d
\n
"
,
0
,
nDivs
,
1
,
64
*
nWords
);
//fprintf( pFile, "%d %d %d %d\n", 0, nDivs, 1, 64*nWords );
Supp_DeriveDumpSims
(
pFile
,
vDivs
,
nWords
);
Supp_DeriveDumpSims
(
pFile
,
vIsfs
,
nWords
);
fclose
(
pFile
);
RetValue
=
0
;
}
void
Supp_DeriveDumpSol
(
Vec_Int_t
*
vSet
,
Vec_Int_t
*
vRes
,
int
nDivs
)
{
char
Buffer
[
100
];
int
RetValue
=
sprintf
(
Buffer
,
"case01_%02d.sol"
,
s_Counter
);
int
i
,
iLit
,
iLitRes
=
-
1
,
nSupp
=
Vec_IntSize
(
vSet
);
FILE
*
pFile
=
fopen
(
Buffer
,
"wb"
);
if
(
pFile
==
NULL
)
printf
(
"Cannot open output file.
\n
"
);
fprintf
(
pFile
,
"sol name aig %d
\n
"
,
Vec_IntSize
(
vRes
)
/
2
);
//Vec_IntPrint( vSet );
//Vec_IntPrint( vRes );
Vec_IntForEachEntry
(
vRes
,
iLit
,
i
)
{
assert
(
iLit
!=
2
&&
iLit
!=
3
);
if
(
iLit
<
2
)
iLitRes
=
iLit
;
else
if
(
iLit
-
4
<
2
*
nSupp
)
{
int
iDiv
=
Vec_IntEntry
(
vSet
,
Abc_Lit2Var
(
iLit
-
4
));
assert
(
iDiv
>=
0
&&
iDiv
<
nDivs
);
iLitRes
=
Abc_Var2Lit
(
1
+
iDiv
,
Abc_LitIsCompl
(
iLit
));
}
else
iLitRes
=
iLit
+
2
*
((
nDivs
+
1
)
-
(
nSupp
+
2
));
fprintf
(
pFile
,
"%d "
,
iLitRes
);
}
if
(
Vec_IntSize
(
vRes
)
&
1
)
fprintf
(
pFile
,
"%d "
,
iLitRes
);
fprintf
(
pFile
,
"
\n
"
);
fclose
(
pFile
);
RetValue
=
0
;
printf
(
"Dumped solution info file
\"
%s
\"
.
\n
"
,
Buffer
);
}
/**Function*************************************************************
/**Function*************************************************************
Synopsis []
Synopsis []
...
@@ -705,6 +779,7 @@ Vec_Int_t * Supp_ManFindBestSolution( Supp_Man_t * p, Vec_Wec_t * vSols, int fVe
...
@@ -705,6 +779,7 @@ Vec_Int_t * Supp_ManFindBestSolution( Supp_Man_t * p, Vec_Wec_t * vSols, int fVe
Vec_IntForEachEntry
(
vSet
,
iObj
,
i
)
Vec_IntForEachEntry
(
vSet
,
iObj
,
i
)
Vec_IntPush
(
*
pvDivs
,
Vec_IntEntry
(
p
->
vCands
,
iObj
)
);
Vec_IntPush
(
*
pvDivs
,
Vec_IntEntry
(
p
->
vCands
,
iObj
)
);
}
}
//Supp_DeriveDumpSol( vSet, vRes, Vec_WrdSize(p->vDivs[1])/p->nWords );
}
}
return
vRes
;
return
vRes
;
}
}
...
@@ -802,11 +877,40 @@ Vec_Int_t * Supp_ManCompute( Vec_Wrd_t * vIsfs, Vec_Int_t * vCands, Vec_Int_t *
...
@@ -802,11 +877,40 @@ Vec_Int_t * Supp_ManCompute( Vec_Wrd_t * vIsfs, Vec_Int_t * vCands, Vec_Int_t *
Supp_PrintOne
(
p
,
iBest
);
Supp_PrintOne
(
p
,
iBest
);
}
}
vRes
=
Supp_ManFindBestSolution
(
p
,
p
->
vSolutions
,
fVerbose
,
pvDivs
);
vRes
=
Supp_ManFindBestSolution
(
p
,
p
->
vSolutions
,
fVerbose
,
pvDivs
);
//Supp_DeriveDumpProb( vIsfs, p->vDivs[1], p->nWords );
s_Counter
++
;
//Vec_IntPrint( vRes );
Supp_ManDelete
(
p
);
Supp_ManDelete
(
p
);
// if ( vRes && Vec_IntSize(vRes) == 0 )
// if ( vRes && Vec_IntSize(vRes) == 0 )
// Vec_IntFreeP( &vRes );
// Vec_IntFreeP( &vRes );
return
vRes
;
return
vRes
;
}
}
void
Supp_ManComputeTest
(
Gia_Man_t
*
p
)
{
Vec_Wrd_t
*
vSimsPi
=
Vec_WrdStartTruthTables
(
Gia_ManCiNum
(
p
)
);
Vec_Wrd_t
*
vSims
=
Gia_ManSimPatSimOut
(
p
,
vSimsPi
,
0
);
int
i
,
iPoId
,
nWords
=
Vec_WrdSize
(
vSimsPi
)
/
Gia_ManCiNum
(
p
);
Vec_Wrd_t
*
vIsfs
=
Vec_WrdStart
(
2
*
nWords
);
Vec_Int_t
*
vCands
=
Vec_IntAlloc
(
4
);
Vec_Int_t
*
vRes
;
// for ( i = 0; i < Gia_ManCiNum(p)+5; i++ )
for
(
i
=
0
;
i
<
Gia_ManCiNum
(
p
);
i
++
)
Vec_IntPush
(
vCands
,
1
+
i
);
iPoId
=
Gia_ObjId
(
p
,
Gia_ManPo
(
p
,
0
));
Abc_TtCopy
(
Vec_WrdEntryP
(
vIsfs
,
0
*
nWords
),
Vec_WrdEntryP
(
vSims
,
iPoId
*
nWords
),
nWords
,
1
);
Abc_TtCopy
(
Vec_WrdEntryP
(
vIsfs
,
1
*
nWords
),
Vec_WrdEntryP
(
vSims
,
iPoId
*
nWords
),
nWords
,
0
);
vRes
=
Supp_ManCompute
(
vIsfs
,
vCands
,
NULL
,
vSims
,
NULL
,
nWords
,
p
,
NULL
,
1
,
1
,
0
);
Vec_IntPrint
(
vRes
);
Vec_WrdFree
(
vSimsPi
);
Vec_WrdFree
(
vSims
);
Vec_WrdFree
(
vIsfs
);
Vec_IntFree
(
vCands
);
Vec_IntFree
(
vRes
);
}
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
/// END OF FILE ///
/// END OF FILE ///
...
...
src/aig/gia/module.make
View file @
ae0f03f4
...
@@ -69,6 +69,7 @@ SRC += src/aig/gia/giaAig.c \
...
@@ -69,6 +69,7 @@ SRC += src/aig/gia/giaAig.c \
src/aig/gia/giaResub.c
\
src/aig/gia/giaResub.c
\
src/aig/gia/giaResub2.c
\
src/aig/gia/giaResub2.c
\
src/aig/gia/giaResub3.c
\
src/aig/gia/giaResub3.c
\
src/aig/gia/giaResub6.c
\
src/aig/gia/giaRetime.c
\
src/aig/gia/giaRetime.c
\
src/aig/gia/giaRex.c
\
src/aig/gia/giaRex.c
\
src/aig/gia/giaSatEdge.c
\
src/aig/gia/giaSatEdge.c
\
...
...
src/base/abci/abc.c
View file @
ae0f03f4
...
@@ -146,6 +146,7 @@ static int Abc_CommandRewrite ( Abc_Frame_t * pAbc, int argc, cha
...
@@ -146,6 +146,7 @@ static int Abc_CommandRewrite ( Abc_Frame_t * pAbc, int argc, cha
static
int
Abc_CommandRefactor
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandRefactor
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandRestructure
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandRestructure
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandResubstitute
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandResubstitute
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandResubCheck
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandRr
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandRr
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandCascade
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandCascade
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandExtract
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandExtract
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
...
@@ -894,6 +895,7 @@ void Abc_Init( Abc_Frame_t * pAbc )
...
@@ -894,6 +895,7 @@ void Abc_Init( Abc_Frame_t * pAbc )
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"refactor"
,
Abc_CommandRefactor
,
1
);
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"refactor"
,
Abc_CommandRefactor
,
1
);
// Cmd_CommandAdd( pAbc, "Synthesis", "restructure", Abc_CommandRestructure, 1 );
// Cmd_CommandAdd( pAbc, "Synthesis", "restructure", Abc_CommandRestructure, 1 );
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"resub"
,
Abc_CommandResubstitute
,
1
);
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"resub"
,
Abc_CommandResubstitute
,
1
);
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"resub_check"
,
Abc_CommandResubCheck
,
0
);
// Cmd_CommandAdd( pAbc, "Synthesis", "rr", Abc_CommandRr, 1 );
// Cmd_CommandAdd( pAbc, "Synthesis", "rr", Abc_CommandRr, 1 );
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"cascade"
,
Abc_CommandCascade
,
1
);
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"cascade"
,
Abc_CommandCascade
,
1
);
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"extract"
,
Abc_CommandExtract
,
1
);
Cmd_CommandAdd
(
pAbc
,
"Synthesis"
,
"extract"
,
Abc_CommandExtract
,
1
);
...
@@ -7802,6 +7804,64 @@ usage:
...
@@ -7802,6 +7804,64 @@ usage:
SeeAlso []
SeeAlso []
***********************************************************************/
***********************************************************************/
int
Abc_CommandResubCheck
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
)
{
extern
void
Res6_ManResubCheck
(
char
*
pFileNameRes
,
char
*
pFileNameSol
,
int
fVerbose
);
char
*
pFileR
=
NULL
,
*
pFileS
=
NULL
;
int
fVerbose
=
0
,
c
;
Extra_UtilGetoptReset
();
while
(
(
c
=
Extra_UtilGetopt
(
argc
,
argv
,
"vh"
)
)
!=
EOF
)
{
switch
(
c
)
{
case
'v'
:
fVerbose
^=
1
;
break
;
case
'h'
:
goto
usage
;
default:
goto
usage
;
}
}
if
(
argc
==
globalUtilOptind
+
2
)
{
pFileR
=
argv
[
globalUtilOptind
];
pFileS
=
argv
[
globalUtilOptind
+
1
];
}
else
if
(
argc
==
globalUtilOptind
+
1
)
{
pFileR
=
argv
[
globalUtilOptind
];
pFileS
=
NULL
;
}
else
{
Abc_Print
(
-
1
,
"Incorrect number of command line arguments.
\n
"
);
return
1
;
}
Res6_ManResubCheck
(
pFileR
,
pFileS
,
fVerbose
);
return
0
;
usage:
Abc_Print
(
-
2
,
"usage: resub_check [-vh] <file1> <file2>
\n
"
);
Abc_Print
(
-
2
,
"
\t
checks solution to a resub problem
\n
"
);
Abc_Print
(
-
2
,
"
\t
-v : toggle verbose printout [default = %s]
\n
"
,
fVerbose
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
<file1> : resub problem file name
\n
"
);
Abc_Print
(
-
2
,
"
\t
<file2> : (optional) solution file name
\n
"
);
Abc_Print
(
-
2
,
"
\t
-h : print the command usage
\n
"
);
return
1
;
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
int
Abc_CommandRr
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
)
int
Abc_CommandRr
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
)
{
{
Abc_Ntk_t
*
pNtk
=
Abc_FrameReadNtk
(
pAbc
);
Abc_Ntk_t
*
pNtk
=
Abc_FrameReadNtk
(
pAbc
);
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment