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
23441c06
Commit
23441c06
authored
Oct 18, 2014
by
Alan Mishchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improved QBF solver.
parent
3653bf53
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
132 additions
and
2 deletions
+132
-2
src/aig/gia/giaQbf.c
+0
-0
src/aig/gia/module.make
+1
-0
src/base/abci/abc.c
+125
-2
src/misc/vec/vecInt.h
+6
-0
No files found.
src/aig/gia/giaQbf.c
0 → 100644
View file @
23441c06
This diff is collapsed.
Click to expand it.
src/aig/gia/module.make
View file @
23441c06
...
...
@@ -46,6 +46,7 @@ SRC += src/aig/gia/giaAig.c \
src/aig/gia/giaMuxes.c
\
src/aig/gia/giaNf.c
\
src/aig/gia/giaPat.c
\
src/aig/gia/giaQbf.c
\
src/aig/gia/giaResub.c
\
src/aig/gia/giaRetime.c
\
src/aig/gia/giaScl.c
\
...
...
src/base/abci/abc.c
View file @
23441c06
...
...
@@ -423,6 +423,7 @@ static int Abc_CommandAbc9BCore ( Abc_Frame_t * pAbc, int argc, cha
static
int
Abc_CommandAbc9ICheck
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandAbc9SatTest
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandAbc9FFTest
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandAbc9Qbf
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandAbc9Inse
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandAbc9Maxi
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
static
int
Abc_CommandAbc9Bmci
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
);
...
...
@@ -1015,6 +1016,7 @@ void Abc_Init( Abc_Frame_t * pAbc )
Cmd_CommandAdd
(
pAbc
,
"ABC9"
,
"&icheck"
,
Abc_CommandAbc9ICheck
,
0
);
Cmd_CommandAdd
(
pAbc
,
"ABC9"
,
"&sattest"
,
Abc_CommandAbc9SatTest
,
0
);
Cmd_CommandAdd
(
pAbc
,
"ABC9"
,
"&fftest"
,
Abc_CommandAbc9FFTest
,
0
);
Cmd_CommandAdd
(
pAbc
,
"ABC9"
,
"&qbf"
,
Abc_CommandAbc9Qbf
,
0
);
Cmd_CommandAdd
(
pAbc
,
"ABC9"
,
"&inse"
,
Abc_CommandAbc9Inse
,
0
);
Cmd_CommandAdd
(
pAbc
,
"ABC9"
,
"&maxi"
,
Abc_CommandAbc9Maxi
,
0
);
Cmd_CommandAdd
(
pAbc
,
"ABC9"
,
"&bmci"
,
Abc_CommandAbc9Bmci
,
0
);
...
...
@@ -12934,7 +12936,7 @@ int Abc_CommandQbf( Abc_Frame_t * pAbc, int argc, char ** argv )
}
if
(
!
(
nPars
>
0
&&
nPars
<
Abc_NtkPiNum
(
pNtk
))
)
{
Abc_Print
(
-
1
,
"The number of paramter variables is invalid (should be > 0 and < PI num).
\n
"
);
Abc_Print
(
-
1
,
"The number of param
e
ter variables is invalid (should be > 0 and < PI num).
\n
"
);
return
1
;
}
if
(
Abc_NtkIsStrash
(
pNtk
)
)
...
...
@@ -26505,7 +26507,7 @@ int Abc_CommandAbc9Cof( Abc_Frame_t * pAbc, int argc, char ** argv )
}
else
{
Abc_Print
(
-
1
,
"One of the paramters, -V <num> or -L <num>, should be set on the command line.
\n
"
);
Abc_Print
(
-
1
,
"One of the param
e
ters, -V <num> or -L <num>, should be set on the command line.
\n
"
);
goto
usage
;
}
return
0
;
...
...
@@ -35686,6 +35688,127 @@ usage:
SeeAlso []
***********************************************************************/
int
Abc_CommandAbc9Qbf
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
)
{
extern
void
Gia_QbfDumpFile
(
Gia_Man_t
*
pGia
,
int
nPars
);
extern
int
Gia_QbfSolve
(
Gia_Man_t
*
pGia
,
int
nPars
,
int
nIterLimit
,
int
nConfLimit
,
int
nTimeOut
,
int
fVerbose
);
int
c
,
nPars
=
-
1
;
int
nIterLimit
=
0
;
int
nConfLimit
=
0
;
int
nTimeOut
=
0
;
int
fDumpCnf
=
0
;
int
fVerbose
=
1
;
Extra_UtilGetoptReset
();
while
(
(
c
=
Extra_UtilGetopt
(
argc
,
argv
,
"PICTdvh"
)
)
!=
EOF
)
{
switch
(
c
)
{
case
'P'
:
if
(
globalUtilOptind
>=
argc
)
{
Abc_Print
(
-
1
,
"Command line switch
\"
-P
\"
should be followed by an integer.
\n
"
);
goto
usage
;
}
nPars
=
atoi
(
argv
[
globalUtilOptind
]);
globalUtilOptind
++
;
if
(
nPars
<
0
)
goto
usage
;
break
;
case
'I'
:
if
(
globalUtilOptind
>=
argc
)
{
Abc_Print
(
-
1
,
"Command line switch
\"
-I
\"
should be followed by an integer.
\n
"
);
goto
usage
;
}
nIterLimit
=
atoi
(
argv
[
globalUtilOptind
]);
globalUtilOptind
++
;
if
(
nIterLimit
<
0
)
goto
usage
;
break
;
case
'C'
:
if
(
globalUtilOptind
>=
argc
)
{
Abc_Print
(
-
1
,
"Command line switch
\"
-C
\"
should be followed by an integer.
\n
"
);
goto
usage
;
}
nConfLimit
=
atoi
(
argv
[
globalUtilOptind
]);
globalUtilOptind
++
;
if
(
nConfLimit
<
0
)
goto
usage
;
break
;
case
'T'
:
if
(
globalUtilOptind
>=
argc
)
{
Abc_Print
(
-
1
,
"Command line switch
\"
-T
\"
should be followed by an integer.
\n
"
);
goto
usage
;
}
nTimeOut
=
atoi
(
argv
[
globalUtilOptind
]);
globalUtilOptind
++
;
if
(
nTimeOut
<
0
)
goto
usage
;
break
;
case
'd'
:
fDumpCnf
^=
1
;
break
;
case
'v'
:
fVerbose
^=
1
;
break
;
case
'h'
:
goto
usage
;
default:
goto
usage
;
}
}
if
(
pAbc
->
pGia
==
NULL
)
{
Abc_Print
(
-
1
,
"There is no current GIA.
\n
"
);
return
1
;
}
if
(
Gia_ManRegNum
(
pAbc
->
pGia
)
)
{
Abc_Print
(
-
1
,
"Works only for combinational networks.
\n
"
);
return
1
;
}
if
(
Gia_ManPoNum
(
pAbc
->
pGia
)
!=
1
)
{
Abc_Print
(
-
1
,
"The miter should have one primary output.
\n
"
);
return
1
;
}
if
(
!
(
nPars
>
0
&&
nPars
<
Gia_ManPiNum
(
pAbc
->
pGia
))
)
{
Abc_Print
(
-
1
,
"The number of parameter variables is invalid (should be > 0 and < PI num).
\n
"
);
return
1
;
}
if
(
fDumpCnf
)
Gia_QbfDumpFile
(
pAbc
->
pGia
,
nPars
);
else
Gia_QbfSolve
(
pAbc
->
pGia
,
nPars
,
nIterLimit
,
nConfLimit
,
nTimeOut
,
fVerbose
);
return
0
;
usage:
Abc_Print
(
-
2
,
"usage: &qbf [-PICT num] [-dvh]
\n
"
);
Abc_Print
(
-
2
,
"
\t
solves QBF problem EpVxM(p,x)
\n
"
);
Abc_Print
(
-
2
,
"
\t
-P num : number of parameters p (should be the first PIs) [default = %d]
\n
"
,
nPars
);
Abc_Print
(
-
2
,
"
\t
-I num : quit after the given iteration even if unsolved [default = %d]
\n
"
,
nIterLimit
);
Abc_Print
(
-
2
,
"
\t
-C num : conflict limit per problem [default = %d]
\n
"
,
nConfLimit
);
Abc_Print
(
-
2
,
"
\t
-T num : global timeout [default = %d]
\n
"
,
nTimeOut
);
Abc_Print
(
-
2
,
"
\t
-d : toggle dumping QDIMACS file instead of solving [default = %s]
\n
"
,
fDumpCnf
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
-v : toggle verbose output [default = %s]
\n
"
,
fVerbose
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
-h : print the command usage
\n
"
);
return
1
;
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
int
Abc_CommandAbc9Inse
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
)
{
extern
Vec_Int_t
*
Gia_ManInseTest
(
Gia_Man_t
*
p
,
Vec_Int_t
*
vInit
,
int
nFrames
,
int
nWords
,
int
nTimeOut
,
int
fSim
,
int
fVerbose
);
src/misc/vec/vecInt.h
View file @
23441c06
...
...
@@ -1758,6 +1758,12 @@ static inline void Vec_IntPrint( Vec_Int_t * vVec )
printf
(
" %d"
,
Entry
);
printf
(
" }
\n
"
);
}
static
inline
void
Vec_IntPrintBinary
(
Vec_Int_t
*
vVec
)
{
int
i
,
Entry
;
Vec_IntForEachEntry
(
vVec
,
Entry
,
i
)
printf
(
"%d"
,
(
int
)(
Entry
!=
0
)
);
}
/**Function*************************************************************
...
...
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