ngsolve 6.2.2506.post74.dev0__cp310-cp310-macosx_10_15_universal2.whl → 6.2.2506.post91.dev0__cp310-cp310-macosx_10_15_universal2.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of ngsolve might be problematic. Click here for more details.

Files changed (54) hide show
  1. netgen/include/kernels.hpp +24 -62
  2. netgen/include/sparsefactorization_interface.hpp +153 -0
  3. netgen/include/statushandler.hpp +8 -8
  4. netgen/libngbla.dylib +0 -0
  5. netgen/libngcomp.dylib +0 -0
  6. netgen/libngfem.dylib +0 -0
  7. netgen/libngla.dylib +0 -0
  8. netgen/libngsbem.dylib +0 -0
  9. netgen/libngsolve.dylib +0 -0
  10. netgen/libngstd.dylib +0 -0
  11. ngsolve/cmake/NGSolveConfig.cmake +1 -1
  12. ngsolve/cmake/ngsolve-targets.cmake +15 -8
  13. ngsolve/config/config.py +5 -5
  14. ngsolve/directsolvers.py +9 -21
  15. ngsolve/solvers/cudss.py +74 -0
  16. {ngsolve-6.2.2506.post74.dev0.dist-info → ngsolve-6.2.2506.post91.dev0.dist-info}/METADATA +2 -2
  17. {ngsolve-6.2.2506.post74.dev0.dist-info → ngsolve-6.2.2506.post91.dev0.dist-info}/RECORD +54 -52
  18. /ngsolve/{solvers.py → solvers/__init__.py} +0 -0
  19. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/Netgen.icns +0 -0
  20. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/bin/ngscxx +0 -0
  21. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/bin/ngsld +0 -0
  22. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/bin/ngsolve.tcl +0 -0
  23. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/bin/ngspy +0 -0
  24. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/beam.geo +0 -0
  25. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/beam.vol +0 -0
  26. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/chip.in2d +0 -0
  27. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/chip.vol +0 -0
  28. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/coil.geo +0 -0
  29. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/coil.vol +0 -0
  30. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/coilshield.geo +0 -0
  31. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/coilshield.vol +0 -0
  32. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/cube.geo +0 -0
  33. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/cube.vol +0 -0
  34. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d10_DGdoubleglazing.pde +0 -0
  35. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d11_chip_nitsche.pde +0 -0
  36. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d1_square.pde +0 -0
  37. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d2_chip.pde +0 -0
  38. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d3_helmholtz.pde +0 -0
  39. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d4_cube.pde +0 -0
  40. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d5_beam.pde +0 -0
  41. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d6_shaft.pde +0 -0
  42. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d7_coil.pde +0 -0
  43. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d8_coilshield.pde +0 -0
  44. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/d9_hybridDG.pde +0 -0
  45. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/doubleglazing.in2d +0 -0
  46. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/doubleglazing.vol +0 -0
  47. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/piezo2d40round4.vol.gz +0 -0
  48. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/shaft.geo +0 -0
  49. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/shaft.vol +0 -0
  50. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/square.in2d +0 -0
  51. {ngsolve-6.2.2506.post74.dev0.data → ngsolve-6.2.2506.post91.dev0.data}/data/share/ngsolve/square.vol +0 -0
  52. {ngsolve-6.2.2506.post74.dev0.dist-info → ngsolve-6.2.2506.post91.dev0.dist-info}/LICENSE +0 -0
  53. {ngsolve-6.2.2506.post74.dev0.dist-info → ngsolve-6.2.2506.post91.dev0.dist-info}/WHEEL +0 -0
  54. {ngsolve-6.2.2506.post74.dev0.dist-info → ngsolve-6.2.2506.post91.dev0.dist-info}/top_level.txt +0 -0
@@ -203,22 +203,28 @@ namespace ngsbem
203
203
 
204
204
  /** HelmholtzSLkernel is the kernel for the double layer potential of the
205
205
  Helmholtz equation $ -\Delta u - \kappa^2 u = 0, \; \kappa>0\,. $ */
206
- template <int DIM> class HelmholtzSLKernel;
206
+ template <int DIM, int COMPS=1> class HelmholtzSLKernel;
207
207
 
208
208
  /** HelmholtzSLkernel in 3D reads
209
209
  $$ G(x-y) = \frac{1 }{4\,\pi} \,\frac{e^{i\,\kappa \, |x-y| }{|x-y|} \,
210
210
  \quad x, y \in \mathbb R^3, \; x\not=y\,. $$ */
211
- template<>
212
- class HelmholtzSLKernel<3> : public BaseKernel
211
+ template<int COMPS>
212
+ class HelmholtzSLKernel<3, COMPS> : public BaseKernel
213
213
  {
214
214
  double kappa;
215
215
  public:
216
216
  typedef Complex value_type;
217
+ using mp_type = typename std::conditional<COMPS == 1,
218
+ Complex,
219
+ Vec<COMPS, Complex>>::type;
217
220
  static string Name() { return "HelmholtzSL"; }
218
- static auto Shape() { return IVec<2>(1,1); }
221
+ static auto Shape() { return IVec<2>(COMPS,COMPS); }
219
222
 
220
223
  /** Construction of the kernel specifies the wavenumber $\kappa$. */
221
- HelmholtzSLKernel (double _kappa) : kappa(_kappa) { }
224
+ HelmholtzSLKernel (double _kappa) : kappa(_kappa) {
225
+ for (size_t i = 0; i < COMPS; i++)
226
+ terms += {1.0, 0, i, i};
227
+ }
222
228
 
223
229
  template <typename T>
224
230
  auto Evaluate (Vec<3,T> x, Vec<3,T> y, Vec<3,T> nx, Vec<3,T> ny) const
@@ -229,26 +235,32 @@ namespace ngsbem
229
235
  return Vec<1,decltype(kern)> (kern);
230
236
  }
231
237
  double GetKappa() const { return kappa; }
232
- Array<KernelTerm> terms = { KernelTerm{1.0, 0, 0, 0}, };
238
+ Array<KernelTerm> terms;
233
239
 
234
240
  auto CreateMultipoleExpansion (Vec<3> c, double r, FMM_Parameters fmm_params) const
235
241
  {
236
- return make_shared<SingularMLExpansion<Complex>> (c, r, kappa, fmm_params);
242
+ return make_shared<SingularMLExpansion<mp_type>> (c, r, kappa, fmm_params);
237
243
  }
238
244
 
239
245
  auto CreateLocalExpansion (Vec<3> c, double r, FMM_Parameters fmm_params) const
240
246
  {
241
- return make_shared<RegularMLExpansion<Complex>> (c, r, kappa, fmm_params);
247
+ return make_shared<RegularMLExpansion<mp_type>> (c, r, kappa, fmm_params);
242
248
  }
243
249
 
