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
f80841a5
Commit
f80841a5
authored
Feb 13, 2012
by
Alan Mishchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Variable timeframe abstraction.
parent
d0713831
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
21 additions
and
20 deletions
+21
-20
src/aig/gia/giaAbsVta.c
+2
-4
src/sat/bsat/satSolver2.c
+19
-16
No files found.
src/aig/gia/giaAbsVta.c
View file @
f80841a5
...
@@ -149,7 +149,7 @@ void Gia_VtaSetDefaultParams( Gia_ParVta_t * p )
...
@@ -149,7 +149,7 @@ void Gia_VtaSetDefaultParams( Gia_ParVta_t * p )
p
->
nFramesStart
=
5
;
// starting frame
p
->
nFramesStart
=
5
;
// starting frame
p
->
nFramesPast
=
4
;
// overlap frames
p
->
nFramesPast
=
4
;
// overlap frames
p
->
nConfLimit
=
0
;
// conflict limit
p
->
nConfLimit
=
0
;
// conflict limit
p
->
nLearntMax
=
1000
0
;
// max number of learned clauses
p
->
nLearntMax
=
0
;
// max number of learned clauses
p
->
nTimeOut
=
0
;
// timeout in seconds
p
->
nTimeOut
=
0
;
// timeout in seconds
p
->
nRatioMin
=
10
;
// stop when less than this % of object is abstracted
p
->
nRatioMin
=
10
;
// stop when less than this % of object is abstracted
p
->
fUseTermVars
=
1
;
// use terminal variables
p
->
fUseTermVars
=
1
;
// use terminal variables
...
@@ -1415,7 +1415,7 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars )
...
@@ -1415,7 +1415,7 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars )
p
->
pPars
->
nConfLimit
,
p
->
pPars
->
nTimeOut
,
pPars
->
nRatioMin
);
p
->
pPars
->
nConfLimit
,
p
->
pPars
->
nTimeOut
,
pPars
->
nRatioMin
);
printf
(
"Frame Abs Confl Cex Core F0 F1 F2 F3 ...
\n
"
);
printf
(
"Frame Abs Confl Cex Core F0 F1 F2 F3 ...
\n
"
);
}
}
for
(
f
=
0
;
!
p
->
pPars
->
nFramesMax
||
f
<
p
->
pPars
->
nFramesMax
;
f
++
)
for
(
f
=
i
=
0
;
!
p
->
pPars
->
nFramesMax
||
f
<
p
->
pPars
->
nFramesMax
;
f
++
)
{
{
int
nConflsBeg
=
sat_solver2_nconflicts
(
p
->
pSat
);
int
nConflsBeg
=
sat_solver2_nconflicts
(
p
->
pSat
);
p
->
pPars
->
iFrame
=
f
;
p
->
pPars
->
iFrame
=
f
;
...
@@ -1423,10 +1423,8 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars )
...
@@ -1423,10 +1423,8 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars )
if
(
f
==
p
->
nWords
*
32
)
if
(
f
==
p
->
nWords
*
32
)
p
->
nWords
=
Vec_IntDoubleWidth
(
p
->
vSeens
,
p
->
nWords
);
p
->
nWords
=
Vec_IntDoubleWidth
(
p
->
vSeens
,
p
->
nWords
);
// check this timeframe
// check this timeframe
i
=
0
;
if
(
f
<
p
->
pPars
->
nFramesStart
)
if
(
f
<
p
->
pPars
->
nFramesStart
)
{
{
// printf( " Adding %8d ", Vec_IntSize(Vec_PtrEntry(p->vFrames, f)) );
Vga_ManAddClausesOne
(
p
,
0
,
f
);
Vga_ManAddClausesOne
(
p
,
0
,
f
);
Vga_ManLoadSlice
(
p
,
(
Vec_Int_t
*
)
Vec_PtrEntry
(
p
->
vFrames
,
f
),
0
);
Vga_ManLoadSlice
(
p
,
(
Vec_Int_t
*
)
Vec_PtrEntry
(
p
->
vFrames
,
f
),
0
);
}
}
...
...
src/sat/bsat/satSolver2.c
View file @
f80841a5
...
@@ -1037,7 +1037,6 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts)
...
@@ -1037,7 +1037,6 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts)
if
(
solver2_dlevel
(
s
)
<=
s
->
root_level
){
if
(
solver2_dlevel
(
s
)
<=
s
->
root_level
){
proof_id
=
solver2_analyze_final
(
s
,
confl
,
0
);
proof_id
=
solver2_analyze_final
(
s
,
confl
,
0
);
assert
(
proof_id
>
0
);
assert
(
proof_id
>
0
);
// solver2_record(s,&s->conf_final, proof_id);
s
->
hProofLast
=
proof_id
;
s
->
hProofLast
=
proof_id
;
veci_delete
(
&
learnt_clause
);
veci_delete
(
&
learnt_clause
);
return
l_False
;
return
l_False
;
...
@@ -1093,8 +1092,11 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts)
...
@@ -1093,8 +1092,11 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts)
if
(
next
==
var_Undef
){
if
(
next
==
var_Undef
){
// Model found:
// Model found:
int
i
;
int
i
;
for
(
i
=
0
;
i
<
s
->
size
;
i
++
)
for
(
i
=
0
;
i
<
s
->
size
;
i
++
)
{
assert
(
var_value
(
s
,
i
)
!=
varX
);
s
->
model
[
i
]
=
(
var_value
(
s
,
i
)
==
var1
?
l_True
:
l_False
);
s
->
model
[
i
]
=
(
var_value
(
s
,
i
)
==
var1
?
l_True
:
l_False
);
}
solver2_canceluntil
(
s
,
s
->
root_level
);
solver2_canceluntil
(
s
,
s
->
root_level
);
veci_delete
(
&
learnt_clause
);
veci_delete
(
&
learnt_clause
);
return
l_True
;
return
l_True
;
...
@@ -1493,14 +1495,16 @@ void sat_solver2_reducedb(sat_solver2* s)
...
@@ -1493,14 +1495,16 @@ void sat_solver2_reducedb(sat_solver2* s)
void
sat_solver2_rollback
(
sat_solver2
*
s
)
void
sat_solver2_rollback
(
sat_solver2
*
s
)
{
{
int
i
,
k
,
j
;
int
i
,
k
,
j
;
assert
(
s
->
qhead
==
s
->
qtail
);
assert
(
s
->
iVarPivot
>=
0
&&
s
->
iVarPivot
<=
s
->
size
);
assert
(
s
->
iSimpPivot
>=
0
&&
s
->
iSimpPivot
<=
s
->
qtail
);
assert
(
s
->
hClausePivot
>=
1
&&
s
->
hClausePivot
<=
veci_size
(
&
s
->
clauses
)
);
assert
(
s
->
hClausePivot
>=
1
&&
s
->
hClausePivot
<=
veci_size
(
&
s
->
clauses
)
);
assert
(
s
->
hLearntPivot
>=
1
&&
s
->
hLearntPivot
<=
veci_size
(
&
s
->
learnts
)
);
assert
(
s
->
hLearntPivot
>=
1
&&
s
->
hLearntPivot
<=
veci_size
(
&
s
->
learnts
)
);
assert
(
s
->
iVarPivot
>=
0
&&
s
->
iVarPivot
<=
s
->
size
);
// reset implication queue
veci_resize
(
&
s
->
order
,
0
);
solver2_canceluntil_rollback
(
s
,
s
->
iSimpPivot
);
if
(
s
->
hClausePivot
>
1
||
s
->
hLearntPivot
>
1
)
// update order
if
(
s
->
iVarPivot
<
s
->
size
)
{
{
// update order
veci_resize
(
&
s
->
order
,
0
);
for
(
i
=
0
;
i
<
s
->
iVarPivot
;
i
++
)
for
(
i
=
0
;
i
<
s
->
iVarPivot
;
i
++
)
{
{
if
(
var_value
(
s
,
i
)
!=
varX
)
if
(
var_value
(
s
,
i
)
!=
varX
)
...
@@ -1509,7 +1513,10 @@ void sat_solver2_rollback( sat_solver2* s )
...
@@ -1509,7 +1513,10 @@ void sat_solver2_rollback( sat_solver2* s )
veci_push
(
&
s
->
order
,
i
);
veci_push
(
&
s
->
order
,
i
);
order_update
(
s
,
i
);
order_update
(
s
,
i
);
}
}
// compact watches
}
// compact watches
if
(
s
->
hClausePivot
>
1
||
s
->
hLearntPivot
>
1
)
{
for
(
i
=
0
;
i
<
s
->
size
*
2
;
i
++
)
for
(
i
=
0
;
i
<
s
->
size
*
2
;
i
++
)
{
{
cla
*
pArray
=
veci_begin
(
&
s
->
wlists
[
i
]);
cla
*
pArray
=
veci_begin
(
&
s
->
wlists
[
i
]);
...
@@ -1519,9 +1526,6 @@ void sat_solver2_rollback( sat_solver2* s )
...
@@ -1519,9 +1526,6 @@ void sat_solver2_rollback( sat_solver2* s )
veci_resize
(
&
s
->
wlists
[
i
],
j
);
veci_resize
(
&
s
->
wlists
[
i
],
j
);
}
}
}
}
// reset implication queue
assert
(
solver2_dlevel
(
s
)
==
0
);
solver2_canceluntil_rollback
(
s
,
s
->
iSimpPivot
);
// reset problem clauses
// reset problem clauses
if
(
s
->
hClausePivot
<
veci_size
(
&
s
->
clauses
)
)
if
(
s
->
hClausePivot
<
veci_size
(
&
s
->
clauses
)
)
{
{
...
@@ -1557,6 +1561,7 @@ void sat_solver2_rollback( sat_solver2* s )
...
@@ -1557,6 +1561,7 @@ void sat_solver2_rollback( sat_solver2* s )
s
->
activity
[
i
]
=
(
1
<<
10
);
s
->
activity
[
i
]
=
(
1
<<
10
);
#endif
#endif
s
->
model
[
i
]
=
0
;
s
->
model
[
i
]
=
0
;
s
->
orderpos
[
i
]
=
-
1
;
}
}
s
->
size
=
s
->
iVarPivot
;
s
->
size
=
s
->
iVarPivot
;
// initialize other vars
// initialize other vars
...
@@ -1613,7 +1618,7 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose )
...
@@ -1613,7 +1618,7 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose )
if
(
(
pArray
[
k
]
>>
1
)
==
Hand
)
if
(
(
pArray
[
k
]
>>
1
)
==
Hand
)
{
{
if
(
fVerbose
)
if
(
fVerbose
)
printf
(
"Clause found in list %d
.
\n
"
,
k
);
printf
(
"Clause found in list %d
at position.
\n
"
,
i
,
k
);
Found
=
1
;
Found
=
1
;
break
;
break
;
}
}
...
@@ -1621,12 +1626,12 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose )
...
@@ -1621,12 +1626,12 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose )
if
(
Found
==
0
)
if
(
Found
==
0
)
{
{
if
(
fVerbose
)
if
(
fVerbose
)
printf
(
"Clause with hand %d is not found.
\n
"
,
Hand
);
printf
(
"Clause with hand
le
%d is not found.
\n
"
,
Hand
);
}
}
return
Found
;
return
Found
;
}
}
// verify that all clauses are satisfied
// verify that all
problem
clauses are satisfied
void
sat_solver2_verify
(
sat_solver2
*
s
)
void
sat_solver2_verify
(
sat_solver2
*
s
)
{
{
satset
*
c
;
satset
*
c
;
...
@@ -1738,7 +1743,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim
...
@@ -1738,7 +1743,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim
if
(
var_level
(
s
,
lit_var
(
p
))
>
0
)
if
(
var_level
(
s
,
lit_var
(
p
))
>
0
)
veci_push
(
&
s
->
conf_final
,
p
);
veci_push
(
&
s
->
conf_final
,
p
);
}
}
// solver2_record(s, &s->conf_final, proof_id, 1);
s
->
hProofLast
=
proof_id
;
s
->
hProofLast
=
proof_id
;
solver2_canceluntil
(
s
,
0
);
solver2_canceluntil
(
s
,
0
);
return
l_False
;
return
l_False
;
...
@@ -1749,7 +1753,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim
...
@@ -1749,7 +1753,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim
if
(
confl
!=
NULL
){
if
(
confl
!=
NULL
){
proof_id
=
solver2_analyze_final
(
s
,
confl
,
0
);
proof_id
=
solver2_analyze_final
(
s
,
confl
,
0
);
assert
(
s
->
conf_final
.
size
>
0
);
assert
(
s
->
conf_final
.
size
>
0
);
// solver2_record(s,&s->conf_final, proof_id, 1);
s
->
hProofLast
=
proof_id
;
s
->
hProofLast
=
proof_id
;
solver2_canceluntil
(
s
,
0
);
solver2_canceluntil
(
s
,
0
);
return
l_False
;
return
l_False
;
...
...
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