ddfem 1.0.10__py3-none-any.whl → 1.0.11__py3-none-any.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.
Files changed (112) hide show
  1. ddfem/__init__.py +9 -5
  2. ddfem/__main__.py +11 -12
  3. ddfem/boundary.py +2 -2
  4. ddfem/data/2.11.dev20250709/extra.modules +14 -0
  5. ddfem/data/2.11.dev20250709/femscheme_0bb54cd4f1cd1df2477f5f59393c6a2e.cc +43 -0
  6. ddfem/data/2.11.dev20250709/femscheme_5c9e2700386c07226eb4db155fa5ef14.cc +43 -0
  7. ddfem/data/2.11.dev20250709/femscheme_765ef00d995a939c34bdc0d0cc4847ca.cc +43 -0
  8. ddfem/data/2.11.dev20250709/femspace_11b3436cb033df683615c50d5d4239bd_f14dd0b3b474c0cd816334330f55ad72.cc +45 -0
  9. ddfem/data/2.11.dev20250709/femspace_f4f043307753c8e74af23c94c28a3b0d_438586e783f51d84a82e82b0d8daceea.cc +45 -0
  10. ddfem/data/2.11.dev20250709/{integrands_3bde0abfafcf45a3cff4d1029568ab5cv1_3_a524c1196983e65de1c06d7d6afdeb44.cc → integrands_0003e4cbb961fd653fe295d2c4fa50a7v1_3_a524c1196983e65de1c06d7d6afdeb44.cc} +367 -14
  11. ddfem/data/2.11.dev20250709/{integrands_2e6d4e3b5cff269867d26022ac7cee09v1_3_a524c1196983e65de1c06d7d6afdeb44.cc → integrands_0fa4a1c37449cf574971977e10cf682av1_3_a524c1196983e65de1c06d7d6afdeb44.cc} +8 -8
  12. ddfem/data/2.11.dev20250709/{integrands_96ea175da69be26acf1a8d94dc0b3c93v1_3_a524c1196983e65de1c06d7d6afdeb44.cc → integrands_29b696aa653181a57d036f771efa8be9v1_3_a524c1196983e65de1c06d7d6afdeb44.cc} +8 -8
  13. ddfem/data/2.11.dev20250709/integrands_536f9ba0ea4ecd1f7d4e2bc43ef29d08v1_3_a524c1196983e65de1c06d7d6afdeb44.cc +453 -0
  14. ddfem/data/2.11.dev20250709/{integrands_008eefa148b772fa3192dd3c1728c140v1_3_a524c1196983e65de1c06d7d6afdeb44.cc → integrands_5907ab5c70328c21dd308abf09e529aev1_3_a524c1196983e65de1c06d7d6afdeb44.cc} +8 -8
  15. ddfem/data/2.11.dev20250709/{integrands_59ef814e4fbd86ef9c0aeac61e84e9a7v1_3_a524c1196983e65de1c06d7d6afdeb44.cc → integrands_68eba4e963a61031a52da3365f515585v1_3_a524c1196983e65de1c06d7d6afdeb44.cc} +8 -8
  16. ddfem/data/2.11.dev20250709/integrands_83927be37e79b291517b827b9ddc1983v1_3_a524c1196983e65de1c06d7d6afdeb44.cc +533 -0
  17. ddfem/data/2.11.dev20250709/integrands_8ed2f23c088e3a3d82a3259b663796c7v1_3_a524c1196983e65de1c06d7d6afdeb44.cc +533 -0
  18. ddfem/data/2.11.dev20250709/integrands_af3bbe7d629df162ef8c570e1503bf62v1_3_a524c1196983e65de1c06d7d6afdeb44.cc +762 -0
  19. ddfem/data/2.11.dev20250709/{integrands_00ee9b3b89e4e44212e5b7ad7948a24ev1_3_a524c1196983e65de1c06d7d6afdeb44.cc → integrands_d0634430f14d3432dae186e57ec5aecav1_3_a524c1196983e65de1c06d7d6afdeb44.cc} +8 -8
  20. ddfem/data/2.11.dev20250709/intro.modules +33 -102
  21. ddfem/data/2.11.dev20250709/localfunction_10f9d7a54f79c12d6ca923b9ee56b80d_a524c1196983e65de1c06d7d6afdeb44.cc +324 -0
  22. ddfem/data/2.11.dev20250709/localfunction_10f9d7a54f79c12d6ca923b9ee56b80d_af122c1df944c95cd395ec0f91d0f970.cc +322 -0
  23. ddfem/data/2.11.dev20250709/localfunction_1c20e613977d8cea4cf5227c12aa68a6_a524c1196983e65de1c06d7d6afdeb44.cc +164 -0
  24. ddfem/data/2.11.dev20250709/{localfunction_191355e6250b2d2e260d96f519ad9976_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_217e4bf8b368a7768c4897cf58f71d84_a524c1196983e65de1c06d7d6afdeb44.cc} +14 -14
  25. ddfem/data/2.11.dev20250709/localfunction_22e797a8f3e8c322f33c41e07bd15165_a524c1196983e65de1c06d7d6afdeb44.cc +1445 -0
  26. ddfem/data/2.11.dev20250709/localfunction_2e2afc8df6107683d574a8d96d5249f4_af122c1df944c95cd395ec0f91d0f970.cc +512 -0
  27. ddfem/data/2.11.dev20250709/localfunction_32613626342183eafa360dc1f0f18924_a524c1196983e65de1c06d7d6afdeb44.cc +1425 -0
  28. ddfem/data/2.11.dev20250709/localfunction_37174cfc9d6bf565336cac0d2ea785f5_a524c1196983e65de1c06d7d6afdeb44.cc +786 -0
  29. ddfem/data/2.11.dev20250709/{localfunction_d75993d7ae5919d23117b153e900840d_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_3d957c5b2628e5120636b8e3f461bc0d_a524c1196983e65de1c06d7d6afdeb44.cc} +64 -29
  30. ddfem/data/2.11.dev20250709/localfunction_3ecaa105be9e3abddf3a85d8adc5d36f_a524c1196983e65de1c06d7d6afdeb44.cc +697 -0
  31. ddfem/data/2.11.dev20250709/{localfunction_f626cd43dc8558135fe0b32cde016644_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_3ecaf7de7505b53bb0b5fb6d78549387_a524c1196983e65de1c06d7d6afdeb44.cc} +14 -14
  32. ddfem/data/2.11.dev20250709/{localfunction_1d27a90a52b9053192c9cc902283f79b_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_4192604521151252f1c8fa56a1f9f226_a524c1196983e65de1c06d7d6afdeb44.cc} +14 -14
  33. ddfem/data/2.11.dev20250709/localfunction_4976bbef3267846b59f3a26497ffe9db_a524c1196983e65de1c06d7d6afdeb44.cc +474 -0
  34. ddfem/data/2.11.dev20250709/{localfunction_a8c726f728cd35d137188b33301aeef1_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_4adfaf8a08fac23151af0b1e790db1f7_a524c1196983e65de1c06d7d6afdeb44.cc} +14 -14
  35. ddfem/data/2.11.dev20250709/{localfunction_00f2e5593eeb23f01906255d67244f6e_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_4f6a526abfe63959f81b09a5796c5eb1_a524c1196983e65de1c06d7d6afdeb44.cc} +44 -29
  36. ddfem/data/2.11.dev20250709/localfunction_5591a2c803b9658084d8f11d44bf3ae1_a524c1196983e65de1c06d7d6afdeb44.cc +485 -0
  37. ddfem/data/2.11.dev20250709/localfunction_6363af791dde11d699a9a3d876cc5d9a_a524c1196983e65de1c06d7d6afdeb44.cc +549 -0
  38. ddfem/data/2.11.dev20250709/localfunction_6363af791dde11d699a9a3d876cc5d9a_af122c1df944c95cd395ec0f91d0f970.cc +547 -0
  39. ddfem/data/2.11.dev20250709/localfunction_6eccfc8fd91ce34d81e7c3962ece5d94_a524c1196983e65de1c06d7d6afdeb44.cc +766 -0
  40. ddfem/data/2.11.dev20250709/localfunction_762aa49bc5a47ad3d8d8bbde36b42ee5_a524c1196983e65de1c06d7d6afdeb44.cc +723 -0
  41. ddfem/data/2.11.dev20250709/localfunction_76e8db0f046ac9e37a793e0bb13eea7b_a524c1196983e65de1c06d7d6afdeb44.cc +292 -0
  42. ddfem/data/2.11.dev20250709/localfunction_7792f4273b0fd848c5a0fc9d6f12683e_a524c1196983e65de1c06d7d6afdeb44.cc +280 -0
  43. ddfem/data/2.11.dev20250709/localfunction_7f7ef99c50708814ba5a82b0956b0aed_a524c1196983e65de1c06d7d6afdeb44.cc +461 -0
  44. ddfem/data/2.11.dev20250709/localfunction_898de4ae138e0ed305ef1399c66aa10a_a524c1196983e65de1c06d7d6afdeb44.cc +313 -0
  45. ddfem/data/2.11.dev20250709/{localfunction_1d13146d4bff10e178aba773fe2a9f1d_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_a99a0c7f35b06ac5a1fa7f081b5e64f9_a524c1196983e65de1c06d7d6afdeb44.cc} +14 -14
  46. ddfem/data/2.11.dev20250709/{localfunction_82d7cb9338bf118426fac2abf41a91a4_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_cda923259a47bb19861404a9fdb64303_a524c1196983e65de1c06d7d6afdeb44.cc} +14 -14
  47. ddfem/data/2.11.dev20250709/localfunction_d3d9b8a21e3075c9ff40117c5244f28e_a524c1196983e65de1c06d7d6afdeb44.cc +381 -0
  48. ddfem/data/2.11.dev20250709/localfunction_d4b9ca85d48735ee01f395a42eaa0cee_af122c1df944c95cd395ec0f91d0f970.cc +774 -0
  49. ddfem/data/2.11.dev20250709/localfunction_dd1fb4bd60f2d8b3a062dbbdaedb9fee_a524c1196983e65de1c06d7d6afdeb44.cc +869 -0
  50. ddfem/data/2.11.dev20250709/localfunction_dd5ab085a9d94f578c1f3d337ea360a3_a524c1196983e65de1c06d7d6afdeb44.cc +161 -0
  51. ddfem/data/2.11.dev20250709/{localfunction_aeb3d963412cdc65630e0a4c3c0dde0f_a524c1196983e65de1c06d7d6afdeb44.cc → localfunction_e2b19c5987f9b6fb0cd5453bfa7f4f9f_a524c1196983e65de1c06d7d6afdeb44.cc} +14 -30
  52. ddfem/data/extra.modules +13 -0
  53. ddfem/examples/beam.py +43 -50
  54. ddfem/examples/chemical_reaction.py +1 -1
  55. ddfem/examples/five_circle_flat.py +42 -28
  56. ddfem/examples/linear_elasticity.py +5 -1
  57. ddfem/examples/triple_circle.py +86 -83
  58. ddfem/examples/triple_circle_beam.py +71 -61
  59. ddfem-1.0.11.dist-info/METADATA +78 -0
  60. ddfem-1.0.11.dist-info/RECORD +124 -0
  61. ddfem/data/2.11.dev20250709/boundary.modules +0 -9
  62. ddfem/data/2.11.dev20250709/femspace_90f0a9524a8cb701e8ee5027b7658a0e_0faf32f13b591f4f60f83c591507b9be.cc +0 -40
  63. ddfem/data/2.11.dev20250709/geometry.modules +0 -84
  64. ddfem/data/2.11.dev20250709/hierarchicalgrid_472c2c2d007bf5604887ab2f16b7eb13.cc +0 -30
  65. ddfem/data/2.11.dev20250709/hierarchicalgrid_966e2a5c8356c5b278ccd3acad180f0a.cc +0 -30
  66. ddfem/data/2.11.dev20250709/localfunction_10ad0a2d88c74db5f4bf5f81e138974f_a524c1196983e65de1c06d7d6afdeb44.cc +0 -135
  67. ddfem/data/2.11.dev20250709/localfunction_1460b632dc5919e94a2147108f4f34f4_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -468
  68. ddfem/data/2.11.dev20250709/localfunction_161bbe6dde741c6e3f90c2919b8d17a4_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -171
  69. ddfem/data/2.11.dev20250709/localfunction_268716e3e3ec528038367ee04d335ea1_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -289
  70. ddfem/data/2.11.dev20250709/localfunction_29566243d89228735978e58471af60be_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -246
  71. ddfem/data/2.11.dev20250709/localfunction_2a890b2a64788a92607670296c0d37ac_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -311
  72. ddfem/data/2.11.dev20250709/localfunction_2bbefabe87db948827d02bdb8d69a7d1_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -240
  73. ddfem/data/2.11.dev20250709/localfunction_34a46b87fa5c0a5a4f0bc44949f2eda9_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -239
  74. ddfem/data/2.11.dev20250709/localfunction_3c10414582133a0fa8e341c4544a97c7_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -220
  75. ddfem/data/2.11.dev20250709/localfunction_3dfb73430ddb90a26b6f50f85e52e2a4_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -216
  76. ddfem/data/2.11.dev20250709/localfunction_3e323e81c52891c0ecb656eac273e52f_a524c1196983e65de1c06d7d6afdeb44.cc +0 -135
  77. ddfem/data/2.11.dev20250709/localfunction_465e17370f4344b8997151adacf7aec6_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -403
  78. ddfem/data/2.11.dev20250709/localfunction_57e9651c5364ef528f41cf138e126115_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -272
  79. ddfem/data/2.11.dev20250709/localfunction_5c2a00bf7ec417475a0a378ed462beeb_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -350
  80. ddfem/data/2.11.dev20250709/localfunction_5d71e054c405bc6584738437908af804_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -364
  81. ddfem/data/2.11.dev20250709/localfunction_6343878b30d190cc70b631d882009dec_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -342
  82. ddfem/data/2.11.dev20250709/localfunction_639a3f3873411f43337e687cb070368f_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -230
  83. ddfem/data/2.11.dev20250709/localfunction_6661b21a0e1340a9a9f7b32da595f130_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -468
  84. ddfem/data/2.11.dev20250709/localfunction_75e876499fa3b7abc096aa08f88a1c2d_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -213
  85. ddfem/data/2.11.dev20250709/localfunction_8647b4efdf8a37595f73652bc1905df2_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -335
  86. ddfem/data/2.11.dev20250709/localfunction_86a0670f34bf2ac8155423a1c1bc2e75_a524c1196983e65de1c06d7d6afdeb44.cc +0 -135
  87. ddfem/data/2.11.dev20250709/localfunction_98b32c4b5bc0d8083f3d2c394aa33429_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -340
  88. ddfem/data/2.11.dev20250709/localfunction_9b741917efb5aa6a09e375272e4ae3aa_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -317
  89. ddfem/data/2.11.dev20250709/localfunction_a369aff055312b472a92ee7e257534ff_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -392
  90. ddfem/data/2.11.dev20250709/localfunction_a6cc88a79948487ce95a6c3f22487b36_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -395
  91. ddfem/data/2.11.dev20250709/localfunction_aa506761997f291dfd2e62b678f010b2_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -280
  92. ddfem/data/2.11.dev20250709/localfunction_b5edf0c36f0fc96cc6f5f3677c6557a1_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -214
  93. ddfem/data/2.11.dev20250709/localfunction_bdfb7ddf42a423f7d0791458634d4b8f_a524c1196983e65de1c06d7d6afdeb44.cc +0 -135
  94. ddfem/data/2.11.dev20250709/localfunction_c3d0902cf8bb4b86b62a2293de2b74e9_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -1131
  95. ddfem/data/2.11.dev20250709/localfunction_cf4a29dc25e72137baf2f8fb8b8d3c50_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -267
  96. ddfem/data/2.11.dev20250709/localfunction_d40efa41ac661ff77278d2ae4812b06d_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -377
  97. ddfem/data/2.11.dev20250709/localfunction_e69118a51208cfab8a028711e966e76c_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -236
  98. ddfem/data/2.11.dev20250709/localfunction_e9c8d4f4cedd30cab76a588b95bbccab_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -325
  99. ddfem/data/2.11.dev20250709/localfunction_f0d3fe89de368f7ea295a1982a807bd8_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -281
  100. ddfem/data/2.11.dev20250709/localfunction_f4b1d42cbb447375f39ed834570cd3f0_a524c1196983e65de1c06d7d6afdeb44.cc +0 -135
  101. ddfem/data/2.11.dev20250709/localfunction_fb15e1ad2c62e6660c67949fcf166d81_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -339
  102. ddfem/data/2.11.dev20250709/localfunction_fb17410b0b5d479dce9ffc6f9d61ab37_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -317
  103. ddfem/data/2.11.dev20250709/localfunction_fc22d5adaf3b9563160dc2aec55e8ba1_19659fe2f2f74bcfb5d532f1a0d38be9.cc +0 -113
  104. ddfem/data/2.11.dev20250709/referenceelements_fe266b8abf61f4601198949ea6b0dfd3.cc +0 -24
  105. ddfem/data/2.11.dev20250709/transformers.modules +0 -13
  106. ddfem/data/2.11.dev20250709/yaspcoordinates_dim2_ctdouble.cc +0 -55
  107. ddfem/data/2.11.dev20250709/yaspcoordinates_dim3_ctdouble.cc +0 -55
  108. ddfem-1.0.10.dist-info/METADATA +0 -101
  109. ddfem-1.0.10.dist-info/RECORD +0 -138
  110. {ddfem-1.0.10.dist-info → ddfem-1.0.11.dist-info}/WHEEL +0 -0
  111. {ddfem-1.0.10.dist-info → ddfem-1.0.11.dist-info}/licenses/LICENSE +0 -0
  112. {ddfem-1.0.10.dist-info → ddfem-1.0.11.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,322 @@
1
+ #ifndef GUARD_10f9d7a54f79c12d6ca923b9ee56b80d
2
+ #define GUARD_10f9d7a54f79c12d6ca923b9ee56b80d
3
+
4
+ #define USING_DUNE_PYTHON 1
5
+ #include <config.h>
6
+ #include <dune/alugrid/dgf.hh>
7
+ #include <dune/alugrid/grid.hh>
8
+ #include <dune/fem/gridpart/adaptiveleafgridpart.hh>
9
+ #include <dune/fempy/py/gridview.hh>
10
+ #include <dune/python/grid/gridview.hh>
11
+ #include <dune/python/grid/hierarchical.hh>
12
+ #include <dune/fem/function/localfunction/bindable.hh>
13
+ #include <dune/fem/common/intersectionside.hh>
14
+ #include <dune/python/pybind11/pybind11.h>
15
+ #include <dune/python/pybind11/extensions.h>
16
+ #include <dune/fempy/py/grid/gridpart.hh>
17
+ #include <dune/common/exceptions.hh>
18
+ #include <dune/fempy/py/ufllocalfunction.hh>
19
+
20
+ namespace UFLLocalFunctions_10f9d7a54f79c12d6ca923b9ee56b80d
21
+ {
22
+
23
+ // UFLLocalFunction
24
+ // ----------------
25
+
26
+ template< class GridPart >
27
+ struct UFLLocalFunction
28
+ : public Dune::Fem::BindableGridFunctionWithSpace<GridPart,Dune::Dim<1>>
29
+ {
30
+ typedef GridPart GridPartType;
31
+ typedef typename GridPartType::GridViewType GridView;
32
+ typedef typename GridView::ctype ctype;
33
+ typedef Dune::Fem::BindableGridFunctionWithSpace<GridPart,Dune::Dim<1>> BaseType;
34
+ typedef Dune::Fem::GridFunctionSpace<GridPartType,Dune::Dim<1>> FunctionSpaceType;
35
+ typedef typename GridPartType::template Codim< 0 >::EntityType EntityType;
36
+ typedef typename GridPartType::IntersectionType IntersectionType;
37
+ typedef typename EntityType::Geometry Geometry;
38
+ typedef typename Geometry::GlobalCoordinate GlobalCoordinateType;
39
+ typedef Dune::Fem::IntersectionSide Side;
40
+ typedef std::tuple<> ConstantTupleType;
41
+ typedef std::tuple<> CoefficientTupleType;
42
+ static constexpr bool gridPartValid = true;
43
+ template< std::size_t i >
44
+ using CoefficientType = std::tuple_element_t< i, CoefficientTupleType >;
45
+ template< std::size_t i >
46
+ using ConstantType = typename std::tuple_element_t< i, ConstantTupleType >::element_type;
47
+ using BaseType::entity;
48
+ using BaseType::geometry;
49
+
50
+ UFLLocalFunction ( const GridPartType &gridPart, const std::string &name, int order, const Dune::Fem::ParameterReader &parameter = Dune::Fem::Parameter::container() )
51
+ : BaseType(gridPart,name,order)
52
+ {}
53
+
54
+ void bind ( const IntersectionType &intersection, Side side )
55
+ {
56
+ BaseType::bind(intersection, side);
57
+ }
58
+
59
+ void bind ( const EntityType &entity )
60
+ {
61
+ BaseType::bind(entity);
62
+ }
63
+
64
+ void unbind ()
65
+ {
66
+ BaseType::unbind();
67
+ }
68
+
69
+ template< class Point >
70
+ void evaluate ( const Point &x, typename FunctionSpaceType::RangeType &result ) const
71
+ {
72
+ using std::max;
73
+ using std::min;
74
+ using std::sqrt;
75
+ GlobalCoordinateType tmp0 = geometry().global( Dune::Fem::coordinate( x ) );
76
+ const auto tmp1 = tmp0[ 1 ] * tmp0[ 1 ];
77
+ const auto tmp2 = tmp0[ 0 ] * tmp0[ 0 ];
78
+ const auto tmp3 = tmp2 + tmp1;
79
+ const auto tmp4 = 1e-10 + tmp3;
80
+ const auto tmp5 = std::sqrt( tmp4 );
81
+ const auto tmp6 = -0.4 + tmp5;
82
+ const auto tmp7 = 0.15 + tmp0[ 1 ];
83
+ const auto tmp8 = tmp7 * tmp7;
84
+ const auto tmp9 = 0.15 + tmp0[ 0 ];
85
+ const auto tmp10 = tmp9 * tmp9;
86
+ const auto tmp11 = tmp10 + tmp8;
87
+ const auto tmp12 = 1e-10 + tmp11;
88
+ const auto tmp13 = std::sqrt( tmp12 );
89
+ const auto tmp14 = -0.3 + tmp13;
90
+ const auto tmp15 = -0.15 + tmp0[ 1 ];
91
+ const auto tmp16 = tmp15 * tmp15;
92
+ const auto tmp17 = -0.15 + tmp0[ 0 ];
93
+ const auto tmp18 = tmp17 * tmp17;
94
+ const auto tmp19 = tmp18 + tmp16;
95
+ const auto tmp20 = 1e-10 + tmp19;
96
+ const auto tmp21 = std::sqrt( tmp20 );
97
+ const auto tmp22 = -0.3 + tmp21;
98
+ const auto tmp23 = std::min( tmp22, tmp14 );
99
+ const auto tmp24 = std::max( tmp23, tmp6 );
100
+ result[ 0 ] = tmp24;
101
+ }
102
+
103
+ template< class Point >
104
+ void jacobian ( const Point &x, typename FunctionSpaceType::JacobianRangeType &result ) const
105
+ {
106
+ using std::min;
107
+ using std::sqrt;
108
+ GlobalCoordinateType tmp0 = geometry().global( Dune::Fem::coordinate( x ) );
109
+ const auto tmp1 = tmp0[ 1 ] * tmp0[ 1 ];
110
+ const auto tmp2 = tmp0[ 0 ] * tmp0[ 0 ];
111
+ const auto tmp3 = tmp2 + tmp1;
112
+ const auto tmp4 = 1e-10 + tmp3;
113
+ const auto tmp5 = std::sqrt( tmp4 );
114
+ const auto tmp6 = -0.4 + tmp5;
115
+ const auto tmp7 = 0.15 + tmp0[ 1 ];
116
+ const auto tmp8 = tmp7 * tmp7;
117
+ const auto tmp9 = 0.15 + tmp0[ 0 ];
118
+ const auto tmp10 = tmp9 * tmp9;
119
+ const auto tmp11 = tmp10 + tmp8;
120
+ const auto tmp12 = 1e-10 + tmp11;
121
+ const auto tmp13 = std::sqrt( tmp12 );
122
+ const auto tmp14 = -0.3 + tmp13;
123
+ const auto tmp15 = -0.15 + tmp0[ 1 ];
124
+ const auto tmp16 = tmp15 * tmp15;
125
+ const auto tmp17 = -0.15 + tmp0[ 0 ];
126
+ const auto tmp18 = tmp17 * tmp17;
127
+ const auto tmp19 = tmp18 + tmp16;
128
+ const auto tmp20 = 1e-10 + tmp19;
129
+ const auto tmp21 = std::sqrt( tmp20 );
130
+ const auto tmp22 = -0.3 + tmp21;
131
+ const auto tmp23 = std::min( tmp22, tmp14 );
132
+ const auto tmp24 = 2 * tmp21;
133
+ const auto tmp25 = tmp17 + tmp17;
134
+ const auto tmp26 = tmp25 / tmp24;
135
+ const auto tmp27 = tmp26 * (tmp22 < tmp14 ? 1 : 0.0);
136
+ const auto tmp28 = 2 * tmp13;
137
+ const auto tmp29 = tmp9 + tmp9;
138
+ const auto tmp30 = tmp29 / tmp28;
139
+ const auto tmp31 = -1 * (tmp22 < tmp14 ? 1 : 0.0);
140
+ const auto tmp32 = 1.0 + tmp31;
141
+ const auto tmp33 = tmp32 * tmp30;
142
+ const auto tmp34 = tmp33 + tmp27;
143
+ const auto tmp35 = tmp34 * (tmp23 > tmp6 ? 1 : 0.0);
144
+ const auto tmp36 = 2 * tmp5;
145
+ const auto tmp37 = tmp0[ 0 ] + tmp0[ 0 ];
146
+ const auto tmp38 = tmp37 / tmp36;
147
+ const auto tmp39 = -1 * (tmp23 > tmp6 ? 1 : 0.0);
148
+ const auto tmp40 = 1.0 + tmp39;
149
+ const auto tmp41 = tmp40 * tmp38;
150
+ const auto tmp42 = tmp41 + tmp35;
151
+ const auto tmp43 = tmp15 + tmp15;
152
+ const auto tmp44 = tmp43 / tmp24;
153
+ const auto tmp45 = tmp44 * (tmp22 < tmp14 ? 1 : 0.0);
154
+ const auto tmp46 = tmp7 + tmp7;
155
+ const auto tmp47 = tmp46 / tmp28;
156
+ const auto tmp48 = tmp32 * tmp47;
157
+ const auto tmp49 = tmp48 + tmp45;
158
+ const auto tmp50 = tmp49 * (tmp23 > tmp6 ? 1 : 0.0);
159
+ const auto tmp51 = tmp0[ 1 ] + tmp0[ 1 ];
160
+ const auto tmp52 = tmp51 / tmp36;
161
+ const auto tmp53 = tmp40 * tmp52;
162
+ const auto tmp54 = tmp53 + tmp50;
163
+ (result[ 0 ])[ 0 ] = tmp42;
164
+ (result[ 0 ])[ 1 ] = tmp54;
165
+ }
166
+
167
+ template< class Point >
168
+ void hessian ( const Point &x, typename FunctionSpaceType::HessianRangeType &result ) const
169
+ {
170
+ using std::min;
171
+ using std::sqrt;
172
+ GlobalCoordinateType tmp0 = geometry().global( Dune::Fem::coordinate( x ) );
173
+ const auto tmp1 = tmp0[ 1 ] * tmp0[ 1 ];
174
+ const auto tmp2 = tmp0[ 0 ] * tmp0[ 0 ];
175
+ const auto tmp3 = tmp2 + tmp1;
176
+ const auto tmp4 = 1e-10 + tmp3;
177
+ const auto tmp5 = std::sqrt( tmp4 );
178
+ const auto tmp6 = -0.4 + tmp5;
179
+ const auto tmp7 = 0.15 + tmp0[ 1 ];
180
+ const auto tmp8 = tmp7 * tmp7;
181
+ const auto tmp9 = 0.15 + tmp0[ 0 ];
182
+ const auto tmp10 = tmp9 * tmp9;
183
+ const auto tmp11 = tmp10 + tmp8;
184
+ const auto tmp12 = 1e-10 + tmp11;
185
+ const auto tmp13 = std::sqrt( tmp12 );
186
+ const auto tmp14 = -0.3 + tmp13;
187
+ const auto tmp15 = -0.15 + tmp0[ 1 ];
188
+ const auto tmp16 = tmp15 * tmp15;
189
+ const auto tmp17 = -0.15 + tmp0[ 0 ];
190
+ const auto tmp18 = tmp17 * tmp17;
191
+ const auto tmp19 = tmp18 + tmp16;
192
+ const auto tmp20 = 1e-10 + tmp19;
193
+ const auto tmp21 = std::sqrt( tmp20 );
194
+ const auto tmp22 = -0.3 + tmp21;
195
+ const auto tmp23 = std::min( tmp22, tmp14 );
196
+ const auto tmp24 = 2 * tmp21;
197
+ const auto tmp25 = tmp17 + tmp17;
198
+ const auto tmp26 = tmp25 / tmp24;
199
+ const auto tmp27 = 2 * tmp26;
200
+ const auto tmp28 = tmp27 * tmp26;
201
+ const auto tmp29 = -1 * tmp28;
202
+ const auto tmp30 = 2 + tmp29;
203
+ const auto tmp31 = tmp30 / tmp24;
204
+ const auto tmp32 = tmp31 * (tmp22 < tmp14 ? 1 : 0.0);
205
+ const auto tmp33 = 2 * tmp13;
206
+ const auto tmp34 = tmp9 + tmp9;
207
+ const auto tmp35 = tmp34 / tmp33;
208
+ const auto tmp36 = 2 * tmp35;
209
+ const auto tmp37 = tmp36 * tmp35;
210
+ const auto tmp38 = -1 * tmp37;
211
+ const auto tmp39 = 2 + tmp38;
212
+ const auto tmp40 = tmp39 / tmp33;
213
+ const auto tmp41 = -1 * (tmp22 < tmp14 ? 1 : 0.0);
214
+ const auto tmp42 = 1.0 + tmp41;
215
+ const auto tmp43 = tmp42 * tmp40;
216
+ const auto tmp44 = tmp43 + tmp32;
217
+ const auto tmp45 = tmp44 * (tmp23 > tmp6 ? 1 : 0.0);
218
+ const auto tmp46 = 2 * tmp5;
219
+ const auto tmp47 = tmp0[ 0 ] + tmp0[ 0 ];
220
+ const auto tmp48 = tmp47 / tmp46;
221
+ const auto tmp49 = 2 * tmp48;
222
+ const auto tmp50 = tmp49 * tmp48;
223
+ const auto tmp51 = -1 * tmp50;
224
+ const auto tmp52 = 2 + tmp51;
225
+ const auto tmp53 = tmp52 / tmp46;
226
+ const auto tmp54 = -1 * (tmp23 > tmp6 ? 1 : 0.0);
227
+ const auto tmp55 = 1.0 + tmp54;
228
+ const auto tmp56 = tmp55 * tmp53;
229
+ const auto tmp57 = tmp56 + tmp45;
230
+ const auto tmp58 = tmp15 + tmp15;
231
+ const auto tmp59 = tmp58 / tmp24;
232
+ const auto tmp60 = 2 * tmp59;
233
+ const auto tmp61 = tmp60 * tmp26;
234
+ const auto tmp62 = -1 * tmp61;
235
+ const auto tmp63 = tmp62 / tmp24;
236
+ const auto tmp64 = tmp63 * (tmp22 < tmp14 ? 1 : 0.0);
237
+ const auto tmp65 = tmp7 + tmp7;
238
+ const auto tmp66 = tmp65 / tmp33;
239
+ const auto tmp67 = 2 * tmp66;
240
+ const auto tmp68 = tmp67 * tmp35;
241
+ const auto tmp69 = -1 * tmp68;
242
+ const auto tmp70 = tmp69 / tmp33;
243
+ const auto tmp71 = tmp42 * tmp70;
244
+ const auto tmp72 = tmp71 + tmp64;
245
+ const auto tmp73 = tmp72 * (tmp23 > tmp6 ? 1 : 0.0);
246
+ const auto tmp74 = tmp0[ 1 ] + tmp0[ 1 ];
247
+ const auto tmp75 = tmp74 / tmp46;
248
+ const auto tmp76 = 2 * tmp75;
249
+ const auto tmp77 = tmp76 * tmp48;
250
+ const auto tmp78 = -1 * tmp77;
251
+ const auto tmp79 = tmp78 / tmp46;
252
+ const auto tmp80 = tmp55 * tmp79;
253
+ const auto tmp81 = tmp80 + tmp73;
254
+ const auto tmp82 = tmp27 * tmp59;
255
+ const auto tmp83 = -1 * tmp82;
256
+ const auto tmp84 = tmp83 / tmp24;
257
+ const auto tmp85 = tmp84 * (tmp22 < tmp14 ? 1 : 0.0);
258
+ const auto tmp86 = tmp36 * tmp66;
259
+ const auto tmp87 = -1 * tmp86;
260
+ const auto tmp88 = tmp87 / tmp33;
261
+ const auto tmp89 = tmp42 * tmp88;
262
+ const auto tmp90 = tmp89 + tmp85;
263
+ const auto tmp91 = tmp90 * (tmp23 > tmp6 ? 1 : 0.0);
264
+ const auto tmp92 = tmp49 * tmp75;
265
+ const auto tmp93 = -1 * tmp92;
266
+ const auto tmp94 = tmp93 / tmp46;
267
+ const auto tmp95 = tmp55 * tmp94;
268
+ const auto tmp96 = tmp95 + tmp91;
269
+ const auto tmp97 = tmp60 * tmp59;
270
+ const auto tmp98 = -1 * tmp97;
271
+ const auto tmp99 = 2 + tmp98;
272
+ const auto tmp100 = tmp99 / tmp24;
273
+ const auto tmp101 = tmp100 * (tmp22 < tmp14 ? 1 : 0.0);
274
+ const auto tmp102 = tmp67 * tmp66;
275
+ const auto tmp103 = -1 * tmp102;
276
+ const auto tmp104 = 2 + tmp103;
277
+ const auto tmp105 = tmp104 / tmp33;
278
+ const auto tmp106 = tmp42 * tmp105;
279
+ const auto tmp107 = tmp106 + tmp101;
280
+ const auto tmp108 = tmp107 * (tmp23 > tmp6 ? 1 : 0.0);
281
+ const auto tmp109 = tmp76 * tmp75;
282
+ const auto tmp110 = -1 * tmp109;
283
+ const auto tmp111 = 2 + tmp110;
284
+ const auto tmp112 = tmp111 / tmp46;
285
+ const auto tmp113 = tmp55 * tmp112;
286
+ const auto tmp114 = tmp113 + tmp108;
287
+ ((result[ 0 ])[ 0 ])[ 0 ] = tmp57;
288
+ ((result[ 0 ])[ 0 ])[ 1 ] = tmp81;
289
+ ((result[ 0 ])[ 1 ])[ 0 ] = tmp96;
290
+ ((result[ 0 ])[ 1 ])[ 1 ] = tmp114;
291
+ }
292
+
293
+ template< std::size_t i >
294
+ const ConstantType< i > &constant () const
295
+ {
296
+ return *std::get< i >( constants_ );
297
+ }
298
+
299
+ template< std::size_t i >
300
+ ConstantType< i > &constant ()
301
+ {
302
+ return *std::get< i >( constants_ );
303
+ }
304
+ ConstantTupleType constants_;
305
+ std::tuple< > coefficients_;
306
+ };
307
+
308
+ } // namespace UFLLocalFunctions_10f9d7a54f79c12d6ca923b9ee56b80d
309
+
310
+ PYBIND11_MODULE( localfunction_10f9d7a54f79c12d6ca923b9ee56b80d_af122c1df944c95cd395ec0f91d0f970, module )
311
+ {
312
+ typedef UFLLocalFunctions_10f9d7a54f79c12d6ca923b9ee56b80d::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > > LocalFunctionType;
313
+ if constexpr( LocalFunctionType::gridPartValid )
314
+ {
315
+ auto cls = Dune::Python::insertClass<LocalFunctionType>(module,"UFLLocalFunction",Dune::Python::GenerateTypeName("UFLLocalFunctions_10f9d7a54f79c12d6ca923b9ee56b80d::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >"), Dune::Python::IncludeFiles({"python/dune/generated/localfunction_10f9d7a54f79c12d6ca923b9ee56b80d_af122c1df944c95cd395ec0f91d0f970.cc"})).first;
316
+ Dune::FemPy::registerUFLLocalFunction( module, cls );
317
+ cls.def( pybind11::init( [] ( pybind11::object gridView, const std::string &name, int order ) {return new LocalFunctionType( Dune::FemPy::gridPart<Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > >>(gridView),name,order); } ), pybind11::keep_alive< 1, 2 >() );
318
+ cls.def_property_readonly( "virtualized", [] ( LocalFunctionType& ) -> bool { return true;});
319
+ }
320
+ }
321
+
322
+ #endif
@@ -0,0 +1,164 @@
1
+ #ifndef GUARD_1c20e613977d8cea4cf5227c12aa68a6
2
+ #define GUARD_1c20e613977d8cea4cf5227c12aa68a6
3
+
4
+ #define USING_DUNE_PYTHON 1
5
+ #include <config.h>
6
+ #include <dune/alugrid/dgf.hh>
7
+ #include <dune/alugrid/grid.hh>
8
+ #include <dune/fem/gridpart/adaptiveleafgridpart.hh>
9
+ #include <dune/fem/gridpart/filter/simple.hh>
10
+ #include <dune/fem/gridpart/filteredgridpart.hh>
11
+ #include <dune/fempy/py/gridview.hh>
12
+ #include <dune/python/grid/gridview.hh>
13
+ #include <dune/python/grid/hierarchical.hh>
14
+ #include <dune/fem/function/localfunction/bindable.hh>
15
+ #include <dune/fem/common/intersectionside.hh>
16
+ #include <dune/python/pybind11/pybind11.h>
17
+ #include <dune/python/pybind11/extensions.h>
18
+ #include <dune/fempy/py/grid/gridpart.hh>
19
+ #include <dune/common/exceptions.hh>
20
+ #include <dune/fempy/function/virtualizedgridfunction.hh>
21
+ #include <dune/fempy/py/ufllocalfunction.hh>
22
+
23
+ namespace UFLLocalFunctions_1c20e613977d8cea4cf5227c12aa68a6
24
+ {
25
+
26
+ // UFLLocalFunction
27
+ // ----------------
28
+
29
+ template< class GridPart, class Coeffpsi_h >
30
+ struct UFLLocalFunction
31
+ : public Dune::Fem::BindableGridFunctionWithSpace<GridPart,Dune::Dim<2>>
32
+ {
33
+ typedef GridPart GridPartType;
34
+ typedef typename GridPartType::GridViewType GridView;
35
+ typedef typename GridView::ctype ctype;
36
+ typedef Dune::Fem::BindableGridFunctionWithSpace<GridPart,Dune::Dim<2>> BaseType;
37
+ typedef Dune::Fem::GridFunctionSpace<GridPartType,Dune::Dim<2>> FunctionSpaceType;
38
+ typedef typename GridPartType::template Codim< 0 >::EntityType EntityType;
39
+ typedef typename GridPartType::IntersectionType IntersectionType;
40
+ typedef typename EntityType::Geometry Geometry;
41
+ typedef typename Geometry::GlobalCoordinate GlobalCoordinateType;
42
+ typedef Dune::Fem::IntersectionSide Side;
43
+ typedef std::tuple<> ConstantTupleType;
44
+ typedef std::tuple< Dune::Fem::GridFunctionSpace< GridPartType, Dune::FieldVector< double, 1 > > > CoefficientFunctionSpaceTupleType;
45
+ typedef std::tuple< Coeffpsi_h > CoefficientTupleType;
46
+ template< std::size_t i >
47
+ using CoefficientFunctionSpaceType = std::tuple_element_t< i, CoefficientFunctionSpaceTupleType >;
48
+ template< std::size_t i >
49
+ using CoefficientRangeType = typename CoefficientFunctionSpaceType< i >::RangeType;
50
+ template< std::size_t i >
51
+ using CoefficientJacobianRangeType = typename CoefficientFunctionSpaceType< i >::JacobianRangeType;
52
+ static constexpr bool gridPartValid = Dune::Fem::checkGridPartValid<GridPartType,Dune::Fem::ConstLocalFunction<Coeffpsi_h>>();
53
+ template< std::size_t i >
54
+ using CoefficientType = std::tuple_element_t< i, CoefficientTupleType >;
55
+ template< std::size_t i >
56
+ using ConstantType = typename std::tuple_element_t< i, ConstantTupleType >::element_type;
57
+ using BaseType::entity;
58
+ using BaseType::geometry;
59
+
60
+ UFLLocalFunction ( const GridPartType &gridPart, const std::string &name, int order, const Coeffpsi_h &coeffpsi_h, const Dune::Fem::ParameterReader &parameter = Dune::Fem::Parameter::container() )
61
+ : BaseType(gridPart,name,order),
62
+ coefficients_( Dune::Fem::ConstLocalFunction< Coeffpsi_h >( coeffpsi_h ) )
63
+ {}
64
+
65
+ void bind ( const IntersectionType &intersection, Side side )
66
+ {
67
+ BaseType::bind(intersection, side);
68
+ std::get< 0 >( coefficients_ ).bind( this->entity() );
69
+ }
70
+
71
+ void bind ( const EntityType &entity )
72
+ {
73
+ BaseType::bind(entity);
74
+ std::get< 0 >( coefficients_ ).bind( this->entity() );
75
+ }
76
+
77
+ void unbind ()
78
+ {
79
+ BaseType::unbind();
80
+ std::get< 0 >( coefficients_ ).unbind();
81
+ }
82
+
83
+ template< class Point >
84
+ void evaluate ( const Point &x, typename FunctionSpaceType::RangeType &result ) const
85
+ {
86
+ typename CoefficientFunctionSpaceType< 0 >::JacobianRangeType tmp0 = jacobianCoefficient< 0 >( x );
87
+ const auto tmp1 = -1 * (tmp0[ 0 ])[ 1 ];
88
+ result[ 0 ] = tmp1;
89
+ result[ 1 ] = (tmp0[ 0 ])[ 0 ];
90
+ }
91
+
92
+ template< class Point >
93
+ void jacobian ( const Point &x, typename FunctionSpaceType::JacobianRangeType &result ) const
94
+ {
95
+ typename CoefficientFunctionSpaceType< 0 >::HessianRangeType tmp0 = hessianCoefficient< 0 >( x );
96
+ const auto tmp1 = -1 * ((tmp0[ 0 ])[ 1 ])[ 0 ];
97
+ const auto tmp2 = -1 * ((tmp0[ 0 ])[ 1 ])[ 1 ];
98
+ (result[ 0 ])[ 0 ] = tmp1;
99
+ (result[ 0 ])[ 1 ] = tmp2;
100
+ (result[ 1 ])[ 0 ] = ((tmp0[ 0 ])[ 0 ])[ 0 ];
101
+ (result[ 1 ])[ 1 ] = ((tmp0[ 0 ])[ 0 ])[ 1 ];
102
+ }
103
+
104
+ template< class Point >
105
+ void hessian ( const Point &x, typename FunctionSpaceType::HessianRangeType &result ) const
106
+ {
107
+ DUNE_THROW(Dune::NotImplemented,"hessian method could not be generated for local function (TooHighDerivative('CodeGenerator does not allow for third order derivatives, yet.'))");
108
+ result=typename FunctionSpaceType::HessianRangeType(0);
109
+ }
110
+
111
+ template< std::size_t i >
112
+ const ConstantType< i > &constant () const
113
+ {
114
+ return *std::get< i >( constants_ );
115
+ }
116
+
117
+ template< std::size_t i >
118
+ ConstantType< i > &constant ()
119
+ {
120
+ return *std::get< i >( constants_ );
121
+ }
122
+
123
+ template< std::size_t i, class Point >
124
+ typename CoefficientFunctionSpaceType< i >::RangeType evaluateCoefficient ( const Point &x ) const
125
+ {
126
+ typename CoefficientFunctionSpaceType< i >::RangeType result;
127
+ std::get< i >( coefficients_ ).evaluate( x, result );;
128
+ return result;
129
+ }
130
+
131
+ template< std::size_t i, class Point >
132
+ typename CoefficientFunctionSpaceType< i >::JacobianRangeType jacobianCoefficient ( const Point &x ) const
133
+ {
134
+ typename CoefficientFunctionSpaceType< i >::JacobianRangeType result;
135
+ std::get< i >( coefficients_ ).jacobian( x, result );;
136
+ return result;
137
+ }
138
+
139
+ template< std::size_t i, class Point >
140
+ typename CoefficientFunctionSpaceType< i >::HessianRangeType hessianCoefficient ( const Point &x ) const
141
+ {
142
+ typename CoefficientFunctionSpaceType< i >::HessianRangeType result;
143
+ std::get< i >( coefficients_ ).hessian( x, result );;
144
+ return result;
145
+ }
146
+ ConstantTupleType constants_;
147
+ std::tuple< Dune::Fem::ConstLocalFunction< Coeffpsi_h > > coefficients_;
148
+ };
149
+
150
+ } // namespace UFLLocalFunctions_1c20e613977d8cea4cf5227c12aa68a6
151
+
152
+ PYBIND11_MODULE( localfunction_1c20e613977d8cea4cf5227c12aa68a6_a524c1196983e65de1c06d7d6afdeb44, module )
153
+ {
154
+ typedef UFLLocalFunctions_1c20e613977d8cea4cf5227c12aa68a6::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true > >, Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > > LocalFunctionType;
155
+ if constexpr( LocalFunctionType::gridPartValid )
156
+ {
157
+ auto cls = Dune::Python::insertClass<LocalFunctionType>(module,"UFLLocalFunction",Dune::Python::GenerateTypeName("UFLLocalFunctions_1c20e613977d8cea4cf5227c12aa68a6::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true > >, Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > >"), Dune::Python::IncludeFiles({"python/dune/generated/localfunction_1c20e613977d8cea4cf5227c12aa68a6_a524c1196983e65de1c06d7d6afdeb44.cc"})).first;
158
+ Dune::FemPy::registerUFLLocalFunction( module, cls );
159
+ cls.def( pybind11::init( [] ( pybind11::object gridView, const std::string &name, int order, const Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > &coeffpsi_h ) {return new LocalFunctionType( Dune::FemPy::gridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>(gridView),name,order, coeffpsi_h); } ), pybind11::keep_alive< 1, 2 >(), pybind11::keep_alive< 1, 3 >() );
160
+ cls.def_property_readonly( "virtualized", [] ( LocalFunctionType& ) -> bool { return true;});
161
+ }
162
+ }
163
+
164
+ #endif
@@ -1,5 +1,5 @@
1
- #ifndef GUARD_191355e6250b2d2e260d96f519ad9976
2
- #define GUARD_191355e6250b2d2e260d96f519ad9976
1
+ #ifndef GUARD_217e4bf8b368a7768c4897cf58f71d84
2
+ #define GUARD_217e4bf8b368a7768c4897cf58f71d84
3
3
 
4
4
  #define USING_DUNE_PYTHON 1
5
5
  #include <config.h>
@@ -20,13 +20,13 @@
20
20
  #include <dune/fempy/function/virtualizedgridfunction.hh>
21
21
  #include <dune/fempy/py/ufllocalfunction.hh>
22
22
 
23
- namespace UFLLocalFunctions_191355e6250b2d2e260d96f519ad9976
23
+ namespace UFLLocalFunctions_217e4bf8b368a7768c4897cf58f71d84
24
24
  {
25
25
 
26
26
  // UFLLocalFunction
27
27
  // ----------------
28
28
 
29
- template< class GridPart, class Coeffddm >
29
+ template< class GridPart, class Coeffuh >
30
30
  struct UFLLocalFunction
31
31
  : public Dune::Fem::BindableGridFunctionWithSpace<GridPart,Dune::Dim<1>>
32
32
  {
@@ -42,14 +42,14 @@ struct UFLLocalFunction
42
42
  typedef Dune::Fem::IntersectionSide Side;
43
43
  typedef std::tuple<> ConstantTupleType;
44
44
  typedef std::tuple< Dune::Fem::GridFunctionSpace< GridPartType, Dune::FieldVector< double, 1 > > > CoefficientFunctionSpaceTupleType;
45
- typedef std::tuple< Coeffddm > CoefficientTupleType;
45
+ typedef std::tuple< Coeffuh > CoefficientTupleType;
46
46
  template< std::size_t i >
47
47
  using CoefficientFunctionSpaceType = std::tuple_element_t< i, CoefficientFunctionSpaceTupleType >;
48
48
  template< std::size_t i >
49
49
  using CoefficientRangeType = typename CoefficientFunctionSpaceType< i >::RangeType;
50
50
  template< std::size_t i >
51
51
  using CoefficientJacobianRangeType = typename CoefficientFunctionSpaceType< i >::JacobianRangeType;
52
- static constexpr bool gridPartValid = Dune::Fem::checkGridPartValid<GridPartType,Dune::Fem::ConstLocalFunction<Coeffddm>>();
52
+ static constexpr bool gridPartValid = Dune::Fem::checkGridPartValid<GridPartType,Dune::Fem::ConstLocalFunction<Coeffuh>>();
53
53
  template< std::size_t i >
54
54
  using CoefficientType = std::tuple_element_t< i, CoefficientTupleType >;
55
55
  template< std::size_t i >
@@ -57,9 +57,9 @@ struct UFLLocalFunction
57
57
  using BaseType::entity;
58
58
  using BaseType::geometry;
59
59
 
60
- UFLLocalFunction ( const GridPartType &gridPart, const std::string &name, int order, const Coeffddm &coeffddm, const Dune::Fem::ParameterReader &parameter = Dune::Fem::Parameter::container() )
60
+ UFLLocalFunction ( const GridPartType &gridPart, const std::string &name, int order, const Coeffuh &coeffuh, const Dune::Fem::ParameterReader &parameter = Dune::Fem::Parameter::container() )
61
61
  : BaseType(gridPart,name,order),
62
- coefficients_( Dune::Fem::ConstLocalFunction< Coeffddm >( coeffddm ) )
62
+ coefficients_( Dune::Fem::ConstLocalFunction< Coeffuh >( coeffuh ) )
63
63
  {}
64
64
 
65
65
  void bind ( const IntersectionType &intersection, Side side )
@@ -172,19 +172,19 @@ struct UFLLocalFunction
172
172
  return result;
173
173
  }
174
174
  ConstantTupleType constants_;
175
- std::tuple< Dune::Fem::ConstLocalFunction< Coeffddm > > coefficients_;
175
+ std::tuple< Dune::Fem::ConstLocalFunction< Coeffuh > > coefficients_;
176
176
  };
177
177
 
178
- } // namespace UFLLocalFunctions_191355e6250b2d2e260d96f519ad9976
178
+ } // namespace UFLLocalFunctions_217e4bf8b368a7768c4897cf58f71d84
179
179
 
