Files
create/src/Mod/Ship/simRun/clSim/BEMsolver.py
Jose Luis Cercós Pita f9e1c43285 Regenerated branch
2013-05-21 08:27:00 -04:00

62 lines
2.5 KiB
Python

#***************************************************************************
#* *
#* Copyright (c) 2011, 2012 *
#* Jose Luis Cercos Pita <jlcercos@gmail.com> *
#* *
#* This program is free software; you can redistribute it and/or modify *
#* it under the terms of the GNU Lesser General Public License (LGPL) *
#* as published by the Free Software Foundation; either version 2 of *
#* the License, or (at your option) any later version. *
#* for detail see the LICENCE text file. *
#* *
#* 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 Library General Public License for more details. *
#* *
#* You should have received a copy of the GNU Library General Public *
#* License along with this program; if not, write to the Free Software *
#* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 *
#* USA *
#* *
#***************************************************************************
# numpy
import numpy as np
from bem_jacobi_cl import jacobi
from bem_minres_cl import minres
from bem_lsqr_cl import lsqr
import FreeCAD
grav=9.81
class simBEMSolver_cl:
def __init__(self, context=None, queue=None):
""" Constructor.
@param context OpenCL context where apply.
@param queue OpenCL command queue.
"""
self.context = context
self.queue = queue
self.solver = lsqr(context, queue)
def execute(self, bem):
""" Compute potential unknow data (gradients for free surface, and
potentials for the other ones).
@param bem Boundary Element Method instance.
"""
"""
[bem['gradp'], r, iters] = self.solver.solve(bem['A'], bem['B'], bem['gradp'])
if(iters >= 300):
FreeCAD.Console.PrintError("\t\t[Sim]: Solving velocity potentials.\n")
FreeCAD.Console.PrintError("\t\t\tSolutions seems don't convergs after 300 iterations (%g residual)\n" % (r))
FreeCAD.Console.PrintMessage((r,iters))
FreeCAD.Console.PrintMessage("\n")
"""
import scipy.linalg as la
[bem['gradp'], residues, rank, s] = la.lstsq(bem['A'], bem['B'])
if(rank < bem['N']):
FreeCAD.Console.PrintError("\t\t[Sim]: Solving velocity potentials.\n")
FreeCAD.Console.PrintError("\t\t\tEffective rank of linear system matrix is {0} (N = {1})\n".format(rank, bem['N']))