244
- void AddSource (SingularMLExpansion<Complex> & mp, Vec<3> pnt, Vec<3> nv, BareSliceVector<Complex> val) const
250
+ void AddSource (SingularMLExpansion<mp_type> & mp, Vec<3> pnt, Vec<3> nv, BareSliceVector<Complex> val) const
245
251
  {
246
- mp.AddCharge(pnt, val(0));
252
+ if constexpr (COMPS == 1)
253
+ mp.AddCharge (pnt, val(0));
254
+ else
255
+ mp.AddCharge (pnt, val);
247
256
  }
248
257
 
249
- void EvaluateMP (RegularMLExpansion<Complex> & mp, Vec<3> pnt, Vec<3> nv, BareSliceVector<Complex> val) const
258
+ void EvaluateMP (RegularMLExpansion<mp_type> & mp, Vec<3> pnt, Vec<3> nv, BareSliceVector<Complex> val) const
250
259
  {
251
- val(0) = mp.Evaluate (pnt);
260
+ if constexpr (COMPS == 1)
261
+ val(0) = mp.Evaluate (pnt);
262
+ else
263
+ val = mp.Evaluate (pnt);
252
264
  }
253
265
  };
254
266
 
@@ -317,56 +329,6 @@ namespace ngsbem
317
329
  };
318
330
 
319
331
 
320
- template <int DIM> class HelmholtzSLVecKernel;
321
-
322
- template<>
323
- class HelmholtzSLVecKernel<3> : public BaseKernel
324
- {
325
- double kappa;
326
- public:
327
- typedef Complex value_type;
328
- static string Name() { return "HelmholtzSLVec"; }
329
- static auto Shape() { return IVec<2>(3,3); }
330
-
331
- HelmholtzSLVecKernel (double _kappa) : kappa(_kappa) { }
332
-
333
- template <typename T>
334
- auto Evaluate (Vec<3,T> x, Vec<3,T> y, Vec<3,T> nx, Vec<3,T> ny) const
335
- {
336
- T norm = L2Norm(x-y);
337
- auto kern = exp(Complex(0,kappa)*norm) / (4 * M_PI * norm);
338
- return Vec<1,decltype(kern)> (kern);
339
- }
340
- double GetKappa() const { return kappa; }
341
- Array<KernelTerm> terms =
342
- {
343
- KernelTerm{1.0, 0, 0, 0},
344
- KernelTerm{1.0, 0, 1, 1},
345
- KernelTerm{1.0, 0, 2, 2},
346
- };
347
-
348
- auto CreateMultipoleExpansion (Vec<3> c, double r, FMM_Parameters fmm_params) const
349
- {
350
- return make_shared<SingularMLExpansion<Vec<3,Complex>>> (c, r, kappa, fmm_params);
351
- }
352
-
353
- auto CreateLocalExpansion (Vec<3> c, double r, FMM_Parameters fmm_params) const
354
- {
355
- return make_shared<RegularMLExpansion<Vec<3,Complex>>> (c, r, kappa, fmm_params);
356
- }
357
-
358
- void AddSource (SingularMLExpansion<Vec<3,Complex>> & mp, Vec<3> pnt, Vec<3> nv, BareSliceVector<Complex> val) const
359
- {
360
- mp.AddCharge(pnt, val);
361
- }
362
-
363
- void EvaluateMP (RegularMLExpansion<Vec<3,Complex>> & mp, Vec<3> pnt, Vec<3> nv, BareSliceVector<Complex> val) const
364
- {
365
- val = mp.Evaluate (pnt);
366
- }
367
- };
368
-
369
-
370
332
  template <int DIM> class HelmholtzHSKernel;
371
333
 
372
334
  template<>
@@ -0,0 +1,153 @@
1
+ #ifndef SPARSEFACTORIZATION_INTERFACE_HPP
2
+ #define SPARSEFACTORIZATION_INTERFACE_HPP
3
+
4
+ #include "basevector.hpp"
5
+ #include "sparsecholesky.hpp"
6
+ #include "sparsematrix.hpp"
7
+ #include "../ngstd/python_ngstd.hpp"
8
+
9
+ namespace ngla {
10
+
11
+ void ExportSparseFactorizationInterface(py::module &m);
12
+
13
+ struct MapInnerDofs {
14
+ shared_ptr<BitArray> inner;
15
+ shared_ptr<const Array<int>> cluster;
16
+ Array<int> project;
17
+ Array<int> embed;
18
+ size_t size = 0;
19
+
20
+ MapInnerDofs(shared_ptr<BitArray> ainner,
21
+ shared_ptr<const Array<int>> acluster = nullptr)
22
+ : inner(ainner), cluster(acluster) {
23
+ if (!inner && !cluster) {
24
+ size = 0;
25
+ return;
26
+ }
27
+ if (inner) {
28
+ size = inner->NumSet();
29
+ project.SetSize(size);
30
+ embed.SetSize(inner->Size());
31
+ int j = 0;
32
+ for (int i = 0; i < inner->Size(); i++) {
33
+ if ((*inner)[i]) {
34
+ project[j] = i;
35
+ embed[i] = j++;
36
+ } else
37
+ embed[i] = -1;
38
+ }
39
+ return;
40
+ }
41
+
42
+ int j = 0;
43
+ for (int i = 0; i < cluster->Size(); i++) {
44
+ if ((*cluster)[i]) {
45
+ project.Append(i);
46
+ embed.Append(j++);
47
+ } else {
48
+ embed.Append(-1);
49
+ }
50
+ }
51
+ size = project.Size();
52
+ }
53
+
54
+ operator bool() const { return inner || cluster; }
55
+
56
+ template <typename T>
57
+ void Project(FlatVector<T> dst, FlatVector<T> src) const {
58
+ for (size_t i = 0; i < project.Size(); i++)
59
+ dst[i] = src[project[i]];
60
+ }
61
+
62
+ template <typename T> void Embed(T &dst, const T &src) const {
63
+ for (size_t i : Range(embed)) {
64
+ if (embed[i] >= 0)
65
+ dst[i] = src[embed[i]];
66
+ else
67
+ dst[i] = 0.0;
68
+ }
69
+ }
70
+
71
+ template <typename T>
72
+ void EmbedAdd(FlatVector<T> dst, FlatVector<T> src, T scale) const {
73
+ for (size_t i : Range(embed))
74
+ if (embed[i] >= 0)
75
+ dst[i] += scale * src[embed[i]];
76
+ }
77
+
78
+ template <typename T>
79
+ shared_ptr<SparseMatrixTM<T>>
80
+ ProjectMatrix(shared_ptr<const SparseMatrixTM<T>> m) {
81
+ Array<int> rowi, coli;
82
+ Array<T> vals;
83
+ auto &dofs = *inner;
84
+
85
+ auto vals_ori = m->GetValues();
86
+
87
+ auto &cluster_array = *cluster;
88
+ auto &inner_bitarray = *inner;
89
+ auto is_used = [this, &inner_bitarray, &cluster_array](int i, int j) {
90
+ if (inner)
91
+ return inner_bitarray[i] && inner_bitarray[j];
92
+ return cluster_array[i] == cluster_array[j];
93
+ };
94
+
95
+ for (auto i : project)
96
+ for (auto j : m->GetRowIndices(i))
97
+ if (is_used(i, j)) {
98
+ rowi.Append(embed[i]);
99
+ coli.Append(embed[j]);
100
+ vals.Append(vals_ori[m->GetPosition(i, j)]);
101
+ }
102
+
103
+ auto res = SparseMatrixTM<T>::CreateFromCOO(rowi, coli, vals,
104
+ project.Size(), project.Size());
105
+ res->SetSPD(m->IsSPD());
106
+ return res;
107
+ }
108
+ };
109
+
110
+ class SparseFactorizationInterface : public SparseFactorization {
111
+ protected:
112
+ shared_ptr<const BaseSparseMatrix> inner_mat;
113
+ shared_ptr<BaseVector> inner_rhs, inner_solution;
114
+ MapInnerDofs map_inner_dofs;
115
+ bool is_complex = false;
116
+ bool is_symmetric = false;
117
+ bool is_symmetric_storage = false;
118
+ bool is_analyzed = false;
119
+ int width, height, inner_width, inner_height;
120
+
121
+ public:
122
+ SparseFactorizationInterface() = delete;
123
+ SparseFactorizationInterface(shared_ptr<const BaseMatrix> m,
124
+ shared_ptr<BitArray> ainner = nullptr,
125
+ shared_ptr<const Array<int>> acluster = nullptr);
126
+
127
+ virtual ~SparseFactorizationInterface() {}
128
+
129
+ AutoVector CreateRowVector() const override {
130
+ return make_unique<VVector<double>>(Width());
131
+ }
132
+
133
+ AutoVector CreateColVector() const override {
134
+ return make_unique<VVector<double>>(Height());
135
+ }
136
+
137
+ shared_ptr<const BaseSparseMatrix> GetInnerMatrix() const {
138
+ return inner_mat;
139
+ }
140
+
141
+ void MultAdd(double s, const BaseVector &x, BaseVector &y) const override;
142
+ void MultAdd(Complex s, const BaseVector &x, BaseVector &y) const override;
143
+
144
+ virtual void Update() override;
145
+
146
+ virtual void Analyze() {}
147
+ virtual void Factor() {}
148
+ virtual void Solve(const BaseVector &rhs, BaseVector &solution) const = 0;
149
+ };
150
+
151
+ } // namespace ngla
152
+
153
+ #endif // SPARSEFACTORIZATION_INTERFACE_HPP
@@ -3,27 +3,27 @@
3
3
 
