From fd4af9c712ad9db9ed2b485aaef56b1ad8393c62 Mon Sep 17 00:00:00 2001
From: Thomas Fischer <thomas.fischer@ufz.de>
Date: Wed, 8 Jul 2020 12:45:55 +0200
Subject: [PATCH] [T] partmesh: partition mesh including field data.

Metis converted input prepared with
partmesh -i cube_1x1x1_hex_8.vtu --ogs2metis
mpmetis -gtype=nodal cube_1x1x1_hex_8.mesh 2
---
 Applications/Utils/Tests.cmake                |  18 +++++++++++
 .../partmesh/cube_1x1x1_hex_8.mesh.epart.2    |   8 +++++
 .../partmesh/cube_1x1x1_hex_8.mesh.npart.2    |  27 ++++++++++++++++
 .../partmesh/cube_1x1x1_hex_8.vtu             |  30 ++++++++++++++++++
 ...hex_8_partitioned_cell_properties_cfg2.bin | Bin 0 -> 85 bytes
 ...hex_8_partitioned_cell_properties_val2.bin | Bin 0 -> 64 bytes
 .../cube_1x1x1_hex_8_partitioned_msh_cfg2.bin | Bin 0 -> 224 bytes
 .../cube_1x1x1_hex_8_partitioned_msh_ele2.bin |   0
 ...ube_1x1x1_hex_8_partitioned_msh_ele_g2.bin | Bin 0 -> 1536 bytes
 .../cube_1x1x1_hex_8_partitioned_msh_nod2.bin | Bin 0 -> 1728 bytes
 ...hex_8_partitioned_node_properties_cfg2.bin | Bin 0 -> 225 bytes
 ...hex_8_partitioned_node_properties_val2.bin | Bin 0 -> 2592 bytes
 12 files changed, 83 insertions(+)
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.epart.2
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.npart.2
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.vtu
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_cell_properties_cfg2.bin
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_cell_properties_val2.bin
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_cfg2.bin
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_ele2.bin
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_ele_g2.bin
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_nod2.bin
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_node_properties_cfg2.bin
 create mode 100644 Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_node_properties_val2.bin

diff --git a/Applications/Utils/Tests.cmake b/Applications/Utils/Tests.cmake
index 9b796f071fd..5b820fe769d 100644
--- a/Applications/Utils/Tests.cmake
+++ b/Applications/Utils/Tests.cmake
@@ -313,6 +313,24 @@ foreach(element_type tri quad)
     )
 endforeach()
 
