Graphite Version 3
An experimental 3D geometry processing program
Loading...
Searching...
No Matches
blas.h
1/*
2 * OGF/Graphite: Geometry and Graphics Programming Library + Utilities
3 * Copyright (C) 2000 Bruno Levy
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18 *
19 * If you modify this software, you should include a notice giving the
20 * name of the person performing the modification, the date of modification,
21 * and the reason for such modification.
22 *
23 * Contact: Bruno Levy
24 *
25 * levy@loria.fr
26 *
27 * ISA Project
28 * LORIA, INRIA Lorraine,
29 * Campus Scientifique, BP 239
30 * 54506 VANDOEUVRE LES NANCY CEDEX
31 * FRANCE
32 *
33 * Note that the GNU General Public License does not permit incorporating
34 * the Software into proprietary programs.
35 */
36
37#ifndef H_OGF_SCENE_GRAPH_NL_BLAS_H
38#define H_OGF_SCENE_GRAPH_NL_BLAS_H
39
42
43struct NLBlas;
44typedef NLBlas* NLBlas_t;
45
46namespace OGF {
47 namespace NL {
48
49 class Vector;
50
55 gom_class SCENE_GRAPH_API Blas : public Object {
56 public:
61
65 ~Blas() override;
66
67 gom_slots:
68
75 void copy(const Vector* x, Vector* y);
76
83 void scal(double a, Vector* x);
84
91 double dot(const Vector* x, const Vector* y);
92
99 double nrm2(const Vector* x);
100
108 void axpy(double a, const Vector* x, Vector* y);
109
110 private:
111 NLBlas_t impl_;
112 };
113
118 }
119}
120
121
122#endif
123
A smart pointer with reference-counted copy semantics.
Wrapper class for BLAS operations on vectors (Basic Linear Algebra).
Definition blas.h:55
~Blas() override
Blas destructor.
void axpy(double a, const Vector *x, Vector *y)
Computes a linear combination of two vectors.
void scal(double a, Vector *x)
Scales a vector.
double dot(const Vector *x, const Vector *y)
Computes the dot product between two vectors.
Blas()
Blas constructor.
double nrm2(const Vector *x)
Computes the norm of a vector.
A scriptable Vector objects.
Definition vector.h:54
Base class for all objects in the GOM system.
Definition object.h:65
Global Graphite namespace.
Definition common.h:76
struct NLBlas * NLBlas_t
A handle to a BLAS abstraction layer.
Definition nl_blas.h:63
The base class for all objects in the GOM system.
Definitions common to all include files in the scene_graph library.