NiHu  2.0
klline_surface.mex.cpp
1 // This file is a part of NiHu, a C++ BEM template library.
2 //
3 // Copyright (C) 2012-2014 Peter Fiala <fiala@hit.bme.hu>
4 // Copyright (C) 2012-2014 Peter Rucz <rucz@hit.bme.hu>
5 //
6 // This program is free software: you can redistribute it and/or modify
7 // it under the terms of the GNU General Public License as published by
8 // the Free Software Foundation, either version 3 of the License, or
9 // (at your option) any later version.
10 //
11 // This program is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
15 //
16 // You should have received a copy of the GNU General Public License
17 // along with this program. If not, see <http://www.gnu.org/licenses/>.
18 
21 #include "util/mex_matrix.hpp"
22 #include "library/lib_element.hpp"
23 
25 
26 typedef NiHu::exponential_covariance_kernel<NiHu::space_2d<>, NiHu::field_dimension::_1d> kernel_t;
27 
30 // [D, B] = mex(nodes, elements, var, d);
31 void mexFunction(int nlhs, mxArray *lhs[], int nrhs, mxArray const *rhs[])
32 {
33  mexPrintf("%d \n", NiHu::line_1_elem::id);
34  dMatrix nodes(rhs[0]), elem(rhs[1]);
35  auto mesh = NiHu::create_mesh(nodes, elem, NiHu::line_1_tag());
36  auto const &w = NiHu::constant_view(mesh);
37 
38  kernel_t::field_variance_t var = dMatrix(rhs[2]);
39  double d = NiHu::mex::get_scalar<double>(rhs[3]);
42 
43  size_t N = w.get_num_dofs();
44  mexPrintf("Number of DOFs: %d\n", N);
45 
46  dMatrix D(N, N, lhs[0]), B(N, N, lhs[1]);
47  D.setZero();
48  B.setZero();
49  mexPrintf("Matrices initialised\n");
50  D << (w * C[w]);
51  mexPrintf("D matrix ready\n");
52  B << (w * I[w]);
53  mexPrintf("B matrix ready\n");
54 }
55 
NiHu::create_integral_operator
integral_operator< Kernel > create_integral_operator(Kernel &&kernel)
factory function of an integral operator
Definition: integral_operator.hpp:421
NiHu::type2tag
Metafunction assigning a tag to a type.
Definition: type2tag.hpp:17
NiHu::create_mesh
mesh< tmp::vector< typename tag2type< Args >::type... > > create_mesh(nodes_t const &nodes, elements_t const &elements, Args...)
factory function to create a mesh from nodes and elements matrices
Definition: mesh.hpp:298
C
Definition: bbfmm_covariance.cpp:47
covariance_kernel.hpp
Implementation of kernels representing covariance functions of stochastic processes.
NiHu::identity_integral_operator
The identity integral operator .
Definition: integral_operator.hpp:310
NiHu::exponential_covariance_kernel
Definition: covariance_kernel.hpp:42
NiHu::constant_view
const function_space_view< Mesh, field_option::constant, Dimension > & constant_view(mesh_base< Mesh > const &msh, Dimension dim=Dimension())
factory function to transform a mesh into a constant function space
Definition: function_space.hpp:304
weighted_residual.hpp
declaration of class NiHu::weighted_residual
mex_matrix.hpp
A Matlab mex matrix interface.
NiHu::mex::real_matrix
Definition: mex_matrix_separate.hpp:133
lib_element.hpp