dist_admlocalm4_DATA = \
check_sphinx.m4 \
+ ac_python_devel.m4 \
check_HEXABLOCK.m4
--- /dev/null
+# ===========================================================================
+# http://www.gnu.org/software/autoconf-archive/ax_python_devel.html
+# ===========================================================================
+#
+# SYNOPSIS
+#
+# AX_PYTHON_DEVEL([version])
+#
+# DESCRIPTION
+#
+# Note: Defines as a precious variable "PYTHON_VERSION". Don't override it
+# in your configure.ac.
+#
+# This macro checks for Python and tries to get the include path to
+# 'Python.h'. It provides the $(PYTHON_CPPFLAGS) and $(PYTHON_LDFLAGS)
+# output variables. It also exports $(PYTHON_EXTRA_LIBS) and
+# $(PYTHON_EXTRA_LDFLAGS) for embedding Python in your code.
+#
+# You can search for some particular version of Python by passing a
+# parameter to this macro, for example ">= '2.3.1'", or "== '2.4'". Please
+# note that you *have* to pass also an operator along with the version to
+# match, and pay special attention to the single quotes surrounding the
+# version number. Don't use "PYTHON_VERSION" for this: that environment
+# variable is declared as precious and thus reserved for the end-user.
+#
+# This macro should work for all versions of Python >= 2.1.0. As an end
+# user, you can disable the check for the python version by setting the
+# PYTHON_NOVERSIONCHECK environment variable to something else than the
+# empty string.
+#
+# If you need to use this macro for an older Python version, please
+# contact the authors. We're always open for feedback.
+#
+# LICENSE
+#
+# Copyright (c) 2009 Sebastian Huber <sebastian-huber@web.de>
+# Copyright (c) 2009 Alan W. Irwin <irwin@beluga.phys.uvic.ca>
+# Copyright (c) 2009 Rafael Laboissiere <rafael@laboissiere.net>
+# Copyright (c) 2009 Andrew Collier <colliera@ukzn.ac.za>
+# Copyright (c) 2009 Matteo Settenvini <matteo@member.fsf.org>
+# Copyright (c) 2009 Horst Knorr <hk_classes@knoda.org>
+#
+# This program is free software: you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by the
+# Free Software Foundation, either version 3 of the License, or (at your
+# option) any later version.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
+# Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along
+# with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+# As a special exception, the respective Autoconf Macro's copyright owner
+# gives unlimited permission to copy, distribute and modify the configure
+# scripts that are the output of Autoconf when processing the Macro. You
+# need not follow the terms of the GNU General Public License when using
+# or distributing such scripts, even though portions of the text of the
+# Macro appear in them. The GNU General Public License (GPL) does govern
+# all other use of the material that constitutes the Autoconf Macro.
+#
+# This special exception to the GPL applies to versions of the Autoconf
+# Macro released by the Autoconf Archive. When you make and distribute a
+# modified version of the Autoconf Macro, you may extend this special
+# exception to the GPL to apply to your modified version as well.
+
+#serial 8
+
+AC_DEFUN([AX_PYTHON_DEVEL],[
+ #
+ # Allow the use of a (user set) custom python version
+ #
+ AC_ARG_VAR([PYTHON_VERSION],[The installed Python
+ version to use, for example '2.3'. This string
+ will be appended to the Python interpreter
+ canonical name.])
+
+ AC_PATH_PROG([PYTHON],[python[$PYTHON_VERSION]])
+ if test -z "$PYTHON"; then
+ AC_MSG_ERROR([Cannot find python$PYTHON_VERSION in your system path])
+ PYTHON_VERSION=""
+ fi
+
+ #
+ # Check for a version of Python >= 2.1.0
+ #
+ AC_MSG_CHECKING([for a version of Python >= '2.1.0'])
+ ac_supports_python_ver=`$PYTHON -c "import sys; \
+ ver = sys.version.split ()[[0]]; \
+ print (ver >= '2.1.0')"`
+ if test "$ac_supports_python_ver" != "True"; then
+ if test -z "$PYTHON_NOVERSIONCHECK"; then
+ AC_MSG_RESULT([no])
+ AC_MSG_FAILURE([
+This version of the AC@&t@_PYTHON_DEVEL macro
+doesn't work properly with versions of Python before
+2.1.0. You may need to re-run configure, setting the
+variables PYTHON_CPPFLAGS, PYTHON_LDFLAGS, PYTHON_SITE_PKG,
+PYTHON_EXTRA_LIBS and PYTHON_EXTRA_LDFLAGS by hand.
+Moreover, to disable this check, set PYTHON_NOVERSIONCHECK
+to something else than an empty string.
+])
+ else
+ AC_MSG_RESULT([skip at user request])
+ fi
+ else
+ AC_MSG_RESULT([yes])
+ fi
+
+ #
+ # if the macro parameter ``version'' is set, honour it
+ #
+ if test -n "$1"; then
+ AC_MSG_CHECKING([for a version of Python $1])
+ ac_supports_python_ver=`$PYTHON -c "import sys; \
+ ver = sys.version.split ()[[0]]; \
+ print (ver $1)"`
+ if test "$ac_supports_python_ver" = "True"; then
+ AC_MSG_RESULT([yes])
+ else
+ AC_MSG_RESULT([no])
+ AC_MSG_ERROR([this package requires Python $1.
+If you have it installed, but it isn't the default Python
+interpreter in your system path, please pass the PYTHON_VERSION
+variable to configure. See ``configure --help'' for reference.
+])
+ PYTHON_VERSION=""
+ fi
+ fi
+
+ #
+ # Check if you have distutils, else fail
+ #
+ AC_MSG_CHECKING([for the distutils Python package])
+ ac_distutils_result=`$PYTHON -c "import distutils" 2>&1`
+ if test -z "$ac_distutils_result"; then
+ AC_MSG_RESULT([yes])
+ else
+ AC_MSG_RESULT([no])
+ AC_MSG_ERROR([cannot import Python module "distutils".
+Please check your Python installation. The error was:
+$ac_distutils_result])
+ PYTHON_VERSION=""
+ fi
+
+ #
+ # Check for Python include path
+ #
+ AC_MSG_CHECKING([for Python include path])
+ if test -z "$PYTHON_CPPFLAGS"; then
+ python_path=`$PYTHON -c "import distutils.sysconfig; \
+ print (distutils.sysconfig.get_python_inc ());"`
+ if test -n "${python_path}"; then
+ python_path="-I$python_path"
+ fi
+ PYTHON_CPPFLAGS=$python_path
+ fi
+ AC_MSG_RESULT([$PYTHON_CPPFLAGS])
+ AC_SUBST([PYTHON_CPPFLAGS])
+
+ #
+ # Check for Python library path
+ #
+ AC_MSG_CHECKING([for Python library path])
+ if test -z "$PYTHON_LDFLAGS"; then
+ # (makes two attempts to ensure we've got a version number
+ # from the interpreter)
+ ac_python_version=`cat<<EOD | $PYTHON -
+
+# join all versioning strings, on some systems
+# major/minor numbers could be in different list elements
+from distutils.sysconfig import *
+ret = ''
+for e in get_config_vars ('VERSION'):
+ if (e != None):
+ ret += e
+print (ret)
+EOD`
+
+ if test -z "$ac_python_version"; then
+ if test -n "$PYTHON_VERSION"; then
+ ac_python_version=$PYTHON_VERSION
+ else
+ ac_python_version=`$PYTHON -c "import sys; \
+ print (sys.version[[:3]])"`
+ fi
+ fi
+
+ # Make the versioning information available to the compiler
+ AC_DEFINE_UNQUOTED([HAVE_PYTHON], ["$ac_python_version"],
+ [If available, contains the Python version number currently in use.])
+
+ # First, the library directory:
+ ac_python_libdir=`cat<<EOD | $PYTHON -
+
+# There should be only one
+import distutils.sysconfig
+for e in distutils.sysconfig.get_config_vars ('LIBDIR'):
+ if e != None:
+ print (e)
+ break
+EOD`
+
+ # Before checking for libpythonX.Y, we need to know
+ # the extension the OS we're on uses for libraries
+ # (we take the first one, if there's more than one fix me!):
+ ac_python_soext=`$PYTHON -c \
+ "import distutils.sysconfig; \
+ print (distutils.sysconfig.get_config_vars('SO')[[0]])"`
+
+ # Now, for the library:
+ ac_python_soname=`$PYTHON -c \
+ "import distutils.sysconfig; \
+ print (distutils.sysconfig.get_config_vars('LDLIBRARY')[[0]])"`
+
+ # Strip away extension from the end to canonicalize its name:
+ ac_python_library=`echo "$ac_python_soname" | sed "s/${ac_python_soext}$//"`
+
+ # This small piece shamelessly adapted from PostgreSQL python macro;
+ # credits goes to momjian, I think. I'd like to put the right name
+ # in the credits, if someone can point me in the right direction... ?
+ #
+ if test -n "$ac_python_libdir" -a -n "$ac_python_library" \
+ -a x"$ac_python_library" != x"$ac_python_soname"
+ then
+ # use the official shared library
+ ac_python_library=`echo "$ac_python_library" | sed "s/^lib//"`
+ PYTHON_LDFLAGS="-L$ac_python_libdir -l$ac_python_library"
+ else
+ # old way: use libpython from python_configdir
+ ac_python_libdir=`$PYTHON -c \
+ "from distutils.sysconfig import get_python_lib as f; \
+ import os; \
+ print (os.path.join(f(plat_specific=1, standard_lib=1), 'config'));"`
+ PYTHON_LDFLAGS="-L$ac_python_libdir -lpython$ac_python_version"
+ fi
+
+ if test -z "PYTHON_LDFLAGS"; then
+ AC_MSG_ERROR([
+ Cannot determine location of your Python DSO. Please check it was installed with
+ dynamic libraries enabled, or try setting PYTHON_LDFLAGS by hand.
+ ])
+ fi
+ fi
+ AC_MSG_RESULT([$PYTHON_LDFLAGS])
+ AC_SUBST([PYTHON_LDFLAGS])
+
+ #
+ # Check for site packages
+ #
+ AC_MSG_CHECKING([for Python site-packages path])
+ if test -z "$PYTHON_SITE_PKG"; then
+ PYTHON_SITE_PKG=`$PYTHON -c "import distutils.sysconfig; \
+ print (distutils.sysconfig.get_python_lib(0,0));"`
+ fi
+ AC_MSG_RESULT([$PYTHON_SITE_PKG])
+ AC_SUBST([PYTHON_SITE_PKG])
+
+ #
+ # libraries which must be linked in when embedding
+ #
+ AC_MSG_CHECKING(python extra libraries)
+ if test -z "$PYTHON_EXTRA_LIBS"; then
+ PYTHON_EXTRA_LIBS=`$PYTHON -c "import distutils.sysconfig; \
+ conf = distutils.sysconfig.get_config_var; \
+ print (conf('LOCALMODLIBS') + ' ' + conf('LIBS'))"`
+ fi
+ AC_MSG_RESULT([$PYTHON_EXTRA_LIBS])
+ AC_SUBST(PYTHON_EXTRA_LIBS)
+
+ #
+ # linking flags needed when embedding
+ #
+ AC_MSG_CHECKING(python extra linking flags)
+ if test -z "$PYTHON_EXTRA_LDFLAGS"; then
+ PYTHON_EXTRA_LDFLAGS=`$PYTHON -c "import distutils.sysconfig; \
+ conf = distutils.sysconfig.get_config_var; \
+ print (conf('LINKFORSHARED'))"`
+ fi
+ AC_MSG_RESULT([$PYTHON_EXTRA_LDFLAGS])
+ AC_SUBST(PYTHON_EXTRA_LDFLAGS)
+
+ #
+ # final check to see if everything compiles alright
+ #
+ AC_MSG_CHECKING([consistency of all components of python development environment])
+ # save current global flags
+ ac_save_LIBS="$LIBS"
+ ac_save_CPPFLAGS="$CPPFLAGS"
+ LIBS="$ac_save_LIBS $PYTHON_LDFLAGS $PYTHON_EXTRA_LDFLAGS $PYTHON_EXTRA_LIBS"
+ CPPFLAGS="$ac_save_CPPFLAGS $PYTHON_CPPFLAGS"
+ AC_LANG_PUSH([C])
+ AC_LINK_IFELSE([
+ AC_LANG_PROGRAM([[#include <Python.h>]],
+ [[Py_Initialize();]])
+ ],[pythonexists=yes],[pythonexists=no])
+ AC_LANG_POP([C])
+ # turn back to default flags
+ CPPFLAGS="$ac_save_CPPFLAGS"
+ LIBS="$ac_save_LIBS"
+
+ AC_MSG_RESULT([$pythonexists])
+
+ if test ! "x$pythonexists" = "xyes"; then
+ AC_MSG_FAILURE([
+ Could not link test program to Python. Maybe the main Python library has been
+ installed in some non-standard library path. If so, pass it to configure,
+ via the LDFLAGS environment variable.
+ Example: ./configure LDFLAGS="-L/usr/non-standard-path/python/lib"
+ ============================================================================
+ ERROR!
+ You probably have to install the development version of the Python package
+ for your distribution. The exact name of this package varies among them.
+ ============================================================================
+ ])
+ PYTHON_VERSION=""
+ fi
+
+ #
+ # all done!
+ #
+])
+AC_DEFUN([AC_PYTHON_DEVEL], [AX_PYTHON_DEVEL])
-EXTRA_DIST+= $(RSTFILES) _static cas_test_python pyplots test_doc
+EXTRA_DIST+= $(RSTFILES) _static cas_test_python
install-data-local:
$(INSTALL) -d $(DESTDIR)$(hexablockdocdir)
-// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE
+// Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
# This local variable defines the list of dependant libraries common to all target in this package.
COMMON_LIBS =\
@CPPUNIT_LIBS@ \
- $(RPATH)/HEXABLOCK/libHEXABLOCKimpl.la
+ $(RPATH)/HEXABLOCK/libHEXABLOCKEngine.la
# ===============================================================
# Libraries targets
Test_HEXABLOCK_CPPFLAGS = $(COMMON_CPPFLAGS)
Test_HEXABLOCK_LDADD = \
libHEXABLOCKTest.la \
- ../HEXABLOCK/libHEXABLOCKimpl.la \
+ ../HEXABLOCK/libHEXABLOCKEngine.la \
$(COMMON_LIBS)
UNIT_TEST_PROG = ./Test_HEXABLOCK
# test_cartesi1_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_cartesi1_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
# test_clone_SOURCES = test_clone.cpp
# test_clone_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_clone_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
# test_cyl_SOURCES = test_cyl.cpp
# test_cyl_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_cyl_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
# test_decoupage_SOURCES = test_decoupage.cpp
# test_decoupage_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_decoupage_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
# test_find_SOURCES = test_find.cpp
# test_find_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_find_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
# test_gen_xml_SOURCES = test_gen_xml.cpp
# test_gen_xml_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_gen_xml_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
# test_joint_SOURCES = test_joint.cpp
# test_joint_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_joint_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
# test_lecture_SOURCES = test_lecture.cpp
# test_lecture_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_lecture_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
# test_propagation_SOURCES = test_propagation.cpp
# test_propagation_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_propagation_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
#
# test_separ_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_separ_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
# test_hexa1_CPPFLAGS = $(COMMON_CPPFLAGS)
# test_hexa1_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
#
# UNIT_TEST_PROG = ./test_hexa1
# bielle_SOURCES = bielle.cpp
# bielle_CPPFLAGS = $(COMMON_CPPFLAGS)
# bielle_LDADD = \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
# tuyau_SOURCES = tuyau.cpp
# tuyau_CPPFLAGS = $(COMMON_CPPFLAGS)
# tuyau_LDADD = \
# libHEXATest.la \
-# ../HEXA/libHEXAimpl.la \
+# ../HEXA/libHEXAEngine.la \
# $(COMMON_LIBS)
Hex::Vector* vectj = doc->addVector (0,1,0);
Hex::Vector* vecti = doc->addVector (1,0,0);
Hex::Elements* grid2 = doc->makeCylindrical (orig2, vecti, vectj,
- 1, 180, 1, dimz,dimy,dimx);
+ 1, 180, 1, dimz,dimy,dimx, true);
int mx = dimx/2;
int my = dimy/2;
int nl = 10;
/* Hex::Elements* cyl1 = */ doc->makeCylindrical(orig1, vy,vz, dr, da,
- dl,nr,na,nl);
+ dl,nr,na,nl, false);
/* Hex::Elements* cyl2 = */ doc->makeCylindrical(orig2, vz,vx, dr/2, da,
- dl,nr,na,nl);
+ dl,nr,na,nl, false);
doc->saveVtk ("deux_cylindres.vtk");
CPPUNIT_ASSERT( true );
}
#include "HexVertex.hxx"
#include "HexPropagation.hxx"
-#include "HexOldShape.hxx"
#include "HexLaw.hxx"
#include "HexMatrix.hxx"
#include "HexCramer.hxx"
Hex::Vector* vectj = doc->addVector (0,1,0);
Hex::Vector* vecti = doc->addVector (1,0,0);
Hex::Elements* grid2 = doc->makeCylindrical (orig2, vecti, vectj,
- 1, 180, 1, dimz,dimy,dimx);
+ 1, 180, 1, dimz,dimy,dimx, true);
int mx = dimx/2;
int my = dimy/2;
int nr = 2;
int nl = 3;
- Hex::Elements* c1;
-
- c1 = doc->makeCylindrical (orig1, vx,vz,dr, 360, dl,nr, 10, nl, false);
+// Hex::Elements* c1 =
+ doc->makeCylindrical (orig1, vx,vz,dr, 360, dl,nr, 10, nl, false);
HexDisplay (doc->countVertex ());
HexDisplay (doc->countUsedVertex ());
Hex::Vertex* orig = doc->addVertex (0,0,0);
Hex::Vector* dir = doc->addVector (1,1,1);
- Hex::Elements* grid = doc->makeCartesian (orig, dir, size_x,size_y,size_z);
+ // Hex::Elements* grid =
+ doc->makeCartesian (orig, dir, size_x,size_y,size_z);
- Hex::Hexa* cell = grid->getHexa (0);
+ // Hex::Hexa* cell = grid->getHexa (0);
// Hex::Quad* face = cell->getQuad (0);
// Hex::Edge* arete = cell->getEdge (0);
// Hex::Vertex* noeud = cell->getVertex (0);
Hex::Vertex* orig = doc->addVertex (0,0,0);
Hex::Vector* dir = doc->addVector (1,1,1);
- Hex::Elements* grid = doc->makeCartesian (orig, dir, size_x,size_y,size_z);
+ // Hex::Elements* grid =
+ doc->makeCartesian (orig, dir, size_x,size_y,size_z);
- Hex::Hexa* cell = grid->getHexa (0);
+ // Hex::Hexa* cell = grid->getHexa (0);
// Hex::Quad* face = cell->getQuad (0);
// Hex::Edge* arete = cell->getEdge (0);
// Hex::Vertex* noeud = cell->getVertex (0);
double rayon = 1;
int nbr = 3;
- Hex::Elements* grid = doc->makeSpherical (orig, rayon, nbr);
+ Hex::Elements* grid = doc->makeSpherical (orig, rayon, nbr, 1);
int nbhexas = grid->countHexa ();
HexDisplay (nbhexas);
- for (int nro=0 ; nro<nbhexas ; nro +=3)
+ for (int nro=3 ; nro<nbhexas ; nro +=3)
grid->getHexa(nro)->remove();
HexDisplay (doc->countHexa ());
doc->saveVtk ("shperical.vtk");
int nr = 2;
int nl = 3;
- Hex::Elements *c1, *c2, *c3, *c4, *c5, *c6;
-
- c1 = doc->makeCylindrical (orig1, vx,vz,dr, 360, dl,nr, 4, nl, true);
- c2 = doc->makeCylindrical (orig2, vx,vz,dr, 360, dl,nr, 8, nl, true);
- c3 = doc->makeCylindrical (orig3, vx,vz,dr, 270, dl,nr, 8, nl, true);
- c4 = doc->makeCylindrical (orig4, vx,vz,dr, 270, dl,nr, 7, nl, true);
- c5 = doc->makeCylindrical (orig5, vx,vz,dr, 360, dl,nr, 5, nl, true);
- c6 = doc->makeCylindrical (orig6, vx,vz,dr, 360, dl,nr, 6, nl, true);
+ doc->makeCylindrical (orig1, vx,vz,dr, 360, dl,nr, 4, nl, true);
+ Hex::Elements* c2 =
+ doc->makeCylindrical (orig2, vx,vz,dr, 360, dl,nr, 8, nl, true);
+ doc->makeCylindrical (orig3, vx,vz,dr, 270, dl,nr, 8, nl, true);
+ doc->makeCylindrical (orig4, vx,vz,dr, 270, dl,nr, 7, nl, true);
+ doc->makeCylindrical (orig5, vx,vz,dr, 360, dl,nr, 5, nl, true);
+ doc->makeCylindrical (orig6, vx,vz,dr, 360, dl,nr, 6, nl, true);
int base2 = nr*nl*8;
c2->getHexa(base2 + 0)->setScalar (5);
// Hex::Cylinder* cyl = doc->addCylinder (orig, vz, nr, nl);
// Hex::Elements* grid = doc->makeCylinder (cyl, vx, nr, na, nl);
doc->makeCylindrical (orig,vx, vz, dr,da,dl, nr,na, nl, true);
- doc ->saveVtk (fic_vtk, na);
+ doc->saveVtk (fic_vtk, na);
return HOK;
}
// ===================================================== test_cylinder
int test_croix (int nbargs, cpchar tabargs[])
{
Hex::Hex mon_ex;
- docu = mon_ex.addDocument ();
+ case_name = "croix";
+ docu = mon_ex.addDocument (case_name);
- Hex::Vertex* ori1 = docu->addVertex ( 100,0,0);
+ Hex::Vertex* ori1 = docu->addVertex ( 0,0,0);
Hex::Vertex* ori2 = docu->addVertex (-5,0,5);
Hex::Vector* vz = docu->addVector ( 0,0,1);
Hex::Vector* vx = docu->addVector ( 1,0,0);
double r1 = 2;
double r2 = 3;
- double l1 = 5;
+ double l1 = 10;
double l2 = 10;
Hex::Cylinder* cyl1 = docu->addCylinder (ori1, vz, r1, l1);
Hex::Cylinder* cyl2 = docu->addCylinder (ori2, vx, r2, l2);
Hex::CrossElements* grid = docu->makeCylinders (cyl1, cyl2);
- case_name = "croix";
save_vtk ();
PutData ((BadElement (grid)));
del_tranche (grid, 1, 1, 2, 2);
return HOK;
}
+// ======================================================== test_croix2
+int test_croix2 (int nbargs, cpchar tabargs[])
+{
+ Hex::Hex mon_ex;
+ case_name = "croix";
+ docu = mon_ex.addDocument (case_name);
+
+ Hex::Vertex* pt1 = docu->addVertex ( 0,0,0);
+ Hex::Vertex* pt2 = docu->addVertex (10,0,0);
+
+ Hex::Vector* dx = docu->addVector ( 1,0,0);
+ Hex::Vector* dy = docu->addVector ( 0,1,0);
+ Hex::Vector* dz = docu->addVector ( 0,0,1);
+
+ double r1 = 4;
+ double r2 = 2;
+ double l1 = 20;
+ double l2 = 15;
+
+ Hex::Cylinder* cyl1 = docu->addCylinder (pt1, dx, r1, l1);
+ Hex::Cylinder* cyl2 = docu->addCylinder (pt2, dz, r2, l2);
+
+ int nr = 3;
+ int na = 8;
+ int nl = 2;
+ Hex::Elements* grid1 = docu->makeCylinder (cyl1, dy, nr, na, nl);
+ grid1->saveVtk ("cyl_big.vtk");
+ Hex::Elements* grid2 = docu->makeCylinder (cyl2, dy, nr, na, nl);
+ grid2->saveVtk ("cyl_small.vtk");
+
+ PutData ((BadElement (grid1)));
+ PutData ((BadElement (grid2)));
+
+ Hex::CrossElements* grid = docu->makeCylinders (cyl1, cyl2);
+
+ grid->saveVtk ("cyl_all.vtk");
+ return HOK;
+}
// ======================================================== test_pipes
int test_pipes (int nbargs, cpchar tabargs[])
{
Hex::Vertex* orig = doc->addVertex (0, 0, 0);
Hex::Vector* vx = doc->addVector (1 ,0, 0);
- doc->addEdge (orig, vx);
+ doc->addEdgeVector (orig, vx);
HexDisplay (doc->countVertex());
HexDisplay (doc->countEdge());
nr1 = 2
nl1 = 10
- nr2 = 1
+ nr2 = 1.8
nl2 = 10
cyl1 = doc.addCylinder (ori1, vz, nr1, nl1)
# ================================================================= Begin
-doc = test_pipes ()
-doc.setLevel (747)
+## doc = test_pipes ()
+doc = test_croix ()
+## doc.setLevel (747)
law = doc.addLaw("Uniform", 4)