2019-10-08 11:13:38 +02:00
<?xml version="1.0" encoding="utf-8"?>
2020-01-15 16:23:40 +01:00
<?xml version="1.0" encoding="utf-8"?>
2019-10-08 11:13:38 +02:00
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
< html xmlns = "http://www.w3.org/1999/xhtml" lang = "en" xml:lang = "en" >
< head >
2020-03-13 17:40:22 +01:00
<!-- 2020 - 03 - 13 ven. 17:39 -->
2019-10-08 11:13:38 +02:00
< meta http-equiv = "Content-Type" content = "text/html;charset=utf-8" / >
< meta name = "viewport" content = "width=device-width, initial-scale=1" / >
2020-01-15 16:23:40 +01:00
< title > Active Damping applied on the Simscape Model< / title >
2019-10-08 11:13:38 +02:00
< meta name = "generator" content = "Org mode" / >
< meta name = "author" content = "Dehaeze Thomas" / >
< style type = "text/css" >
<!-- /* --> <![CDATA[/*> <!-- */
.title { text-align: center;
margin-bottom: .2em; }
.subtitle { text-align: center;
font-size: medium;
font-weight: bold;
margin-top:0; }
.todo { font-family: monospace; color: red; }
.done { font-family: monospace; color: green; }
.priority { font-family: monospace; color: orange; }
.tag { background-color: #eee; font-family: monospace;
padding: 2px; font-size: 80%; font-weight: normal; }
.timestamp { color: #bebebe; }
.timestamp-kwd { color: #5f9ea0; }
.org-right { margin-left: auto; margin-right: 0px; text-align: right; }
.org-left { margin-left: 0px; margin-right: auto; text-align: left; }
.org-center { margin-left: auto; margin-right: auto; text-align: center; }
.underline { text-decoration: underline; }
#postamble p, #preamble p { font-size: 90%; margin: .2em; }
p.verse { margin-left: 3%; }
pre {
border: 1px solid #ccc;
box-shadow: 3px 3px 3px #eee;
padding: 8pt;
font-family: monospace;
overflow: auto;
margin: 1.2em;
}
pre.src {
position: relative;
overflow: visible;
padding-top: 1.2em;
}
pre.src:before {
display: none;
position: absolute;
background-color: white;
top: -10px;
right: 10px;
padding: 3px;
border: 1px solid black;
}
pre.src:hover:before { display: inline;}
/* Languages per Org manual */
pre.src-asymptote:before { content: 'Asymptote'; }
pre.src-awk:before { content: 'Awk'; }
pre.src-C:before { content: 'C'; }
/* pre.src-C++ doesn't work in CSS */
pre.src-clojure:before { content: 'Clojure'; }
pre.src-css:before { content: 'CSS'; }
pre.src-D:before { content: 'D'; }
pre.src-ditaa:before { content: 'ditaa'; }
pre.src-dot:before { content: 'Graphviz'; }
pre.src-calc:before { content: 'Emacs Calc'; }
pre.src-emacs-lisp:before { content: 'Emacs Lisp'; }
pre.src-fortran:before { content: 'Fortran'; }
pre.src-gnuplot:before { content: 'gnuplot'; }
pre.src-haskell:before { content: 'Haskell'; }
pre.src-hledger:before { content: 'hledger'; }
pre.src-java:before { content: 'Java'; }
pre.src-js:before { content: 'Javascript'; }
pre.src-latex:before { content: 'LaTeX'; }
pre.src-ledger:before { content: 'Ledger'; }
pre.src-lisp:before { content: 'Lisp'; }
pre.src-lilypond:before { content: 'Lilypond'; }
pre.src-lua:before { content: 'Lua'; }
pre.src-matlab:before { content: 'MATLAB'; }
pre.src-mscgen:before { content: 'Mscgen'; }
pre.src-ocaml:before { content: 'Objective Caml'; }
pre.src-octave:before { content: 'Octave'; }
pre.src-org:before { content: 'Org mode'; }
pre.src-oz:before { content: 'OZ'; }
pre.src-plantuml:before { content: 'Plantuml'; }
pre.src-processing:before { content: 'Processing.js'; }
pre.src-python:before { content: 'Python'; }
pre.src-R:before { content: 'R'; }
pre.src-ruby:before { content: 'Ruby'; }
pre.src-sass:before { content: 'Sass'; }
pre.src-scheme:before { content: 'Scheme'; }
pre.src-screen:before { content: 'Gnu Screen'; }
pre.src-sed:before { content: 'Sed'; }
pre.src-sh:before { content: 'shell'; }
pre.src-sql:before { content: 'SQL'; }
pre.src-sqlite:before { content: 'SQLite'; }
/* additional languages in org.el's org-babel-load-languages alist */
pre.src-forth:before { content: 'Forth'; }
pre.src-io:before { content: 'IO'; }
pre.src-J:before { content: 'J'; }
pre.src-makefile:before { content: 'Makefile'; }
pre.src-maxima:before { content: 'Maxima'; }
pre.src-perl:before { content: 'Perl'; }
pre.src-picolisp:before { content: 'Pico Lisp'; }
pre.src-scala:before { content: 'Scala'; }
pre.src-shell:before { content: 'Shell Script'; }
pre.src-ebnf2ps:before { content: 'ebfn2ps'; }
/* additional language identifiers per "defun org-babel-execute"
in ob-*.el */
pre.src-cpp:before { content: 'C++'; }
pre.src-abc:before { content: 'ABC'; }
pre.src-coq:before { content: 'Coq'; }
pre.src-groovy:before { content: 'Groovy'; }
/* additional language identifiers from org-babel-shell-names in
ob-shell.el: ob-shell is the only babel language using a lambda to put
the execution function name together. */
pre.src-bash:before { content: 'bash'; }
pre.src-csh:before { content: 'csh'; }
pre.src-ash:before { content: 'ash'; }
pre.src-dash:before { content: 'dash'; }
pre.src-ksh:before { content: 'ksh'; }
pre.src-mksh:before { content: 'mksh'; }
pre.src-posh:before { content: 'posh'; }
/* Additional Emacs modes also supported by the LaTeX listings package */
pre.src-ada:before { content: 'Ada'; }
pre.src-asm:before { content: 'Assembler'; }
pre.src-caml:before { content: 'Caml'; }
pre.src-delphi:before { content: 'Delphi'; }
pre.src-html:before { content: 'HTML'; }
pre.src-idl:before { content: 'IDL'; }
pre.src-mercury:before { content: 'Mercury'; }
pre.src-metapost:before { content: 'MetaPost'; }
pre.src-modula-2:before { content: 'Modula-2'; }
pre.src-pascal:before { content: 'Pascal'; }
pre.src-ps:before { content: 'PostScript'; }
pre.src-prolog:before { content: 'Prolog'; }
pre.src-simula:before { content: 'Simula'; }
pre.src-tcl:before { content: 'tcl'; }
pre.src-tex:before { content: 'TeX'; }
pre.src-plain-tex:before { content: 'Plain TeX'; }
pre.src-verilog:before { content: 'Verilog'; }
pre.src-vhdl:before { content: 'VHDL'; }
pre.src-xml:before { content: 'XML'; }
pre.src-nxml:before { content: 'XML'; }
/* add a generic configuration mode; LaTeX export needs an additional
(add-to-list 'org-latex-listings-langs '(conf " ")) in .emacs */
pre.src-conf:before { content: 'Configuration File'; }
table { border-collapse:collapse; }
caption.t-above { caption-side: top; }
caption.t-bottom { caption-side: bottom; }
td, th { vertical-align:top; }
th.org-right { text-align: center; }
th.org-left { text-align: center; }
th.org-center { text-align: center; }
td.org-right { text-align: right; }
td.org-left { text-align: left; }
td.org-center { text-align: center; }
dt { font-weight: bold; }
.footpara { display: inline; }
.footdef { margin-bottom: 1em; }
.figure { padding: 1em; }
.figure p { text-align: center; }
.equation-container {
display: table;
text-align: center;
width: 100%;
}
.equation {
vertical-align: middle;
}
.equation-label {
display: table-cell;
text-align: right;
vertical-align: middle;
}
.inlinetask {
padding: 10px;
border: 2px solid gray;
margin: 10px;
background: #ffffcc;
}
#org-div-home-and-up
{ text-align: right; font-size: 70%; white-space: nowrap; }
textarea { overflow-x: auto; }
.linenr { font-size: smaller }
.code-highlighted { background-color: #ffff00; }
.org-info-js_info-navigation { border-style: none; }
#org-info-js_console-label
{ font-size: 10px; font-weight: bold; white-space: nowrap; }
.org-info-js_search-highlight
{ background-color: #ffff00; color: #000000; font-weight: bold; }
.org-svg { width: 90%; }
/*]]>*/-->
< / style >
2020-02-25 18:21:17 +01:00
< link rel = "stylesheet" type = "text/css" href = "./css/htmlize.css" / >
< link rel = "stylesheet" type = "text/css" href = "./css/readtheorg.css" / >
< link rel = "stylesheet" type = "text/css" href = "./css/zenburn.css" / >
< script type = "text/javascript" src = "./js/jquery.min.js" > < / script >
< script type = "text/javascript" src = "./js/bootstrap.min.js" > < / script >
< script type = "text/javascript" src = "./js/jquery.stickytableheaders.min.js" > < / script >
< script type = "text/javascript" src = "./js/readtheorg.js" > < / script >
2019-10-08 11:13:38 +02:00
< script type = "text/javascript" >
2020-03-13 17:40:22 +01:00
// @license magnet:?xt=urn:btih:1f739d935676111cfff4b4693e3816e664797050& dn=gpl-3.0.txt GPL-v3-or-Later
2019-10-08 11:13:38 +02:00
<!-- /* --> <![CDATA[/*> <!-- */
2020-03-13 17:40:22 +01:00
function CodeHighlightOn(elem, id)
{
var target = document.getElementById(id);
if(null != target) {
elem.cacheClassElem = elem.className;
elem.cacheClassTarget = target.className;
target.className = "code-highlighted";
elem.className = "code-highlighted";
}
}
function CodeHighlightOff(elem, id)
{
var target = document.getElementById(id);
if(elem.cacheClassElem)
elem.className = elem.cacheClassElem;
if(elem.cacheClassTarget)
target.className = elem.cacheClassTarget;
}
/*]]>*///-->
// @license-end
2019-10-08 11:13:38 +02:00
< / script >
2020-02-04 16:13:52 +01:00
< script >
MathJax = {
tex: { macros: {
bm: ["\\boldsymbol{#1}",1],
}
}
};
< / script >
< script type = "text/javascript"
src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js">< / script >
2019-10-08 11:13:38 +02:00
< / head >
< body >
< div id = "org-div-home-and-up" >
2020-02-25 18:21:17 +01:00
< a accesskey = "h" href = "./index.html" > UP < / a >
2019-10-08 11:13:38 +02:00
|
2020-02-25 18:21:17 +01:00
< a accesskey = "H" href = "./index.html" > HOME < / a >
2019-10-08 11:13:38 +02:00
< / div > < div id = "content" >
2020-01-15 16:23:40 +01:00
< h1 class = "title" > Active Damping applied on the Simscape Model< / h1 >
2019-10-18 17:34:45 +02:00
< div id = "table-of-contents" >
< h2 > Table of Contents< / h2 >
< div id = "text-table-of-contents" >
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org9f12ca2" > 1. Undamped System< / a >
2020-01-15 16:23:40 +01:00
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orga668d6d" > 1.1. Identification of the dynamics for Active Damping< / a >
2020-01-15 16:23:40 +01:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org4d53135" > 1.1.1. Identification< / a > < / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orge632d78" > 1.1.2. Obtained Plants for Active Damping< / a > < / li >
2020-01-15 16:23:40 +01:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orgacbac97" > 1.2. Identification of the dynamics for High Authority Control< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org71a0d47" > 1.2.1. Identification< / a > < / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org245ebc9" > 1.2.2. Obtained Plants< / a > < / li >
2020-02-06 17:07:11 +01:00
< / ul >
< / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org6dbda79" > 1.3. Tomography Experiment< / a >
2020-02-06 17:07:11 +01:00
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orgd2384a9" > 1.3.1. Simulation< / a > < / li >
< li > < a href = "#orgd00d359" > 1.3.2. Results< / a > < / li >
2020-01-15 16:23:40 +01:00
< / ul >
< / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orgdbb1be8" > 2. Variability of the system dynamics for Active Damping< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org31548ad" > 2.1. Variation of the Sample Mass< / a > < / li >
< li > < a href = "#org9e8fe7a" > 2.2. Variation of the Spindle Angle< / a > < / li >
< li > < a href = "#orge339ac8" > 2.3. Variation of the Spindle Rotation Speed< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orgf1f5ffe" > 2.3.1. Dynamics of the Active Damping plants< / a > < / li >
< li > < a href = "#orga866f6f" > 2.3.2. Variation of the poles and zeros with the Spindle rotation frequency< / a > < / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org89179a2" > 2.4. Variation of the Tilt Angle< / a > < / li >
< li > < a href = "#org701d7f3" > 2.5. Scans of the Translation Stage< / a > < / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org8edc6af" > 2.6. Conclusion< / a > < / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org28bb8b8" > 3. Integral Force Feedback< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgd40d19e" > 3.1. Control Design< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgae652a4" > 3.1.1. Plant< / a > < / li >
< li > < a href = "#org3cc819b" > 3.1.2. Control Design< / a > < / li >
< li > < a href = "#orgd4051da" > 3.1.3. Diagonal Controller< / a > < / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org394b3ba" > 3.2. Tomography Experiment< / a >
2020-01-15 16:23:40 +01:00
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orge827289" > 3.2.1. Simulation with IFF Controller< / a > < / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgeb184b2" > 3.2.2. Compare with Undamped system< / a > < / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org6b98a86" > 3.3. Conclusion< / a > < / li >
2020-01-15 16:23:40 +01:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orge2515a1" > 4. Direct Velocity Feedback< / a >
2020-01-15 16:23:40 +01:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgac2118b" > 4.1. Control Design< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgb031bdb" > 4.1.1. Plant< / a > < / li >
< li > < a href = "#orgd082061" > 4.1.2. Control Design< / a > < / li >
< li > < a href = "#orgd3a0a62" > 4.1.3. Diagonal Controller< / a > < / li >
2020-01-15 16:23:40 +01:00
< / ul >
< / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orge87de8b" > 4.2. Tomography Experiment< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orge6278a1" > 4.2.1. Initialize the Simulation< / a > < / li >
< li > < a href = "#orge7a0ad9" > 4.2.2. Compare with Undamped system< / a > < / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgc00cb88" > 4.3. Conclusion< / a > < / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org5047e99" > 5. Inertial Control< / a >
2020-01-15 16:23:40 +01:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org40e3ea7" > 5.1. Control Design< / a >
2020-02-04 16:13:52 +01:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgbceccd1" > 5.1.1. Plant< / a > < / li >
< li > < a href = "#orgc8e27a6" > 5.1.2. Control Design< / a > < / li >
< li > < a href = "#org165dd29" > 5.1.3. Diagonal Controller< / a > < / li >
2020-01-21 17:28:49 +01:00
< / ul >
< / li >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org5587c6f" > 5.2. Conclusion< / a > < / li >
2020-02-04 16:13:52 +01:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orgd2a9c18" > 6. Comparison< / a >
2020-02-06 17:07:11 +01:00
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org68994db" > 6.1. Load the plants< / a > < / li >
< li > < a href = "#orge9d62ca" > 6.2. Sensitivity to Disturbance< / a > < / li >
< li > < a href = "#org60554fc" > 6.3. Damped Plant< / a > < / li >
< li > < a href = "#orgd49b825" > 6.4. Tomography Experiment - Frequency Domain analysis< / a > < / li >
2020-02-04 16:13:52 +01:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#org1623377" > 7. Useful Functions< / a >
2020-02-04 16:13:52 +01:00
< ul >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orgcf56890" > 7.1. prepareLinearizeIdentification< / a >
2020-01-21 17:28:49 +01:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#orgbcbb56e" > Function Description< / a > < / li >
< li > < a href = "#orgb2bfb6d" > Optional Parameters< / a > < / li >
< li > < a href = "#org491e801" > Initialize the Simulation< / a > < / li >
2020-01-15 16:23:40 +01:00
< / ul >
< / li >
2020-02-25 18:10:20 +01:00
< li > < a href = "#orgc2b4408" > 7.2. prepareTomographyExperiment< / a >
2019-10-18 17:34:45 +02:00
< ul >
2020-03-13 17:40:22 +01:00
< li > < a href = "#org8c658fc" > Function Description< / a > < / li >
< li > < a href = "#org80c975b" > Optional Parameters< / a > < / li >
< li > < a href = "#org65e26b7" > Initialize the Simulation< / a > < / li >
2020-01-15 16:23:40 +01:00
< / ul >
< / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / li >
< / ul >
< / div >
< / div >
< p >
2020-02-06 17:07:11 +01:00
The goal of this file is to study the use of active damping for the control of the NASS.
2019-10-18 17:34:45 +02:00
< / p >
< p >
2020-02-06 17:07:11 +01:00
In general, three sensors can be used for Active Damping:
2019-10-18 17:34:45 +02:00
< / p >
< ul class = "org-ul" >
2020-02-06 17:07:11 +01:00
< li > A force sensor< / li >
< li > A relative motion sensor such as a capacitive sensor< / li >
< li > An inertial sensor such as an accelerometer of geophone< / li >
2019-10-18 17:34:45 +02:00
< / ul >
< p >
2020-02-25 18:10:20 +01:00
First, in section < a href = "#orgf7acc8a" > 1< / a > , we look at the undamped system and we identify the dynamics from the actuators to the three sensor types.
2020-02-06 17:07:11 +01:00
< / p >
< p >
2020-02-25 18:10:20 +01:00
Then, in section < a href = "#orgc27e210" > 2< / a > , we study the change of dynamics for the active damping plants with respect to various experimental conditions such as the sample mass and the spindle rotation speed.
2020-02-06 17:07:11 +01:00
< / p >
< p >
Then, we will apply and compare the results of three active damping techniques:
2019-10-18 17:34:45 +02:00
< / p >
< ul class = "org-ul" >
2020-02-25 18:10:20 +01:00
< li > In section < a href = "#orgbed66ac" > 3< / a > : Integral Force Feedback is applied< / li >
< li > In section < a href = "#org61bdc7e" > 4< / a > : Direct Velocity Feedback using a relative motion sensor is applied< / li >
< li > In section < a href = "#org4574fa3" > 5< / a > : Inertial Control using a geophone is applied< / li >
2019-10-18 17:34:45 +02:00
< / ul >
< p >
2020-02-06 17:07:11 +01:00
For each of the active damping technique, we:
2019-10-18 17:34:45 +02:00
< / p >
< ul class = "org-ul" >
2020-02-06 17:07:11 +01:00
< li > Look at the obtain damped plant that will be used for High Authority control< / li >
< li > Simulate tomography experiments< / li >
< li > Compare the sensitivity from disturbances< / li >
2019-10-18 17:34:45 +02:00
< / ul >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org9f12ca2" class = "outline-2" >
< h2 id = "org9f12ca2" > < span class = "section-number-2" > 1< / span > Undamped System< / h2 >
2019-10-18 17:34:45 +02:00
< div class = "outline-text-2" id = "text-1" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "orgf7acc8a" > < / a >
2019-10-18 17:34:45 +02:00
< / p >
< p >
2020-02-04 18:36:27 +01:00
In this section, we identify the dynamic of the system from forces applied in the nano-hexapod legs to the various sensors included in the nano-hexapod that could be use for Active Damping, namely:
< / p >
< ul class = "org-ul" >
< li > A relative motion sensor, measuring the relative displacement of each of the leg< / li >
< li > A force sensor measuring the total force transmitted to the top part of the leg in the direction of the leg< / li >
< li > A absolute velocity sensor measuring the absolute velocity of the top part of the leg in the direction of the leg< / li >
< / ul >
< p >
After that, a tomography experiment is simulation without any active damping techniques.
2019-10-18 17:34:45 +02:00
< / p >
< / div >
2019-10-25 16:02:23 +02:00
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orga668d6d" class = "outline-3" >
< h3 id = "orga668d6d" > < span class = "section-number-3" > 1.1< / span > Identification of the dynamics for Active Damping< / h3 >
2019-10-18 17:34:45 +02:00
< div class = "outline-text-3" id = "text-1-1" >
2020-01-15 16:23:40 +01:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org4d53135" class = "outline-4" >
< h4 id = "org4d53135" > < span class = "section-number-4" > 1.1.1< / span > Identification< / h4 >
2020-01-15 16:23:40 +01:00
< div class = "outline-text-4" id = "text-1-1-1" >
2019-10-18 17:34:45 +02:00
< p >
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
2020-02-06 17:07:11 +01:00
< pre class = "src src-matlab" > prepareLinearizeIdentification();
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-02-06 17:07:11 +01:00
We identify the dynamics of the system using the < code > linearize< / code > function.
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > < span class = "org-matlab-cellbreak" > < span class = "org-comment" > %% Options for Linearized< / span > < / span >
options = linearizeOptions;
options.SampleTime = 0;
< span class = "org-matlab-cellbreak" > < span class = "org-comment" > %% Name of the Simulink File< / span > < / span >
2020-02-25 17:50:37 +01:00
mdl = < span class = "org-string" > 'nass_model'< / span > ;
2020-01-15 16:23:40 +01:00
< span class = "org-matlab-cellbreak" > < span class = "org-comment" > %% Input/Output definition< / span > < / span >
clear io; io_i = 1;
2020-02-25 17:50:37 +01:00
io(io_i) = linio([mdl, < span class = "org-string" > '/Controller'< / span > ], 1, < span class = "org-string" > 'openinput'< / span > ); io_i = io_i < span class = "org-type" > +< / span > 1; < span class = "org-comment" > % Actuator Inputs< / span >
2020-02-04 18:36:27 +01:00
io(io_i) = linio([mdl, < span class = "org-string" > '/Micro-Station'< / span > ], 3, < span class = "org-string" > 'openoutput'< / span > , [], < span class = "org-string" > 'Dnlm'< / span > ); io_i = io_i < span class = "org-type" > +< / span > 1; < span class = "org-comment" > % Relative Motion Outputs< / span >
io(io_i) = linio([mdl, < span class = "org-string" > '/Micro-Station'< / span > ], 3, < span class = "org-string" > 'openoutput'< / span > , [], < span class = "org-string" > 'Fnlm'< / span > ); io_i = io_i < span class = "org-type" > +< / span > 1; < span class = "org-comment" > % Force Sensors< / span >
io(io_i) = linio([mdl, < span class = "org-string" > '/Micro-Station'< / span > ], 3, < span class = "org-string" > 'openoutput'< / span > , [], < span class = "org-string" > 'Vlm'< / span > ); io_i = io_i < span class = "org-type" > +< / span > 1; < span class = "org-comment" > % Absolute Velocity Outputs< / span >
2020-01-15 16:23:40 +01:00
< span class = "org-matlab-cellbreak" > < span class = "org-comment" > %% Run the linearization< / span > < / span >
2020-02-04 16:13:52 +01:00
G = linearize(mdl, io, 0.5, options);
2020-01-15 16:23:40 +01:00
G.InputName = {< span class = "org-string" > 'Fnl1'< / span > , < span class = "org-string" > 'Fnl2'< / span > , < span class = "org-string" > 'Fnl3'< / span > , < span class = "org-string" > 'Fnl4'< / span > , < span class = "org-string" > 'Fnl5'< / span > , < span class = "org-string" > 'Fnl6'< / span > };
G.OutputName = {< span class = "org-string" > 'Dnlm1'< / span > , < span class = "org-string" > 'Dnlm2'< / span > , < span class = "org-string" > 'Dnlm3'< / span > , < span class = "org-string" > 'Dnlm4'< / span > , < span class = "org-string" > 'Dnlm5'< / span > , < span class = "org-string" > 'Dnlm6'< / span > , ...
< span class = "org-string" > 'Fnlm1'< / span > , < span class = "org-string" > 'Fnlm2'< / span > , < span class = "org-string" > 'Fnlm3'< / span > , < span class = "org-string" > 'Fnlm4'< / span > , < span class = "org-string" > 'Fnlm5'< / span > , < span class = "org-string" > 'Fnlm6'< / span > , ...
2020-02-06 17:07:11 +01:00
< span class = "org-string" > 'Vnlm1'< / span > , < span class = "org-string" > 'Vnlm2'< / span > , < span class = "org-string" > 'Vnlm3'< / span > , < span class = "org-string" > 'Vnlm4'< / span > , < span class = "org-string" > 'Vnlm5'< / span > , < span class = "org-string" > 'Vnlm6'< / span > };
2020-01-15 16:23:40 +01:00
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
2019-10-25 16:02:23 +02:00
2020-01-15 16:23:40 +01:00
< p >
We then create transfer functions corresponding to the active damping plants.
2019-10-25 16:02:23 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > G_iff = minreal(G({< span class = "org-string" > 'Fnlm1'< / span > , < span class = "org-string" > 'Fnlm2'< / span > , < span class = "org-string" > 'Fnlm3'< / span > , < span class = "org-string" > 'Fnlm4'< / span > , < span class = "org-string" > 'Fnlm5'< / span > , < span class = "org-string" > 'Fnlm6'< / span > }, {< span class = "org-string" > 'Fnl1'< / span > , < span class = "org-string" > 'Fnl2'< / span > , < span class = "org-string" > 'Fnl3'< / span > , < span class = "org-string" > 'Fnl4'< / span > , < span class = "org-string" > 'Fnl5'< / span > , < span class = "org-string" > 'Fnl6'< / span > }));
G_dvf = minreal(G({< span class = "org-string" > 'Dnlm1'< / span > , < span class = "org-string" > 'Dnlm2'< / span > , < span class = "org-string" > 'Dnlm3'< / span > , < span class = "org-string" > 'Dnlm4'< / span > , < span class = "org-string" > 'Dnlm5'< / span > , < span class = "org-string" > 'Dnlm6'< / span > }, {< span class = "org-string" > 'Fnl1'< / span > , < span class = "org-string" > 'Fnl2'< / span > , < span class = "org-string" > 'Fnl3'< / span > , < span class = "org-string" > 'Fnl4'< / span > , < span class = "org-string" > 'Fnl5'< / span > , < span class = "org-string" > 'Fnl6'< / span > }));
G_ine = minreal(G({< span class = "org-string" > 'Vnlm1'< / span > , < span class = "org-string" > 'Vnlm2'< / span > , < span class = "org-string" > 'Vnlm3'< / span > , < span class = "org-string" > 'Vnlm4'< / span > , < span class = "org-string" > 'Vnlm5'< / span > , < span class = "org-string" > 'Vnlm6'< / span > }, {< span class = "org-string" > 'Fnl1'< / span > , < span class = "org-string" > 'Fnl2'< / span > , < span class = "org-string" > 'Fnl3'< / span > , < span class = "org-string" > 'Fnl4'< / span > , < span class = "org-string" > 'Fnl5'< / span > , < span class = "org-string" > 'Fnl6'< / span > }));
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
< p >
2020-01-15 16:23:40 +01:00
And we save them for further analysis.
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > save(< span class = "org-string" > './mat/active_damping_undamped_plants.mat'< / span > , < span class = "org-string" > 'G_iff'< / span > , < span class = "org-string" > 'G_dvf'< / span > , < span class = "org-string" > 'G_ine'< / span > );
2020-01-15 16:23:40 +01:00
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orge632d78" class = "outline-4" >
< h4 id = "orge632d78" > < span class = "section-number-4" > 1.1.2< / span > Obtained Plants for Active Damping< / h4 >
2020-02-06 17:07:11 +01:00
< div class = "outline-text-4" id = "text-1-1-2" >
2020-01-21 17:28:49 +01:00
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_undamped_plants.mat'< / span > , < span class = "org-string" > 'G_iff'< / span > , < span class = "org-string" > 'G_dvf'< / span > , < span class = "org-string" > 'G_ine'< / span > );
2020-01-21 17:28:49 +01:00
< / pre >
< / div >
2019-10-25 16:02:23 +02:00
2020-01-21 17:28:49 +01:00
2020-02-25 18:10:20 +01:00
< div id = "orgb962e48" class = " figure " >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_active_damping_iff_plant.png" alt = "nass_active_damping_iff_plant.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-04 18:36:27 +01:00
< p > < span class = "figure-number" > Figure 1: < / span > < code > G_iff< / code > : Transfer functions from forces applied in the actuators to the force sensor in each actuator (< a href = "./figs/nass_active_damping_iff_plant.png" > png< / a > , < a href = "./figs/nass_active_damping_iff_plant.pdf" > pdf< / a > )< / p >
2019-10-18 17:34:45 +02:00
< / div >
2019-10-25 16:02:23 +02:00
2019-10-18 17:34:45 +02:00
2020-02-25 18:10:20 +01:00
< div id = "org62d36fc" class = "figure" >
2020-02-04 18:36:27 +01:00
< p > < img src = "figs/nass_active_damping_dvf_plant.png" alt = "nass_active_damping_dvf_plant.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-04 18:36:27 +01:00
< p > < span class = "figure-number" > Figure 2: < / span > < code > G_dvf< / code > : Transfer functions from forces applied in the actuators to the relative motion sensor in each actuator (< a href = "./figs/nass_active_damping_dvf_plant.png" > png< / a > , < a href = "./figs/nass_active_damping_dvf_plant.pdf" > pdf< / a > )< / p >
2019-10-18 17:34:45 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org1ff6cfd" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_active_damping_inertial_plant.png" alt = "nass_active_damping_inertial_plant.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-04 18:36:27 +01:00
< p > < span class = "figure-number" > Figure 3: < / span > < code > G_ine< / code > : Transfer functions from forces applied in the actuators to the geophone located in each leg measuring the absolute velocity of the top part of the leg in the direction of the leg (< a href = "./figs/nass_active_damping_inertial_plant.png" > png< / a > , < a href = "./figs/nass_active_damping_inertial_plant.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
< / div >
< / div >
2019-10-18 17:34:45 +02:00
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgacbac97" class = "outline-3" >
< h3 id = "orgacbac97" > < span class = "section-number-3" > 1.2< / span > Identification of the dynamics for High Authority Control< / h3 >
2020-01-15 16:23:40 +01:00
< div class = "outline-text-3" id = "text-1-2" >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org71a0d47" class = "outline-4" >
< h4 id = "org71a0d47" > < span class = "section-number-4" > 1.2.1< / span > Identification< / h4 >
2020-01-15 16:23:40 +01:00
< div class = "outline-text-4" id = "text-1-2-1" >
2019-10-18 17:34:45 +02:00
< p >
2020-02-06 17:07:11 +01:00
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > prepareLinearizeIdentification();
< / pre >
< / div >
< p >
We identify the dynamics of the system using the < code > linearize< / code > function.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > < span class = "org-matlab-cellbreak" > < span class = "org-comment" > %% Options for Linearized< / span > < / span >
options = linearizeOptions;
options.SampleTime = 0;
< span class = "org-matlab-cellbreak" > < span class = "org-comment" > %% Name of the Simulink File< / span > < / span >
2020-02-25 17:50:37 +01:00
mdl = < span class = "org-string" > 'nass_model'< / span > ;
2020-02-06 17:07:11 +01:00
< span class = "org-matlab-cellbreak" > < span class = "org-comment" > %% Input/Output definition< / span > < / span >
clear io; io_i = 1;
2020-02-25 17:50:37 +01:00
io(io_i) = linio([mdl, < span class = "org-string" > '/Controller'< / span > ], 1, < span class = "org-string" > 'openinput'< / span > ); io_i = io_i < span class = "org-type" > +< / span > 1; < span class = "org-comment" > % Actuator Inputs< / span >
io(io_i) = linio([mdl, < span class = "org-string" > '/Tracking Error'< / span > ], 1, < span class = "org-string" > 'openoutput'< / span > , [], < span class = "org-string" > 'En'< / span > ); io_i = io_i < span class = "org-type" > +< / span > 1; < span class = "org-comment" > % Metrology Outputs< / span >
2020-02-06 17:07:11 +01:00
< / pre >
< / div >
< div class = "org-src-container" >
< pre class = "src src-matlab" > masses = [1, 10, 50]; < span class = "org-comment" > % [kg]< / span >
< / pre >
< / div >
< p >
And we save them for further analysis.
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > save(< span class = "org-string" > './mat/active_damping_cart_plants.mat'< / span > , < span class = "org-string" > 'G_cart'< / span > , < span class = "org-string" > 'masses'< / span > );
2020-02-06 17:07:11 +01:00
< / pre >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org245ebc9" class = "outline-4" >
< h4 id = "org245ebc9" > < span class = "section-number-4" > 1.2.2< / span > Obtained Plants< / h4 >
2020-02-06 17:07:11 +01:00
< div class = "outline-text-4" id = "text-1-2-2" >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_cart_plants.mat'< / span > , < span class = "org-string" > 'G_cart'< / span > , < span class = "org-string" > 'masses'< / span > );
2020-02-06 17:07:11 +01:00
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org0c485bf" class = "figure" >
2020-02-06 17:07:11 +01:00
< p > < img src = "figs/undamped_hac_plant_translations.png" alt = "undamped_hac_plant_translations.png" / >
< / p >
< p > < span class = "figure-number" > Figure 4: < / span > Undamped Plant - Translations (< a href = "./figs/undamped_hac_plant_translations.png" > png< / a > , < a href = "./figs/undamped_hac_plant_translations.pdf" > pdf< / a > )< / p >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgd9cc8d5" class = "figure" >
2020-02-06 17:07:11 +01:00
< p > < img src = "figs/undamped_hac_plant_rotations.png" alt = "undamped_hac_plant_rotations.png" / >
< / p >
< p > < span class = "figure-number" > Figure 5: < / span > Undamped Plant - Rotations (< a href = "./figs/undamped_hac_plant_rotations.png" > png< / a > , < a href = "./figs/undamped_hac_plant_rotations.pdf" > pdf< / a > )< / p >
< / div >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org6dbda79" class = "outline-3" >
< h3 id = "org6dbda79" > < span class = "section-number-3" > 1.3< / span > Tomography Experiment< / h3 >
2020-02-06 17:07:11 +01:00
< div class = "outline-text-3" id = "text-1-3" >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgd2384a9" class = "outline-4" >
< h4 id = "orgd2384a9" > < span class = "section-number-4" > 1.3.1< / span > Simulation< / h4 >
2020-02-06 17:07:11 +01:00
< div class = "outline-text-4" id = "text-1-3-1" >
< p >
2020-01-15 16:23:40 +01:00
We initialize elements for the tomography experiment.
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > prepareTomographyExperiment();
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
< p >
2020-01-15 16:23:40 +01:00
We change the simulation stop time.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > 'mat/conf_simulink.mat'< / span > );
< span class = "org-matlab-simulink-keyword" > set_param< / span > (< span class = "org-variable-name" > conf_simulink< / span > , < span class = "org-string" > 'StopTime'< / span > , < span class = "org-string" > '4.5'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
And we simulate the system.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > < span class = "org-matlab-simulink-keyword" > sim< / span > (< span class = "org-string" > 'nass_model'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
Finally, we save the simulation results for further analysis
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > save(< span class = "org-string" > './mat/active_damping_tomo_exp.mat'< / span > , < span class = "org-string" > 'En'< / span > , < span class = "org-string" > 'Eg'< / span > , < span class = "org-string" > '-append'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
2019-10-18 17:34:45 +02:00
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgd00d359" class = "outline-4" >
< h4 id = "orgd00d359" > < span class = "section-number-4" > 1.3.2< / span > Results< / h4 >
2020-02-06 17:07:11 +01:00
< div class = "outline-text-4" id = "text-1-3-2" >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
We load the results of tomography experiments.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_tomo_exp.mat'< / span > , < span class = "org-string" > 'En'< / span > );
2020-02-06 17:07:11 +01:00
Fs = 1e3; < span class = "org-comment" > % Sampling Frequency of the Data< / span >
t = (1< span class = "org-type" > /< / span > Fs)< span class = "org-type" > *< / span > [0< span class = "org-type" > :< / span > length(En(< span class = "org-type" > :< / span > ,1))< span class = "org-type" > -< / span > 1];
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgdf8e194" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_act_damp_undamped_sim_tomo_trans.png" alt = "nass_act_damp_undamped_sim_tomo_trans.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 6: < / span > Position Error during tomography experiment - Translations (< a href = "./figs/nass_act_damp_undamped_sim_tomo_trans.png" > png< / a > , < a href = "./figs/nass_act_damp_undamped_sim_tomo_trans.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org542244c" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_act_damp_undamped_sim_tomo_rot.png" alt = "nass_act_damp_undamped_sim_tomo_rot.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 7: < / span > Position Error during tomography experiment - Rotations (< a href = "./figs/nass_act_damp_undamped_sim_tomo_rot.png" > png< / a > , < a href = "./figs/nass_act_damp_undamped_sim_tomo_rot.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgdbb1be8" class = "outline-2" >
< h2 id = "orgdbb1be8" > < span class = "section-number-2" > 2< / span > Variability of the system dynamics for Active Damping< / h2 >
2020-01-15 16:23:40 +01:00
< div class = "outline-text-2" id = "text-2" >
2019-10-18 17:34:45 +02:00
< p >
2020-02-25 18:10:20 +01:00
< a id = "orgc27e210" > < / a >
2020-02-04 16:13:52 +01:00
< / p >
< p >
The goal of this section is to study how the dynamics of the Active Damping plants are changing with the experimental conditions.
These experimental conditions are:
< / p >
< ul class = "org-ul" >
2020-02-25 18:10:20 +01:00
< li > The mass of the sample (section < a href = "#orgbf7603c" > 2.1< / a > )< / li >
< li > The spindle angle with a null rotating speed (section < a href = "#org22aaf6a" > 2.2< / a > )< / li >
< li > The spindle rotation speed (section < a href = "#org38d7c27" > 2.3< / a > )< / li >
< li > The tilt angle (section < a href = "#orgcff3abb" > 2.4< / a > )< / li >
< li > The scans of the translation stage (section < a href = "#org4b32bef" > 2.5< / a > )< / li >
2020-02-04 16:13:52 +01:00
< / ul >
< p >
For the identification of the dynamics, the system is simulation for \(\approx 0.5s\) before the linearization is performed.
This is done in order for the transient phase to be over.
< / p >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org31548ad" class = "outline-3" >
< h3 id = "org31548ad" > < span class = "section-number-3" > 2.1< / span > Variation of the Sample Mass< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-2-1" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "orgbf7603c" > < / a >
2020-02-04 16:13:52 +01:00
< / p >
< p >
For all the identifications, the disturbances are disabled and no controller are used.
< / p >
2020-02-06 17:07:11 +01:00
< p >
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > prepareLinearizeIdentification();
< / pre >
< / div >
2020-02-04 16:13:52 +01:00
< p >
We identify the dynamics for the following sample mass.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > masses = [1, 10, 50]; < span class = "org-comment" > % [kg]< / span >
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgc02fea2" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_iff_sample_mass.png" alt = "act_damp_variability_iff_sample_mass.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 8: < / span > Variability of the dynamics from actuator force to force sensor with the Sample Mass (< a href = "./figs/act_damp_variability_iff_sample_mass.png" > png< / a > , < a href = "./figs/act_damp_variability_iff_sample_mass.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org65d6278" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_dvf_sample_mass.png" alt = "act_damp_variability_dvf_sample_mass.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 9: < / span > Variability of the dynamics from actuator force to relative motion sensor with the Sample Mass (< a href = "./figs/act_damp_variability_dvf_sample_mass.png" > png< / a > , < a href = "./figs/act_damp_variability_dvf_sample_mass.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org30d3e8e" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_ine_sample_mass.png" alt = "act_damp_variability_ine_sample_mass.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 10: < / span > Variability of the dynamics from actuator force to absolute velocity with the Sample Mass (< a href = "./figs/act_damp_variability_ine_sample_mass.png" > png< / a > , < a href = "./figs/act_damp_variability_ine_sample_mass.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org9e8fe7a" class = "outline-3" >
< h3 id = "org9e8fe7a" > < span class = "section-number-3" > 2.2< / span > Variation of the Spindle Angle< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-2-2" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "org22aaf6a" > < / a >
2020-02-04 16:13:52 +01:00
< / p >
2020-02-06 17:07:11 +01:00
< p >
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > prepareLinearizeIdentification();
< / pre >
< / div >
2020-02-04 16:13:52 +01:00
< p >
We identify the dynamics for the following Spindle angles.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > Rz_amplitudes = [0, < span class = "org-constant" > pi< / span > < span class = "org-type" > /< / span > 4, < span class = "org-constant" > pi< / span > < span class = "org-type" > /< / span > 2, < span class = "org-constant" > pi< / span > ]; < span class = "org-comment" > % [rad]< / span >
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org00155d0" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_iff_spindle_angle.png" alt = "act_damp_variability_iff_spindle_angle.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 11: < / span > Variability of the dynamics from the actuator force to the force sensor with the Spindle Angle (< a href = "./figs/act_damp_variability_iff_spindle_angle.png" > png< / a > , < a href = "./figs/act_damp_variability_iff_spindle_angle.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgabdb3d0" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_dvf_spindle_angle.png" alt = "act_damp_variability_dvf_spindle_angle.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 12: < / span > Variability of the dynamics from actuator force to relative motion sensor with the Spindle Angle (< a href = "./figs/act_damp_variability_dvf_spindle_angle.png" > png< / a > , < a href = "./figs/act_damp_variability_dvf_spindle_angle.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org359eded" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_ine_spindle_angle.png" alt = "act_damp_variability_ine_spindle_angle.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 13: < / span > Variability of the dynamics from actuator force to absolute velocity with the Spindle Angle (< a href = "./figs/act_damp_variability_ine_spindle_angle.png" > png< / a > , < a href = "./figs/act_damp_variability_ine_spindle_angle.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orge339ac8" class = "outline-3" >
< h3 id = "orge339ac8" > < span class = "section-number-3" > 2.3< / span > Variation of the Spindle Rotation Speed< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-2-3" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "org38d7c27" > < / a >
2020-02-06 17:07:11 +01:00
< / p >
< p >
We initialize all the stages with the default parameters.
2020-02-04 16:13:52 +01:00
< / p >
2020-02-06 17:07:11 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > prepareLinearizeIdentification();
< / pre >
< / div >
2020-02-04 16:13:52 +01:00
< p >
We identify the dynamics for the following Spindle rotation periods.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > Rz_periods = [60, 6, 2, 1]; < span class = "org-comment" > % [s]< / span >
< / pre >
< / div >
< p >
The identification of the dynamics is done at the same Spindle angle position.
< / p >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgf1f5ffe" class = "outline-4" >
< h4 id = "orgf1f5ffe" > < span class = "section-number-4" > 2.3.1< / span > Dynamics of the Active Damping plants< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-2-3-1" >
2020-02-25 18:10:20 +01:00
< div id = "orgb6a07dd" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_iff_spindle_speed.png" alt = "act_damp_variability_iff_spindle_speed.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 14: < / span > Variability of the dynamics from the actuator force to the force sensor with the Spindle rotation speed (< a href = "./figs/act_damp_variability_iff_spindle_speed.png" > png< / a > , < a href = "./figs/act_damp_variability_iff_spindle_speed.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org390cc01" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_iff_spindle_speed_zoom.png" alt = "act_damp_variability_iff_spindle_speed_zoom.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 15: < / span > Variability of the dynamics from the actuator force to the force sensor with the Spindle rotation speed (< a href = "./figs/act_damp_variability_iff_spindle_speed_zoom.png" > png< / a > , < a href = "./figs/act_damp_variability_iff_spindle_speed_zoom.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org291934a" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_dvf_spindle_speed.png" alt = "act_damp_variability_dvf_spindle_speed.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 16: < / span > Variability of the dynamics from the actuator force to the relative motion sensor with the Spindle rotation speed (< a href = "./figs/act_damp_variability_dvf_spindle_speed.png" > png< / a > , < a href = "./figs/act_damp_variability_dvf_spindle_speed.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org2350585" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_dvf_spindle_speed_zoom.png" alt = "act_damp_variability_dvf_spindle_speed_zoom.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 17: < / span > Variability of the dynamics from the actuator force to the relative motion sensor with the Spindle rotation speed (< a href = "./figs/act_damp_variability_dvf_spindle_speed_zoom.png" > png< / a > , < a href = "./figs/act_damp_variability_dvf_spindle_speed_zoom.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgd7430d6" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_ine_spindle_speed.png" alt = "act_damp_variability_ine_spindle_speed.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 18: < / span > Variability of the dynamics from the actuator force to the absolute velocity sensor with the Spindle rotation speed (< a href = "./figs/act_damp_variability_ine_spindle_speed.png" > png< / a > , < a href = "./figs/act_damp_variability_ine_spindle_speed.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org9fcefce" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_ine_spindle_speed_zoom.png" alt = "act_damp_variability_ine_spindle_speed_zoom.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 19: < / span > Variability of the dynamics from the actuator force to the absolute velocity sensor with the Spindle rotation speed (< a href = "./figs/act_damp_variability_ine_spindle_speed_zoom.png" > png< / a > , < a href = "./figs/act_damp_variability_ine_spindle_speed_zoom.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orga866f6f" class = "outline-4" >
< h4 id = "orga866f6f" > < span class = "section-number-4" > 2.3.2< / span > Variation of the poles and zeros with the Spindle rotation frequency< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-2-3-2" >
2020-02-25 18:10:20 +01:00
< div id = "org9640321" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/campbell_diagram_spindle_rotation.png" alt = "campbell_diagram_spindle_rotation.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 20: < / span > Evolution of the pole with respect to the spindle rotation speed (< a href = "./figs/campbell_diagram_spindle_rotation.png" > png< / a > , < a href = "./figs/campbell_diagram_spindle_rotation.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org08bedae" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/variation_zeros_active_damping_plants.png" alt = "variation_zeros_active_damping_plants.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 21: < / span > Evolution of the zero with respect to the spindle rotation speed (< a href = "./figs/variation_zeros_active_damping_plants.png" > png< / a > , < a href = "./figs/variation_zeros_active_damping_plants.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org89179a2" class = "outline-3" >
< h3 id = "org89179a2" > < span class = "section-number-3" > 2.4< / span > Variation of the Tilt Angle< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-2-4" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "orgcff3abb" > < / a >
2020-02-04 16:13:52 +01:00
< / p >
2020-02-06 17:07:11 +01:00
< p >
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > prepareLinearizeIdentification();
< / pre >
< / div >
2020-02-04 16:13:52 +01:00
< p >
We identify the dynamics for the following Tilt stage angles.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > Ry_amplitudes = [< span class = "org-type" > -< / span > 3< span class = "org-type" > *< / span > < span class = "org-constant" > pi< / span > < span class = "org-type" > /< / span > 180, 3< span class = "org-type" > *< / span > < span class = "org-constant" > pi< / span > < span class = "org-type" > /< / span > 180]; < span class = "org-comment" > % [rad]< / span >
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org8da9c57" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_iff_tilt_angle.png" alt = "act_damp_variability_iff_tilt_angle.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 22: < / span > Variability of the dynamics from the actuator force to the force sensor with the Tilt stage Angle (< a href = "./figs/act_damp_variability_iff_tilt_angle.png" > png< / a > , < a href = "./figs/act_damp_variability_iff_tilt_angle.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgd8caed9" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_dvf_tilt_angle.png" alt = "act_damp_variability_dvf_tilt_angle.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 23: < / span > Variability of the dynamics from the actuator force to the relative motion sensor with the Tilt Angle (< a href = "./figs/act_damp_variability_dvf_tilt_angle.png" > png< / a > , < a href = "./figs/act_damp_variability_dvf_tilt_angle.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org79615ad" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_ine_tilt_angle.png" alt = "act_damp_variability_ine_tilt_angle.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 24: < / span > Variability of the dynamics from the actuator force to the absolute velocity sensor with the Tilt Angle (< a href = "./figs/act_damp_variability_ine_tilt_angle.png" > png< / a > , < a href = "./figs/act_damp_variability_ine_tilt_angle.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org701d7f3" class = "outline-3" >
< h3 id = "org701d7f3" > < span class = "section-number-3" > 2.5< / span > Scans of the Translation Stage< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-2-5" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "org4b32bef" > < / a >
2020-02-04 16:13:52 +01:00
< / p >
< p >
We want here to verify if the dynamics used for Active damping is varying when using the translation stage for scans.
< / p >
< p >
2020-02-06 17:07:11 +01:00
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > prepareLinearizeIdentification();
< / pre >
< / div >
< p >
2020-02-25 18:10:20 +01:00
We initialize the translation stage reference to be a sinus with an amplitude of 5mm and a period of 1s (Figure < a href = "#org54b3f59" > 25< / a > ).
2020-02-04 16:13:52 +01:00
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeReferences(< span class = "org-string" > 'Dy_type'< / span > , < span class = "org-string" > 'sinusoidal'< / span > , ...
< span class = "org-string" > 'Dy_amplitude'< / span > , 5e< span class = "org-type" > -< / span > 3, ...< span class = "org-comment" > % [m]< / span >
< span class = "org-string" > 'Dy_period'< / span > , 1); < span class = "org-comment" > % [s]< / span >
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org54b3f59" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/ty_scanning_reference_sinus.png" alt = "ty_scanning_reference_sinus.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 25: < / span > Reference path for the translation stage (< a href = "./figs/ty_scanning_reference_sinus.png" > png< / a > , < a href = "./figs/ty_scanning_reference_sinus.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
< p >
We identify the dynamics at different positions (times) when scanning with the Translation stage.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > t_lin = [0.5, 0.75, 1, 1.25];
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org4480dce" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_iff_ty_scans.png" alt = "act_damp_variability_iff_ty_scans.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 26: < / span > Variability of the dynamics from the actuator force to the absolute velocity sensor plant at different Ty scan positions (< a href = "./figs/act_damp_variability_iff_ty_scans.png" > png< / a > , < a href = "./figs/act_damp_variability_iff_ty_scans.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orge7e59d9" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_dvf_ty_scans.png" alt = "act_damp_variability_dvf_ty_scans.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 27: < / span > Variability of the dynamics from actuator force to relative displacement sensor at different Ty scan positions (< a href = "./figs/act_damp_variability_dvf_ty_scans.png" > png< / a > , < a href = "./figs/act_damp_variability_dvf_ty_scans.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgf856754" class = "figure" >
2020-02-04 16:13:52 +01:00
< p > < img src = "figs/act_damp_variability_ine_ty_scans.png" alt = "act_damp_variability_ine_ty_scans.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 28: < / span > Variability of the Inertial plant at different Ty scan positions (< a href = "./figs/act_damp_variability_ine_ty_scans.png" > png< / a > , < a href = "./figs/act_damp_variability_ine_ty_scans.pdf" > pdf< / a > )< / p >
2020-02-04 16:13:52 +01:00
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org8edc6af" class = "outline-3" >
< h3 id = "org8edc6af" > < span class = "section-number-3" > 2.6< / span > Conclusion< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-2-6" >
2020-02-25 18:10:20 +01:00
< table id = "org664ed44" border = "2" cellspacing = "0" cellpadding = "6" rules = "groups" frame = "hsides" >
2020-02-04 16:13:52 +01:00
< caption class = "t-above" > < span class = "table-number" > Table 1:< / span > Conclusion on the variability of the system dynamics for active damping< / caption >
< colgroup >
< col class = "org-center" / >
< col class = "org-center" / >
< / colgroup >
< thead >
< tr >
< th scope = "col" class = "org-center" >   < / th >
< th scope = "col" class = "org-center" > < b > Change of Dynamics< / b > < / th >
< / tr >
< / thead >
< tbody >
< tr >
< td class = "org-center" > < b > Sample Mass< / b > < / td >
< td class = "org-center" > Large< / td >
< / tr >
< tr >
< td class = "org-center" > < b > Spindle Angle< / b > < / td >
< td class = "org-center" > Small< / td >
< / tr >
< tr >
< td class = "org-center" > < b > Spindle Rotation Speed< / b > < / td >
< td class = "org-center" > First resonance is split in two resonances< / td >
< / tr >
< tr >
< td class = "org-center" > < b > Tilt Angle< / b > < / td >
< td class = "org-center" > Negligible< / td >
< / tr >
< tr >
< td class = "org-center" > < b > Translation Stage scans< / b > < / td >
< td class = "org-center" > Negligible< / td >
< / tr >
< / tbody >
< / table >
< p >
Also, for the Inertial Sensor, a RHP zero may appear when the spindle is rotating fast.
< / p >
< div class = "important" >
< p >
When using either a force sensor or a relative motion sensor for active damping, the only “ parameter” that induce a large change for the dynamics to be controlled is the < b > sample mass< / b > .
Thus, the developed damping techniques should be robust to variations of the sample mass.
< / p >
< / div >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org28bb8b8" class = "outline-2" >
< h2 id = "org28bb8b8" > < span class = "section-number-2" > 3< / span > Integral Force Feedback< / h2 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-2" id = "text-3" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "orgbed66ac" > < / a >
2020-01-15 16:23:40 +01:00
< / p >
< div class = "note" >
< p >
All the files (data and Matlab scripts) are accessible < a href = "data/iff.zip" > here< / a > .
< / p >
< / div >
< p >
2020-02-04 18:36:27 +01:00
Here, we study the use of < b > Integral Force Feedback< / b > (IFF) to actively damp the resonances.
2020-01-15 16:23:40 +01:00
< / p >
2020-02-04 18:36:27 +01:00
< p >
The IFF control is applied in a decentralized way: there is on controller for each leg.
< / p >
< p >
2020-02-25 18:10:20 +01:00
The control architecture is represented in figure < a href = "#org03ecebf" > 29< / a > where one of the 6 nano-hexapod legs is represented.
2020-02-04 18:36:27 +01:00
< / p >
2020-02-25 18:10:20 +01:00
< div id = "org03ecebf" class = "figure" >
2020-02-04 18:36:27 +01:00
< p > < img src = "figs/iff_1dof.png" alt = "iff_1dof.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 29: < / span > Integral Force Feedback applied to a 1dof system< / p >
2020-02-04 18:36:27 +01:00
< / div >
2020-01-15 16:23:40 +01:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgd40d19e" class = "outline-3" >
< h3 id = "orgd40d19e" > < span class = "section-number-3" > 3.1< / span > Control Design< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-3-1" >
2020-01-15 16:23:40 +01:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgae652a4" class = "outline-4" >
< h4 id = "orgae652a4" > < span class = "section-number-4" > 3.1.1< / span > Plant< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-3-1-1" >
2020-01-15 16:23:40 +01:00
< p >
2020-02-04 18:36:27 +01:00
Let’ s load the previously identified undamped plant:
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_undamped_plants.mat'< / span > , < span class = "org-string" > 'G_iff'< / span > );
load(< span class = "org-string" > './mat/active_damping_plants_variable.mat'< / span > , < span class = "org-string" > 'masses'< / span > , < span class = "org-string" > 'Gm_iff'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-02-25 18:10:20 +01:00
Let’ s look at the transfer function from actuator forces in the nano-hexapod to the force sensor in the nano-hexapod legs for all 6 pairs of actuator/sensor (figure < a href = "#orgefc507a" > 30< / a > ).
2019-10-18 17:34:45 +02:00
< / p >
2020-02-25 18:10:20 +01:00
< div id = "orgefc507a" class = "figure" >
2019-10-18 17:34:45 +02:00
< p > < img src = "figs/iff_plant.png" alt = "iff_plant.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 30: < / span > Transfer function from forces applied in the legs to force sensor (< a href = "./figs/iff_plant.png" > png< / a > , < a href = "./figs/iff_plant.pdf" > pdf< / a > )< / p >
2019-10-18 17:34:45 +02:00
< / div >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
2019-10-18 17:34:45 +02:00
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org3cc819b" class = "outline-4" >
< h4 id = "org3cc819b" > < span class = "section-number-4" > 3.1.2< / span > Control Design< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-3-1-2" >
2019-10-18 17:34:45 +02:00
< p >
The controller for each pair of actuator/sensor is:
< / p >
< div class = "org-src-container" >
2020-02-04 18:36:27 +01:00
< pre class = "src src-matlab" > w0 = 2< span class = "org-type" > *< / span > < span class = "org-constant" > pi< / span > < span class = "org-type" > *< / span > 50;
K_iff = < span class = "org-type" > -< / span > 5000< span class = "org-type" > /< / span > s < span class = "org-type" > *< / span > (s< span class = "org-type" > /< / span > w0)< span class = "org-type" > /< / span > (1 < span class = "org-type" > +< / span > s< span class = "org-type" > /< / span > w0);
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-02-25 18:10:20 +01:00
The corresponding loop gains are shown in figure < a href = "#orge32c0c8" > 31< / a > .
2019-10-18 17:34:45 +02:00
< / p >
2020-02-25 18:10:20 +01:00
< div id = "orge32c0c8" class = "figure" >
2019-10-18 17:34:45 +02:00
< p > < img src = "figs/iff_open_loop.png" alt = "iff_open_loop.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 31: < / span > Loop Gain for the Integral Force Feedback (< a href = "./figs/iff_open_loop.png" > png< / a > , < a href = "./figs/iff_open_loop.pdf" > pdf< / a > )< / p >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgd4051da" class = "outline-4" >
< h4 id = "orgd4051da" > < span class = "section-number-4" > 3.1.3< / span > Diagonal Controller< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-3-1-3" >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
We create the diagonal controller and we add a minus sign as we have a positive
feedback architecture.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-01-15 16:23:40 +01:00
< pre class = "src src-matlab" > K_iff = < span class = "org-type" > -< / span > K_iff< span class = "org-type" > *< / span > eye(6);
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
We save the controller for further analysis.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > save(< span class = "org-string" > './mat/active_damping_K_iff.mat'< / span > , < span class = "org-string" > 'K_iff'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
< / div >
2019-10-18 17:34:45 +02:00
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org394b3ba" class = "outline-3" >
< h3 id = "org394b3ba" > < span class = "section-number-3" > 3.2< / span > Tomography Experiment< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-3-2" >
2020-01-15 16:23:40 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orge827289" class = "outline-4" >
< h4 id = "orge827289" > < span class = "section-number-4" > 3.2.1< / span > Simulation with IFF Controller< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-3-2-1" >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
We initialize elements for the tomography experiment.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-01-15 16:23:40 +01:00
< pre class = "src src-matlab" > prepareTomographyExperiment();
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
We set the IFF controller.
2019-10-25 16:02:23 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_K_iff.mat'< / span > , < span class = "org-string" > 'K_iff'< / span > );
2020-02-25 17:50:37 +01:00
initializeController(< span class = "org-string" > 'type'< / span > , < span class = "org-string" > 'iff'< / span > , < span class = "org-string" > 'K'< / span > , K_iff);
2019-10-25 16:02:23 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
We change the simulation stop time.
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > 'mat/conf_simulink.mat'< / span > );
< span class = "org-matlab-simulink-keyword" > set_param< / span > (< span class = "org-variable-name" > conf_simulink< / span > , < span class = "org-string" > 'StopTime'< / span > , < span class = "org-string" > '4.5'< / span > );
2020-01-15 16:23:40 +01:00
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
< p >
2020-01-15 16:23:40 +01:00
And we simulate the system.
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > < span class = "org-matlab-simulink-keyword" > sim< / span > (< span class = "org-string" > 'nass_model'< / span > );
2020-01-15 16:23:40 +01:00
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
2020-01-15 16:23:40 +01:00
< p >
Finally, we save the simulation results for further analysis
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > En_iff = En;
Eg_iff = Eg;
2020-03-13 17:40:22 +01:00
save(< span class = "org-string" > './mat/active_damping_tomo_exp.mat'< / span > , < span class = "org-string" > 'En_iff'< / span > , < span class = "org-string" > 'Eg_iff'< / span > , < span class = "org-string" > '-append'< / span > );
2020-01-15 16:23:40 +01:00
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgeb184b2" class = "outline-4" >
< h4 id = "orgeb184b2" > < span class = "section-number-4" > 3.2.2< / span > Compare with Undamped system< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-3-2-2" >
2020-01-20 17:20:50 +01:00
2020-02-25 18:10:20 +01:00
< div id = "orgc83ffab" class = "figure" >
2020-01-20 17:20:50 +01:00
< p > < img src = "figs/nass_act_damp_iff_sim_tomo_xy.png" alt = "nass_act_damp_iff_sim_tomo_xy.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 32: < / span > Position Error during tomography experiment - XY Motion (< a href = "./figs/nass_act_damp_iff_sim_tomo_xy.png" > png< / a > , < a href = "./figs/nass_act_damp_iff_sim_tomo_xy.pdf" > pdf< / a > )< / p >
2020-01-20 17:20:50 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org0411d04" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_act_damp_iff_sim_tomo_trans.png" alt = "nass_act_damp_iff_sim_tomo_trans.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 33: < / span > Position Error during tomography experiment - Translations (< a href = "./figs/nass_act_damp_iff_sim_tomo_trans.png" > png< / a > , < a href = "./figs/nass_act_damp_iff_sim_tomo_trans.pdf" > pdf< / a > )< / p >
2019-10-18 17:34:45 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgde3aa5f" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_act_damp_iff_sim_tomo_rot.png" alt = "nass_act_damp_iff_sim_tomo_rot.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 34: < / span > Position Error during tomography experiment - Rotations (< a href = "./figs/nass_act_damp_iff_sim_tomo_rot.png" > png< / a > , < a href = "./figs/nass_act_damp_iff_sim_tomo_rot.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org6b98a86" class = "outline-3" >
< h3 id = "org6b98a86" > < span class = "section-number-3" > 3.3< / span > Conclusion< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-3-3" >
2019-10-18 17:34:45 +02:00
< div class = "important" >
< p >
2020-02-06 17:07:11 +01:00
Integral Force Feedback using a force sensor:
2019-10-18 17:34:45 +02:00
< / p >
< ul class = "org-ul" >
< li > Robust (guaranteed stability)< / li >
< li > Acceptable Damping< / li >
< li > Increase the sensitivity to disturbances at low frequencies< / li >
< / ul >
< / div >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orge2515a1" class = "outline-2" >
< h2 id = "orge2515a1" > < span class = "section-number-2" > 4< / span > Direct Velocity Feedback< / h2 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-2" id = "text-4" >
2019-10-18 17:34:45 +02:00
< p >
2020-02-25 18:10:20 +01:00
< a id = "org61bdc7e" > < / a >
2019-10-18 17:34:45 +02:00
< / p >
2019-10-25 16:02:23 +02:00
< div class = "note" >
< p >
2020-01-15 16:23:40 +01:00
All the files (data and Matlab scripts) are accessible < a href = "data/dvf.zip" > here< / a > .
2019-10-25 16:02:23 +02:00
< / p >
< / div >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
In the Direct Velocity Feedback (DVF), a derivative feedback is applied between the measured actuator displacement to the actuator force input.
The actuator displacement can be measured with a capacitive sensor for instance.
2019-10-18 17:34:45 +02:00
< / p >
< / div >
2019-10-25 16:02:23 +02:00
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgac2118b" class = "outline-3" >
< h3 id = "orgac2118b" > < span class = "section-number-3" > 4.1< / span > Control Design< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-4-1" >
2019-10-18 17:34:45 +02:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgb031bdb" class = "outline-4" >
< h4 id = "orgb031bdb" > < span class = "section-number-4" > 4.1.1< / span > Plant< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-4-1-1" >
2020-01-15 16:23:40 +01:00
< p >
Let’ s load the undamped plant:
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_undamped_plants.mat'< / span > , < span class = "org-string" > 'G_dvf'< / span > );
load(< span class = "org-string" > './mat/active_damping_plants_variable.mat'< / span > , < span class = "org-string" > 'masses'< / span > , < span class = "org-string" > 'Gm_dvf'< / span > );
2020-01-15 16:23:40 +01:00
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
< p >
2020-02-25 18:10:20 +01:00
Let’ s look at the transfer function from actuator forces in the nano-hexapod to the measured displacement of the actuator for all 6 pairs of actuator/sensor (figure < a href = "#org8635294" > 35< / a > ).
2019-10-18 17:34:45 +02:00
< / p >
2020-02-25 18:10:20 +01:00
< div id = "org8635294" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/dvf_plant.png" alt = "dvf_plant.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 35: < / span > Transfer function from forces applied in the legs to leg displacement sensor (< a href = "./figs/dvf_plant.png" > png< / a > , < a href = "./figs/dvf_plant.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgd082061" class = "outline-4" >
< h4 id = "orgd082061" > < span class = "section-number-4" > 4.1.2< / span > Control Design< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-4-1-2" >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
The Direct Velocity Feedback is defined below.
A Low pass Filter is added to make the controller transfer function proper.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-02-06 17:07:11 +01:00
< pre class = "src src-matlab" > K_dvf = s< span class = "org-type" > *< / span > 30000< span class = "org-type" > /< / span > (1 < span class = "org-type" > +< / span > s< span class = "org-type" > /< / span > 2< span class = "org-type" > /< / span > < span class = "org-constant" > pi< / span > < span class = "org-type" > /< / span > 10000);
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-02-25 18:10:20 +01:00
The obtained loop gains are shown in figure < a href = "#org713f5d4" > 36< / a > .
2019-10-18 17:34:45 +02:00
< / p >
2020-02-25 18:10:20 +01:00
< div id = "org713f5d4" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/dvf_open_loop.png" alt = "dvf_open_loop.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 36: < / span > Loop Gain for the Integral Force Feedback (< a href = "./figs/dvf_open_loop.png" > png< / a > , < a href = "./figs/dvf_open_loop.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
2019-10-18 17:34:45 +02:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgd3a0a62" class = "outline-4" >
< h4 id = "orgd3a0a62" > < span class = "section-number-4" > 4.1.3< / span > Diagonal Controller< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-4-1-3" >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
We create the diagonal controller and we add a minus sign as we have a positive feedback architecture.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-01-15 16:23:40 +01:00
< pre class = "src src-matlab" > K_dvf = < span class = "org-type" > -< / span > K_dvf< span class = "org-type" > *< / span > eye(6);
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
We save the controller for further analysis.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > save(< span class = "org-string" > './mat/active_damping_K_dvf.mat'< / span > , < span class = "org-string" > 'K_dvf'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orge87de8b" class = "outline-3" >
< h3 id = "orge87de8b" > < span class = "section-number-3" > 4.2< / span > Tomography Experiment< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-4-2" >
2020-01-15 16:23:40 +01:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orge6278a1" class = "outline-4" >
< h4 id = "orge6278a1" > < span class = "section-number-4" > 4.2.1< / span > Initialize the Simulation< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-4-2-1" >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
We initialize elements for the tomography experiment.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-01-15 16:23:40 +01:00
< pre class = "src src-matlab" > prepareTomographyExperiment();
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
We set the DVF controller.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_K_dvf.mat'< / span > , < span class = "org-string" > 'K_dvf'< / span > );
2020-02-25 17:50:37 +01:00
initializeController(< span class = "org-string" > 'type'< / span > , < span class = "org-string" > 'dvf'< / span > , < span class = "org-string" > 'K'< / span > , K_dvf);
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
We change the simulation stop time.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > 'mat/conf_simulink.mat'< / span > );
< span class = "org-matlab-simulink-keyword" > set_param< / span > (< span class = "org-variable-name" > conf_simulink< / span > , < span class = "org-string" > 'StopTime'< / span > , < span class = "org-string" > '4.5'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
And we simulate the system.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > < span class = "org-matlab-simulink-keyword" > sim< / span > (< span class = "org-string" > 'nass_model'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
Finally, we save the simulation results for further analysis
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-01-15 16:23:40 +01:00
< pre class = "src src-matlab" > En_dvf = En;
Eg_dvf = Eg;
2020-03-13 17:40:22 +01:00
save(< span class = "org-string" > './mat/active_damping_tomo_exp.mat'< / span > , < span class = "org-string" > 'En_dvf'< / span > , < span class = "org-string" > 'Eg_dvf'< / span > , < span class = "org-string" > '-append'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
2019-10-18 17:34:45 +02:00
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orge7a0ad9" class = "outline-4" >
< h4 id = "orge7a0ad9" > < span class = "section-number-4" > 4.2.2< / span > Compare with Undamped system< / h4 >
2020-02-06 17:07:11 +01:00
< div class = "outline-text-4" id = "text-4-2-2" >
2019-10-18 17:34:45 +02:00
2020-02-25 18:10:20 +01:00
< div id = "orge2d1a4a" class = "figure" >
2020-01-20 17:20:50 +01:00
< p > < img src = "figs/nass_act_damp_dvf_sim_tomo_xy.png" alt = "nass_act_damp_dvf_sim_tomo_xy.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 37: < / span > Position Error during tomography experiment - XY Motion (< a href = "./figs/nass_act_damp_dvf_sim_tomo_xy.png" > png< / a > , < a href = "./figs/nass_act_damp_dvf_sim_tomo_xy.pdf" > pdf< / a > )< / p >
2020-01-20 17:20:50 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org9d80b08" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_act_damp_dvf_sim_tomo_trans.png" alt = "nass_act_damp_dvf_sim_tomo_trans.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 38: < / span > Position Error during tomography experiment - Translations (< a href = "./figs/nass_act_damp_dvf_sim_tomo_trans.png" > png< / a > , < a href = "./figs/nass_act_damp_dvf_sim_tomo_trans.pdf" > pdf< / a > )< / p >
2019-10-18 17:34:45 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org7864a83" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/nass_act_damp_dvf_sim_tomo_rot.png" alt = "nass_act_damp_dvf_sim_tomo_rot.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 39: < / span > Position Error during tomography experiment - Rotations (< a href = "./figs/nass_act_damp_dvf_sim_tomo_rot.png" > png< / a > , < a href = "./figs/nass_act_damp_dvf_sim_tomo_rot.pdf" > pdf< / a > )< / p >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgc00cb88" class = "outline-3" >
< h3 id = "orgc00cb88" > < span class = "section-number-3" > 4.3< / span > Conclusion< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-4-3" >
2019-10-18 17:34:45 +02:00
< div class = "important" >
< p >
2020-02-06 17:07:11 +01:00
Direct Velocity Feedback using a relative motion sensor:
2019-10-18 17:34:45 +02:00
< / p >
< ul class = "org-ul" >
2020-02-06 17:07:11 +01:00
< li > Robust (guaranteed stability)< / li >
2019-10-18 17:34:45 +02:00
< / ul >
< / div >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org5047e99" class = "outline-2" >
< h2 id = "org5047e99" > < span class = "section-number-2" > 5< / span > Inertial Control< / h2 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-2" id = "text-5" >
2019-10-18 17:34:45 +02:00
< p >
2020-02-25 18:10:20 +01:00
< a id = "org4574fa3" > < / a >
2019-10-25 16:02:23 +02:00
< / p >
< div class = "note" >
< p >
2020-01-15 16:23:40 +01:00
All the files (data and Matlab scripts) are accessible < a href = "data/ine.zip" > here< / a > .
2019-10-18 17:34:45 +02:00
< / p >
2019-10-25 16:02:23 +02:00
< / div >
2019-10-18 17:34:45 +02:00
< p >
2020-01-20 17:20:50 +01:00
In Inertial Control, a feedback is applied between the measured < b > absolute< / b > motion (velocity or acceleration) of the platform to the actuator force input.
2019-10-18 17:34:45 +02:00
< / p >
< / div >
2019-10-25 16:02:23 +02:00
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org40e3ea7" class = "outline-3" >
< h3 id = "org40e3ea7" > < span class = "section-number-3" > 5.1< / span > Control Design< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-5-1" >
2019-10-18 17:34:45 +02:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgbceccd1" class = "outline-4" >
< h4 id = "orgbceccd1" > < span class = "section-number-4" > 5.1.1< / span > Plant< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-5-1-1" >
2020-01-15 16:23:40 +01:00
< p >
Let’ s load the undamped plant:
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_undamped_plants.mat'< / span > , < span class = "org-string" > 'G_ine'< / span > );
load(< span class = "org-string" > './mat/active_damping_plants_variable.mat'< / span > , < span class = "org-string" > 'masses'< / span > , < span class = "org-string" > 'Gm_ine'< / span > );
2020-01-15 16:23:40 +01:00
< / pre >
2019-10-18 17:34:45 +02:00
< / div >
< p >
2020-02-25 18:10:20 +01:00
Let’ s look at the transfer function from actuator forces in the nano-hexapod to the measured velocity of the nano-hexapod platform in the direction of the corresponding actuator for all 6 pairs of actuator/sensor (figure < a href = "#orgb358af9" > 40< / a > ).
2019-10-18 17:34:45 +02:00
< / p >
2020-02-25 18:10:20 +01:00
< div id = "orgb358af9" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/ine_plant.png" alt = "ine_plant.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 40: < / span > Transfer function from forces applied in the legs to leg velocity sensor (< a href = "./figs/ine_plant.png" > png< / a > , < a href = "./figs/ine_plant.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgc8e27a6" class = "outline-4" >
< h4 id = "orgc8e27a6" > < span class = "section-number-4" > 5.1.2< / span > Control Design< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-5-1-2" >
2019-10-18 17:34:45 +02:00
< p >
2020-02-25 18:10:20 +01:00
The controller is defined below and the obtained loop gain is shown in figure < a href = "#org76d929a" > 41< / a > .
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-02-06 17:07:11 +01:00
< pre class = "src src-matlab" > K_ine = 2.5e4;
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org76d929a" class = "figure" >
2020-01-15 16:23:40 +01:00
< p > < img src = "figs/ine_open_loop_gain.png" alt = "ine_open_loop_gain.png" / >
2019-10-18 17:34:45 +02:00
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 41: < / span > Loop Gain for Inertial Control (< a href = "./figs/ine_open_loop_gain.png" > png< / a > , < a href = "./figs/ine_open_loop_gain.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
2019-10-18 17:34:45 +02:00
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org165dd29" class = "outline-4" >
< h4 id = "org165dd29" > < span class = "section-number-4" > 5.1.3< / span > Diagonal Controller< / h4 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-4" id = "text-5-1-3" >
2019-10-18 17:34:45 +02:00
< p >
2020-01-15 16:23:40 +01:00
We create the diagonal controller and we add a minus sign as we have a positive feedback architecture.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-01-15 16:23:40 +01:00
< pre class = "src src-matlab" > K_ine = < span class = "org-type" > -< / span > K_ine< span class = "org-type" > *< / span > eye(6);
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< p >
2020-01-15 16:23:40 +01:00
We save the controller for further analysis.
2019-10-18 17:34:45 +02:00
< / p >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > save(< span class = "org-string" > './mat/active_damping_K_ine.mat'< / span > , < span class = "org-string" > 'K_ine'< / span > );
2019-10-18 17:34:45 +02:00
< / pre >
< / div >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org5587c6f" class = "outline-3" >
< h3 id = "org5587c6f" > < span class = "section-number-3" > 5.2< / span > Conclusion< / h3 >
2020-02-04 16:13:52 +01:00
< div class = "outline-text-3" id = "text-5-2" >
2019-10-18 17:34:45 +02:00
< div class = "important" >
< p >
2020-02-06 17:07:11 +01:00
Inertial Control should not be used.
2019-10-18 17:34:45 +02:00
< / p >
< / div >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgd2a9c18" class = "outline-2" >
< h2 id = "orgd2a9c18" > < span class = "section-number-2" > 6< / span > Comparison< / h2 >
2020-01-21 17:28:49 +01:00
< div class = "outline-text-2" id = "text-6" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "org3fdf55a" > < / a >
2020-01-21 17:28:49 +01:00
< / p >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org68994db" class = "outline-3" >
< h3 id = "org68994db" > < span class = "section-number-3" > 6.1< / span > Load the plants< / h3 >
2020-01-21 17:28:49 +01:00
< div class = "outline-text-3" id = "text-6-1" >
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_plants.mat'< / span > , < span class = "org-string" > 'G'< / span > , < span class = "org-string" > 'G_iff'< / span > , < span class = "org-string" > 'G_ine'< / span > , < span class = "org-string" > 'G_dvf'< / span > );
2020-01-21 17:28:49 +01:00
< / pre >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orge9d62ca" class = "outline-3" >
< h3 id = "orge9d62ca" > < span class = "section-number-3" > 6.2< / span > Sensitivity to Disturbance< / h3 >
2020-01-21 17:28:49 +01:00
< div class = "outline-text-3" id = "text-6-2" >
2020-02-25 18:10:20 +01:00
< div id = "org7bba1a3" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/sensitivity_comp_ground_motion_z.png" alt = "sensitivity_comp_ground_motion_z.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 42: < / span > Sensitivity to ground motion in the Z direction on the Z motion error (< a href = "./figs/sensitivity_comp_ground_motion_z.png" > png< / a > , < a href = "./figs/sensitivity_comp_ground_motion_z.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org614d020" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/sensitivity_comp_direct_forces_z.png" alt = "sensitivity_comp_direct_forces_z.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 43: < / span > Compliance in the Z direction: Sensitivity of direct forces applied on the sample in the Z direction on the Z motion error (< a href = "./figs/sensitivity_comp_direct_forces_z.png" > png< / a > , < a href = "./figs/sensitivity_comp_direct_forces_z.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org066adb3" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/sensitivity_comp_spindle_z.png" alt = "sensitivity_comp_spindle_z.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 44: < / span > Sensitivity to forces applied in the Z direction by the Spindle on the Z motion error (< a href = "./figs/sensitivity_comp_spindle_z.png" > png< / a > , < a href = "./figs/sensitivity_comp_spindle_z.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgf1e951d" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/sensitivity_comp_ty_z.png" alt = "sensitivity_comp_ty_z.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 45: < / span > Sensitivity to forces applied in the Z direction by the Y translation stage on the Z motion error (< a href = "./figs/sensitivity_comp_ty_z.png" > png< / a > , < a href = "./figs/sensitivity_comp_ty_z.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgc4a35d9" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/sensitivity_comp_ty_x.png" alt = "sensitivity_comp_ty_x.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 46: < / span > Sensitivity to forces applied in the X direction by the Y translation stage on the X motion error (< a href = "./figs/sensitivity_comp_ty_x.png" > png< / a > , < a href = "./figs/sensitivity_comp_ty_x.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org60554fc" class = "outline-3" >
< h3 id = "org60554fc" > < span class = "section-number-3" > 6.3< / span > Damped Plant< / h3 >
2020-01-21 17:28:49 +01:00
< div class = "outline-text-3" id = "text-6-3" >
2019-10-25 16:02:23 +02:00
2020-02-25 18:10:20 +01:00
< div id = "org958641d" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/plant_comp_damping_z.png" alt = "plant_comp_damping_z.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 47: < / span > Plant for the \(z\) direction for different active damping technique used (< a href = "./figs/plant_comp_damping_z.png" > png< / a > , < a href = "./figs/plant_comp_damping_z.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org64e3b04" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/plant_comp_damping_x.png" alt = "plant_comp_damping_x.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 48: < / span > Plant for the \(x\) direction for different active damping technique used (< a href = "./figs/plant_comp_damping_x.png" > png< / a > , < a href = "./figs/plant_comp_damping_x.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "org7a73add" class = "figure" >
2019-10-25 16:02:23 +02:00
< p > < img src = "figs/plant_comp_damping_coupling.png" alt = "plant_comp_damping_coupling.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 49: < / span > Comparison of one off-diagonal plant for different damping technique applied (< a href = "./figs/plant_comp_damping_coupling.png" > png< / a > , < a href = "./figs/plant_comp_damping_coupling.pdf" > pdf< / a > )< / p >
2020-01-15 16:23:40 +01:00
< / div >
< / div >
< / div >
2020-01-20 17:40:31 +01:00
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgd49b825" class = "outline-3" >
< h3 id = "orgd49b825" > < span class = "section-number-3" > 6.4< / span > Tomography Experiment - Frequency Domain analysis< / h3 >
2020-01-21 17:28:49 +01:00
< div class = "outline-text-3" id = "text-6-4" >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
2020-03-13 17:40:22 +01:00
< pre class = "src src-matlab" > load(< span class = "org-string" > './mat/active_damping_tomo_exp.mat'< / span > , < span class = "org-string" > 'En'< / span > , < span class = "org-string" > 'En_iff'< / span > , < span class = "org-string" > 'En_dvf'< / span > );
2020-02-06 17:07:11 +01:00
Fs = 1e3; < span class = "org-comment" > % Sampling Frequency of the Data< / span >
t = (1< span class = "org-type" > /< / span > Fs)< span class = "org-type" > *< / span > [0< span class = "org-type" > :< / span > length(En(< span class = "org-type" > :< / span > ,1))< span class = "org-type" > -< / span > 1];
2020-01-15 16:23:40 +01:00
< / pre >
< / div >
2020-02-06 17:07:11 +01:00
< p >
We remove the first 0.5 seconds where the transient behavior is fading out.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > [< span class = "org-type" > ~< / span > , i_start] = min(abs(t < span class = "org-type" > -< / span > 0.5)); < span class = "org-comment" > % find the indice corresponding to 0.5s< / span >
t = t(i_start< span class = "org-type" > :< / span > end) < span class = "org-type" > -< / span > t(i_start);
En = En(i_start< span class = "org-type" > :< / span > end, < span class = "org-type" > :< / span > );
En_dvf = En_dvf(i_start< span class = "org-type" > :< / span > end, < span class = "org-type" > :< / span > );
En_iff = En_iff(i_start< span class = "org-type" > :< / span > end, < span class = "org-type" > :< / span > );
< / pre >
2020-01-20 17:36:30 +01:00
< / div >
2020-01-15 16:23:40 +01:00
2020-01-20 17:36:30 +01:00
< p >
Window used for < code > pwelch< / code > function.
< / p >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
2020-02-06 17:07:11 +01:00
< pre class = "src src-matlab" > n_av = 4;
2020-01-20 17:36:30 +01:00
han_win = hanning(ceil(length(En(< span class = "org-type" > :< / span > , 1))< span class = "org-type" > /< / span > n_av));
2020-01-15 16:23:40 +01:00
< / pre >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "orgf4d8b56" class = "figure" >
2020-01-20 17:36:30 +01:00
< p > < img src = "figs/act_damp_tomo_exp_comp_psd_trans.png" alt = "act_damp_tomo_exp_comp_psd_trans.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 50: < / span > PSD of the translation errors in the X direction for applied Active Damping techniques (< a href = "./figs/act_damp_tomo_exp_comp_psd_trans.png" > png< / a > , < a href = "./figs/act_damp_tomo_exp_comp_psd_trans.pdf" > pdf< / a > )< / p >
2020-01-20 17:36:30 +01:00
< / div >
2020-01-15 16:23:40 +01:00
2020-01-20 17:36:30 +01:00
2020-02-25 18:10:20 +01:00
< div id = "org95a2aeb" class = "figure" >
2020-01-20 17:36:30 +01:00
< p > < img src = "figs/act_damp_tomo_exp_comp_psd_rot.png" alt = "act_damp_tomo_exp_comp_psd_rot.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 51: < / span > PSD of the rotation errors in the X direction for applied Active Damping techniques (< a href = "./figs/act_damp_tomo_exp_comp_psd_rot.png" > png< / a > , < a href = "./figs/act_damp_tomo_exp_comp_psd_rot.pdf" > pdf< / a > )< / p >
2020-01-20 17:20:50 +01:00
< / div >
2020-01-20 17:36:30 +01:00
2020-02-25 18:10:20 +01:00
< div id = "org2e954db" class = "figure" >
2020-01-20 17:36:30 +01:00
< p > < img src = "figs/act_damp_tomo_exp_comp_cps_trans.png" alt = "act_damp_tomo_exp_comp_cps_trans.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 52: < / span > CPS of the translation errors in the X direction for applied Active Damping techniques (< a href = "./figs/act_damp_tomo_exp_comp_cps_trans.png" > png< / a > , < a href = "./figs/act_damp_tomo_exp_comp_cps_trans.pdf" > pdf< / a > )< / p >
2020-01-20 17:20:50 +01:00
< / div >
2020-01-20 17:36:30 +01:00
2020-02-25 18:10:20 +01:00
< div id = "orgfffedef" class = "figure" >
2020-01-20 17:36:30 +01:00
< p > < img src = "figs/act_damp_tomo_exp_comp_cps_rot.png" alt = "act_damp_tomo_exp_comp_cps_rot.png" / >
< / p >
2020-02-06 17:07:11 +01:00
< p > < span class = "figure-number" > Figure 53: < / span > CPS of the rotation errors in the X direction for applied Active Damping techniques (< a href = "./figs/act_damp_tomo_exp_comp_cps_rot.png" > png< / a > , < a href = "./figs/act_damp_tomo_exp_comp_cps_rot.pdf" > pdf< / a > )< / p >
2019-10-25 16:02:23 +02:00
< / div >
< / div >
< / div >
2019-10-18 17:34:45 +02:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-org1623377" class = "outline-2" >
< h2 id = "org1623377" > < span class = "section-number-2" > 7< / span > Useful Functions< / h2 >
2020-01-21 17:28:49 +01:00
< div class = "outline-text-2" id = "text-7" >
2020-01-15 16:23:40 +01:00
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgcf56890" class = "outline-3" >
< h3 id = "orgcf56890" > < span class = "section-number-3" > 7.1< / span > prepareLinearizeIdentification< / h3 >
2020-01-21 17:28:49 +01:00
< div class = "outline-text-3" id = "text-7-1" >
2019-10-18 17:34:45 +02:00
< p >
2020-02-25 18:10:20 +01:00
< a id = "org5680c48" > < / a >
2020-02-06 17:07:11 +01:00
< / p >
< p >
This Matlab function is accessible < a href = "src/prepareLinearizeIdentification.m" > here< / a > .
< / p >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgbcbb56e" class = "outline-4" >
< h4 id = "orgbcbb56e" > Function Description< / h4 >
< div class = "outline-text-4" id = "text-orgbcbb56e" >
2020-02-06 17:07:11 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > < span class = "org-keyword" > function< / span > < span class = "org-variable-name" > []< / span > = < span class = "org-function-name" > prepareLinearizeIdentification< / span > (< span class = "org-variable-name" > args< / span > )
< / pre >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-orgb2bfb6d" class = "outline-4" >
< h4 id = "orgb2bfb6d" > Optional Parameters< / h4 >
< div class = "outline-text-4" id = "text-orgb2bfb6d" >
2020-02-06 17:07:11 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > arguments
args.nass_actuator char {mustBeMember(args.nass_actuator,{< span class = "org-string" > 'piezo'< / span > , < span class = "org-string" > 'lorentz'< / span > })} = < span class = "org-string" > 'piezo'< / span >
args.sample_mass (1,1) double {mustBeNumeric, mustBePositive} = 50 < span class = "org-comment" > % [kg]< / span >
< span class = "org-keyword" > end< / span >
< / pre >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org491e801" class = "outline-4" >
< h4 id = "org491e801" > Initialize the Simulation< / h4 >
< div class = "outline-text-4" id = "text-org491e801" >
2020-02-06 17:07:11 +01:00
< p >
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeGround();
initializeGranite();
initializeTy();
initializeRy();
initializeRz();
initializeMicroHexapod();
initializeAxisc();
initializeMirror();
< / pre >
< / div >
< p >
The nano-hexapod is a piezoelectric hexapod and the sample has a mass of 50kg.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeNanoHexapod(< span class = "org-string" > 'actuator'< / span > , args.nass_actuator);
initializeSample(< span class = "org-string" > 'mass'< / span > , args.sample_mass);
< / pre >
< / div >
< p >
We set the references and disturbances to zero.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeReferences();
initializeDisturbances(< span class = "org-string" > 'enable'< / span > , < span class = "org-constant" > false< / span > );
< / pre >
< / div >
< p >
2020-02-25 17:50:37 +01:00
We set the controller type to Open-Loop.
2020-02-06 17:07:11 +01:00
< / p >
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > initializeController(< span class = "org-string" > 'type'< / span > , < span class = "org-string" > 'open-loop'< / span > );
< / pre >
< / div >
< p >
And we put some gravity.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeSimscapeConfiguration(< span class = "org-string" > 'gravity'< / span > , < span class = "org-constant" > true< / span > );
< / pre >
< / div >
< p >
We do not need to log any signal.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeLoggingConfiguration(< span class = "org-string" > 'log'< / span > , < span class = "org-string" > 'none'< / span > );
2020-02-06 17:07:11 +01:00
< / pre >
< / div >
< / div >
< / div >
< / div >
2020-02-25 18:10:20 +01:00
< div id = "outline-container-orgc2b4408" class = "outline-3" >
< h3 id = "orgc2b4408" > < span class = "section-number-3" > 7.2< / span > prepareTomographyExperiment< / h3 >
2020-02-06 17:07:11 +01:00
< div class = "outline-text-3" id = "text-7-2" >
< p >
2020-02-25 18:10:20 +01:00
< a id = "org9c419c3" > < / a >
2019-10-18 17:34:45 +02:00
< / p >
2020-01-15 16:23:40 +01:00
< p >
This Matlab function is accessible < a href = "src/prepareTomographyExperiment.m" > here< / a > .
< / p >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org8c658fc" class = "outline-4" >
< h4 id = "org8c658fc" > Function Description< / h4 >
< div class = "outline-text-4" id = "text-org8c658fc" >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > < span class = "org-keyword" > function< / span > < span class = "org-variable-name" > []< / span > = < span class = "org-function-name" > prepareTomographyExperiment< / span > (< span class = "org-variable-name" > args< / span > )
< / pre >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org80c975b" class = "outline-4" >
< h4 id = "org80c975b" > Optional Parameters< / h4 >
< div class = "outline-text-4" id = "text-org80c975b" >
2020-01-15 16:23:40 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > arguments
args.nass_actuator char {mustBeMember(args.nass_actuator,{< span class = "org-string" > 'piezo'< / span > , < span class = "org-string" > 'lorentz'< / span > })} = < span class = "org-string" > 'piezo'< / span >
2020-02-04 18:36:27 +01:00
args.sample_mass (1,1) double {mustBeNumeric, mustBePositive} = 50 < span class = "org-comment" > % [kg]< / span >
args.Rz_period (1,1) double {mustBeNumeric, mustBePositive} = 1 < span class = "org-comment" > % [s]< / span >
2020-01-15 16:23:40 +01:00
< span class = "org-keyword" > end< / span >
< / pre >
< / div >
< / div >
< / div >
2020-03-13 17:40:22 +01:00
< div id = "outline-container-org65e26b7" class = "outline-4" >
< h4 id = "org65e26b7" > Initialize the Simulation< / h4 >
< div class = "outline-text-4" id = "text-org65e26b7" >
2020-01-15 16:23:40 +01:00
< p >
We initialize all the stages with the default parameters.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeGround();
initializeGranite();
initializeTy();
initializeRy();
initializeRz();
initializeMicroHexapod();
initializeAxisc();
initializeMirror();
< / pre >
< / div >
< p >
The nano-hexapod is a piezoelectric hexapod and the sample has a mass of 50kg.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeNanoHexapod(< span class = "org-string" > 'actuator'< / span > , args.nass_actuator);
initializeSample(< span class = "org-string" > 'mass'< / span > , args.sample_mass);
< / pre >
< / div >
< p >
2020-02-06 17:07:11 +01:00
We set the references that corresponds to a tomography experiment.
2020-01-15 16:23:40 +01:00
< / p >
< div class = "org-src-container" >
2020-02-04 18:36:27 +01:00
< pre class = "src src-matlab" > initializeReferences(< span class = "org-string" > 'Rz_type'< / span > , < span class = "org-string" > 'rotating'< / span > , < span class = "org-string" > 'Rz_period'< / span > , args.Rz_period);
2020-01-15 16:23:40 +01:00
< / pre >
< / div >
2020-02-06 17:07:11 +01:00
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeDisturbances();
< / pre >
< / div >
2020-01-15 16:23:40 +01:00
< p >
2020-02-25 17:50:37 +01:00
Open Loop.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeController(< span class = "org-string" > 'type'< / span > , < span class = "org-string" > 'open-loop'< / span > );
< / pre >
< / div >
< p >
And we put some gravity.
< / p >
< div class = "org-src-container" >
< pre class = "src src-matlab" > initializeSimscapeConfiguration(< span class = "org-string" > 'gravity'< / span > , < span class = "org-constant" > true< / span > );
< / pre >
< / div >
< p >
We log the signals.
2020-01-15 16:23:40 +01:00
< / p >
< div class = "org-src-container" >
2020-02-25 17:50:37 +01:00
< pre class = "src src-matlab" > initializeLoggingConfiguration(< span class = "org-string" > 'log'< / span > , < span class = "org-string" > 'all'< / span > );
2020-01-15 16:23:40 +01:00
< / pre >
< / div >
< / div >
< / div >
2019-10-18 17:34:45 +02:00
< / div >
< / div >
2019-10-08 11:13:38 +02:00
< / div >
< div id = "postamble" class = "status" >
< p class = "author" > Author: Dehaeze Thomas< / p >
2020-03-13 17:40:22 +01:00
< p class = "date" > Created: 2020-03-13 ven. 17:39< / p >
2019-10-08 11:13:38 +02:00
< / div >
< / body >
< / html >