180
- PYBIND11_MODULE( localfunction_191355e6250b2d2e260d96f519ad9976_a524c1196983e65de1c06d7d6afdeb44, module )
180
+ PYBIND11_MODULE( localfunction_217e4bf8b368a7768c4897cf58f71d84_a524c1196983e65de1c06d7d6afdeb44, module )
181
181
  {
182
- typedef UFLLocalFunctions_191355e6250b2d2e260d96f519ad9976::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true > >, Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > > LocalFunctionType;
182
+ typedef UFLLocalFunctions_217e4bf8b368a7768c4897cf58f71d84::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true > >, Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > > LocalFunctionType;
183
183
  if constexpr( LocalFunctionType::gridPartValid )
184
184
  {
185
- auto cls = Dune::Python::insertClass<LocalFunctionType>(module,"UFLLocalFunction",Dune::Python::GenerateTypeName("UFLLocalFunctions_191355e6250b2d2e260d96f519ad9976::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true > >, Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > >"), Dune::Python::IncludeFiles({"python/dune/generated/localfunction_191355e6250b2d2e260d96f519ad9976_a524c1196983e65de1c06d7d6afdeb44.cc"})).first;
185
+ auto cls = Dune::Python::insertClass<LocalFunctionType>(module,"UFLLocalFunction",Dune::Python::GenerateTypeName("UFLLocalFunctions_217e4bf8b368a7768c4897cf58f71d84::UFLLocalFunction< typename Dune::FemPy::GridPart< Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true > >, Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > >"), Dune::Python::IncludeFiles({"python/dune/generated/localfunction_217e4bf8b368a7768c4897cf58f71d84_a524c1196983e65de1c06d7d6afdeb44.cc"})).first;
186
186
  Dune::FemPy::registerUFLLocalFunction( module, cls );
187
- cls.def( pybind11::init( [] ( pybind11::object gridView, const std::string &name, int order, const Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > &coeffddm ) {return new LocalFunctionType( Dune::FemPy::gridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>(gridView),name,order, coeffddm); } ), pybind11::keep_alive< 1, 2 >(), pybind11::keep_alive< 1, 3 >() );
187
+ cls.def( pybind11::init( [] ( pybind11::object gridView, const std::string &name, int order, const Dune::FemPy::VirtualizedGridFunction< Dune::FemPy::GridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>, Dune::FieldVector< double, 1 > > &coeffuh ) {return new LocalFunctionType( Dune::FemPy::gridPart<Dune::Fem::FilteredGridPart< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > >, Dune::Fem::SimpleFilter< Dune::FemPy::GridPart< Dune::Fem::AdaptiveLeafGridPart< Dune::ALUGrid< 2, 2, Dune::simplex > > > >, true >>(gridView),name,order, coeffuh); } ), pybind11::keep_alive< 1, 2 >(), pybind11::keep_alive< 1, 3 >() );
188
188
  cls.def_property_readonly( "virtualized", [] ( LocalFunctionType& ) -> bool { return true;});
189
189
  }
190
190
  }