Skip to content

Commit

Permalink
Introduce changeable magnitude weight factors for polling
Browse files Browse the repository at this point in the history
  • Loading branch information
jamescowens committed Oct 20, 2024
1 parent c6b0d35 commit 373a431
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 0 deletions.
17 changes: 17 additions & 0 deletions src/gridcoin/voting/result.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
// Distributed under the MIT/X11 software license, see the accompanying
// file COPYING or https://opensource.org/licenses/mit-license.php.

#include "gridcoin/protocol.h"
#include "main.h"
#include "gridcoin/beacon.h"
#include "gridcoin/quorum.h"
Expand Down Expand Up @@ -1133,6 +1134,22 @@ CAmount ResolveMoneySupplyForPoll(const Poll& poll)

return pindex->nMoneySupply;
}

Fraction ResolveMagnitudeWeightFactorForPoll(const Poll& poll)
{
Fraction magnitude_weight_factor(100, 567);

if (!poll.Expired(pindexBest->nTime)) {
ProtocolEntryOption protocol_entry = GetProtocolRegistry().Try("magnitudeweightfactor");

if (protocol_entry != nullptr) {
magnitude_weight_factor = Fraction().FromString(protocol_entry->m_value);
}
}

// TODO: Determine correct protocol entry for expired poll (i.e. protocol entry valid at the last poll block.
}

} // Anonymous namespace

// -----------------------------------------------------------------------------
Expand Down
12 changes: 12 additions & 0 deletions src/test/util_tests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1326,6 +1326,18 @@ BOOST_AUTO_TEST_CASE(util_Fraction_Initialization_from_int64_t)
BOOST_CHECK_EQUAL(fraction.IsNonNegative(), false);
}

BOOST_AUTO_TEST_CASE(util_Fraction_Initialization_from_string)
{
Fraction fraction = Fraction().FromString("100/-567");

BOOST_CHECK_EQUAL(fraction.GetNumerator(), -100);
BOOST_CHECK_EQUAL(fraction.GetDenominator(), 567);
BOOST_CHECK_EQUAL(fraction.IsSimplified(), true);
BOOST_CHECK_EQUAL(fraction.IsZero(), false);
BOOST_CHECK_EQUAL(fraction.IsPositive(), false);
BOOST_CHECK_EQUAL(fraction.IsNonNegative(), false);
}

BOOST_AUTO_TEST_CASE(util_Fraction_Simplify)
{
Fraction fraction(-4, -6);
Expand Down
16 changes: 16 additions & 0 deletions src/util.h
Original file line number Diff line number Diff line change
Expand Up @@ -340,6 +340,22 @@ class Fraction {
return strprintf("%" PRId64 "/" "%" PRId64, m_numerator, m_denominator);
}

Fraction FromString(const std::string& string) const
{
std::vector<std::string> string_fraction = split(string, "/");

int64_t numerator;
int64_t denominator;

if (string_fraction.size() != 2
|| !ParseInt64(string_fraction[0], &numerator)
|| !ParseInt64(string_fraction[1], &denominator)) {
throw std::out_of_range("Fraction input string cannot be parsed to fraction.");
}

return Fraction(numerator, denominator, true);
}

bool operator!()
{
return IsZero();
Expand Down

0 comments on commit 373a431

Please sign in to comment.