This example shows how to define a simple unconstrained optimization problem using ordinary C++ functions.
This example shows how to define a simple unconstrained optimization problem using ordinary C++ functions.
\[ \begin{aligned}
& \underset{x, y}{\text{minimize}} && (a - x)^2 + b (y - x^2)^2 \\
\end{aligned} \]
    1#include <alpaqa/example-util.hpp>
    5 
    6#include <iostream>
    7 
    8
    9
   11    
   12    RosenbrockProblem() : UnconstrProblem{2} {}
   13 
   14    
   15    real_t a = 2, b = 100;
   16 
   17    
   18    real_t eval_objective(crvec xy) const {
   19        auto x = xy(0), y = xy(1);
   20        return sq(a - x) + b * sq(y - sq(x));
   21    }
   22 
   23    
   24    void eval_objective_gradient(crvec xy, rvec grad) const {
   25        auto x = xy(0), y = xy(1);
   26        grad(0) = (2 * x) - (2 * a) - (4 * b * x * y) + (4 * b * x * sq(x));
   27        grad(1) = 2 * b * (y - sq(x));
   28    }
   29 
   30    
   31    static real_t sq(real_t x) { return x * x; }
   32};
   33 
   35    alpaqa::init_stdout();
   37 
   38    
   39    RosenbrockProblem problem;
   40 
   41    
   43 
   44    
   47 
   48    
   49    Solver::Params panocparam;
   50    panocparam.max_iter       = 500;
   51    panocparam.print_interval = 1;
   52    
   53    Direction::AcceleratorParams lbfgsparam;
   54    lbfgsparam.memory = 2;
   55 
   56    
   57    Solver solver{panocparam, lbfgsparam};
   58 
   59    
   61 
   62    
   63    auto stats = solver(counted_problem, {.tolerance = 1e-8}, x);
   64    
   65 
   66    
   67    std::cout << '\n' << *counted_problem.evaluations << '\n';
   68    std::cout << "status: " << stats.status << '\n'
   69              << "f = " << problem.eval_objective(x) << '\n'
   70              << "iterations: " << stats.iterations << '\n'
   71              << "ε = " << stats.ε << '\n'
   72              << "elapsed time:     "
   73              << std::chrono::duration<double>{stats.elapsed_time}.count()
   74              << " s" << '\n'
   75              << "x = " << x.transpose() << '\n'
   76              << "avg τ = " << (stats.sum_τ / stats.count_τ) << '\n'
   77              << "L-BFGS rejected = " << stats.direction_update_rejected << '\n'
   78              << "L-BFGS failures = " << stats.direction_failures << '\n'
   79              << "Line search failures = " << stats.linesearch_failures << '\n'
   80              << std::endl;
   81}
int main(int argc, const char *argv[])
Implements common problem functions for minimization problems without constraints.
#define USING_ALPAQA_CONFIG(Conf)
auto problem_with_counters_ref(Problem &p)
Wraps the given problem into a ProblemWithCounters and keeps track of how many times each function is...