Solving a strong form differential equation (FEM) using MATLAB
$begingroup$
I need some diagnosis on how I'm solving my differential equation. This was a template given to me by my professor and I manipulated it to the best of my ability.
The governing equations are here:
And here is my code:
clear;
clc;
close all;
% u,,xx=-(f/ea) on [0,L]
% u,x(L)= R
% u(0)=0
% Parameters
L= 1;
% Parameters in force function
A= .0001;
E= 70e9;
R= 1000;
a= 1000;
g= R/E*A;
f= @(x) ((((-1)*(a)*(x))/E*A));
% solve analytical solution
u1 = dsolve(['D2y = ' char(sym(f))], ['Dy(1) = ' num2str(g)], ['y(0) ='
num2str(0)] ,'x');
% change symbolic function to anonymous matlab function for easier
computing
u = matlabFunction(u1);
% plot the analytical solution
n= 20;
x = linspace(0, 1, n);
plot(x, u(x), '-ro', 'LineWidth', 4)
title('Analytical Solution u')
axis([0, 1, 0, 3])
xlabel('x')
ylabel('u')
I come across issues when I try to plot my values. The analytical solution should be around in the .21428 range or something. I figured that it has to be an issue with my differential solver or the way that I am plotting it but I definitely think its the ODE solving that's got me messed up.
I'm pretty much stuck at this point. I checked my equations to be sure they were right but alas no issues there so I could definitely use another brain.
If you need to see the question prompt let me know. I was wary of posting it because of my professor so I didn't think it'd be too necessary.
Note: u,xx is a second order and u,x is a first order.
matlab
New contributor
$endgroup$
add a comment |
$begingroup$
I need some diagnosis on how I'm solving my differential equation. This was a template given to me by my professor and I manipulated it to the best of my ability.
The governing equations are here:
And here is my code:
clear;
clc;
close all;
% u,,xx=-(f/ea) on [0,L]
% u,x(L)= R
% u(0)=0
% Parameters
L= 1;
% Parameters in force function
A= .0001;
E= 70e9;
R= 1000;
a= 1000;
g= R/E*A;
f= @(x) ((((-1)*(a)*(x))/E*A));
% solve analytical solution
u1 = dsolve(['D2y = ' char(sym(f))], ['Dy(1) = ' num2str(g)], ['y(0) ='
num2str(0)] ,'x');
% change symbolic function to anonymous matlab function for easier
computing
u = matlabFunction(u1);
% plot the analytical solution
n= 20;
x = linspace(0, 1, n);
plot(x, u(x), '-ro', 'LineWidth', 4)
title('Analytical Solution u')
axis([0, 1, 0, 3])
xlabel('x')
ylabel('u')
I come across issues when I try to plot my values. The analytical solution should be around in the .21428 range or something. I figured that it has to be an issue with my differential solver or the way that I am plotting it but I definitely think its the ODE solving that's got me messed up.
I'm pretty much stuck at this point. I checked my equations to be sure they were right but alas no issues there so I could definitely use another brain.
If you need to see the question prompt let me know. I was wary of posting it because of my professor so I didn't think it'd be too necessary.
Note: u,xx is a second order and u,x is a first order.
matlab
New contributor
$endgroup$
add a comment |
$begingroup$
I need some diagnosis on how I'm solving my differential equation. This was a template given to me by my professor and I manipulated it to the best of my ability.
The governing equations are here:
And here is my code:
clear;
clc;
close all;
% u,,xx=-(f/ea) on [0,L]
% u,x(L)= R
% u(0)=0
% Parameters
L= 1;
% Parameters in force function
A= .0001;
E= 70e9;
R= 1000;
a= 1000;
g= R/E*A;
f= @(x) ((((-1)*(a)*(x))/E*A));
% solve analytical solution
u1 = dsolve(['D2y = ' char(sym(f))], ['Dy(1) = ' num2str(g)], ['y(0) ='
num2str(0)] ,'x');
% change symbolic function to anonymous matlab function for easier
computing
u = matlabFunction(u1);
% plot the analytical solution
n= 20;
x = linspace(0, 1, n);
plot(x, u(x), '-ro', 'LineWidth', 4)
title('Analytical Solution u')
axis([0, 1, 0, 3])
xlabel('x')
ylabel('u')
I come across issues when I try to plot my values. The analytical solution should be around in the .21428 range or something. I figured that it has to be an issue with my differential solver or the way that I am plotting it but I definitely think its the ODE solving that's got me messed up.
I'm pretty much stuck at this point. I checked my equations to be sure they were right but alas no issues there so I could definitely use another brain.
If you need to see the question prompt let me know. I was wary of posting it because of my professor so I didn't think it'd be too necessary.
Note: u,xx is a second order and u,x is a first order.
matlab
New contributor
$endgroup$
I need some diagnosis on how I'm solving my differential equation. This was a template given to me by my professor and I manipulated it to the best of my ability.
The governing equations are here:
And here is my code:
clear;
clc;
close all;
% u,,xx=-(f/ea) on [0,L]
% u,x(L)= R
% u(0)=0
% Parameters
L= 1;
% Parameters in force function
A= .0001;
E= 70e9;
R= 1000;
a= 1000;
g= R/E*A;
f= @(x) ((((-1)*(a)*(x))/E*A));
% solve analytical solution
u1 = dsolve(['D2y = ' char(sym(f))], ['Dy(1) = ' num2str(g)], ['y(0) ='
num2str(0)] ,'x');
% change symbolic function to anonymous matlab function for easier
computing
u = matlabFunction(u1);
% plot the analytical solution
n= 20;
x = linspace(0, 1, n);
plot(x, u(x), '-ro', 'LineWidth', 4)
title('Analytical Solution u')
axis([0, 1, 0, 3])
xlabel('x')
ylabel('u')
I come across issues when I try to plot my values. The analytical solution should be around in the .21428 range or something. I figured that it has to be an issue with my differential solver or the way that I am plotting it but I definitely think its the ODE solving that's got me messed up.
I'm pretty much stuck at this point. I checked my equations to be sure they were right but alas no issues there so I could definitely use another brain.
If you need to see the question prompt let me know. I was wary of posting it because of my professor so I didn't think it'd be too necessary.
Note: u,xx is a second order and u,x is a first order.
matlab
matlab
New contributor
New contributor
New contributor
asked 20 mins ago
Lil_TEELil_TEE
1
1
New contributor
New contributor
add a comment |
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function () {
return StackExchange.using("mathjaxEditing", function () {
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
});
});
}, "mathjax-editing");
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "196"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Lil_TEE is a new contributor. Be nice, and check out our Code of Conduct.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f211886%2fsolving-a-strong-form-differential-equation-fem-using-matlab%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Lil_TEE is a new contributor. Be nice, and check out our Code of Conduct.
Lil_TEE is a new contributor. Be nice, and check out our Code of Conduct.
Lil_TEE is a new contributor. Be nice, and check out our Code of Conduct.
Lil_TEE is a new contributor. Be nice, and check out our Code of Conduct.
Thanks for contributing an answer to Code Review Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
Use MathJax to format equations. MathJax reference.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f211886%2fsolving-a-strong-form-differential-equation-fem-using-matlab%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown