From 42b2674d406e1ff0d59a2d113759a55d9fe17e84 Mon Sep 17 00:00:00 2001 From: John Siirola Date: Fri, 20 Sep 2024 03:30:25 -0600 Subject: [PATCH 01/17] Remove Octeract from the list of expected NEOS solvers --- pyomo/neos/tests/test_neos.py | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/pyomo/neos/tests/test_neos.py b/pyomo/neos/tests/test_neos.py index 681856781be..f14600fdb84 100644 --- a/pyomo/neos/tests/test_neos.py +++ b/pyomo/neos/tests/test_neos.py @@ -79,9 +79,6 @@ def test_doc(self): doc = pyomo.neos.doc dockeys = set(doc.keys()) - # Octeract interface is disabled, see #3321 - amplsolvers.remove('octeract') - self.assertEqual(amplsolvers, dockeys) # gamssolvers = set(v[0].lower() for v in tmp if v[1]=='GAMS') @@ -152,8 +149,9 @@ def test_minto(self): def test_mosek(self): self._run('mosek') - # [16 Jul 24] Octeract is erroring. We will disable the interface + # [16 Jul 24]: Octeract is erroring. We will disable the interface # (and testing) until we have time to resolve #3321 + # [20 Sep 24]: and appears to have been removed from NEOS # # def test_octeract(self): # self._run('octeract') From 2035cb435677690a15a035723852bec4d8c34824 Mon Sep 17 00:00:00 2001 From: John Siirola Date: Sun, 29 Sep 2024 21:01:52 -0600 Subject: [PATCH 02/17] Ensure PKGCONFIG is installed on Windows --- .github/workflows/test_branches.yml | 2 ++ .github/workflows/test_pr_and_main.yml | 2 ++ 2 files changed, 4 insertions(+) diff --git a/.github/workflows/test_branches.yml b/.github/workflows/test_branches.yml index 92c47b2d64b..9a0c058842a 100644 --- a/.github/workflows/test_branches.yml +++ b/.github/workflows/test_branches.yml @@ -215,6 +215,8 @@ jobs: if: matrix.TARGET == 'win' run: | echo "SETUPTOOLS_USE_DISTUTILS=local" >> $GITHUB_ENV + run: | + choco install pkgconfiglite - name: Set up Python ${{ matrix.python }} if: matrix.PYENV == 'pip' diff --git a/.github/workflows/test_pr_and_main.yml b/.github/workflows/test_pr_and_main.yml index 34efa4a029b..f08784d76df 100644 --- a/.github/workflows/test_pr_and_main.yml +++ b/.github/workflows/test_pr_and_main.yml @@ -243,6 +243,8 @@ jobs: if: matrix.TARGET == 'win' run: | echo "SETUPTOOLS_USE_DISTUTILS=local" >> $GITHUB_ENV + run: | + choco install pkgconfiglite - name: Set up Python ${{ matrix.python }} if: matrix.PYENV == 'pip' From e1815612dd3112ea12d6e6dddf0ab52701ea915f Mon Sep 17 00:00:00 2001 From: John Siirola Date: Sun, 29 Sep 2024 21:02:31 -0600 Subject: [PATCH 03/17] Reduce diffs between test drivers --- .github/workflows/test_branches.yml | 6 ++++++ .github/workflows/test_pr_and_main.yml | 17 +++++++++-------- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/.github/workflows/test_branches.yml b/.github/workflows/test_branches.yml index 9a0c058842a..e5aba64a38a 100644 --- a/.github/workflows/test_branches.yml +++ b/.github/workflows/test_branches.yml @@ -75,6 +75,12 @@ jobs: other: [""] category: [""] + # win/3.8 conda builds no longer work due to environment not being able + # to resolve. We are skipping it now. + exclude: + - os: windows-latest + python: 3.8 + include: - os: ubuntu-latest python: '3.12' diff --git a/.github/workflows/test_pr_and_main.yml b/.github/workflows/test_pr_and_main.yml index f08784d76df..33f21f9b1d1 100644 --- a/.github/workflows/test_pr_and_main.yml +++ b/.github/workflows/test_pr_and_main.yml @@ -77,6 +77,7 @@ jobs: exclude: - os: windows-latest python: 3.8 + include: - os: ubuntu-latest TARGET: linux @@ -108,14 +109,6 @@ jobs: PYENV: conda PACKAGES: openmpi mpi4py - - os: ubuntu-latest - python: '3.11' - other: /singletest - category: "-m 'neos or importtest'" - skip_doctest: 1 - TARGET: linux - PYENV: pip - - os: ubuntu-latest python: '3.10' other: /cython @@ -132,6 +125,14 @@ jobs: TARGET: win PYENV: pip + - os: ubuntu-latest + python: '3.11' + other: /singletest + category: "-m 'neos or importtest'" + skip_doctest: 1 + TARGET: linux + PYENV: pip + - os: ubuntu-latest python: 3.8 other: /slim From 7c6b32c8aeb8fbab686c4cd026fd297ecadc3e29 Mon Sep 17 00:00:00 2001 From: John Siirola Date: Sun, 29 Sep 2024 21:06:22 -0600 Subject: [PATCH 04/17] Fix redundant 'run' definition --- .github/workflows/test_branches.yml | 1 - .github/workflows/test_pr_and_main.yml | 1 - 2 files changed, 2 deletions(-) diff --git a/.github/workflows/test_branches.yml b/.github/workflows/test_branches.yml index e5aba64a38a..921520e5720 100644 --- a/.github/workflows/test_branches.yml +++ b/.github/workflows/test_branches.yml @@ -221,7 +221,6 @@ jobs: if: matrix.TARGET == 'win' run: | echo "SETUPTOOLS_USE_DISTUTILS=local" >> $GITHUB_ENV - run: | choco install pkgconfiglite - name: Set up Python ${{ matrix.python }} diff --git a/.github/workflows/test_pr_and_main.yml b/.github/workflows/test_pr_and_main.yml index 33f21f9b1d1..a006f6516f9 100644 --- a/.github/workflows/test_pr_and_main.yml +++ b/.github/workflows/test_pr_and_main.yml @@ -244,7 +244,6 @@ jobs: if: matrix.TARGET == 'win' run: | echo "SETUPTOOLS_USE_DISTUTILS=local" >> $GITHUB_ENV - run: | choco install pkgconfiglite - name: Set up Python ${{ matrix.python }} From a39a3ee1b7a58920eb1f0e6e33be03c9c3c6ba69 Mon Sep 17 00:00:00 2001 From: Miranda Mundt <55767766+mrmundt@users.noreply.github.com> Date: Mon, 30 Sep 2024 13:43:35 -0600 Subject: [PATCH 05/17] Pin setuptools to <74 for windows --- .github/workflows/test_pr_and_main.yml | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.github/workflows/test_pr_and_main.yml b/.github/workflows/test_pr_and_main.yml index a006f6516f9..ad989a08482 100644 --- a/.github/workflows/test_pr_and_main.yml +++ b/.github/workflows/test_pr_and_main.yml @@ -382,6 +382,10 @@ jobs: done echo "" echo "*** Install Pyomo dependencies ***" + # For windows, cannot use newer setuptools because of APPSI compilation issues + if test "${{matrix.TARGET}}" == 'win'; then + CONDA_DEPENDENCIES = "$CONDA_DEPENDENCIES setuptools<74.0.0" + fi # Note: this will fail the build if any installation fails (or # possibly if it outputs messages to stderr) conda install --update-deps -q -y $CONDA_DEPENDENCIES From fac372249bc8c7ed237fd0029917bb00edd78f7c Mon Sep 17 00:00:00 2001 From: Miranda Mundt <55767766+mrmundt@users.noreply.github.com> Date: Mon, 30 Sep 2024 13:44:13 -0600 Subject: [PATCH 06/17] Pinning to setuptools<74 for win --- .github/workflows/test_branches.yml | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.github/workflows/test_branches.yml b/.github/workflows/test_branches.yml index 921520e5720..89a5786c12c 100644 --- a/.github/workflows/test_branches.yml +++ b/.github/workflows/test_branches.yml @@ -359,6 +359,10 @@ jobs: done echo "" echo "*** Install Pyomo dependencies ***" + # For windows, cannot use newer setuptools because of APPSI compilation issues + if test "${{matrix.TARGET}}" == 'win'; then + CONDA_DEPENDENCIES = "$CONDA_DEPENDENCIES setuptools<74.0.0" + fi # Note: this will fail the build if any installation fails (or # possibly if it outputs messages to stderr) conda install --update-deps -q -y $CONDA_DEPENDENCIES From 6b8420b530f7d5b054e25573246f87c430fb9df1 Mon Sep 17 00:00:00 2001 From: Miranda Mundt <55767766+mrmundt@users.noreply.github.com> Date: Mon, 30 Sep 2024 13:56:28 -0600 Subject: [PATCH 07/17] Accidental extra spaces --- .github/workflows/test_pr_and_main.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/test_pr_and_main.yml b/.github/workflows/test_pr_and_main.yml index ad989a08482..b21d8a1c924 100644 --- a/.github/workflows/test_pr_and_main.yml +++ b/.github/workflows/test_pr_and_main.yml @@ -384,7 +384,7 @@ jobs: echo "*** Install Pyomo dependencies ***" # For windows, cannot use newer setuptools because of APPSI compilation issues if test "${{matrix.TARGET}}" == 'win'; then - CONDA_DEPENDENCIES = "$CONDA_DEPENDENCIES setuptools<74.0.0" + CONDA_DEPENDENCIES="$CONDA_DEPENDENCIES setuptools<74.0.0" fi # Note: this will fail the build if any installation fails (or # possibly if it outputs messages to stderr) From 14e6aefa897f981bc2909bda4f8aeed01aeb4cb2 Mon Sep 17 00:00:00 2001 From: Miranda Mundt <55767766+mrmundt@users.noreply.github.com> Date: Mon, 30 Sep 2024 13:56:49 -0600 Subject: [PATCH 08/17] Extra spaces --- .github/workflows/test_branches.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/test_branches.yml b/.github/workflows/test_branches.yml index 89a5786c12c..0e4284cc64d 100644 --- a/.github/workflows/test_branches.yml +++ b/.github/workflows/test_branches.yml @@ -361,7 +361,7 @@ jobs: echo "*** Install Pyomo dependencies ***" # For windows, cannot use newer setuptools because of APPSI compilation issues if test "${{matrix.TARGET}}" == 'win'; then - CONDA_DEPENDENCIES = "$CONDA_DEPENDENCIES setuptools<74.0.0" + CONDA_DEPENDENCIES="$CONDA_DEPENDENCIES setuptools<74.0.0" fi # Note: this will fail the build if any installation fails (or # possibly if it outputs messages to stderr) From 7408778b6ed76c59dbdb138ecef98d738d1dd23c Mon Sep 17 00:00:00 2001 From: Miranda Mundt <55767766+mrmundt@users.noreply.github.com> Date: Mon, 30 Sep 2024 14:42:02 -0600 Subject: [PATCH 09/17] Switch to macos-latest --- .github/workflows/test_pr_and_main.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/test_pr_and_main.yml b/.github/workflows/test_pr_and_main.yml index b21d8a1c924..33aacaa9e35 100644 --- a/.github/workflows/test_pr_and_main.yml +++ b/.github/workflows/test_pr_and_main.yml @@ -67,7 +67,7 @@ jobs: strategy: fail-fast: false matrix: - os: [ubuntu-latest, macos-13, windows-latest] + os: [ubuntu-latest, macos-latest, windows-latest] python: [ 3.8, 3.9, '3.10', '3.11', '3.12' ] other: [""] category: [""] @@ -83,7 +83,7 @@ jobs: TARGET: linux PYENV: pip - - os: macos-13 + - os: macos-latest TARGET: osx PYENV: pip From 21d1d2e8bb6618e136977242eeb762be26c23cbb Mon Sep 17 00:00:00 2001 From: Miranda Mundt <55767766+mrmundt@users.noreply.github.com> Date: Mon, 30 Sep 2024 14:42:24 -0600 Subject: [PATCH 10/17] Switch to macos-latest --- .github/workflows/test_branches.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/test_branches.yml b/.github/workflows/test_branches.yml index 0e4284cc64d..c1029ff3d7b 100644 --- a/.github/workflows/test_branches.yml +++ b/.github/workflows/test_branches.yml @@ -87,7 +87,7 @@ jobs: TARGET: linux PYENV: pip - - os: macos-13 + - os: macos-latest python: '3.10' TARGET: osx PYENV: pip From 9552b6986cb37cc76b59ad789f298374e5bcc1e7 Mon Sep 17 00:00:00 2001 From: Emma Johnson Date: Mon, 30 Sep 2024 20:51:08 -0600 Subject: [PATCH 11/17] Removing unreachable code in the kernel Delaunay test --- .../core/tests/unit/kernel/test_piecewise.py | 22 ++++++++----------- 1 file changed, 9 insertions(+), 13 deletions(-) diff --git a/pyomo/core/tests/unit/kernel/test_piecewise.py b/pyomo/core/tests/unit/kernel/test_piecewise.py index 3d9cf66e39c..7103ee39856 100644 --- a/pyomo/core/tests/unit/kernel/test_piecewise.py +++ b/pyomo/core/tests/unit/kernel/test_piecewise.py @@ -209,19 +209,15 @@ def test_generate_delaunay(self): vlist.append(variable(lb=0, ub=1)) vlist.append(variable(lb=1, ub=2)) vlist.append(variable(lb=2, ub=3)) - if not (util.numpy_available and util.scipy_available): - with self.assertRaises(ImportError): - util.generate_delaunay(vlist) - else: - tri = util.generate_delaunay(vlist, num=2) - self.assertTrue(isinstance(tri, util.scipy.spatial.Delaunay)) - self.assertEqual(len(tri.simplices), 6) - self.assertEqual(len(tri.points), 8) - - tri = util.generate_delaunay(vlist, num=3) - self.assertTrue(isinstance(tri, util.scipy.spatial.Delaunay)) - self.assertEqual(len(tri.simplices), 62) - self.assertEqual(len(tri.points), 27) + tri = util.generate_delaunay(vlist, num=2) + self.assertTrue(isinstance(tri, util.scipy.spatial.Delaunay)) + self.assertEqual(len(tri.simplices), 6) + self.assertEqual(len(tri.points), 8) + + tri = util.generate_delaunay(vlist, num=3) + self.assertTrue(isinstance(tri, util.scipy.spatial.Delaunay)) + self.assertEqual(len(tri.simplices), 62) + self.assertEqual(len(tri.points), 27) # # Check cases where not all variables are bounded From b89fd054f6ac14676d13dcf2a6158eaefe966e1d Mon Sep 17 00:00:00 2001 From: Miranda Mundt Date: Tue, 1 Oct 2024 14:01:19 -0600 Subject: [PATCH 12/17] Fix typos, one of which really doesn't seem like a typo --- pyomo/core/kernel/base.py | 2 +- pyomo/core/tests/unit/test_sets.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/pyomo/core/kernel/base.py b/pyomo/core/kernel/base.py index d599c76f6a1..0653868e109 100644 --- a/pyomo/core/kernel/base.py +++ b/pyomo/core/kernel/base.py @@ -156,7 +156,7 @@ def getname( Args: fully_qualified (bool): Generate a full name by - iterating through all anscestor containers. + iterating through all ancestor containers. Default is :const:`False`. convert (function): A function that converts a storage key into a string diff --git a/pyomo/core/tests/unit/test_sets.py b/pyomo/core/tests/unit/test_sets.py index 52c4523eaba..e9f96a417f4 100644 --- a/pyomo/core/tests/unit/test_sets.py +++ b/pyomo/core/tests/unit/test_sets.py @@ -2979,7 +2979,7 @@ def test_initialize_and_clone_from_dict_keys(self): # # While deepcopying a model is generally not supported, this is # an easy way to ensure that this simple model is cleanly - # clonable. + # able to be cloned. ref = """1 Set Declarations INDEX : Size=1, Index=None, Ordered=Insertion Key : Dimen : Domain : Size : Members From 2acc2d1734e971144017be4c7ffa2b4807525d20 Mon Sep 17 00:00:00 2001 From: Emma Johnson Date: Tue, 1 Oct 2024 14:06:36 -0600 Subject: [PATCH 13/17] Not testing number of simplices when we do a Delaunay triangulation over a grid (because the triangulation is not unique)--just checking that we used the points we expected and that we did indeed get simplices. --- pyomo/core/tests/unit/kernel/test_piecewise.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/pyomo/core/tests/unit/kernel/test_piecewise.py b/pyomo/core/tests/unit/kernel/test_piecewise.py index 7103ee39856..e376bdce8b3 100644 --- a/pyomo/core/tests/unit/kernel/test_piecewise.py +++ b/pyomo/core/tests/unit/kernel/test_piecewise.py @@ -216,8 +216,10 @@ def test_generate_delaunay(self): tri = util.generate_delaunay(vlist, num=3) self.assertTrue(isinstance(tri, util.scipy.spatial.Delaunay)) - self.assertEqual(len(tri.simplices), 62) - self.assertEqual(len(tri.points), 27) + # we got some simplices + self.assertTrue(len(tri.simplices) > 1) + # all the given points are accounted for + self.assertEqual(len(tri.points) + len(tri.coplanar), 27) # # Check cases where not all variables are bounded From 897d2ef1f80193ecd8402c93a2828b32fcd095bf Mon Sep 17 00:00:00 2001 From: John Siirola Date: Thu, 3 Oct 2024 12:54:37 -0600 Subject: [PATCH 14/17] Remove degeneracy from book example (does not change the book - only changes the use o a solver to test the book) --- examples/pyomobook/gdp-ch/gdp_uc.py | 5 ++++ examples/pyomobook/gdp-ch/pyomo.gdp_uc.txt | 30 +++++++++++----------- 2 files changed, 20 insertions(+), 15 deletions(-) diff --git a/examples/pyomobook/gdp-ch/gdp_uc.py b/examples/pyomobook/gdp-ch/gdp_uc.py index 6268bcce068..b87ee35e4e2 100644 --- a/examples/pyomobook/gdp-ch/gdp_uc.py +++ b/examples/pyomobook/gdp-ch/gdp_uc.py @@ -116,3 +116,8 @@ def obj(m): @model.Constraint(model.GENERATORS) def nontrivial(m, g): return sum(m.Power[g, t] for t in m.TIME) >= len(m.TIME) / 2 * m.MinPower[g] + +@model.ConstraintList() +def nondegenerate(m): + for i, g in enumerate(m.GENERATORS): + yield m.Power[g, i+1] == 0 diff --git a/examples/pyomobook/gdp-ch/pyomo.gdp_uc.txt b/examples/pyomobook/gdp-ch/pyomo.gdp_uc.txt index 477336d48ba..f0b5a5c4795 100644 --- a/examples/pyomobook/gdp-ch/pyomo.gdp_uc.txt +++ b/examples/pyomobook/gdp-ch/pyomo.gdp_uc.txt @@ -22,9 +22,9 @@ Problem: Lower bound: 45.0 Upper bound: 45.0 Number of objectives: 1 - Number of constraints: 58 + Number of constraints: 60 Number of variables: 24 - Number of nonzeros: 124 + Number of nonzeros: 126 Sense: minimize # ---------------------------------------------------------- # Solver Information @@ -34,8 +34,8 @@ Solver: Termination condition: optimal Statistics: Branch and bound: - Number of bounded subproblems: 15 - Number of created subproblems: 15 + Number of bounded subproblems: 9 + Number of created subproblems: 9 Error rc: 0 Time: 0.007754325866699219 # ---------------------------------------------------------- @@ -51,24 +51,24 @@ Solution: obj: Value: 45 Variable: - GenOff[g1,2].binary_indicator_var: + GenOff[g1,1].binary_indicator_var: Value: 1 - GenOff[g2,1].binary_indicator_var: + GenOff[g2,2].binary_indicator_var: Value: 1 - GenOn[g1,1].binary_indicator_var: + GenOn[g1,3].binary_indicator_var: Value: 1 - GenOn[g2,3].binary_indicator_var: + GenOn[g2,1].binary_indicator_var: Value: 1 - GenStartup[g1,3].binary_indicator_var: + GenStartup[g1,2].binary_indicator_var: Value: 1 - GenStartup[g2,2].binary_indicator_var: + GenStartup[g2,3].binary_indicator_var: Value: 1 - Power[g1,1]: - Value: 10 - Power[g1,3]: + Power[g1,2]: Value: 5 - Power[g2,2]: + Power[g1,3]: Value: 10 - Power[g2,3]: + Power[g2,1]: Value: 20 + Power[g2,3]: + Value: 10 Constraint: No values From 52d5667ada272ef843eeb786681de0902df6d8d2 Mon Sep 17 00:00:00 2001 From: John Siirola Date: Thu, 3 Oct 2024 12:59:53 -0600 Subject: [PATCH 15/17] Apply black --- examples/pyomobook/gdp-ch/gdp_uc.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/examples/pyomobook/gdp-ch/gdp_uc.py b/examples/pyomobook/gdp-ch/gdp_uc.py index b87ee35e4e2..ff3c554c039 100644 --- a/examples/pyomobook/gdp-ch/gdp_uc.py +++ b/examples/pyomobook/gdp-ch/gdp_uc.py @@ -117,7 +117,8 @@ def obj(m): def nontrivial(m, g): return sum(m.Power[g, t] for t in m.TIME) >= len(m.TIME) / 2 * m.MinPower[g] + @model.ConstraintList() def nondegenerate(m): for i, g in enumerate(m.GENERATORS): - yield m.Power[g, i+1] == 0 + yield m.Power[g, i + 1] == 0 From 0776d04c7c916de1577ee61d89ad32add4986661 Mon Sep 17 00:00:00 2001 From: Emma Johnson Date: Thu, 3 Oct 2024 13:54:02 -0600 Subject: [PATCH 16/17] Adding slight negative tolerance to post processing in FME test to see if that makes osx/3.12 happier? --- pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py b/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py index dc721488f74..c80eff9097b 100644 --- a/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py +++ b/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py @@ -562,7 +562,7 @@ def test_post_processing(self): fme = TransformationFactory('contrib.fourier_motzkin_elimination') fme.apply_to(m, vars_to_eliminate=disaggregatedVars, do_integer_arithmetic=True) # post-process - fme.post_process_fme_constraints(m, SolverFactory('glpk')) + fme.post_process_fme_constraints(m, SolverFactory('glpk'), tolerance=-1e-4) constraints = m._pyomo_contrib_fme_transformation.projected_constraints self.assertEqual(len(constraints), 11) From ad049f464c0bec9851bda19b2a492e4c6f543481 Mon Sep 17 00:00:00 2001 From: Emma Johnson Date: Thu, 3 Oct 2024 14:19:00 -0600 Subject: [PATCH 17/17] Tightening tolerance a little --- pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py b/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py index c80eff9097b..961d34a68c7 100644 --- a/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py +++ b/pyomo/contrib/fme/tests/test_fourier_motzkin_elimination.py @@ -562,7 +562,7 @@ def test_post_processing(self): fme = TransformationFactory('contrib.fourier_motzkin_elimination') fme.apply_to(m, vars_to_eliminate=disaggregatedVars, do_integer_arithmetic=True) # post-process - fme.post_process_fme_constraints(m, SolverFactory('glpk'), tolerance=-1e-4) + fme.post_process_fme_constraints(m, SolverFactory('glpk'), tolerance=-1e-6) constraints = m._pyomo_contrib_fme_transformation.projected_constraints self.assertEqual(len(constraints), 11)