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
8eb651c3
Commit
8eb651c3
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
ae0f03f4
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
91 additions
and
7 deletions
+91
-7
src/aig/gia/giaResub6.c
+50
-2
src/aig/gia/giaSupps.c
+41
-5
No files found.
src/aig/gia/giaResub6.c
View file @
8eb651c3
...
@@ -119,7 +119,7 @@ Res6_Man_t * Res6_ManRead( char * pFileName )
...
@@ -119,7 +119,7 @@ Res6_Man_t * Res6_ManRead( char * pFileName )
printf
(
"Cannot open input file
\"
%s
\"
.
\n
"
,
pFileName
);
printf
(
"Cannot open input file
\"
%s
\"
.
\n
"
,
pFileName
);
else
else
{
{
int
i
,
k
,
nIns
,
nNodes
,
nOuts
,
nPats
,
iLit
=
0
;
int
i
,
k
,
nIns
,
nNodes
,
nOuts
,
nPats
;
char
Temp
[
100
],
Buffer
[
100
];
char
Temp
[
100
],
Buffer
[
100
];
char
*
pLine
=
fgets
(
Buffer
,
100
,
pFile
);
char
*
pLine
=
fgets
(
Buffer
,
100
,
pFile
);
if
(
pLine
==
NULL
)
if
(
pLine
==
NULL
)
...
@@ -279,11 +279,57 @@ static inline void Res6_LitPrint( int iLit, int nDivs )
...
@@ -279,11 +279,57 @@ static inline void Res6_LitPrint( int iLit, int nDivs )
printf
(
"%d"
,
Abc_Lit2Var
(
iLit
)
);
printf
(
"%d"
,
Abc_Lit2Var
(
iLit
)
);
}
}
}
}
Vec_Int_t
*
Res6_FindSupport
(
Vec_Int_t
*
vSol
,
int
nDivs
)
{
int
i
,
iLit
;
Vec_Int_t
*
vSupp
=
Vec_IntAlloc
(
10
);
Vec_IntForEachEntry
(
vSol
,
iLit
,
i
)
if
(
iLit
>=
2
&&
iLit
<
2
*
nDivs
)
Vec_IntPushUnique
(
vSupp
,
Abc_Lit2Var
(
iLit
)
);
return
vSupp
;
}
void
Res6_PrintSuppSims
(
Vec_Int_t
*
vSol
,
word
**
ppLits
,
int
nWords
,
int
nDivs
)
{
Vec_Int_t
*
vSupp
=
Res6_FindSupport
(
vSol
,
nDivs
);
int
i
,
k
,
iObj
;
Vec_IntForEachEntry
(
vSupp
,
iObj
,
i
)
{
for
(
k
=
0
;
k
<
64
*
nWords
;
k
++
)
if
(
Abc_TtGetBit
(
ppLits
[
2
*
iObj
+
1
],
k
)
)
printf
(
"0"
);
else
if
(
Abc_TtGetBit
(
ppLits
[
2
*
iObj
],
k
)
)
printf
(
"1"
);
else
printf
(
"-"
);
printf
(
"
\n
"
);
}
for
(
k
=
0
;
k
<
64
*
nWords
;
k
++
)
{
Vec_IntForEachEntry
(
vSupp
,
iObj
,
i
)
if
(
Abc_TtGetBit
(
ppLits
[
2
*
iObj
+
1
],
k
)
)
printf
(
"0"
);
else
if
(
Abc_TtGetBit
(
ppLits
[
2
*
iObj
+
0
],
k
)
)
printf
(
"1"
);
else
printf
(
"-"
);
printf
(
"
\n
"
);
if
(
k
==
9
)
break
;
}
Vec_IntFree
(
vSupp
);
}
int
Res6_FindSupportSize
(
Vec_Int_t
*
vSol
,
int
nDivs
)
{
Vec_Int_t
*
vSupp
=
Res6_FindSupport
(
vSol
,
nDivs
);
int
Res
=
Vec_IntSize
(
vSupp
);
Vec_IntFree
(
vSupp
);
return
Res
;
}
void
Res6_PrintSolution
(
Vec_Int_t
*
vSol
,
int
nDivs
)
void
Res6_PrintSolution
(
Vec_Int_t
*
vSol
,
int
nDivs
)
{
{
int
iNode
,
nNodes
=
Vec_IntSize
(
vSol
)
/
2
-
1
;
int
iNode
,
nNodes
=
Vec_IntSize
(
vSol
)
/
2
-
1
;
assert
(
Vec_IntSize
(
vSol
)
%
2
==
0
);
assert
(
Vec_IntSize
(
vSol
)
%
2
==
0
);
printf
(
"Solution: In
+Div = %d Node = %d Out = %d
\n
"
,
nDivs
-
1
,
nNodes
,
1
);
printf
(
"Solution: In
= %d Div = %d Node = %d Out = %d
\n
"
,
Res6_FindSupportSize
(
vSol
,
nDivs
)
,
nDivs
-
1
,
nNodes
,
1
);
for
(
iNode
=
0
;
iNode
<=
nNodes
;
iNode
++
)
for
(
iNode
=
0
;
iNode
<=
nNodes
;
iNode
++
)
{
{
int
*
pLits
=
Vec_IntEntryP
(
vSol
,
2
*
iNode
);
int
*
pLits
=
Vec_IntEntryP
(
vSol
,
2
*
iNode
);
...
@@ -386,6 +432,8 @@ void Res6_ManResubCheck( char * pFileNameRes, char * pFileNameSol, int fVerbose
...
@@ -386,6 +432,8 @@ void Res6_ManResubCheck( char * pFileNameRes, char * pFileNameSol, int fVerbose
Res6_ManPrintProblem
(
p
,
0
);
Res6_ManPrintProblem
(
p
,
0
);
if
(
fVerbose
)
if
(
fVerbose
)
Res6_PrintSolution
(
vSol
,
p
->
nDivs
);
Res6_PrintSolution
(
vSol
,
p
->
nDivs
);
//if ( fVerbose )
// Res6_PrintSuppSims( vSol, p->ppLits, p->nWords, p->nDivs );
Res6_ManResubVerify
(
p
,
vSol
);
Res6_ManResubVerify
(
p
,
vSol
);
Vec_IntFree
(
vSol
);
Vec_IntFree
(
vSol
);
Res6_ManStop
(
p
);
Res6_ManStop
(
p
);
...
...
src/aig/gia/giaSupps.c
View file @
8eb651c3
...
@@ -46,6 +46,7 @@ struct Supp_Man_t_
...
@@ -46,6 +46,7 @@ struct Supp_Man_t_
Gia_Man_t
*
pGia
;
// used for object names
Gia_Man_t
*
pGia
;
// used for object names
// computed data
// computed data
Vec_Wrd_t
*
vDivs
[
2
];
// simulation values
Vec_Wrd_t
*
vDivs
[
2
];
// simulation values
Vec_Wrd_t
*
vDivsC
[
2
];
// simulation values
Vec_Wrd_t
*
vPats
[
2
];
// simulation values
Vec_Wrd_t
*
vPats
[
2
];
// simulation values
Vec_Ptr_t
*
vMatrix
;
// simulation values
Vec_Ptr_t
*
vMatrix
;
// simulation values
Vec_Wrd_t
*
vMask
;
// simulation values
Vec_Wrd_t
*
vMask
;
// simulation values
...
@@ -143,9 +144,10 @@ int Supp_DeriveLines( Supp_Man_t * p )
...
@@ -143,9 +144,10 @@ int Supp_DeriveLines( Supp_Man_t * p )
{
{
p
->
vDivs
[
n
]
=
Vec_WrdStart
(
64
*
nWords
*
nDivWords
);
p
->
vDivs
[
n
]
=
Vec_WrdStart
(
64
*
nWords
*
nDivWords
);
p
->
vPats
[
n
]
=
Vec_WrdStart
(
64
*
nWords
*
nDivWords
);
p
->
vPats
[
n
]
=
Vec_WrdStart
(
64
*
nWords
*
nDivWords
);
//p->vDivsC[n] = Vec_WrdStart( 64*nWords*nDivWords );
if
(
p
->
vSimsC
)
if
(
p
->
vSimsC
)
Vec_IntForEachEntry
(
p
->
vCands
,
iObj
,
i
)
Vec_IntForEachEntry
(
p
->
vCands
,
iObj
,
i
)
Abc_TtAndSharp
(
Vec_WrdEntryP
(
p
->
vDivs
[
n
],
i
*
nWords
),
Vec_WrdEntryP
(
p
->
vSimsC
,
iObj
*
nWords
),
Vec_WrdEntryP
(
p
->
vSims
,
iObj
*
nWords
),
nWords
,
!
n
);
Abc_TtAndSharp
(
Vec_WrdEntryP
(
p
->
vDivs
C
[
n
],
i
*
nWords
),
Vec_WrdEntryP
(
p
->
vSimsC
,
iObj
*
nWords
),
Vec_WrdEntryP
(
p
->
vSims
,
iObj
*
nWords
),
nWords
,
!
n
);
else
else
Vec_IntForEachEntry
(
p
->
vCands
,
iObj
,
i
)
Vec_IntForEachEntry
(
p
->
vCands
,
iObj
,
i
)
Abc_TtCopy
(
Vec_WrdEntryP
(
p
->
vDivs
[
n
],
i
*
nWords
),
Vec_WrdEntryP
(
p
->
vSims
,
iObj
*
nWords
),
nWords
,
!
n
);
Abc_TtCopy
(
Vec_WrdEntryP
(
p
->
vDivs
[
n
],
i
*
nWords
),
Vec_WrdEntryP
(
p
->
vSims
,
iObj
*
nWords
),
nWords
,
!
n
);
...
@@ -195,6 +197,8 @@ void Supp_ManDelete( Supp_Man_t * p )
...
@@ -195,6 +197,8 @@ void Supp_ManDelete( Supp_Man_t * p )
Supp_ManCleanMatrix
(
p
);
Supp_ManCleanMatrix
(
p
);
Vec_WrdFreeP
(
&
p
->
vDivs
[
0
]
);
Vec_WrdFreeP
(
&
p
->
vDivs
[
0
]
);
Vec_WrdFreeP
(
&
p
->
vDivs
[
1
]
);
Vec_WrdFreeP
(
&
p
->
vDivs
[
1
]
);
Vec_WrdFreeP
(
&
p
->
vDivsC
[
0
]
);
Vec_WrdFreeP
(
&
p
->
vDivsC
[
1
]
);
Vec_WrdFreeP
(
&
p
->
vPats
[
0
]
);
Vec_WrdFreeP
(
&
p
->
vPats
[
0
]
);
Vec_WrdFreeP
(
&
p
->
vPats
[
1
]
);
Vec_WrdFreeP
(
&
p
->
vPats
[
1
]
);
Vec_PtrFreeP
(
&
p
->
vMatrix
);
Vec_PtrFreeP
(
&
p
->
vMatrix
);
...
@@ -682,10 +686,27 @@ void Supp_DeriveDumpSims( FILE * pFile, Vec_Wrd_t * vDivs, int nWords )
...
@@ -682,10 +686,27 @@ void Supp_DeriveDumpSims( FILE * pFile, Vec_Wrd_t * vDivs, int nWords )
fprintf
(
pFile
,
"
\n
"
);
fprintf
(
pFile
,
"
\n
"
);
}
}
}
}
void
Supp_DeriveDumpSimsC
(
FILE
*
pFile
,
Vec_Wrd_t
*
vDivs
[
2
],
int
nWords
)
{
int
i
,
k
,
nDivs
=
Vec_WrdSize
(
vDivs
[
0
])
/
nWords
;
for
(
i
=
0
;
i
<
nDivs
;
i
++
)
{
word
*
pSim0
=
Vec_WrdEntryP
(
vDivs
[
0
],
i
*
nWords
);
word
*
pSim1
=
Vec_WrdEntryP
(
vDivs
[
1
],
i
*
nWords
);
for
(
k
=
0
;
k
<
64
*
nWords
;
k
++
)
if
(
Abc_TtGetBit
(
pSim0
,
k
)
)
fprintf
(
pFile
,
"0"
);
else
if
(
Abc_TtGetBit
(
pSim1
,
k
)
)
fprintf
(
pFile
,
"1"
);
else
fprintf
(
pFile
,
"-"
);
fprintf
(
pFile
,
"
\n
"
);
}
}
void
Supp_DeriveDumpProb
(
Vec_Wrd_t
*
vIsfs
,
Vec_Wrd_t
*
vDivs
,
int
nWords
)
void
Supp_DeriveDumpProb
(
Vec_Wrd_t
*
vIsfs
,
Vec_Wrd_t
*
vDivs
,
int
nWords
)
{
{
char
Buffer
[
100
];
int
nDivs
=
Vec_WrdSize
(
vDivs
)
/
nWords
;
char
Buffer
[
100
];
int
nDivs
=
Vec_WrdSize
(
vDivs
)
/
nWords
;
int
RetValue
=
sprintf
(
Buffer
,
"
case01_
%02d.resub"
,
s_Counter
);
int
RetValue
=
sprintf
(
Buffer
,
"%02d.resub"
,
s_Counter
);
FILE
*
pFile
=
fopen
(
Buffer
,
"wb"
);
FILE
*
pFile
=
fopen
(
Buffer
,
"wb"
);
if
(
pFile
==
NULL
)
if
(
pFile
==
NULL
)
printf
(
"Cannot open output file.
\n
"
);
printf
(
"Cannot open output file.
\n
"
);
...
@@ -696,10 +717,24 @@ void Supp_DeriveDumpProb( Vec_Wrd_t * vIsfs, Vec_Wrd_t * vDivs, int nWords )
...
@@ -696,10 +717,24 @@ void Supp_DeriveDumpProb( Vec_Wrd_t * vIsfs, Vec_Wrd_t * vDivs, int nWords )
fclose
(
pFile
);
fclose
(
pFile
);
RetValue
=
0
;
RetValue
=
0
;
}
}
void
Supp_DeriveDumpProbC
(
Vec_Wrd_t
*
vIsfs
,
Vec_Wrd_t
*
vDivs
[
2
],
int
nWords
)
{
char
Buffer
[
100
];
int
nDivs
=
Vec_WrdSize
(
vDivs
[
0
])
/
nWords
;
int
RetValue
=
sprintf
(
Buffer
,
"%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_DeriveDumpSimsC
(
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
)
void
Supp_DeriveDumpSol
(
Vec_Int_t
*
vSet
,
Vec_Int_t
*
vRes
,
int
nDivs
)
{
{
char
Buffer
[
100
];
char
Buffer
[
100
];
int
RetValue
=
sprintf
(
Buffer
,
"
case01_
%02d.sol"
,
s_Counter
);
int
RetValue
=
sprintf
(
Buffer
,
"%02d.sol"
,
s_Counter
);
int
i
,
iLit
,
iLitRes
=
-
1
,
nSupp
=
Vec_IntSize
(
vSet
);
int
i
,
iLit
,
iLitRes
=
-
1
,
nSupp
=
Vec_IntSize
(
vSet
);
FILE
*
pFile
=
fopen
(
Buffer
,
"wb"
);
FILE
*
pFile
=
fopen
(
Buffer
,
"wb"
);
if
(
pFile
==
NULL
)
if
(
pFile
==
NULL
)
...
@@ -779,7 +814,10 @@ Vec_Int_t * Supp_ManFindBestSolution( Supp_Man_t * p, Vec_Wec_t * vSols, int fVe
...
@@ -779,7 +814,10 @@ 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_DeriveDumpProbC( p->vIsfs, p->vDivsC, p->nWords );
//Supp_DeriveDumpProb( p->vIsfs, p->vDivs[1], p->nWords );
//Supp_DeriveDumpSol( vSet, vRes, Vec_WrdSize(p->vDivs[1])/p->nWords );
//Supp_DeriveDumpSol( vSet, vRes, Vec_WrdSize(p->vDivs[1])/p->nWords );
//s_Counter++;
}
}
return
vRes
;
return
vRes
;
}
}
...
@@ -877,8 +915,6 @@ Vec_Int_t * Supp_ManCompute( Vec_Wrd_t * vIsfs, Vec_Int_t * vCands, Vec_Int_t *
...
@@ -877,8 +915,6 @@ 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 );
//Vec_IntPrint( vRes );
Supp_ManDelete
(
p
);
Supp_ManDelete
(
p
);
// if ( vRes && Vec_IntSize(vRes) == 0 )
// if ( vRes && Vec_IntSize(vRes) == 0 )
...
...
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