4
4
  namespace ngstd
5
5
  {
6
-
6
+
7
7
  /** Access to statusbar. (and more)
8
8
  */
9
9
 
10
10
  class NGS_DLL_HEADER BaseStatusHandler
11
- {
12
- public:
13
- static void PushStatus (const char * str);
11
+ {
12
+ public:
13
+ static void PushStatus (const std::string& str);
14
14
  static void PopStatus ();
15
15
  static void SetThreadPercentage (double percent);
16
-
16
+
17
17
  static void GetStatus (string & str, double & percent);
18
-
18
+
19
19
  static void SetTerminate(void);
20
20
  static void UnSetTerminate(void);
21
21
  static bool ShouldTerminate(void);
22
-
22
+
23
23
  class Region
24
24
  {
25
25
  public:
26
- Region(const char * str) { PushStatus(str); }
26
+ Region(const string& str) { PushStatus(str); }
27
27
  ~Region() { PopStatus(); }
28
28
  };
29
29
  };
netgen/libngbla.dylib CHANGED
Binary file
netgen/libngcomp.dylib CHANGED
Binary file
netgen/libngfem.dylib CHANGED
Binary file
netgen/libngla.dylib CHANGED
Binary file
netgen/libngsbem.dylib CHANGED
Binary file
netgen/libngsolve.dylib CHANGED
Binary file
netgen/libngstd.dylib CHANGED
Binary file
@@ -1,4 +1,4 @@
1
- set(PACKAGE_VERSION "6.2.2506-74-gd430159c1")
1
+ set(PACKAGE_VERSION "6.2.2506-91-g125cf2190")
2
2
  find_package(Netgen CONFIG REQUIRED HINTS
3
3
  ${CMAKE_CURRENT_LIST_DIR}
4
4
  ${CMAKE_CURRENT_LIST_DIR}/..
@@ -19,7 +19,7 @@ set(CMAKE_IMPORT_FILE_VERSION 1)
19
19
  set(_cmake_targets_defined "")
20
20
  set(_cmake_targets_not_defined "")
21
21
  set(_cmake_expected_targets "")
22
- foreach(_cmake_expected_target IN ITEMS netgen_libs ngs_lapack ngstd ngbla ngla ngfem ngsbem ngcomp ngsolve)
22
+ foreach(_cmake_expected_target IN ITEMS netgen_lib netgen_core_lib ngs_lapack ngstd ngbla ngla ngfem ngsbem ngcomp ngsolve)
23
23
  list(APPEND _cmake_expected_targets "${_cmake_expected_target}")
24
24
  if(TARGET "${_cmake_expected_target}")
25
25
  list(APPEND _cmake_targets_defined "${_cmake_expected_target}")
@@ -54,11 +54,18 @@ if(_IMPORT_PREFIX STREQUAL "/")
54
54
  set(_IMPORT_PREFIX "")
55
55
  endif()
56
56
 
57
- # Create imported target netgen_libs
58
- add_library(netgen_libs INTERFACE IMPORTED)
57
+ # Create imported target netgen_lib
58
+ add_library(netgen_lib INTERFACE IMPORTED)
59
59
 
60
- set_target_properties(netgen_libs PROPERTIES
61
- INTERFACE_LINK_LIBRARIES "nglib;ngcore"
60
+ set_target_properties(netgen_lib PROPERTIES
61
+ INTERFACE_LINK_LIBRARIES "nglib"
62
+ )
63
+
64
+ # Create imported target netgen_core_lib
65
+ add_library(netgen_core_lib INTERFACE IMPORTED)
66
+
67
+ set_target_properties(netgen_core_lib PROPERTIES
68
+ INTERFACE_LINK_LIBRARIES "ngcore"
62
69
  )
63
70
 
64
71
  # Create imported target ngs_lapack
@@ -74,7 +81,7 @@ add_library(ngstd SHARED IMPORTED)
74
81
  set_target_properties(ngstd PROPERTIES
75
82
  INTERFACE_COMPILE_DEFINITIONS "HAVE_NETGEN_SOURCES;HAVE_DLFCN_H;HAVE_CXA_DEMANGLE;USE_TIMEOFDAY;MSG_NOSIGNAL=0;TCL;LAPACK;NGS_PYTHON;USE_UMFPACK"
76
83
  INTERFACE_COMPILE_OPTIONS "\$<\$<COMPILE_LANGUAGE:CXX>:-std=c++17>;\$<\$<COMPILE_LANGUAGE:CXX>:-Wno-undefined-var-template;-Wno-vla-extension>;-DMAX_SYS_DIM=3"
77
- INTERFACE_LINK_LIBRARIES "netgen_libs"
84
+ INTERFACE_LINK_LIBRARIES "netgen_core_lib"
78
85
  )
79
86
 
80
87
  # Create imported target ngbla
@@ -109,14 +116,14 @@ set_target_properties(ngsbem PROPERTIES
109
116
  add_library(ngcomp SHARED IMPORTED)
110
117
 
111
118
  set_target_properties(ngcomp PROPERTIES
112
- INTERFACE_LINK_LIBRARIES "ngfem;ngla;ngbla;ngstd"
119
+ INTERFACE_LINK_LIBRARIES "ngfem;ngla;ngbla;ngstd;netgen_lib"
113
120
  )
114
121
 
115
122
  # Create imported target ngsolve
116
123
  add_library(ngsolve SHARED IMPORTED)
117
124
 
118
125
  set_target_properties(ngsolve PROPERTIES
119
- INTERFACE_LINK_LIBRARIES "netgen_libs;ngsolve;ngcomp;ngfem;ngsbem;ngbla;ngla;ngstd"
126
+ INTERFACE_LINK_LIBRARIES "netgen_lib;netgen_core_lib;ngsolve;ngcomp;ngfem;ngsbem;ngbla;ngla;ngstd"
120
127
  )
121
128
 
122
129
  if(CMAKE_VERSION VERSION_LESS 3.0.0)
ngsolve/config/config.py CHANGED
@@ -29,15 +29,15 @@ NGSOLVE_INSTALL_DIR_INCLUDE = "netgen/include"
29
29
  NGSOLVE_INSTALL_DIR_CMAKE = "ngsolve/cmake"
30
30
  NGSOLVE_INSTALL_DIR_RES = "share"
31
31
 
32
- NGSOLVE_VERSION = "6.2.2506-74-gd430159c1"
33
- NGSOLVE_VERSION_GIT = "v6.2.2506-74-gd430159c1"
34
- NGSOLVE_VERSION_PYTHON = "6.2.2506.post74.dev0"
32
+ NGSOLVE_VERSION = "6.2.2506-91-g125cf2190"
33
+ NGSOLVE_VERSION_GIT = "v6.2.2506-91-g125cf2190"
34
+ NGSOLVE_VERSION_PYTHON = "6.2.2506.post91.dev0"
35
35
 
36
36
  NGSOLVE_VERSION_MAJOR = "6"
37
37
  NGSOLVE_VERSION_MINOR = "2"
38
- NGSOLVE_VERSION_TWEAK = "74"
38
+ NGSOLVE_VERSION_TWEAK = "91"
39
39
  NGSOLVE_VERSION_PATCH = "2506"
40
- NGSOLVE_VERSION_HASH = "gd430159c1"
40
+ NGSOLVE_VERSION_HASH = "g125cf2190"
41
41
 
42
42
  CMAKE_CXX_COMPILER = "/Library/Developer/CommandLineTools/usr/bin/c++"
43
43
  CMAKE_CUDA_COMPILER = ""
ngsolve/directsolvers.py CHANGED
@@ -1,26 +1,14 @@
1
1
  from ngsolve import BaseMatrix, BitArray, BilinearForm, BaseVector
2
+ import ngsolve
2
3
 
3
- class SuperLU(BaseMatrix):
4
- # def __init__(self, a: BaseMatrix | BilinearForm, freedofs: BitArray = None):
5
- def __init__(self, a, freedofs: BitArray = None):
6
- super().__init__()
7
- self.a = a
8
- self.freedofs = freedofs
9
-
10
- def Update(self):
4
+ class SuperLU(ngsolve.la.SparseFactorizationInterface):
5
+ def Factor(self):
11
6
  import scipy.sparse as sp
12
7
  import scipy.sparse.linalg as spla
13
- a = self.a if isinstance(self.a, BaseMatrix) else self.a.mat
14
- mat = sp.csr_matrix(a.CSR())
15
- if self.freedofs is not None:
16
- self.fd = list(self.freedofs)
17
- mat = mat[self.fd,:][:,self.fd]
18
- self.lu = spla.factorized(sp.csc_matrix(mat))
8
+ vals, rows, cols = self.GetInnerMatrix().CSR()
9
+ self.inv_mat = spla.factorized(sp.csr_matrix((vals, rows, cols)))
10
+
11
+ def Solve(self, rhs, sol):
12
+ sol.FV().NumPy()[:] = self.inv_mat(rhs.FV().NumPy())
19
13
 
20
- def Mult(self, x: BaseVector, y: BaseVector):
21
- if not hasattr(self, "lu"):
22
- self.Update()
23
- if self.freedofs is not None:
24
- y.FV().NumPy()[self.fd] = self.lu(x.FV().NumPy()[self.fd])
25
- else:
26
- y.FV().NumPy()[:] = self.lu(x.FV().NumPy())
14
+ ngsolve.la.RegisterInverseType("superlu", SuperLU)
@@ -0,0 +1,74 @@
1
+
2
+ try:
3
+ import nvmath
4
+ import nvmath.sparse.advanced as nvs
5
+ except ImportError:
6
+ raise ImportError("CUDSS solver requires nvmath-python module.")
7
+ import ngsolve.la as ngla
8
+ import scipy.sparse as sp
9
+ import numpy as np
10
+
11
+
12
+ class CudssSolver(ngla.SparseFactorizationInterface):
13
+ def Analyze(self):
14
+ self._mat = self.GetInnerMatrix()
15
+ csr = sp.csr_matrix(self._mat.CSR())
16
+ self._tmp = np.empty(csr.shape[1], dtype=csr.dtype)
17
+ options = make_directsolver_options()
18
+ self.solver = nvs.DirectSolver(csr, self._tmp, options=options)
19
+ self.solver.plan()
20
+
21
+ def Factor(self):
22
+ self.solver.factorize()
23
+
24
+ def Solve(self, b, sol):
25
+ self.solver.reset_operands(b=b.FV().NumPy())
26
+ sol.FV().NumPy()[:] = self.solver.solve()
27
+
28
+
29
+ ngla.RegisterInverseType("cudss", CudssSolver)
30
+
31
+
32
+ # find cudss multithreading lib from installed distribution
33
+
34
+ import os, pathlib
35
+ from importlib import util as importlib_util
36
+ from importlib import metadata as importlib_metadata
37
+
38
+ def _from_dist_files():
39
+ # Use the wheel’s file manifest (most reliable)
40
+ candidates = []
41
+ for dist_name in ("nvidia-cudss-cu12", "nvidia_cudss_cu12", "nvidia-cudss"): # try common variants
42
+ try:
43
+ dist = importlib_metadata.distribution(dist_name)
44
+ except importlib_metadata.PackageNotFoundError:
45
+ continue
46
+ for f in dist.files or []:
47
+ name = f.name.lower()
48
+ # check for name ends in .so or .so.*
49
+ endwith_so = name.endswith(".so") or (".so." in name and name.rsplit(".so.", 1)[1].replace(".", "").isdigit())
50
+ if name.startswith("libcudss_mtlayer_") and endwith_so:
51
+ candidates.append(dist.locate_file(f))
52
+ if name.startswith("cudss_mtlayer_") and name.endswith(".dll"):
53
+ candidates.append(dist.locate_file(f))
54
+ if candidates:
55
+ # Prefer anything in bin/ or lib/ if multiple
56
+ candidates.sort(key=lambda p: ("bin" not in str(p) and "lib" not in str(p), str(p)))
57
+ return str(candidates[0])
58
+ return None
59
+
60
+
61
+ def make_directsolver_options():
62
+ # Helpful on Windows (Python 3.8+): ensure DLL deps can be found
63
+ if os.name == "nt":
64
+ for var in ("CUDA_PATH", "CUDSS_PATH", "CONDA_PREFIX"):
65
+ base = os.environ.get(var)
66
+ if base:
67
+ p = pathlib.Path(base) / "bin"
68
+ if p.exists():
69
+ try:
70
+ os.add_dll_directory(str(p))
71
+ except Exception:
72
+ pass
73
+ mtlib = _from_dist_files()
74
+ return nvs.DirectSolverOptions(multithreading_lib=mtlib)
@@ -1,13 +1,13 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ngsolve
3
- Version: 6.2.2506.post74.dev0
3
+ Version: 6.2.2506.post91.dev0
4
4
  Summary: NGSolve
5
5
  Home-page: UNKNOWN
6
6
  Author: The NGSolve team
7
7
  License: LGPL2.1
8
8
  Platform: UNKNOWN
9
9
  License-File: LICENSE
10
- Requires-Dist: netgen-mesher (==6.2.2506.post11.dev0)
10
+ Requires-Dist: netgen-mesher (==6.2.2506.post20.dev0)
11
11
 
12
12
  UNKNOWN
13
13
 
@@ -1,10 +1,10 @@
1
- netgen/libngbla.dylib,sha256=w-cuU6xFhcc15-AKhq3uZyMGEKVbu7hvid5hwm-rKs8,5989504
2
- netgen/libngcomp.dylib,sha256=3hCAayVRjivHyk-yH-CWHaQC2pC94vU_Py_r-46Q20Y,44571456
3
- netgen/libngfem.dylib,sha256=-s_SfQulzjxRojMJ7jmrD1m9armt6W65SqYYGFxttMY,52053152
4
- netgen/libngla.dylib,sha256=GpwdYKiYeCWArbsXnT2-Ps13lm-yE-CtzXTF3FMrSKs,26137776
5
- netgen/libngsbem.dylib,sha256=MfFtZ3eTQ4GXMiuUsMk4eV7WZGHTtTU-9OyGZvjDwh0,9696096
6
- netgen/libngsolve.dylib,sha256=iYbdJaH2wbM7hhf_Lb4qD-8APMm8KTECOivmbYXuQg8,1069504
7
- netgen/libngstd.dylib,sha256=-l3SOqq1iCKaS-djJZq3lb_VgtpHhmnFJ7WDi7g9pAU,1024720
1
+ netgen/libngbla.dylib,sha256=Y9kRQ3GkXJder33q_TyGjjpSiKvR5clH4gysLMhwuhE,5989504
2
+ netgen/libngcomp.dylib,sha256=40laWoLGpmOVXXAmHCwF04N4cBwSzIgArM4bkbjnH20,44631312
3
+ netgen/libngfem.dylib,sha256=2n6sjsRJhpICPqbUYIFhCR9El3eCG-JH8y0_6ICrJsQ,52053152
4
+ netgen/libngla.dylib,sha256=GgwAAgFO03uFDnvVS7wcGEBqlM5X3pYRS9I_BSOc3QA,26267760
5
+ netgen/libngsbem.dylib,sha256=F2kVk12eQMMeaKB1qsZo99-W3HYdxyM-m3QaOKowLSw,9697344
6
+ netgen/libngsolve.dylib,sha256=ylLd0SLmiYyJVysesGkfhkzAbQlrNzrPek1GPeIUaas,1069520
7
+ netgen/libngstd.dylib,sha256=pvZdRALF5yt24ocP4r5lRIMC7rAro5bWbyQFd9mrVSA,1008512
8
8
  netgen/include/analytic_integrals.hpp,sha256=xLVJ8n0-t6UlU_yKE8i0vYkXilsNuqVixkzJlmxptKw,238
9
9
  netgen/include/arnoldi.hpp,sha256=b8mRu9wGyaLa7z6mXCFIhxfW_xcQvsOMD6TqbfYZ05g,1437
10
10
  netgen/include/bandmatrix.hpp,sha256=zwKz89QY53MPsWgNsl0cXEAFKka_W4sXPIO54M3eT80,7778
@@ -104,7 +104,7 @@ netgen/include/intrule.hpp,sha256=VSDdG7fpraQHY1eZFaKo7bLyfpwBjMM0Z2qJgcmYW3w,80
104
104
  netgen/include/intrules_SauterSchwab.hpp,sha256=1HiSgmdJHNoCp1ZYY7gNFPHdanepbGtay2YJrTaYHBg,650
105
105
  netgen/include/irspace.hpp,sha256=DcpkPMFKx5nDvfLfTWKmpYuLX-X5rBuWF8Ta9e__m-A,1508
106
106
  netgen/include/jacobi.hpp,sha256=hFhMn5Q46_DxHGofXV_or5VCTREslMvpccV7FZCAefE,4738
107
- netgen/include/kernels.hpp,sha256=duCj2F7Gzz6drTp7_vi-oGIra0IiVK9VP5Ov4bpanCg,24354
107
+ netgen/include/kernels.hpp,sha256=dLC0pHlQ1wm_bzs5VuebsxIikLDiwfKvn4rrnLsyM1o,23276
108
108
  netgen/include/l2hofe.hpp,sha256=kbCezYmmgGqfIN0WZRNDKBEoWQTTcgpg7TEuDERolSY,6696
109
109
  netgen/include/l2hofe_impl.hpp,sha256=-rWVybAL7QTkfNNXAz1tP4RYQcBuOVYLTZE3E502tuA,15848
110
110
  netgen/include/l2hofefo.hpp,sha256=sQhmfliTW2Ac_XLucufzbRdtSRr471i3qPFAMSByvU0,16592
@@ -164,12 +164,13 @@ netgen/include/simd_complex.hpp,sha256=1L_WGuaYlR_xQdMMC4o0_aBX484GqrLuShG7pHG4i
164
164
  netgen/include/smoother.hpp,sha256=hZAe15R6BU88hMfhcTM3-eclRgzmHJnPKgYYWol9Sx8,6643
165
165
  netgen/include/solve.hpp,sha256=OZQfkg6HN20eudQ4kkRSecr-miwV35NPEjAtoMcunG4,2034
166
166
  netgen/include/sparsecholesky.hpp,sha256=2HKM6aKO02YX32jxGna6CAjBBfeXvCsmPk4hoWZWIQk,8888
167
+ netgen/include/sparsefactorization_interface.hpp,sha256=Hi6toUHpgKDCo4zqhZNSLbz1qOY_z3FqJVHcXCz-pjY,4143
167
168
  netgen/include/sparsematrix.hpp,sha256=3FCqp4zDtgi0CnrLdmmxzHiiub4jpIqg4yR1-eWQc8Q,32741
168
169
  netgen/include/sparsematrix_dyn.hpp,sha256=u9aWEYl6PhrevL9SPSXVE22_EIwIduDDvzY8xgIsw4Q,2656
169
170
  netgen/include/sparsematrix_impl.hpp,sha256=neN0xhP5nkT90B3U-u2uX2dgqU3l6m_zhsAihI8XtF0,30219
170
171
  netgen/include/special_matrix.hpp,sha256=1moUjxQ_uaS-GWrSbrbN4c8N3pDma9UpSaFqrNUXV80,16526
171
172
  netgen/include/specialelement.hpp,sha256=iiQaIE-cHbwGX014jET8k-rfb8k1GT6Gs_vsMIBWaOA,3226
172
- netgen/include/statushandler.hpp,sha256=Lh0Cevr7xnEoFW4QhTlNzEq9brpneGGmjAbv9o1kotY,646
173
+ netgen/include/statushandler.hpp,sha256=DTwByT_TMdV6jC3JMxw-_kxd9xtUtkKrcEF8ysI53CQ,671
173
174
  netgen/include/stringops.hpp,sha256=QiiQAFqB87FhxuMO_sigJU7L6FHfE3ebBy-cngouf_U,262
174
175
  netgen/include/superluinverse.hpp,sha256=FDSnHdTbVFDsFPF6B56IZJPDQKZx4fp2OubRQjE5_TU,3165
175
176
  netgen/include/symbolicintegrator.hpp,sha256=6LYXezRPon5_7RUSwT9tcqMZXI7ee72XTZ7G08MZ5sw,36047
@@ -201,7 +202,7 @@ ngsolve/__expr.py,sha256=ZJFhvQ6S14AAwm3dVyEy-ixMwPw_ZOhMnOqyfXNVKnw,4215
201
202
  ngsolve/__init__.py,sha256=jiKgjpR98P6_MojCVJKnSRGkr1gbZ0fY3tdLCnoPLec,5472
202
203
  ngsolve/_scikit_build_core_dependencies.py,sha256=3a7XNqFjWNfA4ADwcNA7NhatXcHY2aHf1RuGtaFmmks,735
203
204
  ngsolve/bvp.py,sha256=oRcYhe17uOl3G2zTwf4CYsMDUTcFs0wb4AYu_cKADtk,1987
204
- ngsolve/directsolvers.py,sha256=ilZmA6_fQulvPZmstKfuyCFI8cj9neEleqKUHxqFpQw,995
205
+ ngsolve/directsolvers.py,sha256=Jyx3-M8VVspuKcNkdB_-sdBx8B5BmnbtqshLTI9wnns,512
205
206
  ngsolve/eigenvalues.py,sha256=sQ8cgtK2wRoSVU2OrR3NdJWf1OmLS-KbDnm5K9Av74s,9309
206
207
  ngsolve/internal.py,sha256=bXUxNpvi4zaskEt9QJ_IEiv_Hn43kg5JVv1wmMUYBfE,5113
207
208
  ngsolve/krylovspace.py,sha256=wBSsE4-lmBnJsiNU1BYBKjfYgFAcqR1Ioe84DMwIjIM,31863
@@ -212,17 +213,16 @@ ngsolve/ngslib.so,sha256=auETkwX7txU3crPbwl46mD-8UQy2EL38jwUrgpRf-XM,374584
212
213
  ngsolve/nonlinearsolvers.py,sha256=8Q_CrD9vjdpZRV9sj2Fth7Y_kJJl7djPgarQmTK7Xfw,8216
213
214
  ngsolve/preconditioners.py,sha256=DLRUd9wQwxXUWL1wEBAbHQbWNp71qZYOFvH5Krfa834,239
214
215
  ngsolve/solve_implementation.py,sha256=-yyggHGmivv_hhSfRpShFqfWw2SOECpR3BMvccidvE4,5540
215
- ngsolve/solvers.py,sha256=WgZ9X1x9mtQegXDu8VcTjP-wbS2EnrUS96Y8LXqeflw,304
216
216
  ngsolve/timestepping.py,sha256=SLbsgE5pY5tXYTLGlVypk4kS2Ui8GxOwWmKVxqneZRU,8350
217
217
  ngsolve/timing.py,sha256=Xqkq2byJjNNK9vJjHG2O3cMf6xuKIyySjk8yv6Le2T8,3985
218
218
  ngsolve/utils.py,sha256=V2yVF4K3uv1007-DEs_GrzJ3BOOh09c4lDGGR1Xw-PU,4557
219
219
  ngsolve/webgui.py,sha256=EUhaOtWHZy80aLXhXbHwbCQVNjRSw-BAAE50cz7Ydaw,24313
220
- ngsolve/cmake/NGSolveConfig.cmake,sha256=5jX09OAL8giHXyuHyepzX-JkwwLixsZrwvZ0epOzkOk,5066
220
+ ngsolve/cmake/NGSolveConfig.cmake,sha256=CgCWrANLUqJzrJxannf0I0qC8Dla4-Vhf2LgMxuT4Rw,5066
221
221
  ngsolve/cmake/ngsolve-targets-release.cmake,sha256=2dUHzaaMQX08eT7Tjti0crzp_Ah3oqW86gp5UgSufmw,3426
222
- ngsolve/cmake/ngsolve-targets.cmake,sha256=1cQTFW-4aJfY356XRcuslSbFClmwPOSS03bj3WL15iM,5637
222
+ ngsolve/cmake/ngsolve-targets.cmake,sha256=M4iqepKAN5cMIPI7M3pavgHAx75siSAWiI4rPCnyrOo,5850
223
223
  ngsolve/config/__init__.py,sha256=A00lpnUKg-q3y_b-cN3jKF9urkGTGjb2Yz_gGc9WCLs,22
224
224
  ngsolve/config/__main__.py,sha256=m8k2RrXnXR5oYaUna1dwkKNhOZBiM7EyFSE9kIcZKvo,89
225
- ngsolve/config/config.py,sha256=aB4NtX8xhae2nemSbX_5MlWFCwB_E6cq5JXQfEt4uu0,2467
225
+ ngsolve/config/config.py,sha256=eUWcgkmytLQiYeIMk-mii7IUhcswpg4oW4NurX4tX34,2467
226
226
  ngsolve/demos/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
227
227
  ngsolve/demos/TensorProduct/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
228
228
  ngsolve/demos/TensorProduct/tp_dg_1d_1d.py,sha256=CrJCkbJNinVYUL3DO-4DnCAMGSAhegNc0QVWiJTk3Js,2109
@@ -254,41 +254,43 @@ ngsolve/demos/mpi/mpi_cmagnet.py,sha256=HuN4lttA2q2kNWss6LZNUKraHqskRQNVEBRjkrU2
254
254
  ngsolve/demos/mpi/mpi_navierstokes.py,sha256=Sct0G6EziYVfeIeSa7_b6r3WiYXcxZekoOGsZQALx-c,2911
255
255
  ngsolve/demos/mpi/mpi_poisson.py,sha256=UvXODjpWtqIgqq7lvMJf3ZEoJZLY1Dck-82R7auiW6I,2468
256
256
  ngsolve/demos/mpi/mpi_timeDG.py,sha256=TPJZ-DwmzOpuAol-fFKeU-R2rJ74MbjOm3DDkQI9BcY,1881
257
- ngsolve-6.2.2506.post74.dev0.data/data/Netgen.icns,sha256=Ebqct4LKxLzxdJLwGg0tTUQb1VjLwkKhtmdYhpRhKjg,291475
258
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngscxx,sha256=HFcVHkblKlDxFT-obJQYZU1pGqopDwzoO9kU6MMGS5w,1755
259
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngsld,sha256=50UErkFWLTocn8GtZDTkUWmPTIqsoK5lcfBGwyP0Vnc,557
260
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngsolve.tcl,sha256=SSBYLyp4zgl6eM17LXIiLoj1Doy-h2s4EZg6oKi6ucA,20995
261
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngspy,sha256=KglThT4AqnzC-4q3Q_UdoOrCEvgISINlJFEChpY8GF8,106
262
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/beam.geo,sha256=EtxklGAIo6SxZlHHC_FZHoQGZqZUDGJQSheEMFO-bJ8,387
263
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/beam.vol,sha256=aotG4VA7sIgAsPQsYkzbMP1Jta_TddG2gMCblkSPkqc,13594
264
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/chip.in2d,sha256=g6C-mcoD8-q9JtZpuh4mf4iFEZUIGvvivp4C5YYMlAw,551
265
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/chip.vol,sha256=if0yLn8E3P4mZ_X5sBcrEIp2C4ZhMysGROtB1YCkJHI,27897
266
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coil.geo,sha256=PVD4I9ztZowKwNOUrjnoOP7Tj2KG9J0UCJFRS9EhlxU,364
267
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coil.vol,sha256=IOZe4oPxMUa9vBGJWN4LG9M79XAruY23S2rtAh_2_98,144724
268
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coilshield.geo,sha256=lCUDCAhfowBttSGEY_giyY0xEFInAbgVfIPwSWBb504,605
269
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coilshield.vol,sha256=2Dq5VCX7dqGxo_ExtUhI716I-SnxhLGPawW29IR9nYY,162397
270
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/cube.geo,sha256=kbBNVUYVSf1ogV7-Xf31KXju3LCUIPaDLfvwZHMgddI,386
271
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/cube.vol,sha256=54108a3RvrTUOJSFltxUY8iiNzyWoBTtNrWM0kufj7c,90295
272
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d10_DGdoubleglazing.pde,sha256=bPQAvbYlyvCfLzk9cOzjXDn94UFC_vBCONl7fEIaMVs,1304
273
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d11_chip_nitsche.pde,sha256=Mq3Ap63mWqjQyXsASFAlkRQ0AWxBlY3BYYejTYd-lwg,1101
274
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d1_square.pde,sha256=ysOroxhoAOePmB_Aswps9iGjA2qV5435iu3hOnSvN8M,1029
275
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d2_chip.pde,sha256=AowiGbuAWEdyFUB3d1LlZeQ7rarbkqIYsj1QcWc89-A,950
276
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d3_helmholtz.pde,sha256=nG0HxrxboI2qGoR5_LNZt7RYB7ji2o5jtkyIqTFR4y8,568
277
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d4_cube.pde,sha256=-C4RgoVtBXZu7XHCwZy7F7pr_PGNGcRwWCFzBppq1mQ,1033
278
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d5_beam.pde,sha256=QOYC7YN7LdcjSFeLdJu1Tlfi-lmsVsa7b9G6qoCsGo8,1985
279
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d6_shaft.pde,sha256=Iua3INfuIUeaBk21qNg4u5KZt__H1B8BZUsy5frjhdY,1901
280
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d7_coil.pde,sha256=-ELH2obynMJcvSOqoYT1OThXcllIcdss0ZrklLSimZw,1200
281
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d8_coilshield.pde,sha256=WUUulvd3dsedB25sFVQgU7FgZ3B7BkbxgkXTEBglk1w,1141
282
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d9_hybridDG.pde,sha256=drLxnz1GvCEeme-FV772cGbS-YTgeUB4G5DrbkLdapw,1479
283
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/doubleglazing.in2d,sha256=bKn7m7eCcoLimGgoO3nxhiu7Mm0lIRnbx0TJh5dC1I0,506
284
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/doubleglazing.vol,sha256=Eg-H6nl2Hd5Nr593SFCCLVTDl25kIXuddrWpd7xlrP8,34987
285
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/piezo2d40round4.vol.gz,sha256=RuxM0vtYljoAImOH6U6avt0LmWaUbGNao37n8p_Yd1w,496477
286
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/shaft.geo,sha256=aPbk4EItJSLN_PjpOejnijk74y53QBW-IPCXHvLNlVs,2434
287
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/shaft.vol,sha256=fT8qu1L-p0MkI-l3WVisKG52W5FCzO_NzXaCvMJT1V4,270450
288
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/square.in2d,sha256=evpVgNNzReABv6bIs4J_r1OFeedMppoS-TEzE-tfKgY,192
289
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/square.vol,sha256=IXIHYmq85hkFsMVZ_vEVthUnd0YTQWE4jRegjW8_ImI,9162
290
- ngsolve-6.2.2506.post74.dev0.dist-info/LICENSE,sha256=oZDcnIBDdV2Q-LCnX6ZrnkLUr0yYC_XdxjPwEk2zzuc,26430
291
- ngsolve-6.2.2506.post74.dev0.dist-info/METADATA,sha256=Dxvl74ZFmF-sgrJnaGnFwbcuHBuxkXisg39WlexGWqY,248
292
- ngsolve-6.2.2506.post74.dev0.dist-info/WHEEL,sha256=vYGgz4rYivjGPkIS_2Kj6g97rQxH536HeP_jo4e1Oq8,110
293
- ngsolve-6.2.2506.post74.dev0.dist-info/top_level.txt,sha256=1llU44DxNIP85uPT4RChsIuV3h2d0_5j0Ui_Df5vV8E,15
294
- ngsolve-6.2.2506.post74.dev0.dist-info/RECORD,,
257
+ ngsolve/solvers/__init__.py,sha256=WgZ9X1x9mtQegXDu8VcTjP-wbS2EnrUS96Y8LXqeflw,304
258
+ ngsolve/solvers/cudss.py,sha256=7JbJKFKWafB4gJevID88lzNLaJw-kBUwEPJ68tuTT_g,2663
259
+ ngsolve-6.2.2506.post91.dev0.data/data/Netgen.icns,sha256=Ebqct4LKxLzxdJLwGg0tTUQb1VjLwkKhtmdYhpRhKjg,291475
260
+ ngsolve-6.2.2506.post91.dev0.data/data/bin/ngscxx,sha256=HFcVHkblKlDxFT-obJQYZU1pGqopDwzoO9kU6MMGS5w,1755
261
+ ngsolve-6.2.2506.post91.dev0.data/data/bin/ngsld,sha256=50UErkFWLTocn8GtZDTkUWmPTIqsoK5lcfBGwyP0Vnc,557
262
+ ngsolve-6.2.2506.post91.dev0.data/data/bin/ngsolve.tcl,sha256=SSBYLyp4zgl6eM17LXIiLoj1Doy-h2s4EZg6oKi6ucA,20995
263
+ ngsolve-6.2.2506.post91.dev0.data/data/bin/ngspy,sha256=KglThT4AqnzC-4q3Q_UdoOrCEvgISINlJFEChpY8GF8,106
264
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/beam.geo,sha256=EtxklGAIo6SxZlHHC_FZHoQGZqZUDGJQSheEMFO-bJ8,387
265
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/beam.vol,sha256=aotG4VA7sIgAsPQsYkzbMP1Jta_TddG2gMCblkSPkqc,13594
266
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/chip.in2d,sha256=g6C-mcoD8-q9JtZpuh4mf4iFEZUIGvvivp4C5YYMlAw,551
267
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/chip.vol,sha256=if0yLn8E3P4mZ_X5sBcrEIp2C4ZhMysGROtB1YCkJHI,27897
268
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/coil.geo,sha256=PVD4I9ztZowKwNOUrjnoOP7Tj2KG9J0UCJFRS9EhlxU,364
269
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/coil.vol,sha256=IOZe4oPxMUa9vBGJWN4LG9M79XAruY23S2rtAh_2_98,144724
270
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/coilshield.geo,sha256=lCUDCAhfowBttSGEY_giyY0xEFInAbgVfIPwSWBb504,605
271
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/coilshield.vol,sha256=2Dq5VCX7dqGxo_ExtUhI716I-SnxhLGPawW29IR9nYY,162397
272
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/cube.geo,sha256=kbBNVUYVSf1ogV7-Xf31KXju3LCUIPaDLfvwZHMgddI,386
273
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/cube.vol,sha256=54108a3RvrTUOJSFltxUY8iiNzyWoBTtNrWM0kufj7c,90295
274
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d10_DGdoubleglazing.pde,sha256=bPQAvbYlyvCfLzk9cOzjXDn94UFC_vBCONl7fEIaMVs,1304
275
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d11_chip_nitsche.pde,sha256=Mq3Ap63mWqjQyXsASFAlkRQ0AWxBlY3BYYejTYd-lwg,1101
276
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d1_square.pde,sha256=ysOroxhoAOePmB_Aswps9iGjA2qV5435iu3hOnSvN8M,1029
277
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d2_chip.pde,sha256=AowiGbuAWEdyFUB3d1LlZeQ7rarbkqIYsj1QcWc89-A,950
278
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d3_helmholtz.pde,sha256=nG0HxrxboI2qGoR5_LNZt7RYB7ji2o5jtkyIqTFR4y8,568
279
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d4_cube.pde,sha256=-C4RgoVtBXZu7XHCwZy7F7pr_PGNGcRwWCFzBppq1mQ,1033
280
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d5_beam.pde,sha256=QOYC7YN7LdcjSFeLdJu1Tlfi-lmsVsa7b9G6qoCsGo8,1985
281
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d6_shaft.pde,sha256=Iua3INfuIUeaBk21qNg4u5KZt__H1B8BZUsy5frjhdY,1901
282
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d7_coil.pde,sha256=-ELH2obynMJcvSOqoYT1OThXcllIcdss0ZrklLSimZw,1200
283
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d8_coilshield.pde,sha256=WUUulvd3dsedB25sFVQgU7FgZ3B7BkbxgkXTEBglk1w,1141
284
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/d9_hybridDG.pde,sha256=drLxnz1GvCEeme-FV772cGbS-YTgeUB4G5DrbkLdapw,1479
285
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/doubleglazing.in2d,sha256=bKn7m7eCcoLimGgoO3nxhiu7Mm0lIRnbx0TJh5dC1I0,506
286
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/doubleglazing.vol,sha256=Eg-H6nl2Hd5Nr593SFCCLVTDl25kIXuddrWpd7xlrP8,34987
287
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/piezo2d40round4.vol.gz,sha256=RuxM0vtYljoAImOH6U6avt0LmWaUbGNao37n8p_Yd1w,496477
288
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/shaft.geo,sha256=aPbk4EItJSLN_PjpOejnijk74y53QBW-IPCXHvLNlVs,2434
289
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/shaft.vol,sha256=fT8qu1L-p0MkI-l3WVisKG52W5FCzO_NzXaCvMJT1V4,270450
290
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/square.in2d,sha256=evpVgNNzReABv6bIs4J_r1OFeedMppoS-TEzE-tfKgY,192
291
+ ngsolve-6.2.2506.post91.dev0.data/data/share/ngsolve/square.vol,sha256=IXIHYmq85hkFsMVZ_vEVthUnd0YTQWE4jRegjW8_ImI,9162
292
+ ngsolve-6.2.2506.post91.dev0.dist-info/LICENSE,sha256=oZDcnIBDdV2Q-LCnX6ZrnkLUr0yYC_XdxjPwEk2zzuc,26430
293
+ ngsolve-6.2.2506.post91.dev0.dist-info/METADATA,sha256=-ULXaFCM01Wy1_YxSJv_WYXo8vkoBG1BKooGoVl_JhU,248
294
+ ngsolve-6.2.2506.post91.dev0.dist-info/WHEEL,sha256=vYGgz4rYivjGPkIS_2Kj6g97rQxH536HeP_jo4e1Oq8,110
295
+ ngsolve-6.2.2506.post91.dev0.dist-info/top_level.txt,sha256=1llU44DxNIP85uPT4RChsIuV3h2d0_5j0Ui_Df5vV8E,15
296
+ ngsolve-6.2.2506.post91.dev0.dist-info/RECORD,,
File without changes