(Ferreira, 2009) Matlab Codes For Finite Element Analysis
(Ferreira, 2009) Matlab Codes For Finite Element Analysis
(Ferreira, 2009) Matlab Codes For Finite Element Analysis
Upload
Login
Signup
Home
Explore
Presentation Courses
PowerPoint Courses
by LinkedIn Learning
Search
Successfully reported this slideshow.
We use your LinkedIn profile and activity data to personalize ads and to show you more relevant ads. You can
change your ad preferences anytime.
Chapter 2Discrete systems2.1 IntroductionThe finite element method is nowadays the most used computational
tool, in sci-enc...
2.5 First problem and first MATLAB code 21 We then obtain ...
2.5 First problem and first MATLAB code 23and then obtain the static global equi...
26 2 Discrete systemsdisplacements=zeros(numberNodes,1);forc...
2.5 First problem and first MATLAB code 27 First we define vector prescribedDof, c...
2.6 New code using MATLAB structures 29 The new problem1Structure.m listing is as follows: %...
2.6 New code using MATLAB structures 31This code calls solutionStructure.m which c...
Chapter 3Analysis of bars3.1 A bar elementConsider the two-node bar finite element shown in figure 3.1, with
constant cross-...
Chapter 4Analysis of 2D trusses4.1 IntroductionThis chapter deals with the static analysis of two dimensional
trusses, whi...
Upcoming SlideShare
Loading in …5
×
153 of 236
Share
Like
Download
...
bmxforu
Follow
0 Comments
11 Likes
Statistics
Notes
Full Name
Comment goes here.
12 hours ago Delete Reply Block
Are you sure you want to Yes No
Your message goes here
Prajjwal Patidar
7 months ago
https://www.sl deshare.net/bmxforu/ferre ra-2009-matlab-codes-for-f n te-element-analys s 234/249
18.11.2018 (Ferre ra, 2009) matlab codes for f n te element analys s
gayathri katabathula , Student at Vasireddy Venkatadri Institute of Technology, Nambur (V), Pedakakani(M),
PIN-522508(CC-BQ)
10 months ago
Harish Kumar
1 year ago
Show More
No Downloads
Views
Total views
7,836
On SlideShare
0
From Embeds
0
Number of Embeds
2
Actions
Shares
0
Downloads
514
Comments
0
Likes
11
Embeds 0
No embeds
No notes for slide
should use MATLAB 7.0 or greaterwhen running these codes. Any suggestions or corrections are welcomed
by an email to ferreira@fe.up.pt.Porto, Portugal, Ant´nio Ferreira o 2008 v
4. 4. Contents1 Short introduction to MATLAB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.1 Introduction . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.2 Matrices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . 1 1.3 Operating with matrices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.4
Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 1.5 Matrix functions . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 1.6 Conditionals, if and switch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . 4 1.7 Loops: for and while . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 1.8 Relations . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 1.9 Scalar functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . 7 1.10 Vector functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 1.11 Matrix
functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 1.12 Submatrix . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . 10 1.13 Logical indexing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. 12 1.14 M-files, scripts and functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 1.15 Graphics . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 1.15.1 2D plots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . 14 1.15.2 3D plots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 1.16 Linear
algebra . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 162 Discrete systems . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 2.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . 19 2.2 Springs and bars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 2.3 Equilibrium at nodes
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 2.4 Some basic steps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . 21 2.5 First problem and first MATLAB code . . . . . . . . . . . . . . . . . . . . . . . . 21 2.6 New code
using MATLAB structures . . . . . . . . . . . . . . . . . . . . . . . . . 283 Analysis of bars . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . 33 3.1 A bar element . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
3.2 Numerical integration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 vii
5. 5. viii Contents 3.3 An example of isoparametric bar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 3.4 Problem 2,
using MATLAB struct . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 3.5 Problem 3 . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . 444 Analysis of 2D trusses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
4.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 4.2 2D trusses . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 4.3 Stiffness matrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . 52 4.4 Stresses at the element . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 4.5 First 2D truss
problem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 4.6 A second truss problem . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . 58 4.7 An example of 2D truss with spring . . . . . . . . . . . . . . . . . . . . . . . . . . 635
Trusses in 3D space . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 5.1 Basic formulation . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 5.2 A 3D truss problem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . 69 5.3 A second 3D truss example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 736 Bernoulli beams . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 6.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . 79 6.2 Bernoulli beam problem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 6.3
Bernoulli beam with spring . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 857 2D frames . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 7.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . 89 7.2 An example of 2D frame . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 7.3 Another
example of 2D frame . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 958 Analysis of 3D frames . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . 103 8.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
103 8.2 Stiffness matrix and vector of equivalent nodal forces . . . . . . . . . . . 103 8.3 First 3D frame example .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 8.4 Second 3D frame example . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . 1089 Analysis of grids . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 9.1
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 9.2 A first grid example . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116 9.3 A second grid example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . 11910 Analysis of Timoshenko beams . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 10.1 Introduction
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 10.2 Formulation for static analysis . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . 123 10.3 Free vibrations of Timoshenko beams . . . . . . . . . . . . . . . . . . . . . . . . . 130
10.4 Buckling analysis of Timoshenko beams . . . . . . . . . . . . . . . . . . . . . . . 136
6. 6. Contents ix11 Plane stress . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143 11.1
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143 11.2 Displacements, strains and
stresses . . . . . . . . . . . . . . . . . . . . . . . . . . . 143 11.3 Boundary conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . 144 11.4 Potential energy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145 11.5 Finite
element discretization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145 11.6 Interpolation of displacements . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . 145 11.7 Element energy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . 146 11.8 Quadrilateral element Q4 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147 11.9 Example: plate in
traction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 149 11.10 Example: beam in bending . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . 15212 Analysis of Mindlin plates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161
12.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161 12.2 The Mindlin plate
theory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161 12.2.1 Strains . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
https://www.sl deshare.net/bmxforu/ferre ra-2009-matlab-codes-for-f n te-element-analys s 236/249
18.11.2018 (Ferre ra, 2009) matlab codes for f n te element analys s
> 1; x = x/2,endx = 5x = 2.5000x = 1.2500x = 0.6250Other examples of for/end loops:>> x = []; for i = 1:4,
x=[x,i^2], end
12. 12. 6 1 Short introduction to MATLABx = 1x = 1 4x = 1 4 9x = 1 4 9 16and in inverse form>> x = []; for i =
4:-1:1, x=[x,i^2], endx = 16x = 16 9x = 16 9 4x = 16 9 4 1Note the initial values of x = [] and the possibility
of decreasing cycles.1.8 RelationsRelations in MATLAB are shown in table 1.2. Note the difference between
‘=’ and logical equal ‘==’. The logical operatorsare given in table 1.3. The result if either 0 or 1, as in>>
3<5,3>5,3==5Table 1.2 Some relation operators < Less than > Greater than <= Less or equal than >= Greater
or equal than == Equal to ∼= Not equalTable 1.3 Logical operators & and | or ∼ not
13. 13. 1.9 Scalar functions 7ans = 1ans = 0ans = 0The same is obtained for matrices, as in>> a = rand(5), b =
triu(a), a == ba = 0.1419 0.6557 0.7577 0.7060 0.8235 0.4218 0.0357 0.7431 0.0318 0.6948 0.9157 0.8491
0.3922 0.2769 0.3171 0.7922 0.9340 0.6555 0.0462 0.9502 0.9595 0.6787 0.1712 0.0971 0.0344b = 0.1419
0.6557 0.7577 0.7060 0.8235 0 0.0357 0.7431 0.0318 0.6948 0 0 0.3922 0.2769 0.3171 0 0 0 0.0462 0.9502 0
0 0 0 0.0344ans = 1 1 1 1 1 0 1 1 1 1 0 0 1 1 1 0 0 0 1 1 0 0 0 0 11.9 Scalar functionsSome MATLAB
functions are applied to scalars only. Some of those functions arelisted in table 1.4. Note that such functions
can be applied to all elements of avector or matrix, as in>> a=rand(3,4)a = 0.4387 0.7952 0.4456 0.7547Table
1.4 Scalar functions sin asin exp abs round cos acos log sqrt floor tan atan rem sign ceil
14. 14. 8 1 Short introduction to MATLAB 0.3816 0.1869 0.6463 0.2760 0.7655 0.4898 0.7094 0.6797>>
b=sin(a)b = 0.4248 0.7140 0.4310 0.6851 0.3724 0.1858 0.6022 0.2725 0.6929 0.4704 0.6514 0.6286>>
c=sqrt(b)c = 0.6518 0.8450 0.6565 0.8277 0.6102 0.4310 0.7760 0.5220 0.8324 0.6859 0.8071 0.79281.10
Vector functionsSome MATLAB functions operate on vectors only, such as those illustrated intable 1.5.
Consider for example vector X=1:10. The sum, mean and maximum values areevaluated as>> x=1:10x = 1 2
3 4 5 6 7 8 9 10>> sum(x)ans = 55>> mean(x)ans = 5.5000>> max(x)ans = 10Table 1.5 Vector functions max
sum median any min prod mean all
15. 15. 1.11 Matrix functions 91.11 Matrix functionsSome important matrix functions are listed in table 1.6. In
some cases such functions may use more than one output argument, as in>> A=rand(3)A = 0.8147 0.9134
0.2785 0.9058 0.6324 0.5469 0.1270 0.0975 0.9575>> y=eig(A)y = -0.1879 1.7527 0.8399where we wish to
obtain the eigenvalues only, or in>> [V,D]=eig(A)V = 0.6752 -0.7134 -0.5420 -0.7375 -0.6727 -0.2587
-0.0120 -0.1964 0.7996D = -0.1879 0 0 0 1.7527 0 0 0 0.8399where we obtain the eigenvectors and the
eigenvalues of matrix A.Table 1.6 Matrix functions eig Eigenvalues and eigenvectors chol Choleski
factorization inv Inverse lu LU decomposition qr QR factorization schur Schur decomposition poly
Characteristic polynomial det Determinant size Size of a matrix norm 1-norm, 2-norm, F-norm, ∞-norm cond
Conditioning number of 2-norm rank Rank of a matrix
16. 16. 10 1 Short introduction to MATLAB1.12 SubmatrixIn MATLAB it is possible to manipulate matrices in
order to make code morecompact or more efficient. For example, using the colon we can generate vectors,as
in>> x=1:8x = 1 2 3 4 5 6 7 8or using increments>> x=1.2:0.5:3.7x = 1.2000 1.7000 2.2000 2.7000 3.2000
3.7000This sort of vectorization programming is quite efficient, no for/end cycles are used.This efficiency can
be seen in the generation of a table of sines,>> x=0:pi/2:2*pix = 0 1.5708 3.1416 4.7124 6.2832>> b=sin(x)b
= 0 1.0000 0.0000 -1.0000 -0.0000>> [x’ b’]ans = 0 0 1.5708 1.0000 3.1416 0.0000 4.7124 -1.0000 6.2832
-0.0000The colon can also be used to access one or more elements from a matrix, whereeach dimension is
given a single index or vector of indices. A block is then extractedfrom the matrix, as illustrated next.>>
a=rand(3,4)a = 0.6551 0.4984 0.5853 0.2551 0.1626 0.9597 0.2238 0.5060 0.1190 0.3404 0.7513 0.6991>>
a(2,3)ans = 0.2238
17. 17. 1.12 Submatrix 11>> a(1:2,2:3)ans = 0.4984 0.5853 0.9597 0.2238>> a(1,end)ans = 0.2551>> a(1,:)ans =
0.6551 0.4984 0.5853 0.2551>> a(:,3)ans = 0.5853 0.2238 0.7513It is interesting to note that arrays are stored
linearly in memory, from the firstdimension, second, and so on. So we can in fact access vectors by a single
index,as show below.>> a=[1 2 3;4 5 6; 9 8 7]a = 1 2 3 4 5 6 9 8 7>> a(3)ans = 9>> a(7)ans = 3>> a([1 2 3
4])ans = 1 4 9 2>> a(:)ans = 1 4 9 2 5 8 3 6 7Subscript referencing can also be used in both sides.
18. 18. 12 1 Short introduction to MATLAB>> aa = 1 2 3 4 5 6 9 8 7>> bb = 1 2 3 4 5 6>> b(1,:)=a(1,:)b = 1 2 3
4 5 6>> b(1,:)=a(2,:)b = 4 5 6 4 5 6>> b(:,2)=[]b = 4 6 4 6>> a(3,:)=0a = 1 2 3 4 5 6 0 0 0>> b(3,1)=20b = 4 6
4 6 20 0As you noted in the last example, we can insert one element in matrix B, andMATLAB automatically
resizes the matrix.1.13 Logical indexingLogical indexing arise from logical relations, resulting in a logical
array, with ele-ments 0 or 1.>> aa = 1 2 3 4 5 6 0 0 0
19. 19. 1.14 M-files, scripts and functions 13>> a>2ans = 0 0 1 1 1 1 0 0 0Then we can use such array as a mask
to modify the original matrix, as shownnext.>> a(ans)=20a = 1 2 20 20 20 20 0 0 0This will be very useful in
finite element calculations, particularly when imposingboundary conditions.1.14 M-files, scripts and
functionsA M-file is a plain text file with MATLAB commands, saved with extension .m.The M-files can be
scripts of functions. By using the editor of MATLAB we caninsert comments or statements and then save or
compile the m-file. Note thatthe percent sign % represents a comment. No statement after this sign will
beexecuted. Comments are quite useful for documenting the file. M-files are useful when the number of
statements is large, or when you want toexecute it at a later stage, or frequently, or even to run it in
background. A simple example of a script is given below.% program 1% programmer: Antonio ferreira%
https://www.sl deshare.net/bmxforu/ferre ra-2009-matlab-codes-for-f n te-element-analys s 238/249
18.11.2018 (Ferre ra, 2009) matlab codes for f n te element analys s
date: 2008.05.30% purpose : show how M-files are built% data: a - matrix of numbers; b: matrix with sines of
aa=rand(3,4);b=sin(a); Functions act like subroutines in fortran where a particular set of tasks isperformed. A
typical function is given below, where in the first line we shouldname the function and give the input
parameters (m,n,p) in parenthesis and theoutput parameters (a,b,c) in square parenthesis.function [a,b,c] =
antonio(m,n,p)
20. 20. 14 1 Short introduction to MATLABa = hilb(m);b= magic(n);c= eye(m,p);We then call this function as>>
[a,b,c]=antonio(2,3,4)producing>> [a,b,c]=antonio(2,3,4)a = 1.0000 0.5000 0.5000 0.3333b = 8 1 6 3 5 7 4 9
2c = 1 0 0 0 0 1 0 0It is possible to use only some output parameters.>> [a,b]=antonio(2,3,4)a = 1.0000
0.5000 0.5000 0.3333b = 8 1 6 3 5 7 4 9 21.15 GraphicsMATLAB allows you to produce graphics in a simple
way, either 2D or 3D plots.1.15.1 2D plotsUsing the command plot we can produce simple 2D plots in a
figure, using twovectors with x and y coordinates. A simple examplex = -4:.01:4; y = sin(x);
plot(x,y)producing the plot of figure 1.1.
21. 21. 1.15 Graphics 15Fig. 1.1 2D plot of a 1sinus 0.8 0.6 0.4 0.2 0 −0.2 −0.4 −0.6 −0.8 −1 −4 −3 −2 −1 0 1 2 3
4Table 1.7 Some graphics commands Title Title xlabel x-axis legend ylabel y-axis legend Axis([xmin ,xmax
,ymin ,ymax ]) Sets limits to axis Axis auto Automatic limits Axis square Same scale for both axis Axis equal
Same scale for both axis Axis off Removes scale Axis on Scales again We can insert a title, legends, modify
axes etc., as shown in table 1.7. By using hold on we can produce several plots in the same figure. We can
alsomodify colors of curves or points, as in>> x=0:.01:2*pi; y1=sin(x); y2=sin(2*x); y3=sin(4*x);>>
plot(x,y1,’--’,x,y2,’:’,x,y3,’+’)producing the plot of figure 1.2.1.15.2 3D plotsAs for 2D plots, we can produce
3D plots with plot3 using x, y, and z vectors.For examplet=.01:.01:20*pi; x=cos(t); y=sin(t); z=t.^3;
plot3(x,y,z)produces the plot illustrated in figure 1.3. The next statements produce the graphic illustrated in
figure 1.4.
22. 22. 16 1 Short introduction to MATLABFig. 1.2 Colors and 1markers 0.8 0.6 0.4 0.2 0 −0.2 −0.4 −0.6 −0.8 −1
0 1 2 3 4 5 6 7Fig. 1.3 3D plot x 105 2.5 2 1.5 1 0.5 0 1 0.5 1 0 0.5 0 −0.5 −0.5 −1 −1>>
[xx,yy]=meshgrid(x,x);>> z=exp(-xx.^2-yy.^2);>> surf(xx,yy,z,gradient(z))1.16 Linear algebraIn our finite
element calculations we typically need to solve systems of equations,or obtain the eigenvalues of a matrix.
MATLAB has a large number of functions forlinear algebra. Only the most relevant for finite element analysis
are here presented.
23. 23. 1.16 Linear algebra 17Fig. 1.4 Another 3D plot 1 0.8 0.6 0.4 0.2 0 2 1 2 1 0 0 −1 −1 −2 −2 Consider a
linear system AX = B, where>> a=rand(3)a = 0.8909 0.1386 0.8407 0.9593 0.1493 0.2543 0.5472 0.2575
0.8143>> b=rand(3,1)b = 0.2435 0.9293 0.3500The solution vector X can be easily evaluated by using the
backslash command,>> x=abx = 0.7837 2.9335 -1.0246Consider two matrices (for example a stiffness matrix
and a mass matrix), forwhich we wish to calculate the generalized eigenproblem.>> a=rand(4)a = 0.1966
0.3517 0.9172 0.3804 0.2511 0.8308 0.2858 0.5678 0.6160 0.5853 0.7572 0.0759 0.4733 0.5497 0.7537
0.0540>> b=rand(4)
24. 24. 18 1 Short introduction to MATLABb = 0.5308 0.5688 0.1622 0.1656 0.7792 0.4694 0.7943 0.6020
0.9340 0.0119 0.3112 0.2630 0.1299 0.3371 0.5285 0.6541>> [v,d]=eig(a,b)v = 0.1886 -0.0955 1.0000
-0.9100 0.0180 1.0000 -0.5159 -0.4044 -1.0000 -0.2492 -0.2340 0.0394 0.9522 -0.8833 0.6731 -1.0000d =
-4.8305 0 0 0 0 -0.6993 0 0 0 0 0.1822 0 0 0 0 0.7628The MATLAB function eig can be applied to the
generalized eigenproblem, pro-ducing matrix V, each column containing an eigenvector, and matrix D,
containingthe eigenvalues at its diagonal. If the matrices are the stiffness and the mass ma-trices then the
eigenvectors will be the modes of vibration and the eigenvalues willbe the square roots of the natural
frequencies of the system.
25. 25. Chapter 2Discrete systems2.1 IntroductionThe finite element method is nowadays the most used
computational tool, in sci-ence and engineering applications. The finite element method had its origin
around1950, with reference works of Courant [1], Argyris [2] and Clough [3]. Many finite element books are
available, such as the books by Reddy [4], Onate[5], Zienkiewicz [6], Hughes [7], Hinton [8], just to name a
few. Some recent booksdeal with the finite element analysis with MATLAB codes [9,10]. The
programmingapproach in these books is quite different from the one presented in this book. In this chapter
some basic concepts are illustrated by solving discrete systemsbuilt from springs and bars.2.2 Springs and
barsConsider a bar (or spring) element with two nodes, two degrees of freedom, cor- (e) (e)responding to two
axial displacements u1 , u2 ,1 as illustrated in figure 2.1. Wesuppose an element of length L, constant cross-
section with area A, and modulusof elasticity E. The element supports axial forces only. The deformation in
the bar is obtained as u2 − u 1 = (2.1) L(e)while the stress in the bar is given by the Hooke’s law as u2 − u1 σ
= E (e) = E (e) (2.2) L(e)1 The superscript(e) refers to a generic finite element.A.J.M. Ferreira, MATLAB
Codes for Finite Element Analysis: 19Solids and Structures, Solid Mechanics and Its Applications 157,c
Springer Science+Business Media B.V. 2009
26. 26. 20 2 Discrete systems (e) (e) (e) u1 1 2 u2 (e) (e) R1 R2 L(e)Fig. 2.1 Spring or bar finite element with two
nodesThe axial resultant force is obtained by integration of stresses across the thicknessdirection as u2 − u1 N
= A(e) σ = (EA)(e) (2.3) L(e) (e) (e)Taking into account the static equilibrium of the axial forces R1 and R2 ,
as (e) (e) (e) EA (e) (e) R2 = −R1 = N = (u2 − u1 ) (2.4) L EAwe can write the equations in the form (taking k
https://www.sl deshare.net/bmxforu/ferre ra-2009-matlab-codes-for-f n te-element-analys s 239/249
18.11.2018 (Ferre ra, 2009) matlab codes for f n te element analys s
(e) = L ) (e) (e) R1 1 −1 u1 q(e) = = k (e) = K(e) a(e) (2.5) (e) R2 −1 1 (e) u2where K(e) is the stiffness matrix
of the bar (spring) element, a(e) is the dis-placement vector, and q(e) represents the vector of nodal forces. If
the elementundergoes the action of distributed forces, it is necessary to transform those forcesinto nodal
forces, by (e) 1 −1 u1 (bl)(e) 1 q(e) = k (e) − = K(e) a(e) − f (e) (2.6) −1 1 (e) u2 2 1with f (e) being the vector
of nodal forces equivalent to distributed forces b.2.3 Equilibrium at nodesIn (2.6) we show the equilibrium
relation for one element, but we also need toobtain the equations of equilibrium for the structure. Therefore,
we need to as-semble the contribution of all elements so that a global system of equations can beobtained. To
do that we recall that in each node the sum of all forces arisingfrom various adjacent elements equals the
applied load at that node.
27. 27. 2.5 First problem and first MATLAB code 21 We then obtain ne (e) R(e) = Rj (2.7) e=1where ne
represents the number of elements in the structure, producing a globalsystem of equations in the form ⎡ ⎤⎧ ⎫
⎧ ⎫ K11 K12 . . . K1n ⎪ u1 ⎪ ⎪ f1 ⎪ ⎪ ⎪ ⎪ ⎪ ⎢ K21 K22 . . . K2n ⎥ ⎪ u2 ⎪ ⎪ f2 ⎪ ⎨ ⎬ ⎨ ⎬ ⎢ ⎥ ⎢ . . . ⎥ = . ⎦⎪
. ⎪ ⎪ . ⎪ ⎣ . . . . . ⎪ . ⎪ ⎪ . ⎪ ⎪ . ⎪ ⎪ . ⎪ ⎩ ⎭ ⎩ ⎭ Kn1 Kn2 . . . Knn un fnor in a more compact form Ka = f
(2.8)Here K represents the system (or structure) stiffness matrix, a is the systemdisplacement vector, and f
represents the system force vector.2.4 Some basic stepsIn any finite element problem, some calculation steps
are typical:• Define a set of elements connected at nodes• For each element, compute stiffness matrix K(e) ,
and force vector f (e)• Assemble the contribution of all elements into the global system Ka = f• Modify the
global system by imposing essential (displacements) boundary conditions• Solve the global system and obtain
the global displacements a• For each element, evaluate the strains and stresses (post-processing)2.5 First
problem and first MATLAB codeTo illustrate some of the basic concepts, and introduce the first MATLAB
code,we consider a problem, illustrated in figure 2.2 where the central bar is definedas rigid. Our problem has
three finite elements and four nodes. Three nodes areclamped, being the boundary conditions defined as u1 =
u3 = u4 = 0. In order tosolve this problem, we set k = 1 for all springs and the external applied load atnode 2
to be P = 10. We can write, for each element in turn, the (local) equilibrium equation Spring 1: (1) (1) R1 1 −1
u1 = k (1) R2 (1) −1 1 u2 (1)
28. 28. 22 2 Discrete systems k2 2 3 k1 1 2 P P = 10 k3 ki = 1 2 4 u1 = u3 = u4 = 0 Rigid barFig. 2.2 Problem 1: a
spring problem Spring 2: (2) (2) R1 1 −1 u1 = k (2) (2) R2 −1 1 (2) u2 Spring 3: (3) (3) R1 1 −1 u1 = k (3) (3)
R2 −1 1 (3) u2We then consider the compatibility conditions to relate local (element) and global(structure)
displacements as (1) (1) (2) (2) (3) (3) u1 = u1 ; u2 = u2 ; u1 = u2 ; u2 = u3 ; u1 = u2 ; u2 = u4 (2.9)By
expressing equilibrium of forces at nodes 1 to 4, we can write 3 (1) Node 1: R(e) = F1 ⇔ R1 = F1 (2.10) e=1
3 (1) (2) (3) Node 2: R(e) = P ⇔ R2 + R1 + R1 = P (2.11) e=1 3 (3) Node 3: R(e) = F3 ⇔ R2 = F3 (2.12) e=1
3 (4) Node 4: R(e) = F4 ⇔ R2 = F4 (2.13) e=1
29. 29. 2.5 First problem and first MATLAB code 23and then obtain the static global equilibrium equations in the
form ⎡ ⎤⎧ ⎫ ⎧ ⎫ k1 −k1 0 0 ⎪ u 1 ⎪ ⎪ F1 ⎪ ⎪ ⎪ ⎪ ⎪ ⎢ −k1 k1 + k2 + k3 −k2 −k3 ⎥ ⎨ u2 ⎬ ⎨ P ⎬ ⎢ ⎥ = (2.14)
⎣ 0 −k2 k2 0 ⎦ ⎪ u3 ⎪ ⎪ F3 ⎪ ⎪ ⎪ ⎪ ⎪ ⎩ ⎭ ⎩ ⎭ 0 −k3 0 k3 u4 F4Taking into account the boundary
conditions u1 = u3 = u4 = 0, we may write ⎡ ⎤⎧ ⎫ ⎧ ⎫ k1 −k1 0 0 ⎪ 0 ⎪ ⎪ F1 ⎪ ⎪ ⎪ ⎪ ⎪ ⎢ −k1 k1 + k2 + k3
−k2 −k3 ⎥ ⎨ u2 ⎬ ⎨ P ⎬ ⎢ ⎥ = (2.15) ⎣ 0 −k2 k2 0 ⎦ ⎪ 0 ⎪ ⎪ F3 ⎪ ⎪ ⎪ ⎪ ⎪ ⎩ ⎭ ⎩ ⎭ 0 −k3 0 k3 0 F4At this
stage, we can compute the reactions F1 , F3 , F4 , only after the computationof the global displacements. We
can remove lines and columns of the system,corresponding to u1 = u3 = u4 = 0, and reduce the global system
to one equation (k1 + k2 + k3 )u2 = PThe reactions can then be obtained by −k1 u2 = F1 ; −k2 u2 = F3 ; −k3
u2 = F4Note that the stiffness matrix was obtained by “summing” the contributions ofeach element at the
correct lines and columns corresponding to each element de-grees of freedom. For instance, the degrees of
freedom of element 1 are 1 and 2,and the 2 × 2 stiffness matrix of this element is placed at the corresponding
linesand columns of the global stiffness matrix. ⎡ ⎤ k1 −k1 0 0 ⎢ −k k 0 0 ⎥ K (1) = ⎢ 1 1 ⎣ 0 ⎥ (2.16) 0 0 0⎦ 0 0
00For element 3, the (global) degrees of freedom are 2 and 4 and the 2 × 2 stiffnessmatrix of this element is
placed at the corresponding lines and columns of theglobal stiffness matrix. ⎡ ⎤ 0 0 0 0 ⎢ 0 k3 0 −k3 ⎥ K (3) = ⎢
⎣0 0 0 0 ⎦ ⎥ (2.17) 0 −k3 0 k3A first MATLAB code problem1.m is introduced to solve the problem illustrated
infigure 2.2. Many of the concepts used later on more complex elements are alreadygiven in this code. We set
k = 1 for all elements and P = 10.
30. 30. 24 2 Discrete systems %................................................................ % MATLAB codes for Finite Element
Analysis % problem1.m % antonio ferreira 2008 % clear memory clear all % elementNodes: connections at
elements elementNodes=[1 2;2 3;2 4]; % numberElements: number of Elements
numberElements=size(elementNodes,1); % numberNodes: number of nodes numberNodes=4; % for
structure: % displacements: displacement vector % force : force vector % stiffness: stiffness matrix
displacements=zeros(numberNodes,1); force=zeros(numberNodes,1); stiffness=zeros(numberNodes); %
applied load at node 2 force(2)=10.0; % computation of the system stiffness matrix for e=1:numberElements;
% elementDof: element degrees of freedom (Dof) elementDof=elementNodes(e,:) ;
stiffness(elementDof,elementDof)=... stiffness(elementDof,elementDof)+[1 -1;-1 1]; end % boundary
3.0000 -3.3333 4.0000 -3.33332.6 New code using MATLAB structuresMATLAB structures provide a way to
collect arrays of different types and sizesin a single array. The following codes show how this can be made for
problem1.m.One of the most interesting features is that the argument passing to functions issimplified.
35. 35. 2.6 New code using MATLAB structures 29 The new problem1Structure.m listing is as follows:
%................................................................ % MATLAB codes for Finite Element Analysis %
problem1Structure.m % antonio ferreira 2008 % clear memory clear all % p1 : structure p1=struct(); %
elementNodes: connections at elements p1.elementNodes=[1 2;2 3;2 4]; % GDof: total degrees of freedom
p1.GDof=4; % numberElements: number of Elements p1.numberElements=size(p1.elementNodes,1); %
numberNodes: number of nodes p1.numberNodes=4; % for structure: % displacements: displacement vector
% force : force vector % stiffness: stiffness matrix p1.displacements=zeros(p1.GDof,1);
p1.force=zeros(p1.GDof,1); p1.stiffness=zeros(p1.GDof); % applied load at node 2 p1.force(2)=10.0; %
computation of the system stiffness matrix for e=1:p1.numberElements; % elementDof: element degrees of
freedom (Dof) elementDof=p1.elementNodes(e,:) ; p1.stiffness(elementDof,elementDof)=...
p1.stiffness(elementDof,elementDof)+[1 -1;-1 1]; end
36. 36. 30 2 Discrete systems % boundary conditions and solution % prescribed dofs p1.prescribedDof=[1;3;4];
% solution p1.displacements=solutionStructure(p1) % output displacements/reactions
outputDisplacementsReactionsStructure(p1)Note that p is now a structure that collects most of the problem
data:p1 = elementNodes: [3x2 double] GDof: 4 numberElements: 3 numberNodes: 4 displacements: [4x1
double] force: [4x1 double] stiffness: [4x4 double] prescribedDof: [3x1 double]Information on a particular
data field can be accessed as follows:>> p1.prescribedDofans = 1 3 4or>> p1.displacementsans = 0 3.3333 0 0
37. 37. 2.6 New code using MATLAB structures 31This code calls solutionStructure.m which computes
displacements by eliminatinglines and columns of prescribed degrees of freedom. Notice that the
argumentpassing is made by just providing the structure name (p1). This is simpler thanpassing all relevant
matrices. %................................................................ function displacements=solutionStructure(p) % function
to find solution in terms of global displacements activeDof=setdiff([1:p.GDof]’, [p.prescribedDof]);
U=p.stiffness(activeDof,activeDof)p.force(activeDof); displacements=zeros(p.GDof,1);
displacements(activeDof)=U;It also calls the function outputDisplacementsReactionsStructure.m which
outputsdisplacements and reactions. %................................................................ function
outputDisplacementsReactionsStructure(p) % output of displacements and reactions in % tabular form %
GDof: total number of degrees of freedom of % the problem % displacements disp(’Displacements’)
jj=1:p.GDof; format [jj’ p.displacements] % reactions F=p.stiffness*p.displacements;
reactions=F(p.prescribedDof); disp(’reactions’) [p.prescribedDof reactions]
38. 38. Chapter 3Analysis of bars3.1 A bar elementConsider the two-node bar finite element shown in figure 3.1,
with constant cross-section (area A) and length L = 2a. The bar element can undergo only axialstresses σx ,
which are uniform in every cross-section. The work stored as strain energy dU is obtained as 1 dU = σx x Adx
(3.1) 2The total strain energy is given by a 1 U= σx x Adx (3.2) 2 −aBy assuming a linear elastic behaviour of
the bar material, we can write σx = E x (3.3)where E is the modulus of elasticity. Therefore the strain energy
can be ex-pressed as 1 a U= EA 2 dx x (3.4) 2 −aStrains x can be related with the axial displacements u as du
x = (3.5) dxBy substituting (3.5) into (3.4) we then obtain a 2 1 du U= EA dx (3.6) 2 −a dxA.J.M. Ferreira,
MATLAB Codes for Finite Element Analysis: 33Solids and Structures, Solid Mechanics and Its Applications
157,c Springer Science+Business Media B.V. 2009
39. 39. 34 3 Analysis of barsFig. 3.1 A bar element in its u, xlocal coordinate system dx P 1 2 x = −a x=a L =
2aFig. 3.2 A two-node bar ξ = −1 ξ=1element x = −a x=a 1 2 ξ, x L = 2aIf we consider p as the applied forces
by unit length, the virtual external work ateach element is a δW = pδudx (3.7) −aLet’s consider now a two-
noded finite element, as illustrated in figure 3.2. Theaxial displacements can be interpolated as u = N1 (ξ)u1 +
N2 (ξ)u2 (3.8)where the shape functions are defined as 1 1 N1 (ξ) = (1 − ξ) ; N2 (ξ) = (1 + ξ) (3.9) 2 2in the
natural coordinate system ξ ∈ [−1, +1]. The interpolation (3.8) can bedefined in matrix form as u1 u = N1 N 2
= Nue (3.10) u2The element strain energy is now expressed as a 2 1 2 1 1 du 1 EA du 1 eT EA T U= EA dx =
adξ = u N N dξue 2 −a dx 2 −1 a2 dξ 2 −1 a (3.11) duwhere N = , and dξ 1 eT e e U= u K u (3.12) 2
40. 40. 3.1 A bar element 35The element stiffness matrix, Ke , is given by 1 EA T Ke = N N dξ (3.13) a −1The
integral is evaluated in the natural system, after a transformation of coordi-nates x = aξ, including the
evaluation of the jacobian determinant, |J| = dx = a. dξ In this element the derivatives of the shape functions
are dN1 1 dN2 1 =− ; = (3.14) dξ 2 dξ 2In this case, the stiffness matrix can be given in explicit form as ⎡ 1⎤ −
EA 1 ⎣ 2 ⎦ 1 1 EA 1 −1 Ke = − 2 2 dξ = (3.15) a −1 1 2a −1 1 2By using L = 2a we obtain the same stiffness
matrix as in the direct methodpresented in the previous chapter. The virtual work done by the external forces
is defined as a 1 1 δW e = pδudx = pδuadξ = δueT a pNT dξ (3.16) −a −1 −1or δW e = δueT f e (3.17)where
the vector of nodal forces that are equivalent to distributed forces is given by 1 1 ap 1−ξ 1 fe = a pNT dξ = dξ
= ap (3.18) −1 2 −1 1+ξ 1For a system of bars, the contribution of each element must be assembled.
Forexample in the bar of figure 3.3, we consider five nodes and four elements. In thiscase the structure vector
function and derivatives for L2 elements % shape : Shape functions % naturalDerivatives: derivatives w.r.t. xi
% xi: natural coordinates (-1 ... +1) shape=([1-xi,1+xi]/2)’; naturalDerivatives=[-1;1]/2; end % end function
shapeFunctionL2The function (solution.m) will be used in the remaining of the book. This functioncomputes
the displacements of any FE system in the forthcoming problems.
46. 46. 3.4 Problem 2, using MATLAB struct 41 %................................................................ function
displacements=solution(GDof,prescribedDof,stiffness, force) % function to find solution in terms of global
displacements activeDof=setdiff([1:GDof]’, ... [prescribedDof]);
U=stiffness(activeDof,activeDof)force(activeDof); displacements=zeros(GDof,1);
displacements(activeDof)=U;3.4 Problem 2, using MATLAB structAnother possible code using MATLAB
structures would be problem2Structure.m,as: %................................................................ % MATLAB codes
for Finite Element Analysis % problem2Structure.m % antonio ferreira 2008 % clear memory clear all % p1 :
structure p1=struct(); % E; modulus of elasticity % A: area of cross section % L: length of bar E =
30e6;A=1;EA=E*A; L = 90; % generation of coordinates and connectivities % numberElements: number of
elements p1.numberElements=3; % generation equal spaced coordinates
p1.nodeCoordinates=linspace(0,L,p1.numberElements+1);
47. 47. 42 3 Analysis of bars p1.xx=p1.nodeCoordinates; % numberNodes: number of nodes
p1.numberNodes=size(p1.nodeCoordinates,2); % elementNodes: connections at elements
ii=1:p1.numberElements; p1.elementNodes(:,1)=ii; p1.elementNodes(:,2)=ii+1; % GDof: total degrees of
freedom p1.GDof=p1.numberNodes; % % numberElements: number of Elements %
p1.numberElements=size(p1.elementNodes,1); % % % numberNodes: number of nodes %
p1.numberNodes=4; % for structure: % displacements: displacement vector % force : force vector % stiffness:
stiffness matrix p1.displacements=zeros(p1.GDof,1); p1.force=zeros(p1.GDof,1);
p1.stiffness=zeros(p1.GDof); % applied load at node 2 p1.force(2)=3000.0; % computation of the system
stiffness matrix for e=1:p1.numberElements; % elementDof: element degrees of freedom (Dof)
elementDof=p1.elementNodes(e,:) ; nn=length(elementDof);
length_element=p1.nodeCoordinates(elementDof(2))... -p1.nodeCoordinates(elementDof(1));
detJacobian=length_element/2;invJacobian=1/detJacobian; % central Gauss point (xi=0, weight W=2)
shapeL2=shapeFunctionL2Structure(0.0); Xderivatives=shapeL2.naturalDerivatives*invJacobian; % B matrix
48. 48. 3.4 Problem 2, using MATLAB struct 43 B=zeros(1,nn); B(1:nn) = Xderivatives(:);
p1.stiffness(elementDof,elementDof)=... p1.stiffness(elementDof,elementDof)+B’*B*2*detJacobian*EA; end
% prescribed dofs p1.prescribedDof=find(p1.xx==min(p1.nodeCoordinates(:)) ... |
p1.xx==max(p1.nodeCoordinates(:)))’; % solution p1.displacements=solutionStructure(p1) % output
displacements/reactions outputDisplacementsReactionsStructure(p1)The code needs some change in function
shapeFunctionL2Structure.m, as follows: % ............................................................. function
shapeL2=shapeFunctionL2Structure(xi) % shape function and derivatives for L2 elements % shape : Shape
functions % naturalDerivatives: derivatives w.r.t. xi % xi: natural coordinates (-1 ... +1) shapeL2=struct()
shapeL2.shape=([1-xi,1+xi]/2)’; shapeL2.naturalDerivatives=[-1;1]/2; end % end function
shapeFunctionL2Results are placed in structure p1, as before.>> p1p1 = numberElements: 3 nodeCoordinates:
[0 30 60 90] xx: [0 30 60 90] numberNodes: 4 elementNodes: [3x2 double]
49. 49. 44 3 Analysis of bars GDof: 4 displacements: [4x1 double] force: [4x1 double] stiffness: [4x4 double]
prescribedDof: [2x1 double]We can obtain detailed information on p1, for example, displacements:>>
p1.displacementsans = 0 0.0020 0.0010 03.5 Problem 3Another problem involving bars and springs is
illustrated in figure 3.6. The MAT-LAB code for this problem is problem3.m, using direct stiffness method.
%................................................................ % MATLAB codes for Finite Element Analysis % problem3.m %
ref: D. Logan, A first couse in the finite element method, % third Edition, page 121, exercise P3-10 % direct
stiffness method % antonio ferreira 2008 8kN E = 70GPa A = 200mm2 k 1 2 3 4 k = 2000kN/m 1 2 3 2m
2mFig. 3.6 Illustration of problem 3, problem3.m
50. 50. 3.5 Problem 3 45 % clear memory clear all % E; modulus of elasticity % A: area of cross section % L:
length of bar % k: spring stiffness E=70000;A=200;k=2000; % generation of coordinates and connectivities
% numberElements: number of elements numberElements=3; numberNodes=4; elementNodes=[1 2; 2 3; 3 4];
nodeCoordinates=[0 2000 4000 4000]; xx=nodeCoordinates; % for structure: % displacements: displacement
vector % force : force vector % stiffness: stiffness matrix displacements=zeros(numberNodes,1);
force=zeros(numberNodes,1); stiffness=zeros(numberNodes,numberNodes); % applied load at node 2
force(2)=8000; % computation of the system stiffness matrix for e=1:numberElements; % elementDof:
element degrees of freedom (Dof) elementDof=elementNodes(e,:) ; L=nodeCoordinates(elementDof(2))-
nodeCoordinates(elementDof(1)); if e<3 ea(e)=E*A/L; else ea(e)=k; end
stiffness(elementDof,elementDof)=... stiffness(elementDof,elementDof)+ea(e)*[1 -1;-1 1]; end % boundary
conditions and solution
51. 51. 46 3 Analysis of bars % prescribed dofs prescribedDof=[1;4]; % free Dof : activeDof
activeDof=setdiff([1:numberNodes]’,[prescribedDof]); % solution GDof=4;
displacements=solution(GDof,prescribedDof,stiffness,force); % output displacements/reactions
https://www.sl deshare.net/bmxforu/ferre ra-2009-matlab-codes-for-f n te-element-analys s 244/249
18.11.2018 (Ferre ra, 2009) matlab codes for f n te element analys s
Recommended
Matlab plotting
Amr Rashed
Fem in matlab
Shince Joseph
English
Español
Português
Français
Deutsch
About
Dev & API
Blog
Terms
Privacy
Copyright
Support
Share Clipboard
Facebook
Twitter
LinkedIn
Link
Create a clipboard
Clipping is a handy way to collect important slides you want to go back to later. Now customize the name of a
clipboard to store your clips.