+AddTest(
+    NAME partmesh_with_field_data
+    PATH NodePartitionedMesh/partmesh
+    EXECUTABLE partmesh
+    EXECUTABLE_ARGS -n 2 -i cube_1x1x1_hex_8.vtu -o ${Data_BINARY_DIR}/NodePartitionedMesh/partmesh
+    TESTER diff
+    REQUIREMENTS NOT OGS_USE_MPI
+    DIFF_DATA
+        cube_1x1x1_hex_8_partitioned_cell_properties_cfg2.bin
+        cube_1x1x1_hex_8_partitioned_cell_properties_val2.bin
+        cube_1x1x1_hex_8_partitioned_msh_cfg2.bin
+        cube_1x1x1_hex_8_partitioned_msh_ele2.bin
+        cube_1x1x1_hex_8_partitioned_msh_ele_g2.bin
+        cube_1x1x1_hex_8_partitioned_msh_nod2.bin
+        cube_1x1x1_hex_8_partitioned_node_properties_cfg2.bin
+        cube_1x1x1_hex_8_partitioned_node_properties_val2.bin
+)
+
 if(OGS_USE_NETCDF)
     AddTest(
         NAME NetCDF_2D_Test
diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.epart.2 b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.epart.2
new file mode 100644
index 00000000000..b762556dc02
--- /dev/null
+++ b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.epart.2
@@ -0,0 +1,8 @@
+1
+1
+0
+0
+1
+1
+1
+0
diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.npart.2 b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.npart.2
new file mode 100644
index 00000000000..4d63d616721
--- /dev/null
+++ b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.mesh.npart.2
@@ -0,0 +1,27 @@
+0
+1
+1
+0
+0
+0
+1
+1
+1
+1
+1
+0
+1
+1
+0
+0
+0
+0
+0
+0
+1
+1
+1
+0
+0
+0
+1
diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.vtu b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.vtu
new file mode 100644
index 00000000000..70bc7a619ba
--- /dev/null
+++ b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8.vtu
@@ -0,0 +1,30 @@
+<?xml version="1.0"?>
+<VTKFile type="UnstructuredGrid" version="0.1" byte_order="LittleEndian" header_type="UInt32" compressor="vtkZLibDataCompressor">
+  <UnstructuredGrid>
+    <FieldData>
+      <DataArray type="Int8" Name="OGS_VERSION" NumberOfTuples="42" format="appended" RangeMin="45"                   RangeMax="121"                  offset="0"                   />
+    </FieldData>
+    <Piece NumberOfPoints="27"                   NumberOfCells="8"                   >
+      <PointData>
+        <DataArray type="Float64" Name="D1_left_front_N1_right" format="appended" RangeMin="1"                    RangeMax="1.6753144833"         offset="92"                  />
+        <DataArray type="Float64" Name="Linear_1_to_minus1" format="appended" RangeMin="-1"                   RangeMax="1"                    offset="192"                 />
+        <DataArray type="Float64" Name="pressure" format="appended" RangeMin="-1"                   RangeMax="1"                    offset="248"                 />
+        <DataArray type="Float64" Name="v" NumberOfComponents="3" format="appended" RangeMin="2"                    RangeMax="2"                    offset="304"                 />
+      </PointData>
+      <CellData>
+        <DataArray type="Int32" Name="MaterialIDs" format="appended" RangeMin="0"                    RangeMax="0"                    offset="824"                 />
+      </CellData>
+      <Points>
+        <DataArray type="Float64" Name="Points" NumberOfComponents="3" format="appended" RangeMin="0"                    RangeMax="1.7320508076"         offset="864"                 />
+      </Points>
+      <Cells>
+        <DataArray type="Int64" Name="connectivity" format="appended" RangeMin=""                     RangeMax=""                     offset="996"                 />
+        <DataArray type="Int64" Name="offsets" format="appended" RangeMin=""                     RangeMax=""                     offset="1156"                />
+        <DataArray type="UInt8" Name="types" format="appended" RangeMin=""                     RangeMax=""                     offset="1220"                />
+      </Cells>
+    </Piece>
+  </UnstructuredGrid>
+  <AppendedData encoding="base64">
+   _AQAAAACAAAAqAAAAMQAAAA==eF4FwUEOABAMAMEXabZF9T+aiKu4+L0ZlyoUpWtZ5Bzu0ZHc5z4xDAautDD71j0J/w==AQAAAACAAADYAAAANwAAAA==eF5jYACBD/YMOGjHz9uUbZw/26/LmfNZnPEnXDxi+ZyXCrFf7HXs3frFzv3CqX+gzAEA2G8/mg==AQAAAACAAADYAAAAFgAAAA==eF5jYACBD/YMKODDfoYhLg4Ag8wZzw==AQAAAACAAADYAAAAFgAAAA==eF5jYACBD/YMKODDfoYhLg4Ag8wZzw==AQAAAACAAACIAgAAdAEAAA==eF778R8M7E3OzosTUXO08di8XLzVs2TPP6j44ZbWdem7p+zxcVDefWZ71x4GCHD4CZaeaLOBSepm6r5QG5i4FtSceamHnK5vjt3DBBU/BjUn5duXRQadU+DiX6DmzPCJeFG1bbYNC1RcAWrOE0aI+TDxk1Bz3CDuhIt/gJrD4ezbvdp+kQ3M/ZEzN1z4muO+B2JPO9zeN2B+/p6Lb166JgpN3MMMFX8H5tfu+QWWXwg3JwlqDntxS8yOiYXwcPgDNccB7J4UuPmPoeZcANO9e/5CzcmGmrPZ+F2v3M5MeLixgamCPRDz2m1g5tyAmmNUXRU4w2UD3PzPYHXxe5SExXbNeztpDywcJnByx54v67SpsXTSu3Niyh42qLgFWP+CPe+nz85gW7nR5jfUPd+h5iwHh3813F99UHPUweb32cDCxxhqzhYZRfG8lDV7PkHN+Q01xwoaL7+g4r1Qc7Qg7oT7Vw9qzpfTvibNV47sAQCtyDG/AQAAAACAAAAgAAAACwAAAA==eF5jYMAPAAAgAAE=AQAAAACAAACIAgAATwAAAA==eF6FkbERACAMArOZ+2/hCIxgRYO+0OR8jUKc+WmvNxdwK/u8Ti7guW/5XHIBT5EPurfloJq5Wm7qy1xtTvQOzctqvslH+wfqv+sBQnk+Ow==AQAAAACAAAAAAgAAZAAAAA==eF6Fz7cRwDAQA0HKe+/Vf6EKdBeTySYEMB/C/xLMMcMGWxywR3MpFmiPuQ5HtMcd/1dYojv+n3FCc+7WaI85dxe0J3bfihueeGDsPnM7XmhP7D53/P/gjbH7zLn7oj0fjh4DQQ==AQAAAACAAABAAAAAHgAAAA==eF7jYIAAASgtAaUVoLQGlDaA0hZQ2gFKAwAeQAEhAQAAAACAAAAIAAAACwAAAA==eF7j4YEAAAG4AGE=
+  </AppendedData>
+</VTKFile>
diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_cell_properties_cfg2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_cell_properties_cfg2.bin
new file mode 100644
index 0000000000000000000000000000000000000000..71506fa787bcf76395e4eb01f6619875b4165454
GIT binary patch
literal 85
ocmZQ%fB<eN?VDJVT9lcX<LOe&$jAZ}WQ5WJP#Q*YKpE&X02PG<YXATM

