Mercurial > fem-fenics-eugenio
annotate src/assemble.cc @ 108:5cbc7341ded5
Added the possibility to assemble form of rank 0.
author | gedeone-octave <marcovass89@hotmail.it> |
---|---|
date | Thu, 22 Aug 2013 18:58:55 +0200 |
parents | dc9987325fea |
children | 77eefe47f7ab |
rev | line source |
---|---|
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
1 #include "form.h" |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
2 #include "boundarycondition.h" |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
3 |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
4 DEFUN_DLD (assemble, args, nargout, "A = assemble (FORM, BC)") |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
5 { |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
6 |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
7 int nargin = args.length (); |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
8 octave_value_list retval; |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
9 |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
10 if (nargout == 1) |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
11 { |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
12 if (nargin < 1) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
13 print_usage (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
14 else |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
15 { |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
16 if (! form_type_loaded) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
17 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
18 form::register_type (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
19 form_type_loaded = true; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
20 mlock (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
21 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
22 if (args(0).type_id () == form::static_type_id ()) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
23 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
24 const form & frm |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
25 = static_cast<const form&> (args(0).get_rep ()); |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
26 |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
27 if (! error_state) |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
28 { |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
29 const dolfin::Form & a = frm.get_form (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
30 a.check (); |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
31 |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
32 if (a.rank () == 2) |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
33 { |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
34 dolfin::Matrix A; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
35 dolfin::assemble (A, a); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
36 if (! boundarycondition_type_loaded) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
37 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
38 boundarycondition::register_type (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
39 boundarycondition_type_loaded = true; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
40 mlock (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
41 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
42 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
43 for (std::size_t i = 1; i < nargin; ++i) |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
44 { |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
45 if (args(i).type_id () == boundarycondition::static_type_id ()) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
46 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
47 const boundarycondition & bc |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
48 = static_cast<const boundarycondition&> (args(i).get_rep ()); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
49 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
50 const std::vector<boost::shared_ptr <const dolfin::DirichletBC> > & pbc |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
51 = bc.get_bc (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
52 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
53 for (std::size_t j = 0; j < pbc.size (); ++j) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
54 pbc[j]->apply(A); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
55 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
56 else |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
57 error ("assemble: unknown argument type"); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
58 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
59 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
60 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
61 std::size_t nr = A.size (0), nc = A.size (1); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
62 std::vector<double> data_tmp; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
63 std::vector<std::size_t> cidx_tmp; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
64 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
65 octave_idx_type dims = A.size (0), nz = 0, ii = 0; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
66 ColumnVector ridx (dims), cidx (dims), data (dims); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
67 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
68 for (std::size_t i = 0; i < nr; ++i) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
69 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
70 A.getrow (i, cidx_tmp, data_tmp); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
71 nz += cidx_tmp.size (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
72 if (dims < nz) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
73 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
74 dims = 1.2 * ((nr * nz) / (i + 1));; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
75 ridx.resize (dims); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
76 cidx.resize (dims); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
77 data.resize (dims); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
78 } |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
79 |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
80 for (octave_idx_type j = 0; j < cidx_tmp.size (); ++j) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
81 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
82 ridx.xelem (ii + j) = i + 1; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
83 cidx.xelem (ii + j) = cidx_tmp [j] + 1; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
84 data.xelem (ii + j) = data_tmp [j]; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
85 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
86 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
87 ii = nz; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
88 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
89 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
90 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
91 ridx.resize (ii); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
92 cidx.resize (ii); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
93 data.resize (ii); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
94 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
95 SparseMatrix sm (data, ridx, cidx, nr, nc); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
96 retval(0) = sm; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
97 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
98 else if (a.rank () == 1) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
99 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
100 dolfin::Vector A; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
101 dolfin::assemble (A, a); |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
102 |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
103 if (! boundarycondition_type_loaded) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
104 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
105 boundarycondition::register_type (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
106 boundarycondition_type_loaded = true; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
107 mlock (); |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
108 } |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
109 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
110 for (std::size_t i = 1; i < nargin; ++i) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
111 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
112 if (args(i).type_id () == boundarycondition::static_type_id ()) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
113 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
114 const boundarycondition & bc |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
115 = static_cast<const boundarycondition&> (args(i).get_rep ()); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
116 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
117 const std::vector<boost::shared_ptr <const dolfin::DirichletBC> > & pbc |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
118 = bc.get_bc (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
119 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
120 for (std::size_t j = 0; j < pbc.size (); ++j) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
121 pbc[j]->apply(A); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
122 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
123 else |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
124 error ("assemble: unknown argument type"); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
125 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
126 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
127 dim_vector dims; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
128 dims.resize (2); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
129 dims(0) = A.size (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
130 dims(1) = 1; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
131 Array<double> myb (dims); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
132 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
133 for (std::size_t i = 0; i < A.size (); ++i) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
134 myb.xelem (i) = A[i]; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
135 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
136 retval(0) = myb; |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
137 } |
108
5cbc7341ded5
Added the possibility to assemble form of rank 0.
gedeone-octave <marcovass89@hotmail.it>
parents:
97
diff
changeset
|
138 else if (a.rank () == 0) |
5cbc7341ded5
Added the possibility to assemble form of rank 0.
gedeone-octave <marcovass89@hotmail.it>
parents:
97
diff
changeset
|
139 { |
5cbc7341ded5
Added the possibility to assemble form of rank 0.
gedeone-octave <marcovass89@hotmail.it>
parents:
97
diff
changeset
|
140 double b = dolfin::assemble (a); |
5cbc7341ded5
Added the possibility to assemble form of rank 0.
gedeone-octave <marcovass89@hotmail.it>
parents:
97
diff
changeset
|
141 retval(0) = octave_value (b); |
5cbc7341ded5
Added the possibility to assemble form of rank 0.
gedeone-octave <marcovass89@hotmail.it>
parents:
97
diff
changeset
|
142 } |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
143 |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
144 else |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
145 error ("assemble: unknown size"); |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
146 } |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
147 } |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
148 } |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
149 } |
97
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
150 else if (nargout == 2) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
151 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
152 if (nargin < 2) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
153 print_usage (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
154 else |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
155 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
156 if (! form_type_loaded) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
157 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
158 form::register_type (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
159 form_type_loaded = true; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
160 mlock (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
161 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
162 if (args(0).type_id () == form::static_type_id ()) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
163 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
164 const form & frm |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
165 = static_cast<const form&> (args(0).get_rep ()); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
166 const Array<double> myx = args(1).array_value (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
167 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
168 if (! error_state) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
169 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
170 const dolfin::Form & a = frm.get_form (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
171 a.check (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
172 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
173 if (a.rank () == 1) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
174 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
175 dolfin::Vector A; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
176 dolfin::assemble (A, a); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
177 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
178 dolfin::Vector x (myx.length ()); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
179 for (std::size_t i = 0; i < myx.length (); ++i) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
180 x.setitem (i, myx.xelem (i)); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
181 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
182 if (! boundarycondition_type_loaded) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
183 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
184 boundarycondition::register_type (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
185 boundarycondition_type_loaded = true; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
186 mlock (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
187 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
188 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
189 for (std::size_t i = 2; i < nargin; ++i) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
190 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
191 if (args(i).type_id () == boundarycondition::static_type_id ()) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
192 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
193 const boundarycondition & bc |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
194 = static_cast<const boundarycondition&> (args(i).get_rep ()); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
195 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
196 const std::vector<boost::shared_ptr <const dolfin::DirichletBC> > & pbc |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
197 = bc.get_bc (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
198 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
199 for (std::size_t j = 0; j < pbc.size (); ++j) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
200 pbc[j]->apply(A, x); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
201 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
202 else |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
203 error ("assemble NL vector: unknown argument type"); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
204 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
205 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
206 dim_vector dims; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
207 dims.resize (2); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
208 dims(0) = A.size (); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
209 dims(1) = 1; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
210 Array<double> myb (dims), myc (dims); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
211 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
212 for (std::size_t i = 0; i < A.size (); ++i) |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
213 { |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
214 myb.xelem (i) = A[i]; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
215 myc.xelem (i) = x[i]; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
216 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
217 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
218 retval(0) = myb; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
219 retval(1) = myc; |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
220 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
221 |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
222 else |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
223 error ("assemble NL vector: unknown size"); |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
224 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
225 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
226 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
227 } |
dc9987325fea
Added the possibility to apply BC to a NL problem.
gedeone-octave <marcovass89@hotmail.it>
parents:
91
diff
changeset
|
228 |
91
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
229 return retval; |
51bfdf30b822
New DLD functions for assembling a matrix/vector from a bilinear/linear form
gedeone-octave <marcovass89@hotmail.it>
parents:
diff
changeset
|
230 } |