mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
[yul-phaser] Add --metric option
This commit is contained in:
parent
e4a360947b
commit
8e64c5c6f0
@ -61,6 +61,7 @@ protected:
|
|||||||
CharStream m_sourceStream = CharStream("{}", "");
|
CharStream m_sourceStream = CharStream("{}", "");
|
||||||
Program m_program = get<Program>(Program::load(m_sourceStream));
|
Program m_program = get<Program>(Program::load(m_sourceStream));
|
||||||
FitnessMetricFactory::Options m_options = {
|
FitnessMetricFactory::Options m_options = {
|
||||||
|
/* metric = */ MetricChoice::CodeSize,
|
||||||
/* chromosomeRepetitions = */ 1,
|
/* chromosomeRepetitions = */ 1,
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -141,16 +142,18 @@ BOOST_AUTO_TEST_SUITE(FitnessMetricFactoryTest)
|
|||||||
|
|
||||||
BOOST_FIXTURE_TEST_CASE(build_should_create_metric_of_the_right_type, FitnessMetricFactoryFixture)
|
BOOST_FIXTURE_TEST_CASE(build_should_create_metric_of_the_right_type, FitnessMetricFactoryFixture)
|
||||||
{
|
{
|
||||||
|
m_options.metric = MetricChoice::RelativeCodeSize;
|
||||||
unique_ptr<FitnessMetric> metric = FitnessMetricFactory::build(m_options, m_program);
|
unique_ptr<FitnessMetric> metric = FitnessMetricFactory::build(m_options, m_program);
|
||||||
BOOST_REQUIRE(metric != nullptr);
|
BOOST_REQUIRE(metric != nullptr);
|
||||||
|
|
||||||
auto programSizeMetric = dynamic_cast<ProgramSize*>(metric.get());
|
auto relativeProgramSizeMetric = dynamic_cast<RelativeProgramSize*>(metric.get());
|
||||||
BOOST_REQUIRE(programSizeMetric != nullptr);
|
BOOST_REQUIRE(relativeProgramSizeMetric != nullptr);
|
||||||
BOOST_TEST(toString(programSizeMetric->program()) == toString(m_program));
|
BOOST_TEST(toString(relativeProgramSizeMetric->program()) == toString(m_program));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_FIXTURE_TEST_CASE(build_should_respect_chromosome_repetitions_option, FitnessMetricFactoryFixture)
|
BOOST_FIXTURE_TEST_CASE(build_should_respect_chromosome_repetitions_option, FitnessMetricFactoryFixture)
|
||||||
{
|
{
|
||||||
|
m_options.metric = MetricChoice::CodeSize;
|
||||||
m_options.chromosomeRepetitions = 5;
|
m_options.chromosomeRepetitions = 5;
|
||||||
unique_ptr<FitnessMetric> metric = FitnessMetricFactory::build(m_options, m_program);
|
unique_ptr<FitnessMetric> metric = FitnessMetricFactory::build(m_options, m_program);
|
||||||
BOOST_REQUIRE(metric != nullptr);
|
BOOST_REQUIRE(metric != nullptr);
|
||||||
|
@ -53,10 +53,19 @@ map<Algorithm, string> const AlgorithmToStringMap =
|
|||||||
};
|
};
|
||||||
map<string, Algorithm> const StringToAlgorithmMap = invertMap(AlgorithmToStringMap);
|
map<string, Algorithm> const StringToAlgorithmMap = invertMap(AlgorithmToStringMap);
|
||||||
|
|
||||||
|
map<MetricChoice, string> MetricChoiceToStringMap =
|
||||||
|
{
|
||||||
|
{MetricChoice::CodeSize, "code-size"},
|
||||||
|
{MetricChoice::RelativeCodeSize, "relative-code-size"},
|
||||||
|
};
|
||||||
|
map<string, MetricChoice> const StringToMetricChoiceMap = invertMap(MetricChoiceToStringMap);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
istream& phaser::operator>>(istream& _inputStream, Algorithm& _algorithm) { return deserializeChoice(_inputStream, _algorithm, StringToAlgorithmMap); }
|
istream& phaser::operator>>(istream& _inputStream, Algorithm& _algorithm) { return deserializeChoice(_inputStream, _algorithm, StringToAlgorithmMap); }
|
||||||
ostream& phaser::operator<<(ostream& _outputStream, Algorithm _algorithm) { return serializeChoice(_outputStream, _algorithm, AlgorithmToStringMap); }
|
ostream& phaser::operator<<(ostream& _outputStream, Algorithm _algorithm) { return serializeChoice(_outputStream, _algorithm, AlgorithmToStringMap); }
|
||||||
|
istream& phaser::operator>>(istream& _inputStream, MetricChoice& _metric) { return deserializeChoice(_inputStream, _metric, StringToMetricChoiceMap); }
|
||||||
|
ostream& phaser::operator<<(ostream& _outputStream, MetricChoice _metric) { return serializeChoice(_outputStream, _metric, MetricChoiceToStringMap); }
|
||||||
|
|
||||||
GeneticAlgorithmFactory::Options GeneticAlgorithmFactory::Options::fromCommandLine(po::variables_map const& _arguments)
|
GeneticAlgorithmFactory::Options GeneticAlgorithmFactory::Options::fromCommandLine(po::variables_map const& _arguments)
|
||||||
{
|
{
|
||||||
@ -129,6 +138,7 @@ unique_ptr<GeneticAlgorithm> GeneticAlgorithmFactory::build(
|
|||||||
FitnessMetricFactory::Options FitnessMetricFactory::Options::fromCommandLine(po::variables_map const& _arguments)
|
FitnessMetricFactory::Options FitnessMetricFactory::Options::fromCommandLine(po::variables_map const& _arguments)
|
||||||
{
|
{
|
||||||
return {
|
return {
|
||||||
|
_arguments["metric"].as<MetricChoice>(),
|
||||||
_arguments["chromosome-repetitions"].as<size_t>(),
|
_arguments["chromosome-repetitions"].as<size_t>(),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -138,7 +148,22 @@ unique_ptr<FitnessMetric> FitnessMetricFactory::build(
|
|||||||
Program _program
|
Program _program
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return make_unique<ProgramSize>(move(_program), _options.chromosomeRepetitions);
|
switch (_options.metric)
|
||||||
|
{
|
||||||
|
case MetricChoice::CodeSize:
|
||||||
|
return make_unique<ProgramSize>(
|
||||||
|
move(_program),
|
||||||
|
_options.chromosomeRepetitions
|
||||||
|
);
|
||||||
|
case MetricChoice::RelativeCodeSize:
|
||||||
|
return make_unique<RelativeProgramSize>(
|
||||||
|
move(_program),
|
||||||
|
3,
|
||||||
|
_options.chromosomeRepetitions
|
||||||
|
);
|
||||||
|
default:
|
||||||
|
assertThrow(false, solidity::util::Exception, "Invalid MetricChoice value.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
PopulationFactory::Options PopulationFactory::Options::fromCommandLine(po::variables_map const& _arguments)
|
PopulationFactory::Options PopulationFactory::Options::fromCommandLine(po::variables_map const& _arguments)
|
||||||
@ -391,6 +416,11 @@ Phaser::CommandLineDescription Phaser::buildCommandLineDescription()
|
|||||||
|
|
||||||
po::options_description metricsDescription("METRICS", lineLength, minDescriptionLength);
|
po::options_description metricsDescription("METRICS", lineLength, minDescriptionLength);
|
||||||
metricsDescription.add_options()
|
metricsDescription.add_options()
|
||||||
|
(
|
||||||
|
"metric",
|
||||||
|
po::value<MetricChoice>()->value_name("<NAME>")->default_value(MetricChoice::CodeSize),
|
||||||
|
"Metric used to evaluate the fitness of a chromosome."
|
||||||
|
)
|
||||||
(
|
(
|
||||||
"chromosome-repetitions",
|
"chromosome-repetitions",
|
||||||
po::value<size_t>()->value_name("<COUNT>")->default_value(1),
|
po::value<size_t>()->value_name("<COUNT>")->default_value(1),
|
||||||
|
@ -52,8 +52,16 @@ enum class Algorithm
|
|||||||
GEWEP,
|
GEWEP,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum class MetricChoice
|
||||||
|
{
|
||||||
|
CodeSize,
|
||||||
|
RelativeCodeSize,
|
||||||
|
};
|
||||||
|
|
||||||
std::istream& operator>>(std::istream& _inputStream, solidity::phaser::Algorithm& _algorithm);
|
std::istream& operator>>(std::istream& _inputStream, solidity::phaser::Algorithm& _algorithm);
|
||||||
std::ostream& operator<<(std::ostream& _outputStream, solidity::phaser::Algorithm _algorithm);
|
std::ostream& operator<<(std::ostream& _outputStream, solidity::phaser::Algorithm _algorithm);
|
||||||
|
std::istream& operator>>(std::istream& _inputStream, solidity::phaser::MetricChoice& _metric);
|
||||||
|
std::ostream& operator<<(std::ostream& _outputStream, solidity::phaser::MetricChoice _metric);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builds and validates instances of @a GeneticAlgorithm and its derived classes.
|
* Builds and validates instances of @a GeneticAlgorithm and its derived classes.
|
||||||
@ -91,6 +99,7 @@ class FitnessMetricFactory
|
|||||||
public:
|
public:
|
||||||
struct Options
|
struct Options
|
||||||
{
|
{
|
||||||
|
MetricChoice metric;
|
||||||
size_t chromosomeRepetitions;
|
size_t chromosomeRepetitions;
|
||||||
|
|
||||||
static Options fromCommandLine(boost::program_options::variables_map const& _arguments);
|
static Options fromCommandLine(boost::program_options::variables_map const& _arguments);
|
||||||
|
Loading…
Reference in New Issue
Block a user