<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mintoc.de/index.php?action=history&amp;feed=atom&amp;title=Three_Tank_multimode_problem_%28python%2Fcasadi%29</id>
	<title>Three Tank multimode problem (python/casadi) - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mintoc.de/index.php?action=history&amp;feed=atom&amp;title=Three_Tank_multimode_problem_%28python%2Fcasadi%29"/>
	<link rel="alternate" type="text/html" href="https://mintoc.de/index.php?title=Three_Tank_multimode_problem_(python/casadi)&amp;action=history"/>
	<updated>2026-06-09T07:58:39Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.1</generator>
	<entry>
		<id>https://mintoc.de/index.php?title=Three_Tank_multimode_problem_(python/casadi)&amp;diff=2683&amp;oldid=prev</id>
		<title>RobertLampel at 07:36, 14 October 2025</title>
		<link rel="alternate" type="text/html" href="https://mintoc.de/index.php?title=Three_Tank_multimode_problem_(python/casadi)&amp;diff=2683&amp;oldid=prev"/>
		<updated>2025-10-14T07:36:22Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 07:36, 14 October 2025&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l2&quot;&gt;Line 2:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 2:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;The model in Python code for a fixed control discretization grid using direct multiple shooting. We use pycombina for solving the (CIA) problem.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;The model in Python code for a fixed control discretization grid using direct multiple shooting. We use pycombina for solving the (CIA) problem.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;source &lt;/del&gt;lang=&quot;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Python&lt;/del&gt;&quot;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;syntaxhighlight &lt;/ins&gt;lang=&quot;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;python&lt;/ins&gt;&quot; &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;line&lt;/ins&gt;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;# Three tank optimal control&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;# Three tank optimal control&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l272&quot;&gt;Line 272:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 272:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;source&lt;/del&gt;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;/syntaxhighlight&lt;/ins&gt;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>RobertLampel</name></author>
	</entry>
	<entry>
		<id>https://mintoc.de/index.php?title=Three_Tank_multimode_problem_(python/casadi)&amp;diff=2335&amp;oldid=prev</id>
		<title>ClemensZeile: Created page with &quot;=== Casadi ===  The model in Python code for a fixed control discretization grid using direct multiple shooting. We use pycombina for solving the (CIA) problem. &lt;source lang=&quot;...&quot;</title>
		<link rel="alternate" type="text/html" href="https://mintoc.de/index.php?title=Three_Tank_multimode_problem_(python/casadi)&amp;diff=2335&amp;oldid=prev"/>
		<updated>2020-03-14T09:17:46Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;=== Casadi ===  The model in Python code for a fixed control discretization grid using direct multiple shooting. We use pycombina for solving the (CIA) problem. &amp;lt;source lang=&amp;quot;...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;=== Casadi ===&lt;br /&gt;