literal 0
HcmV?d00001

diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_cell_properties_val2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_cell_properties_val2.bin
new file mode 100644
index 0000000000000000000000000000000000000000..9017fd98b5f67d928cc64c59b2c025472ce74f8c
GIT binary patch
literal 64
LcmZQzpbP*206+i%

literal 0
HcmV?d00001

diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_cfg2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_cfg2.bin
new file mode 100644
index 0000000000000000000000000000000000000000..cf24225b2f11ce472daaaf556554c99905df22bd
GIT binary patch
literal 224
zcmb1UfB<PI4Wl@q3_dg(rVd8K)JMP=1ZbE(7!6YnvyT@l0Ha~*U^GlU%)SI>m<W_c
G;{yQd(gHOA

literal 0
HcmV?d00001

diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_ele2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_ele2.bin
new file mode 100644
index 00000000000..e69de29bb2d
diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_ele_g2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_ele_g2.bin
new file mode 100644
index 0000000000000000000000000000000000000000..d0de84b747713708a3cefe5be9ad5eb54d5e7626
GIT binary patch
literal 1536
zcmb``xsF0H5JXXiVH<Xs4G74|$;rw2|6d`XPGZUG1d@v^`@T}SJsZ4!-{CpDgxByE
z-or--i~N~c2-o2-{0KMUHr$2#5Lz#vyr0>~&o|2YIOOkn<>L9t#@|pbo@v%6gkhVP
zPtL#W<L8r8fBf{Vx9aaJ2j}5`cpwa0Z`B{)u{qCA-+HV5<l<RHv?Of4r>CkvK6y^@
z@bj3bcg;V)_~zEVxo`6$M|JOf=GA@i^XWzJ{Lbscx?DWw)%?n3zrM_I&&wyLcgfEu
tr}xI+^H%+NXYKu)-=4SXkI(xuxBBdPtN!HT@xIJ!&s+7!C#Uzs{{&V~3UB}b

literal 0
HcmV?d00001

diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_nod2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_msh_nod2.bin
new file mode 100644
index 0000000000000000000000000000000000000000..15c1d7a697ca42d682eb1916b8aedee3f0a8e02a
GIT binary patch
literal 1728
zcmc(fS&jlR3`7INI_wOyz-4^@TjU5i0?0j2mQh4~AVmL^T`zHW$B|2U{EWJ|8upmL
z6(23-Bk}gXFZiU(F{@1pUGMi-n<Y*X>*iRlyf^qFaeTDeGV%MQ*=Mq-kJ)TR=o)ng
zyV*K%64o`_V7XF1__oW#{EDy>RXZh@`k2*z2wmZ!--(k1-(k7(-C-UgyhZGbb^F9g
zf*-M5@zGMwiBlhK_Ln$G@Lw#~s5{urE?v&LW~x8xeANG|^Hb;Z?EO&vSNBJquj-HL
euj)@~Unf!XP0hzw&p$Qa)O>vR{8RHy&BrTyDStBn

literal 0
HcmV?d00001

diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_node_properties_cfg2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_node_properties_cfg2.bin
new file mode 100644
index 0000000000000000000000000000000000000000..c56db7546aaf1db6275a5799400f9b2e00295387
GIT binary patch
literal 225
zcmZQ!fB-Ql?P3_8lbTi%pH`HgR}$}M7+;i`o>9WU$N`mSgwkeES_n$}WagzN7R4LJ
sm*mIiX6BU^8{*ajGpnE|wYa#nC>6I#m~CYUCCq3JfN~k6p$v2y0AvFc!vFvP

literal 0
HcmV?d00001

diff --git a/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_node_properties_val2.bin b/Tests/Data/NodePartitionedMesh/partmesh/cube_1x1x1_hex_8_partitioned_node_properties_val2.bin
new file mode 100644
index 0000000000000000000000000000000000000000..20c5f868f2121a839c01598677b9c6fb0a60588e
GIT binary patch
literal 2592
zcmcIjO-Phc6df(BXjkEYL|8(BghaZic<_B{S%EHE1O`n~j8r696fLw?DPl3!#6X5J
zl$#+6nV7I29|aXr^rJygLAzQcm`OAJXg`y^@16_Z;Za}Gx4HAqJNMjk@0%M4{Qkxr
z6Q*KidZ0vAr=9+$-gGc;f^m7SPxOuyhceDer{+}Q(@Ew*$HvFKjHoMd)B%oqHa_mb
zml1k@;@R|p%Y5LdC;P`4^}&-mz-@foPmkVd>K$(rE+f594(~5<&J%ozqrP7}ClCHb
zJ@D{<m38?1kNK>Re2T0~ewasRzPIs_XW_FR<>&P06K6l7p2ShtFP@X<)89<{Lq2@S
zXzK@gd{4gl?0n6d&#8D4-?3<UrP`EA1lu<s*2Hj236D44sd|wL>3r|Pz2DZ}zk4vI
z!=E#Kt2$$hXN+7_b=TIvYZ>TKvxq-7I<jHsf@6Bp++R@8c|-WHi4pyS{OmiI9RAd_
zQK!nsB1>-URq#__ejL!>4X=ZBUXsr0)|M^Z>yzv!ZFmiO*}}q`@%Lx+Z1Qt@-u%$e
zkxq4VZB^Op2Qdww<tG2UzPfm6aDVu+{z!hlk<L1AKFaGO>qJPW)YDf#iGP>oQ|p!t
zKE8HB1K&n{d2{MupQ9$PSwAy<M0x&RpUv7eb;GQ)i*)83YTJH2dXV`OMklJ0`9-f9
zZ*5iR_aXVIA^*UO>3!ekP3Mo3&fMy{lb4)6o_`nhyTbI_rM$UhoiB#ppcCfZTebI2
z0e20}^TXMmJp~u9uud7_nMZXM$DiNhzU18S?zX;c{%!rrzWlxm__q1W_p;5wHaGMu
l=L}rV&9=YTFS)1CvF-It_ZRwdPi=b*pZ{xrZF_3l>tCO2N%jB$

literal 0
HcmV?d00001

-- 
GitLab