Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F12428728
coinselection.h
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
4 KB
Subscribers
None
coinselection.h
View Options
// Copyright (c) 2017 The Bitcoin Core developers
// Distributed under the MIT software license, see the accompanying
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
#ifndef BITCOIN_WALLET_COINSELECTION_H
#define BITCOIN_WALLET_COINSELECTION_H
#include
<amount.h>
#include
<primitives/transaction.h>
#include
<random.h>
class
CFeeRate
;
//! target minimum change amount
static
constexpr
Amount
MIN_CHANGE
{
COIN
/
100
};
//! final minimum change amount after paying for fees
static
const
Amount
MIN_FINAL_CHANGE
=
MIN_CHANGE
/
2
;
class
CInputCoin
{
public
:
CInputCoin
(
const
CTransactionRef
&
tx
,
unsigned
int
i
)
{
if
(
!
tx
)
{
throw
std
::
invalid_argument
(
"tx should not be null"
);
}
if
(
i
>=
tx
->
vout
.
size
())
{
throw
std
::
out_of_range
(
"The output index is out of range"
);
}
outpoint
=
COutPoint
(
tx
->
GetId
(),
i
);
txout
=
tx
->
vout
[
i
];
effective_value
=
txout
.
nValue
;
}
CInputCoin
(
const
CTransactionRef
&
tx
,
unsigned
int
i
,
int
input_bytes
)
:
CInputCoin
(
tx
,
i
)
{
m_input_bytes
=
input_bytes
;
}
COutPoint
outpoint
;
CTxOut
txout
;
Amount
effective_value
;
Amount
m_fee
{
Amount
::
zero
()};
Amount
m_long_term_fee
{
Amount
::
zero
()};
/**
* Pre-computed estimated size of this output as a fully-signed input in a
* transaction. Can be -1 if it could not be calculated.
*/
int
m_input_bytes
{
-1
};
bool
operator
<
(
const
CInputCoin
&
rhs
)
const
{
return
outpoint
<
rhs
.
outpoint
;
}
bool
operator
!=
(
const
CInputCoin
&
rhs
)
const
{
return
outpoint
!=
rhs
.
outpoint
;
}
bool
operator
==
(
const
CInputCoin
&
rhs
)
const
{
return
outpoint
==
rhs
.
outpoint
;
}
};
struct
CoinEligibilityFilter
{
const
int
conf_mine
;
const
int
conf_theirs
;
const
uint64_t
max_ancestors
;
const
uint64_t
max_descendants
;
CoinEligibilityFilter
(
int
conf_mine_
,
int
conf_theirs_
,
uint64_t
max_ancestors_
)
:
conf_mine
(
conf_mine_
),
conf_theirs
(
conf_theirs_
),
max_ancestors
(
max_ancestors_
),
max_descendants
(
max_ancestors_
)
{}
CoinEligibilityFilter
(
int
conf_mine_
,
int
conf_theirs_
,
uint64_t
max_ancestors_
,
uint64_t
max_descendants_
)
:
conf_mine
(
conf_mine_
),
conf_theirs
(
conf_theirs_
),
max_ancestors
(
max_ancestors_
),
max_descendants
(
max_descendants_
)
{}
};
struct
OutputGroup
{
std
::
vector
<
CInputCoin
>
m_outputs
;
bool
m_from_me
{
true
};
Amount
m_value
=
Amount
::
zero
();
int
m_depth
{
999
};
size_t
m_ancestors
{
0
};
size_t
m_descendants
{
0
};
Amount
effective_value
=
Amount
::
zero
();
Amount
fee
=
Amount
::
zero
();
Amount
long_term_fee
=
Amount
::
zero
();
OutputGroup
()
{}
OutputGroup
(
std
::
vector
<
CInputCoin
>
&&
outputs
,
bool
from_me
,
Amount
value
,
int
depth
,
size_t
ancestors
,
size_t
descendants
)
:
m_outputs
(
std
::
move
(
outputs
)),
m_from_me
(
from_me
),
m_value
(
value
),
m_depth
(
depth
),
m_ancestors
(
ancestors
),
m_descendants
(
descendants
)
{}
OutputGroup
(
const
CInputCoin
&
output
,
int
depth
,
bool
from_me
,
size_t
ancestors
,
size_t
descendants
)
:
OutputGroup
()
{
Insert
(
output
,
depth
,
from_me
,
ancestors
,
descendants
);
}
void
Insert
(
const
CInputCoin
&
output
,
int
depth
,
bool
from_me
,
size_t
ancestors
,
size_t
descendants
);
std
::
vector
<
CInputCoin
>::
iterator
Discard
(
const
CInputCoin
&
output
);
bool
EligibleForSpending
(
const
CoinEligibilityFilter
&
eligibility_filter
)
const
;
//! Update the OutputGroup's fee, long_term_fee, and effective_value based
//! on the given feerates
void
SetFees
(
const
CFeeRate
effective_feerate
,
const
CFeeRate
long_term_feerate
);
OutputGroup
GetPositiveOnlyGroup
();
};
bool
SelectCoinsBnB
(
std
::
vector
<
OutputGroup
>
&
utxo_pool
,
const
Amount
&
target_value
,
const
Amount
&
cost_of_change
,
std
::
set
<
CInputCoin
>
&
out_set
,
Amount
&
value_ret
,
const
Amount
not_input_fees
);
// Original coin selection algorithm as a fallback
bool
KnapsackSolver
(
const
Amount
nTargetValue
,
std
::
vector
<
OutputGroup
>
&
groups
,
std
::
set
<
CInputCoin
>
&
setCoinsRet
,
Amount
&
nValueRet
);
#endif
// BITCOIN_WALLET_COINSELECTION_H
File Metadata
Details
Attached
Mime Type
text/x-c++
Expires
Sun, Dec 29, 19:26 (17 h, 18 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
4844940
Default Alt Text
coinselection.h (4 KB)
Attached To
rSTAGING Bitcoin ABC staging
Event Timeline
Log In to Comment