&lt;br /&gt;
The model in Python code for a fixed control discretization grid using direct multiple shooting. We use pycombina for solving the (CIA) problem.&lt;br /&gt;
&amp;lt;source lang=&amp;quot;Python&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
# Three tank optimal control&lt;br /&gt;
# ----------------------&lt;br /&gt;
# An optimal control problem (OCP),&lt;br /&gt;
# solved with direct multiple-shooting.&lt;br /&gt;
#&lt;br /&gt;
# For more information on CasADi see: http://labs.casadi.org/OCP&lt;br /&gt;
from casadi import *&lt;br /&gt;
import pylab as pl&lt;br /&gt;
from pycombina import BinApprox, CombinaBnB&lt;br /&gt;
import matplotlib.pyplot as plt&lt;br /&gt;
&lt;br /&gt;
############# Input variables ############# &lt;br /&gt;
T = 12&lt;br /&gt;
N = 100 # number of control intervals&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
############# End of Input variables ############# &lt;br /&gt;
&lt;br /&gt;
opti = Opti() # Optimization problem&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
#------- parameter values --------------&lt;br /&gt;
# Model parameters&lt;br /&gt;
k_1 = 2&lt;br /&gt;
k_2 = 3&lt;br /&gt;
k_3 = 1&lt;br /&gt;
k_4 = 3&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
c_1 = 1&lt;br /&gt;
c_2 = 2&lt;br /&gt;
c_3 = 0.8&lt;br /&gt;
T = 12&lt;br /&gt;
&lt;br /&gt;
# ---- decision variables ---------&lt;br /&gt;
X = opti.variable(4,N+1) # state trajectory&lt;br /&gt;
x1   = X[0,:]&lt;br /&gt;
x2 = X[1,:]&lt;br /&gt;
x3 = X[2,:]&lt;br /&gt;
x4 = X[3,:]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
U = opti.variable(3,N)   # control trajectory (throttle)&lt;br /&gt;
u1   = U[0,:]&lt;br /&gt;
u2 = U[1,:]&lt;br /&gt;
u3 = U[2,:]&lt;br /&gt;
&lt;br /&gt;
# ---- objective          ---------&lt;br /&gt;
opti.minimize(x4[N]) # Objective as Mayer term&lt;br /&gt;
&lt;br /&gt;
# ---- dynamic constraints -------&lt;br /&gt;
f = lambda x,u: vertcat(c_1*u[0]+c_2*u[1]-(x[0])**0.5-  u[2]* (c_3*x[0])**0.5 , (x[0])**0.5- (x[1])**0.5, (x[1])**0.5- (x[2])**0.5 +u[2]* (c_3*x[0])**0.5 , u[1]*0.0+ k_1*(x[1]-k_2)**2 + k_3*(x[2]-k_4)**2 ) # dx/dt = f(x,u)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
dt = T/N # length of a control interval&lt;br /&gt;
for k in range(N): # loop over control intervals&lt;br /&gt;
   # Runge-Kutta 4 integration&lt;br /&gt;
   k1 = f(X[:,k],         U[:,k])&lt;br /&gt;
   k2 = f(X[:,k]+dt/2*k1, U[:,k])&lt;br /&gt;
   k3 = f(X[:,k]+dt/2*k2, U[:,k])&lt;br /&gt;
   k4 = f(X[:,k]+dt*k3,   U[:,k])&lt;br /&gt;
   x_next = X[:,k] + dt/6*(k1+2*k2+2*k3+k4) &lt;br /&gt;
   opti.subject_to(X[:,k+1]==x_next) # close the gaps&lt;br /&gt;
