Example shows function display with Gnuplot.
// Copyright (C) 2009 by Thomas Moulard, AIST, CNRS, INRIA. // // This file is part of the roboptim. // // roboptim is free software: you can redistribute it and/or modify // it under the terms of the GNU Lesser General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // roboptim is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with roboptim. If not, see <http://www.gnu.org/licenses/>. #include "shared-tests/fixture.hh" #include <iostream> #include <roboptim/core/io.hh> #include <roboptim/core/visualization/gnuplot.hh> #include <roboptim/core/visualization/gnuplot-commands.hh> #include <roboptim/core/visualization/gnuplot-function.hh> using namespace roboptim; using namespace roboptim::visualization; // Define f(x) = x * x struct Square : public Function { explicit Square () : Function (1, 1, "x * x") { } void impl_compute (result_ref result, const_argument_ref argument) const { result[0] = argument[0] * argument[0]; } }; // Define a function that displays a circle. struct Circle : public Function { explicit Circle (double r = 1.) : Function (1, 2, "{sin (x) * r; cos (x) * r}"), r_ (r) { } void impl_compute (result_ref result, const_argument_ref argument) const { result[0] = sin (argument[0]) * r_; result[1] = cos (argument[0]) * r_; } double r_; }; // Define a function that displays a cubic and a quartic monomial. struct Poly : public Function { explicit Poly () : Function (1, 2, "{x^3; x^4}") { } void impl_compute (result_ref result, const_argument_ref argument) const { result[0] = argument[0] * argument[0] * argument[0]; result[1] = result[0] * argument[0]; } }; BOOST_FIXTURE_TEST_SUITE (core, TestSuiteConfiguration) BOOST_AUTO_TEST_CASE (visualization_gnuplot_function) { boost::shared_ptr<boost::test_tools::output_test_stream> output = retrievePattern ("visualization-gnuplot-function"); using namespace roboptim::visualization::gnuplot; Gnuplot gnuplot = Gnuplot::make_interactive_gnuplot (); Square square; discreteInterval_t intervalS (-10., 10., 0.01); Circle circle; discreteInterval_t intervalC (0., 2 * M_PI, 0.01); Poly poly; discreteInterval_t intervalP (-1., 1., 0.01); (*output) << (gnuplot << comment ("Hello, world (complex)!") << set ("multiplot layout 3,1") << plot (square, intervalS) << plot_xy (circle, intervalC) << plot (poly, intervalP) << unset ("multiplot") ); std::cout << output->str () << std::endl; BOOST_CHECK (output->match_pattern ()); } BOOST_AUTO_TEST_SUITE_END ()