Category: Matlab
Category Archives: Matlab
Why do we have to provide the jacobians at the Non-linear MPC of Matlab?
Hello,
this is more of a theory question but I would greatly appreciate if you could cite good sources with the theory behind my following question:
Why do we have to define (either numerically or analytically) the jacobians for the NMPC in Matlab?
I can understand that the Jacobian for the A, B and C matrices are for the linearization of the prediction model, but I don’t really understand why we need Jacobians for the Cost function and the Constraints as well.Hello,
this is more of a theory question but I would greatly appreciate if you could cite good sources with the theory behind my following question:
Why do we have to define (either numerically or analytically) the jacobians for the NMPC in Matlab?
I can understand that the Jacobian for the A, B and C matrices are for the linearization of the prediction model, but I don’t really understand why we need Jacobians for the Cost function and the Constraints as well. Hello,
this is more of a theory question but I would greatly appreciate if you could cite good sources with the theory behind my following question:
Why do we have to define (either numerically or analytically) the jacobians for the NMPC in Matlab?
I can understand that the Jacobian for the A, B and C matrices are for the linearization of the prediction model, but I don’t really understand why we need Jacobians for the Cost function and the Constraints as well. nmpc MATLAB Answers — New Questions
run Simscape HDL Workflow Advisor from script
Hi
I am currently working on automating my workflow with Simscape and the HDL Coder. Unfortunately, I cannot find an option to run and configure the Simscape HDL Workflow Advisor (sschdladvisor) from the command line. Is there any way to do this?
Thanks
MarcoHi
I am currently working on automating my workflow with Simscape and the HDL Coder. Unfortunately, I cannot find an option to run and configure the Simscape HDL Workflow Advisor (sschdladvisor) from the command line. Is there any way to do this?
Thanks
Marco Hi
I am currently working on automating my workflow with Simscape and the HDL Coder. Unfortunately, I cannot find an option to run and configure the Simscape HDL Workflow Advisor (sschdladvisor) from the command line. Is there any way to do this?
Thanks
Marco simscape, hdl-coder, workflow advisor MATLAB Answers — New Questions
why i can’t get same plot when i change Real to Im?
i plot the real one but when i change the plot for abs i can get the abs why i can’t get that of this function
0.2e1 * (0.4e1 * exp((-8 * t + 2 * x)) + 0.9e1 * exp((-27 * t + 3 * x)) + 0.25e2 * exp((-35 * t + 5 * x + 2))) / (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) – 0.2e1 * (0.2e1 * exp((-8 * t + 2 * x)) + 0.3e1 * exp((-27 * t + 3 * x)) + 0.5e1 * exp((-35 * t + 5 * x + 2))) ^ 2 / (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) ^ 2
and my code for ploting is
abs(0.2e1 .* (0.4e1 * exp((-8 * t + 2 * x)) + 0.9e1 .* exp((-27 * t + 3 * x)) + 0.25e2 .* exp((-35 * t + 5 * x + 2))) ./ (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) – 0.2e1 * (0.2e1 .* exp((-8 * t + 2 * x)) + 0.3e1 .* exp((-27 * t + 3 * x)) + 0.5e1 .* exp((-35 * t + 5 * x + 2))) .^ 2 ./ (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 .* x)) + exp((-35 * t + 5 * x + 2))) .^ 2).^2i plot the real one but when i change the plot for abs i can get the abs why i can’t get that of this function
0.2e1 * (0.4e1 * exp((-8 * t + 2 * x)) + 0.9e1 * exp((-27 * t + 3 * x)) + 0.25e2 * exp((-35 * t + 5 * x + 2))) / (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) – 0.2e1 * (0.2e1 * exp((-8 * t + 2 * x)) + 0.3e1 * exp((-27 * t + 3 * x)) + 0.5e1 * exp((-35 * t + 5 * x + 2))) ^ 2 / (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) ^ 2
and my code for ploting is
abs(0.2e1 .* (0.4e1 * exp((-8 * t + 2 * x)) + 0.9e1 .* exp((-27 * t + 3 * x)) + 0.25e2 .* exp((-35 * t + 5 * x + 2))) ./ (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) – 0.2e1 * (0.2e1 .* exp((-8 * t + 2 * x)) + 0.3e1 .* exp((-27 * t + 3 * x)) + 0.5e1 .* exp((-35 * t + 5 * x + 2))) .^ 2 ./ (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 .* x)) + exp((-35 * t + 5 * x + 2))) .^ 2).^2 i plot the real one but when i change the plot for abs i can get the abs why i can’t get that of this function
0.2e1 * (0.4e1 * exp((-8 * t + 2 * x)) + 0.9e1 * exp((-27 * t + 3 * x)) + 0.25e2 * exp((-35 * t + 5 * x + 2))) / (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) – 0.2e1 * (0.2e1 * exp((-8 * t + 2 * x)) + 0.3e1 * exp((-27 * t + 3 * x)) + 0.5e1 * exp((-35 * t + 5 * x + 2))) ^ 2 / (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) ^ 2
and my code for ploting is
abs(0.2e1 .* (0.4e1 * exp((-8 * t + 2 * x)) + 0.9e1 .* exp((-27 * t + 3 * x)) + 0.25e2 .* exp((-35 * t + 5 * x + 2))) ./ (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 * x)) + exp((-35 * t + 5 * x + 2))) – 0.2e1 * (0.2e1 .* exp((-8 * t + 2 * x)) + 0.3e1 .* exp((-27 * t + 3 * x)) + 0.5e1 .* exp((-35 * t + 5 * x + 2))) .^ 2 ./ (exp(0.2e1) + exp((-8 * t + 2 * x)) + exp((-27 * t + 3 .* x)) + exp((-35 * t + 5 * x + 2))) .^ 2).^2 plotting, 3d plots MATLAB Answers — New Questions
Roadrunner: XML validation failed
an error occurs when trying to export as xodr file.an error occurs when trying to export as xodr file. an error occurs when trying to export as xodr file. export, xml, xodr MATLAB Answers — New Questions
Opening text document and sending the info over serial port
I have a text document, called transition.txt, that has this inside it.
L,R,D’,B,U,D,F’,R,B’,L’,B2,R,F2,D2,F,L’,U2,L,U2,L,B2,L’,B2,L2,U2,L2,R2,U2,B2,U2
I need to send it to my arduino. Not sure what the code should do on the Matlab side. Also, how would I make sure the information got to the arduino in the way I wanted it to?
Here is my arduino code.
const size_t maxCommandNumber = 50;
const size_t maxCommandSize = 3 * maxCommandNumber; // if commands fit on 2 characters and a comma, this is enough for maxCommandNumber commands
char receivedChars[maxCommandSize + 1]; // +1 for trailing null char required by cStrings
const char endMarker = ‘n’;
void func_L(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Lp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_L2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_R(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Rp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_R2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_D(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Dp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_D2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_B(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Bp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_B2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_U(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Up(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_U2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_F(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Fp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_F2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_unknown(const char* s) {Serial.print(F("Unknown commmand: ")); Serial.println(s);}
struct {
const char* label;
void (*func)(const char*);
} keys[] = {
{"L", func_L},
{"L’", func_Lp},
{"L2", func_L2},
{"R", func_R},
{"R’", func_Rp},
{"R2", func_R2},
{"D", func_D},
{"D’", func_Dp},
{"D2", func_D2},
{"B", func_B},
{"B’", func_Bp},
{"B2", func_B2},
{"U", func_U},
{"U’", func_Up},
{"U2", func_U2},
{"F", func_F},
{"F’", func_Fp},
{"F2", func_F2},
};
const size_t nbKeys = sizeof keys / sizeof keys[0];
bool findAndExecute(const char* s)
{
bool success = false;
for (size_t i = 0; i < nbKeys; i++)
if (!strcmp(s, keys[i].label)) {
keys[i].func(s);
success = true;
break;
}
if (!success) func_unknown(s);
return success;
}
bool commandAvailable()
{
static size_t commandIndex = 0;
static bool awaitEndMarkerError = false;
int incomingByte = Serial.read();
bool commandComplete = false;
if (incomingByte != -1) { // read returns -1 if there is nothing to read (faster than using available)
if (awaitEndMarkerError) {
if (incomingByte == endMarker) {
awaitEndMarkerError = false;
commandIndex = 0;
receivedChars[0] = ”; // discard what was there
commandComplete = true; // if we want to still notify the parser we got a command (here will be empty)
}
} else {
char incomingCharacter = incomingByte; // grab LSB as a char
if (incomingByte != endMarker) {
if (commandIndex < maxCommandSize) {
if (!isspace(incomingCharacter)) { // discard all spaces. could also add a test to only keep A-Z and ‘ and 2, whatever is legit in the command language
receivedChars[commandIndex++] = incomingCharacter;
receivedChars[commandIndex] = ”; // always maintain a correct cString
}
} else {
Serial.println(F("ERROR: Command line too big. Discarded.nt-> increase maxCommandNumber or send shorter command lines."));
awaitEndMarkerError = true;
}
} else {
commandIndex = 0;
commandComplete = true;
}
}
}
return commandComplete;
}
bool handleCommand()
{
bool success = true;
const char* separators = ",";
Serial.print(F("nparsing : ")); Serial.println(receivedChars);
char* ptr = strtok(receivedChars, separators);
if (*ptr == ”) Serial.println(F("Error: empty command"));
else
while (ptr) {
success &= findAndExecute(ptr);
ptr = strtok(NULL, separators);
}
return success;
}
void setup() {
Serial.begin(115200);
}
void loop() {
if (commandAvailable())
if (! handleCommand())
Serial.println(F("Some commands were not recognized"));
}I have a text document, called transition.txt, that has this inside it.
L,R,D’,B,U,D,F’,R,B’,L’,B2,R,F2,D2,F,L’,U2,L,U2,L,B2,L’,B2,L2,U2,L2,R2,U2,B2,U2
I need to send it to my arduino. Not sure what the code should do on the Matlab side. Also, how would I make sure the information got to the arduino in the way I wanted it to?
Here is my arduino code.
const size_t maxCommandNumber = 50;
const size_t maxCommandSize = 3 * maxCommandNumber; // if commands fit on 2 characters and a comma, this is enough for maxCommandNumber commands
char receivedChars[maxCommandSize + 1]; // +1 for trailing null char required by cStrings
const char endMarker = ‘n’;
void func_L(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Lp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_L2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_R(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Rp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_R2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_D(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Dp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_D2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_B(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Bp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_B2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_U(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Up(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_U2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_F(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Fp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_F2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_unknown(const char* s) {Serial.print(F("Unknown commmand: ")); Serial.println(s);}
struct {
const char* label;
void (*func)(const char*);
} keys[] = {
{"L", func_L},
{"L’", func_Lp},
{"L2", func_L2},
{"R", func_R},
{"R’", func_Rp},
{"R2", func_R2},
{"D", func_D},
{"D’", func_Dp},
{"D2", func_D2},
{"B", func_B},
{"B’", func_Bp},
{"B2", func_B2},
{"U", func_U},
{"U’", func_Up},
{"U2", func_U2},
{"F", func_F},
{"F’", func_Fp},
{"F2", func_F2},
};
const size_t nbKeys = sizeof keys / sizeof keys[0];
bool findAndExecute(const char* s)
{
bool success = false;
for (size_t i = 0; i < nbKeys; i++)
if (!strcmp(s, keys[i].label)) {
keys[i].func(s);
success = true;
break;
}
if (!success) func_unknown(s);
return success;
}
bool commandAvailable()
{
static size_t commandIndex = 0;
static bool awaitEndMarkerError = false;
int incomingByte = Serial.read();
bool commandComplete = false;
if (incomingByte != -1) { // read returns -1 if there is nothing to read (faster than using available)
if (awaitEndMarkerError) {
if (incomingByte == endMarker) {
awaitEndMarkerError = false;
commandIndex = 0;
receivedChars[0] = ”; // discard what was there
commandComplete = true; // if we want to still notify the parser we got a command (here will be empty)
}
} else {
char incomingCharacter = incomingByte; // grab LSB as a char
if (incomingByte != endMarker) {
if (commandIndex < maxCommandSize) {
if (!isspace(incomingCharacter)) { // discard all spaces. could also add a test to only keep A-Z and ‘ and 2, whatever is legit in the command language
receivedChars[commandIndex++] = incomingCharacter;
receivedChars[commandIndex] = ”; // always maintain a correct cString
}
} else {
Serial.println(F("ERROR: Command line too big. Discarded.nt-> increase maxCommandNumber or send shorter command lines."));
awaitEndMarkerError = true;
}
} else {
commandIndex = 0;
commandComplete = true;
}
}
}
return commandComplete;
}
bool handleCommand()
{
bool success = true;
const char* separators = ",";
Serial.print(F("nparsing : ")); Serial.println(receivedChars);
char* ptr = strtok(receivedChars, separators);
if (*ptr == ”) Serial.println(F("Error: empty command"));
else
while (ptr) {
success &= findAndExecute(ptr);
ptr = strtok(NULL, separators);
}
return success;
}
void setup() {
Serial.begin(115200);
}
void loop() {
if (commandAvailable())
if (! handleCommand())
Serial.println(F("Some commands were not recognized"));
} I have a text document, called transition.txt, that has this inside it.
L,R,D’,B,U,D,F’,R,B’,L’,B2,R,F2,D2,F,L’,U2,L,U2,L,B2,L’,B2,L2,U2,L2,R2,U2,B2,U2
I need to send it to my arduino. Not sure what the code should do on the Matlab side. Also, how would I make sure the information got to the arduino in the way I wanted it to?
Here is my arduino code.
const size_t maxCommandNumber = 50;
const size_t maxCommandSize = 3 * maxCommandNumber; // if commands fit on 2 characters and a comma, this is enough for maxCommandNumber commands
char receivedChars[maxCommandSize + 1]; // +1 for trailing null char required by cStrings
const char endMarker = ‘n’;
void func_L(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Lp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_L2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_R(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Rp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_R2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_D(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Dp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_D2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_B(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Bp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_B2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_U(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Up(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_U2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_F(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_Fp(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_F2(const char* s) {Serial.print(F("in Function ")); Serial.println(s);}
void func_unknown(const char* s) {Serial.print(F("Unknown commmand: ")); Serial.println(s);}
struct {
const char* label;
void (*func)(const char*);
} keys[] = {
{"L", func_L},
{"L’", func_Lp},
{"L2", func_L2},
{"R", func_R},
{"R’", func_Rp},
{"R2", func_R2},
{"D", func_D},
{"D’", func_Dp},
{"D2", func_D2},
{"B", func_B},
{"B’", func_Bp},
{"B2", func_B2},
{"U", func_U},
{"U’", func_Up},
{"U2", func_U2},
{"F", func_F},
{"F’", func_Fp},
{"F2", func_F2},
};
const size_t nbKeys = sizeof keys / sizeof keys[0];
bool findAndExecute(const char* s)
{
bool success = false;
for (size_t i = 0; i < nbKeys; i++)
if (!strcmp(s, keys[i].label)) {
keys[i].func(s);
success = true;
break;
}
if (!success) func_unknown(s);
return success;
}
bool commandAvailable()
{
static size_t commandIndex = 0;
static bool awaitEndMarkerError = false;
int incomingByte = Serial.read();
bool commandComplete = false;
if (incomingByte != -1) { // read returns -1 if there is nothing to read (faster than using available)
if (awaitEndMarkerError) {
if (incomingByte == endMarker) {
awaitEndMarkerError = false;
commandIndex = 0;
receivedChars[0] = ”; // discard what was there
commandComplete = true; // if we want to still notify the parser we got a command (here will be empty)
}
} else {
char incomingCharacter = incomingByte; // grab LSB as a char
if (incomingByte != endMarker) {
if (commandIndex < maxCommandSize) {
if (!isspace(incomingCharacter)) { // discard all spaces. could also add a test to only keep A-Z and ‘ and 2, whatever is legit in the command language
receivedChars[commandIndex++] = incomingCharacter;
receivedChars[commandIndex] = ”; // always maintain a correct cString
}
} else {
Serial.println(F("ERROR: Command line too big. Discarded.nt-> increase maxCommandNumber or send shorter command lines."));
awaitEndMarkerError = true;
}
} else {
commandIndex = 0;
commandComplete = true;
}
}
}
return commandComplete;
}
bool handleCommand()
{
bool success = true;
const char* separators = ",";
Serial.print(F("nparsing : ")); Serial.println(receivedChars);
char* ptr = strtok(receivedChars, separators);
if (*ptr == ”) Serial.println(F("Error: empty command"));
else
while (ptr) {
success &= findAndExecute(ptr);
ptr = strtok(NULL, separators);
}
return success;
}
void setup() {
Serial.begin(115200);
}
void loop() {
if (commandAvailable())
if (! handleCommand())
Serial.println(F("Some commands were not recognized"));
} arduino, serial, send MATLAB Answers — New Questions
Create boundaries in an image based on porosity
Hi I am trying to create a boundary in my image between 3 regions of different porosities. I have an algorithm which tells me the porosity of the whole image and when I give it different parts of this image it gives me different porosity values, but I am not sure how to apply that to create the boundaries I want. Please help. Here is the binary image and roughly what I’m trying to do.Hi I am trying to create a boundary in my image between 3 regions of different porosities. I have an algorithm which tells me the porosity of the whole image and when I give it different parts of this image it gives me different porosity values, but I am not sure how to apply that to create the boundaries I want. Please help. Here is the binary image and roughly what I’m trying to do. Hi I am trying to create a boundary in my image between 3 regions of different porosities. I have an algorithm which tells me the porosity of the whole image and when I give it different parts of this image it gives me different porosity values, but I am not sure how to apply that to create the boundaries I want. Please help. Here is the binary image and roughly what I’m trying to do. image segmentation, pore distribution MATLAB Answers — New Questions
Dividing a number by a column matrix in Matlab
For example if I were to type this in matlab:
>> 1/[1, 2 ,3]
There would be an error:
>> Error using /
Matrix dimensions must agree.
But if I were to type this in Matlab
>> 1/[1; 2; 3]
The answer would be:
[0 0 0.3333]
Why is Matlab doing this ?For example if I were to type this in matlab:
>> 1/[1, 2 ,3]
There would be an error:
>> Error using /
Matrix dimensions must agree.
But if I were to type this in Matlab
>> 1/[1; 2; 3]
The answer would be:
[0 0 0.3333]
Why is Matlab doing this ? For example if I were to type this in matlab:
>> 1/[1, 2 ,3]
There would be an error:
>> Error using /
Matrix dimensions must agree.
But if I were to type this in Matlab
>> 1/[1; 2; 3]
The answer would be:
[0 0 0.3333]
Why is Matlab doing this ? matlab, matrix MATLAB Answers — New Questions
Steady state error in DDPG control
I am trying to make some modifications in Control Water Level in a Tank Using a DDPG Agent example. I want to reduce sample time from 1.0 to 0.5, so I set Ts = 0.5. Consequently, I had to make adjustment on StopTrainingValue, i.e., changed its value from 2000 to 4000. The training process was successfully completed as it can be seen below.
But there is something unexpected happened: this modifications introduce a steady state error (or something similar to) that wasn’t there in the original example.
How to overcome this steady state error? Do I need to make additional adjustments, e.g. make changes to the structure of observations, reward function, actor/critic network, StopTrainingCriteria, etc?
Update:
This is the error I get using pre-trained agent (doTraining = false, no change on the original example)
This is the error I get using re-trained agent (doTraining = true, no change on the original example)I am trying to make some modifications in Control Water Level in a Tank Using a DDPG Agent example. I want to reduce sample time from 1.0 to 0.5, so I set Ts = 0.5. Consequently, I had to make adjustment on StopTrainingValue, i.e., changed its value from 2000 to 4000. The training process was successfully completed as it can be seen below.
But there is something unexpected happened: this modifications introduce a steady state error (or something similar to) that wasn’t there in the original example.
How to overcome this steady state error? Do I need to make additional adjustments, e.g. make changes to the structure of observations, reward function, actor/critic network, StopTrainingCriteria, etc?
Update:
This is the error I get using pre-trained agent (doTraining = false, no change on the original example)
This is the error I get using re-trained agent (doTraining = true, no change on the original example) I am trying to make some modifications in Control Water Level in a Tank Using a DDPG Agent example. I want to reduce sample time from 1.0 to 0.5, so I set Ts = 0.5. Consequently, I had to make adjustment on StopTrainingValue, i.e., changed its value from 2000 to 4000. The training process was successfully completed as it can be seen below.
But there is something unexpected happened: this modifications introduce a steady state error (or something similar to) that wasn’t there in the original example.
How to overcome this steady state error? Do I need to make additional adjustments, e.g. make changes to the structure of observations, reward function, actor/critic network, StopTrainingCriteria, etc?
Update:
This is the error I get using pre-trained agent (doTraining = false, no change on the original example)
This is the error I get using re-trained agent (doTraining = true, no change on the original example) control, reinforcement learning, deep learning MATLAB Answers — New Questions
How to include complex numbers in fprintf function?
lambda = [1.064e-6];
R = [30];
w=[0.001];
q = (1./R- i* lambda./pi./w.^2).^(-1);
a=1;
p=1;
m=1;
probe_r=linspace(0,0.003,100);
probe_theta=linspace(0,0.003,100);
rseed=[0*max(w):max(w)/30:3*max(w)];
thetaseed=[0:360]*pi/180;
[r,theta]=meshgrid(rseed,thetaseed);
E=LaguerreGaussianE([p,m,q,lambda,a],r,theta);
V=interp2(r,theta,E,probe_r,probe_theta);
column_names = {‘r’, ‘theta’, ‘V’};
fid = fopen(‘fidtext.txt’,’wt’);
fprintf(fid, ‘%s ‘, column_names{:});
fprintf(fid, ‘n’);
block_of_data = [probe_r, probe_theta, V];
fmt = repmat(‘%15g ‘, 1, 3);
fmt(end:end+1) = ‘n’;
fprintf(fid, fmt, block_of_data.’);
fclose(fid);
With the current code I have I get a .txt file of only the real numbers from my function V along with the values of probe_r and probe_theta. How do I alter this to produce both the real and complex numbers as a 3 column .txt file of r, theta and V as I am unable to see a formatSpec to include complex numbers.lambda = [1.064e-6];
R = [30];
w=[0.001];
q = (1./R- i* lambda./pi./w.^2).^(-1);
a=1;
p=1;
m=1;
probe_r=linspace(0,0.003,100);
probe_theta=linspace(0,0.003,100);
rseed=[0*max(w):max(w)/30:3*max(w)];
thetaseed=[0:360]*pi/180;
[r,theta]=meshgrid(rseed,thetaseed);
E=LaguerreGaussianE([p,m,q,lambda,a],r,theta);
V=interp2(r,theta,E,probe_r,probe_theta);
column_names = {‘r’, ‘theta’, ‘V’};
fid = fopen(‘fidtext.txt’,’wt’);
fprintf(fid, ‘%s ‘, column_names{:});
fprintf(fid, ‘n’);
block_of_data = [probe_r, probe_theta, V];
fmt = repmat(‘%15g ‘, 1, 3);
fmt(end:end+1) = ‘n’;
fprintf(fid, fmt, block_of_data.’);
fclose(fid);
With the current code I have I get a .txt file of only the real numbers from my function V along with the values of probe_r and probe_theta. How do I alter this to produce both the real and complex numbers as a 3 column .txt file of r, theta and V as I am unable to see a formatSpec to include complex numbers. lambda = [1.064e-6];
R = [30];
w=[0.001];
q = (1./R- i* lambda./pi./w.^2).^(-1);
a=1;
p=1;
m=1;
probe_r=linspace(0,0.003,100);
probe_theta=linspace(0,0.003,100);
rseed=[0*max(w):max(w)/30:3*max(w)];
thetaseed=[0:360]*pi/180;
[r,theta]=meshgrid(rseed,thetaseed);
E=LaguerreGaussianE([p,m,q,lambda,a],r,theta);
V=interp2(r,theta,E,probe_r,probe_theta);
column_names = {‘r’, ‘theta’, ‘V’};
fid = fopen(‘fidtext.txt’,’wt’);
fprintf(fid, ‘%s ‘, column_names{:});
fprintf(fid, ‘n’);
block_of_data = [probe_r, probe_theta, V];
fmt = repmat(‘%15g ‘, 1, 3);
fmt(end:end+1) = ‘n’;
fprintf(fid, fmt, block_of_data.’);
fclose(fid);
With the current code I have I get a .txt file of only the real numbers from my function V along with the values of probe_r and probe_theta. How do I alter this to produce both the real and complex numbers as a 3 column .txt file of r, theta and V as I am unable to see a formatSpec to include complex numbers. fprintf, complex numbers MATLAB Answers — New Questions
Why does the “Test Connection” for Bluetooth fail in the hardware setup screen for the Arduino support package on macOS versions 12, 13 and 14 ?
Issue:
Why does the "Test Connection" for Bluetooth fail in the hardware setup screen for the Arduino support package on macOS versions 12, 13 and 14?
I am using an Arduino Uno with an HC-05 Bluetooth module, intending to integrate it with the MATLAB Support Package for Arduino Hardware on my Mac running Ventura OS 13. While I can successfully program the board via the hardware setup screen, the "Test Connection" button consistently triggers a prompt outside of the MATLAB window requesting a device connection. Despite clicking "Connect" on this prompt, the test connection fails in the hardware setup screen, preventing further progress.
This issue also occurs on macOS 12 Monterey and macOS 14 Sonoma.
Prompt:
Test Connection failure:Issue:
Why does the "Test Connection" for Bluetooth fail in the hardware setup screen for the Arduino support package on macOS versions 12, 13 and 14?
I am using an Arduino Uno with an HC-05 Bluetooth module, intending to integrate it with the MATLAB Support Package for Arduino Hardware on my Mac running Ventura OS 13. While I can successfully program the board via the hardware setup screen, the "Test Connection" button consistently triggers a prompt outside of the MATLAB window requesting a device connection. Despite clicking "Connect" on this prompt, the test connection fails in the hardware setup screen, preventing further progress.
This issue also occurs on macOS 12 Monterey and macOS 14 Sonoma.
Prompt:
Test Connection failure: Issue:
Why does the "Test Connection" for Bluetooth fail in the hardware setup screen for the Arduino support package on macOS versions 12, 13 and 14?
I am using an Arduino Uno with an HC-05 Bluetooth module, intending to integrate it with the MATLAB Support Package for Arduino Hardware on my Mac running Ventura OS 13. While I can successfully program the board via the hardware setup screen, the "Test Connection" button consistently triggers a prompt outside of the MATLAB window requesting a device connection. Despite clicking "Connect" on this prompt, the test connection fails in the hardware setup screen, preventing further progress.
This issue also occurs on macOS 12 Monterey and macOS 14 Sonoma.
Prompt:
Test Connection failure: arduino, mac MATLAB Answers — New Questions
Why am I getting a Complex signal mismatch error when using the Simscape power system FACT element – UPFC(phasor model)
I got the following error when I tried a simulink model (named UPFC compensated line) of a power system using only the Simscape powersystem specialised technology components.
Complex signal mismatch. Input port 1 of ‘UPFC_compensated_line/Unified Power Flow Controller (Phasor Type)/Power Components Modeling (Shunt & Series Converter)/Power Components modeling (Shunt Converter)/Demux1’ expects a signal of numeric type real. However, it is driven by a signal of numeric type complex
Component: Simulink | Category: Block error
Complex signal mismatch. Output port 1 of ‘UPFC_compensated_line/Unified Power Flow Controller (Phasor Type)/Power Components Modeling (Shunt & Series Converter)/Power Components modeling (Shunt Converter)/dq-axis model of 3-ph RL branch’ is a signal of numeric type complex. However, it is driving a signal of numeric type real
What might be the reason? Please help to resolve the problemI got the following error when I tried a simulink model (named UPFC compensated line) of a power system using only the Simscape powersystem specialised technology components.
Complex signal mismatch. Input port 1 of ‘UPFC_compensated_line/Unified Power Flow Controller (Phasor Type)/Power Components Modeling (Shunt & Series Converter)/Power Components modeling (Shunt Converter)/Demux1’ expects a signal of numeric type real. However, it is driven by a signal of numeric type complex
Component: Simulink | Category: Block error
Complex signal mismatch. Output port 1 of ‘UPFC_compensated_line/Unified Power Flow Controller (Phasor Type)/Power Components Modeling (Shunt & Series Converter)/Power Components modeling (Shunt Converter)/dq-axis model of 3-ph RL branch’ is a signal of numeric type complex. However, it is driving a signal of numeric type real
What might be the reason? Please help to resolve the problem I got the following error when I tried a simulink model (named UPFC compensated line) of a power system using only the Simscape powersystem specialised technology components.
Complex signal mismatch. Input port 1 of ‘UPFC_compensated_line/Unified Power Flow Controller (Phasor Type)/Power Components Modeling (Shunt & Series Converter)/Power Components modeling (Shunt Converter)/Demux1’ expects a signal of numeric type real. However, it is driven by a signal of numeric type complex
Component: Simulink | Category: Block error
Complex signal mismatch. Output port 1 of ‘UPFC_compensated_line/Unified Power Flow Controller (Phasor Type)/Power Components Modeling (Shunt & Series Converter)/Power Components modeling (Shunt Converter)/dq-axis model of 3-ph RL branch’ is a signal of numeric type complex. However, it is driving a signal of numeric type real
What might be the reason? Please help to resolve the problem upfc, signal mismatch MATLAB Answers — New Questions
Why does Matlab recommend keeping the Documentation on the Web?
Why does Matlab recommend keeping the Documentation on the Web. It is painfully slow compared to having it stored locally on your machine, even with a fast internet connection.Why does Matlab recommend keeping the Documentation on the Web. It is painfully slow compared to having it stored locally on your machine, even with a fast internet connection. Why does Matlab recommend keeping the Documentation on the Web. It is painfully slow compared to having it stored locally on your machine, even with a fast internet connection. documentation MATLAB Answers — New Questions
algorithm of envelope function ‘peak’ option
Hello,
I’m using the envelope function with ‘peak’ option, [yupper,ylower] = envelope(x,np,’peak’).
The description says, ‘The envelopes are determined using spline interpolation over local maxima separated by at least np samples.’
I’m wondering that what order is used in the spline interpolation and also how the local maxima are calculated, separated by ‘at least’ np samples.
If I can, I would like to know the algorithm too.
Thank you.Hello,
I’m using the envelope function with ‘peak’ option, [yupper,ylower] = envelope(x,np,’peak’).
The description says, ‘The envelopes are determined using spline interpolation over local maxima separated by at least np samples.’
I’m wondering that what order is used in the spline interpolation and also how the local maxima are calculated, separated by ‘at least’ np samples.
If I can, I would like to know the algorithm too.
Thank you. Hello,
I’m using the envelope function with ‘peak’ option, [yupper,ylower] = envelope(x,np,’peak’).
The description says, ‘The envelopes are determined using spline interpolation over local maxima separated by at least np samples.’
I’m wondering that what order is used in the spline interpolation and also how the local maxima are calculated, separated by ‘at least’ np samples.
If I can, I would like to know the algorithm too.
Thank you. envelope, algorithm MATLAB Answers — New Questions
Using polyeig with scaling matrices
I’m using the function polyeig to solve a quadratic eigenvalue problem with complex matrices A0.A1 and A2 (A2 is singular; has only two non-zero rows).
The result was so bad, and according to the help center of Mathworks : (Scaling A0,A1,…,Ap to have norm(Ai) roughly equal to 1 might increase the accuracy of polyeig)
https://www.mathworks.com/help/matlab/ref/polyeig.html
Is there any function in Matlab to do this scaling?
Thanks in advance;I’m using the function polyeig to solve a quadratic eigenvalue problem with complex matrices A0.A1 and A2 (A2 is singular; has only two non-zero rows).
The result was so bad, and according to the help center of Mathworks : (Scaling A0,A1,…,Ap to have norm(Ai) roughly equal to 1 might increase the accuracy of polyeig)
https://www.mathworks.com/help/matlab/ref/polyeig.html
Is there any function in Matlab to do this scaling?
Thanks in advance; I’m using the function polyeig to solve a quadratic eigenvalue problem with complex matrices A0.A1 and A2 (A2 is singular; has only two non-zero rows).
The result was so bad, and according to the help center of Mathworks : (Scaling A0,A1,…,Ap to have norm(Ai) roughly equal to 1 might increase the accuracy of polyeig)
https://www.mathworks.com/help/matlab/ref/polyeig.html
Is there any function in Matlab to do this scaling?
Thanks in advance; polyeig, matlab, scaling, complex matrix, eigenvalue-problem MATLAB Answers — New Questions
comsol LiveLink for MATLAB: output solutions on a specific line (in reference or current configuration)
In a 3D comsol model, how to output the solution on a specific line (in reference or current configuration)? In .mph comsol models, it’s like the
comp1.at3
command that is equivalent.In a 3D comsol model, how to output the solution on a specific line (in reference or current configuration)? In .mph comsol models, it’s like the
comp1.at3
command that is equivalent. In a 3D comsol model, how to output the solution on a specific line (in reference or current configuration)? In .mph comsol models, it’s like the
comp1.at3
command that is equivalent. comsol MATLAB Answers — New Questions
Matrix function — problem with the defi
Hi!
I wrote this code where Y is a cell array (actually is a matrix [y1; y2; y3] and F is a matrix that I would like to be like the function of Y — I mean if Y = [y1; y2; y3] -> F(Y) = [1; y3; f(y1, y2, y3)] where f – another function.
How can I realize this in Matlab? Unfortunely this code does not work in an appropriate way. ;(
Thanks!
Y = @(y1, y2, y3) {@(y1) y1; @(y2) y2; @(y3) y3};
F = @(Y) [1; Y(3); f(Y(1), Y(2), Y(3))]Hi!
I wrote this code where Y is a cell array (actually is a matrix [y1; y2; y3] and F is a matrix that I would like to be like the function of Y — I mean if Y = [y1; y2; y3] -> F(Y) = [1; y3; f(y1, y2, y3)] where f – another function.
How can I realize this in Matlab? Unfortunely this code does not work in an appropriate way. ;(
Thanks!
Y = @(y1, y2, y3) {@(y1) y1; @(y2) y2; @(y3) y3};
F = @(Y) [1; Y(3); f(Y(1), Y(2), Y(3))] Hi!
I wrote this code where Y is a cell array (actually is a matrix [y1; y2; y3] and F is a matrix that I would like to be like the function of Y — I mean if Y = [y1; y2; y3] -> F(Y) = [1; y3; f(y1, y2, y3)] where f – another function.
How can I realize this in Matlab? Unfortunely this code does not work in an appropriate way. ;(
Thanks!
Y = @(y1, y2, y3) {@(y1) y1; @(y2) y2; @(y3) y3};
F = @(Y) [1; Y(3); f(Y(1), Y(2), Y(3))] function, matrix, array, cell arrays MATLAB Answers — New Questions
FOC BLDC with mathematical model
I have simulated FOC with BLDC using mathematical model but Iam getting negative speed. Can anyone help me identify what is the issue with the mode. I have used the same with bldc motor block(PMSM block with trapizoidal back emf) that is working but this one is going to negative speed.I have simulated FOC with BLDC using mathematical model but Iam getting negative speed. Can anyone help me identify what is the issue with the mode. I have used the same with bldc motor block(PMSM block with trapizoidal back emf) that is working but this one is going to negative speed. I have simulated FOC with BLDC using mathematical model but Iam getting negative speed. Can anyone help me identify what is the issue with the mode. I have used the same with bldc motor block(PMSM block with trapizoidal back emf) that is working but this one is going to negative speed. foc MATLAB Answers — New Questions
what is 2+2
what is 2+2what is 2+2 what is 2+2 — MATLAB Answers — New Questions
Image Processing for ultrasound
I would like to do image processing to recognize a needle in an ultrasound image. Such as the one below
This image is scaled down to 20%
Currently I am thinking about blurring, created a region of interest, thresholding the image and then identifiying the most continous blob of white pixels.
Does anyone have a way to create a blur that utilizes the brightest pixels to change the pixels around it?
Other feedback and methods and input would also be appreciated.
Also @Image Analyst might be interetstedI would like to do image processing to recognize a needle in an ultrasound image. Such as the one below
This image is scaled down to 20%
Currently I am thinking about blurring, created a region of interest, thresholding the image and then identifiying the most continous blob of white pixels.
Does anyone have a way to create a blur that utilizes the brightest pixels to change the pixels around it?
Other feedback and methods and input would also be appreciated.
Also @Image Analyst might be interetsted I would like to do image processing to recognize a needle in an ultrasound image. Such as the one below
This image is scaled down to 20%
Currently I am thinking about blurring, created a region of interest, thresholding the image and then identifiying the most continous blob of white pixels.
Does anyone have a way to create a blur that utilizes the brightest pixels to change the pixels around it?
Other feedback and methods and input would also be appreciated.
Also @Image Analyst might be interetsted image analysis, digital image processing, ultrasound MATLAB Answers — New Questions
How to combine all script windows into one window with tabs
Hi there
Silly question. I used to have all of my scripts as tabs in a single window. Now, for some reason, Matlab shows me each new script in a separate window, which quickly gets very difficult to manage. How do I revert this sudden change back to the normal setting?
Cheers
JakobHi there
Silly question. I used to have all of my scripts as tabs in a single window. Now, for some reason, Matlab shows me each new script in a separate window, which quickly gets very difficult to manage. How do I revert this sudden change back to the normal setting?
Cheers
Jakob Hi there
Silly question. I used to have all of my scripts as tabs in a single window. Now, for some reason, Matlab shows me each new script in a separate window, which quickly gets very difficult to manage. How do I revert this sudden change back to the normal setting?
Cheers
Jakob matlab, script MATLAB Answers — New Questions