&lt;br /&gt;
# ---- path constraints -----------&lt;br /&gt;
&lt;br /&gt;
opti.subject_to(opti.bounded(0,U,1)) # control is limited&lt;br /&gt;
opti.subject_to(u1+u2+u3 == 1) # SOS1 constraint&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# ---- boundary conditions --------&lt;br /&gt;
opti.subject_to(x1[0]==2)   # intitial values&lt;br /&gt;
opti.subject_to(x2[0]==2) # ... &lt;br /&gt;
opti.subject_to(x3[0]==2) # ... &lt;br /&gt;
opti.subject_to(x4[0]==0) # ... mayer term auxiliary state&lt;br /&gt;
&lt;br /&gt;
#opti.subject_to(pos[-1]==1)  # finish line at position 1&lt;br /&gt;
&lt;br /&gt;
# ---- misc. constraints  ----------&lt;br /&gt;
#opti.subject_to(T&amp;gt;=0) # Time must be positive&lt;br /&gt;
&lt;br /&gt;
# ---- initial values for solver ---&lt;br /&gt;
opti.set_initial(x1, 2)&lt;br /&gt;
opti.set_initial(x2, 2)&lt;br /&gt;
opti.set_initial(x3, 2)&lt;br /&gt;
opti.set_initial(x4, 0)&lt;br /&gt;
opti.set_initial(u1, 1)&lt;br /&gt;
opti.set_initial(u2, 0)&lt;br /&gt;
opti.set_initial(u3, 0)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# ---- solve NLP              ------&lt;br /&gt;
opti.solver(&amp;quot;ipopt&amp;quot;) # set numerical backend&lt;br /&gt;
sol = opti.solve()   # actual solve&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# ---- post-processing        ------&lt;br /&gt;
from pylab import plot, step, figure, legend, show, spy&lt;br /&gt;
&lt;br /&gt;
plt.plot(pl.linspace(0, 12, num=N+1),sol.value(x1),label=&amp;quot;x1&amp;quot;)&lt;br /&gt;
plt.plot(pl.linspace(0, 12, num=N+1),sol.value(x2),label=&amp;quot;x2&amp;quot;)&lt;br /&gt;
plt.plot(pl.linspace(0, 12, num=N+1),sol.value(x3),label=&amp;quot;x3&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
#plot(limit(sol.value(pos)),&amp;#039;r--&amp;#039;,label=&amp;quot;speed limit&amp;quot;)&lt;br /&gt;
plt.step(pl.linspace(0, 12, num=N),sol.value(U[0,:]),&amp;#039;k&amp;#039;,label=&amp;quot;a1&amp;quot;)&lt;br /&gt;
plt.step(pl.linspace(0, 12, num=N),sol.value(U[1,:]),label=&amp;quot;a2&amp;quot;)&lt;br /&gt;
plt.step(pl.linspace(0, 12, num=N),sol.value(U[2,:]),label=&amp;quot;a3&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
plt.xlabel(&amp;#039;t&amp;#039;)&lt;br /&gt;
plt.ylabel(&amp;#039;state and control values&amp;#039;)&lt;br /&gt;
plt.title(&amp;#039;Differential state trajectories for relaxed controls&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
#xlabel=(&amp;quot;t&amp;quot;)&lt;br /&gt;
plt.legend(loc=&amp;quot;upper left&amp;quot;)&lt;br /&gt;
#title=&amp;quot;&lt;br /&gt;
plt.savefig(&amp;#039;three_tank_relaxed_solution.png&amp;#039;)&lt;br /&gt;
  &lt;br /&gt;
#################################################&lt;br /&gt;
&lt;br /&gt;
### Setting up CIA problem&lt;br /&gt;
&lt;br /&gt;
 ################################################&lt;br /&gt;
&lt;br /&gt;
t = np.linspace(0,T,N+1)&lt;br /&gt;
b_rel = np.array([[min(1,max(0,x)) for x in sol.value(U[0,:])], [min(1,max(0,x)) for x in sol.value(U[1,:])], [min(1,max(0,x)) for x in sol.value(U[2,:])]])&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
binapprox = BinApprox(t = t, b_rel = b_rel, binary_threshold = 1e-3, \&lt;br /&gt;
    off_state_included = False)&lt;br /&gt;
&lt;br /&gt;
#binapprox.set_n_max_switches(n_max_switches = max_switches)&lt;br /&gt;
#binapprox.set_min_up_times(min_up_times = [min_up_time])&lt;br /&gt;
#binapprox.set_min_down_times(min_down_times = [min_down_time])&lt;br /&gt;
&lt;br /&gt;
combina = CombinaBnB(binapprox)&lt;br /&gt;
combina.solve(use_warm_start=False, bnb_search_strategy=&amp;#039;dfs&amp;#039;, bnb_opts={&amp;#039;max_iter&amp;#039;: 1000000})&lt;br /&gt;
&lt;br /&gt;
b_bin_orig = pl.asarray(binapprox.b_bin)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
#################################################&lt;br /&gt;
&lt;br /&gt;
### Re-run Optimization Problem with fixed binary controls&lt;br /&gt;
### &amp;#039;Dirty hack&amp;#039;: just copy previous problem set up due to reuse issues of constraints&lt;br /&gt;
&lt;br /&gt;
sol1_x1 = sol.value(x1)&lt;br /&gt;
sol1_x2 = sol.value(x2)&lt;br /&gt;
sol1_x3 = sol.value(x3)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
opti2 = Opti() # Optimization problem&lt;br /&gt;
&lt;br /&gt;
# ---- decision variables ---------&lt;br /&gt;
X = opti2.variable(4,N+1) # state trajectory&lt;br /&gt;
x1   = X[0,:]&lt;br /&gt;
x2 = X[1,:]&lt;br /&gt;
x3 = X[2,:]&lt;br /&gt;
x4 = X[3,:]&lt;br /&gt;
&lt;br /&gt;
U = opti2.variable(3,N)   # control trajectory (throttle)&lt;br /&gt;
u1   = U[0,:]&lt;br /&gt;
u2 = U[1,:]&lt;br /&gt;
u3 = U[2,:]&lt;br /&gt;
&lt;br /&gt;
# ---- objective          ---------&lt;br /&gt;
opti2.minimize(x4[N]) # Objective as Mayer term&lt;br /&gt;
&lt;br /&gt;
# ---- dynamic constraints --------&lt;br /&gt;
f = lambda x,u: vertcat(c_1*u[0]+c_2*u[1]-(x[0])**0.5-  u[2]* (c_3*x[0])**0.5 , (x[0])**0.5- (x[1])**0.5, (x[1])**0.5- (x[2])**0.5 +u[2]* (c_3*x[0])**0.5 , u[1]*0.0+ k_1*(x[1]-k_2)**2 + k_3*(x[2]-k_4)**2)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
dt = T/N # length of a control interval&lt;br /&gt;
for k in range(N): # loop over control intervals&lt;br /&gt;
   # Runge-Kutta 4 integration&lt;br /&gt;
   k1 = f(X[:,k],         U[:,k])&lt;br /&gt;
   k2 = f(X[:,k]+dt/2*k1, U[:,k])&lt;br /&gt;
   k3 = f(X[:,k]+dt/2*k2, U[:,k])&lt;br /&gt;
   k4 = f(X[:,k]+dt*k3,   U[:,k])&lt;br /&gt;
   x_next = X[:,k] + dt/6*(k1+2*k2+2*k3+k4) &lt;br /&gt;
   opti2.subject_to(X[:,k+1]==x_next) # close the gaps&lt;br /&gt;
&lt;br /&gt;
# ---- path constraints -----------&lt;br /&gt;
opti2.subject_to(U==b_bin_orig) # control is fixed&lt;br /&gt;
&lt;br /&gt;
# ---- boundary conditions --------&lt;br /&gt;
opti2.subject_to(x1[0]==2)   # intitial values&lt;br /&gt;
opti2.subject_to(x2[0]==2) # ... &lt;br /&gt;
opti2.subject_to(x3[0]==2) # ... &lt;br /&gt;
opti2.subject_to(x4[0]==0) # ... mayer term auxiliary state&lt;br /&gt;
&lt;br /&gt;
#opti.subject_to(pos[-1]==1)  # finish line at position 1&lt;br /&gt;
&lt;br /&gt;
# ---- misc. constraints  ----------&lt;br /&gt;
#opti.subject_to(T&amp;gt;=0) # Time must be positive&lt;br /&gt;
&lt;br /&gt;
# ---- initial values for solver ---&lt;br /&gt;
opti2.set_initial(sol.value_variables())&lt;br /&gt;
# ---- initial values for solver ---&lt;br /&gt;
opti2.set_initial(x1, sol1_x1)&lt;br /&gt;
opti2.set_initial(x2, sol1_x2)&lt;br /&gt;
opti2.set_initial(x3, sol1_x3)&lt;br /&gt;
opti2.set_initial(x4, 0)&lt;br /&gt;
#opti.set_initial(u1, 0)&lt;br /&gt;
#opti.set_initial(u2, 0)&lt;br /&gt;
#opti.set_initial(u3, 1)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# ---- solve NLP              ------&lt;br /&gt;
opti2.solver(&amp;quot;ipopt&amp;quot;) # set numerical backend&lt;br /&gt;
sol2 = opti2.solve()   # actual solve&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
######################&lt;br /&gt;
#### Plot the binary feasible trajectory solution&lt;br /&gt;
#####################&lt;br /&gt;
&lt;br /&gt;
figure()&lt;br /&gt;
&lt;br /&gt;
plt.plot(pl.linspace(0, 12, num=N+1),sol2.value(x1),label=&amp;quot;x1&amp;quot;)&lt;br /&gt;
plt.plot(pl.linspace(0, 12, num=N+1),sol2.value(x2),label=&amp;quot;x2&amp;quot;)&lt;br /&gt;
plt.plot(pl.linspace(0, 12, num=N+1),sol2.value(x3),label=&amp;quot;x3&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
#plot(limit(sol.value(pos)),&amp;#039;r--&amp;#039;,label=&amp;quot;speed limit&amp;quot;)&lt;br /&gt;
plt.step(pl.linspace(0, 12, num=N),sol2.value(U[0,:]),&amp;#039;k&amp;#039;,label=&amp;quot;w1&amp;quot;)&lt;br /&gt;
plt.step(pl.linspace(0, 12, num=N),sol2.value(U[1,:]),label=&amp;quot;w2&amp;quot;)&lt;br /&gt;
plt.step(pl.linspace(0, 12, num=N),sol2.value(U[2,:]),label=&amp;quot;w3&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
plt.xlabel(&amp;#039;t&amp;#039;)&lt;br /&gt;
plt.ylabel(&amp;#039;state and control values&amp;#039;)&lt;br /&gt;
plt.title(&amp;#039;Differential state trajectories for binary controls&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
#xlabel=(&amp;quot;t&amp;quot;)&lt;br /&gt;
plt.legend(loc=&amp;quot;upper left&amp;quot;)&lt;br /&gt;
#title=&amp;quot;&lt;br /&gt;
show()&lt;br /&gt;
plt.savefig(&amp;#039;three_tank_binary_solution.png&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
######################&lt;br /&gt;
#### Plot also the (CIA) rounding trajectories&lt;br /&gt;
#####################&lt;br /&gt;
&lt;br /&gt;
f, (ax1, ax2, ax3) = pl.subplots(3, sharex = True)&lt;br /&gt;
&lt;br /&gt;
ax1.step(t[:-1], b_bin_orig[0,:], label = &amp;quot;w&amp;quot;, color = &amp;quot;C0&amp;quot;, where = &amp;quot;post&amp;quot;)&lt;br /&gt;
# ax1.step(t[:-1], b_bin_red[0,:], label = &amp;quot;b_bin_red&amp;quot;, color = &amp;quot;C0&amp;quot;, linestyle = &amp;quot;dashed&amp;quot;, where = &amp;quot;post&amp;quot;)&lt;br /&gt;
ax1.scatter(t[:-1], b_rel[0,:], label = &amp;quot;a&amp;quot;, color = &amp;quot;C0&amp;quot;, marker = &amp;quot;x&amp;quot;)&lt;br /&gt;
ax1.legend(loc = &amp;quot;upper left&amp;quot;)&lt;br /&gt;
ax1.set_ylabel(&amp;quot;w_1&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
ax2.step(t[:-1], b_bin_orig[1,:], label = &amp;quot;w&amp;quot;, color = &amp;quot;C1&amp;quot;, where = &amp;quot;post&amp;quot;)&lt;br /&gt;
# ax2.step(t[:-1], b_bin_red[1,:], label = &amp;quot;b_bin_red&amp;quot;, color = &amp;quot;C1&amp;quot;, linestyle = &amp;quot;dashed&amp;quot;, where = &amp;quot;post&amp;quot;)&lt;br /&gt;
ax2.scatter(t[:-1], b_rel[1,:], label = &amp;quot;a&amp;quot;, color = &amp;quot;C1&amp;quot;, marker = &amp;quot;x&amp;quot;)&lt;br /&gt;
ax2.legend(loc = &amp;quot;upper left&amp;quot;)&lt;br /&gt;
ax2.set_ylabel(&amp;quot;w_2&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
ax3.step(t[:-1], b_bin_orig[2,:], label = &amp;quot;w&amp;quot;, color = &amp;quot;C2&amp;quot;, where = &amp;quot;post&amp;quot;)&lt;br /&gt;
# ax3.step(t[:-1], b_bin_red[2,:], label = &amp;quot;b_bin_red&amp;quot;, color = &amp;quot;C2&amp;quot;, linestyle = &amp;quot;dashed&amp;quot;, where = &amp;quot;post&amp;quot;)&lt;br /&gt;
ax3.scatter(t[:-1], b_rel[2,:], label = &amp;quot;a&amp;quot;, color = &amp;quot;C2&amp;quot;, marker = &amp;quot;x&amp;quot;)&lt;br /&gt;
ax3.legend(loc = &amp;quot;upper left&amp;quot;)&lt;br /&gt;
ax3.set_ylabel(&amp;quot;w_3&amp;quot;)&lt;br /&gt;
ax3.set_xlabel(&amp;quot;t&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
show()&lt;br /&gt;
plt.savefig(&amp;#039;three_tank_rounding_solution.png&amp;#039;)&lt;br /&gt;
 ################################################&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;source&amp;gt;&lt;/div&gt;</summary>
		<author><name>ClemensZeile</name></author>
	</entry>
</feed>