File: testChangeObjective.cpp

package info (click to toggle)
soplex 7.1.6%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,560 kB
  • sloc: cpp: 77,063; sh: 1,125; python: 672; makefile: 667; awk: 243; ansic: 93; php: 15
file content (59 lines) | stat: -rw-r--r-- 2,608 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*                                                                           */
/*                  This file is part of the class library                   */
/*       SoPlex --- the Sequential object-oriented simPlex.                  */
/*                                                                           */
/*  Copyright (c) 1996-2025 Zuse Institute Berlin (ZIB)                      */
/*                                                                           */
/*  Licensed under the Apache License, Version 2.0 (the "License");          */
/*  you may not use this file except in compliance with the License.         */
/*  You may obtain a copy of the License at                                  */
/*                                                                           */
/*      http://www.apache.org/licenses/LICENSE-2.0                           */
/*                                                                           */
/*  Unless required by applicable law or agreed to in writing, software      */
/*  distributed under the License is distributed on an "AS IS" BASIS,        */
/*  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/*  See the License for the specific language governing permissions and      */
/*  limitations under the License.                                           */
/*                                                                           */
/*  You should have received a copy of the Apache-2.0 license                */
/*  along with SoPlex; see the file LICENSE. If not email to soplex@zib.de.  */
/*                                                                           */
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */

/* Test a for a bug in soplex (version 1.4), which avoids the change of the objective. */

#include <sstream>
#include <soplex.h>

using namespace soplex;

const char lpstr[] =
  "Maximize               \n"
  " obj: x0 + x1          \n"
  "Subject To             \n"
  " c1: x0 + x1 <= 1      \n"
  " c2: x0 + x1 >= -1     \n"
  " c3: x0 - x1 <= 1      \n"
  " c4: x0 - x1 >= -1     \n"
  "Bounds                 \n"
  " 0 <= x0               \n"
  " 0 <= x1               \n"
  "End                    \n";

int main()
{
   SoPlex lp;
   std::istringstream is(lpstr);
   lp.readLPF(is);

   lp.optimize();
   std::cerr << lp.objValue() << std::endl;

   lp.changeSense(SoPlex::MINIMIZE);
   lp.optimize();
   std::cerr << lp.objValue() << std::endl;

   return 0;
}