Hi @pat_uow, I guess you have two tables - the first one contains coordinates (x, y) for each hole; the second one contains z values for each stratum for each hole. If so, how can you collect every z value corresponding to a single hole? Do the two tables have a common attribute that can be used as a join key?
The records are now in a single table Takashi. Table has HoleID, Holename then x,y (may be repeated several times depending on how many strata types were intersected on the way down), attribute (strata type) and then Z for each strata type. This table and the attribute (strata type) was the result of an unpivot operation on records where the strata type was across the columns.
OK. I think you can create 3D lines for each hole with this procedure.
- If the records have not been sorted by Hole ID and Z, sort them by Hole ID, Z with the Sorter.
- Use the VertexCreator to create 3D points from Z, Y, X for each record. [edit] Swap X and Z here. [/edit]
- Use the LineBuilder (Connection Break Attributes: Hole ID) to create 3D lines for each hole. Here, you can specify a list name to the List Name parameter to save every strata type into a list attribute.
- [edit] Modify the direction of the lines with CoordinateSwapper (Swap Type: X <-> Z). [/edit]
However, there still are two problems.
- For each line, the number of strata types (= records = vertices) is (the number of segments + 1). You will have to resolve this mismatch if you need to map a strata type to a segment of the line. For example, if the original Z indicates the middle of a stratum having some thickness, assume each boundary surface between upper and lower strata, then create a line using Z of boundary surfaces.
- Even if you could resolve the first problem, individual segments of a Line feature cannot have regular attributes. A possible way is to save the strata types of all segments into a list attribute of the Line feature. Alternatively, it's also possible to create individual segments as Line features, store the strata type as their Trait, then connect them to form a Path feature.
How to resolve the problems, depends on the required data structure as the result.
OK. I think you can create 3D lines for each hole with this procedure.
- If the records have not been sorted by Hole ID and Z, sort them by Hole ID, Z with the Sorter.
- Use the VertexCreator to create 3D points from Z, Y, X for each record. [edit] Swap X and Z here. [/edit]
- Use the LineBuilder (Connection Break Attributes: Hole ID) to create 3D lines for each hole. Here, you can specify a list name to the List Name parameter to save every strata type into a list attribute.
- [edit] Modify the direction of the lines with CoordinateSwapper (Swap Type: X <-> Z). [/edit]
However, there still are two problems.
- For each line, the number of strata types (= records = vertices) is (the number of segments + 1). You will have to resolve this mismatch if you need to map a strata type to a segment of the line. For example, if the original Z indicates the middle of a stratum having some thickness, assume each boundary surface between upper and lower strata, then create a line using Z of boundary surfaces.
- Even if you could resolve the first problem, individual segments of a Line feature cannot have regular attributes. A possible way is to save the strata types of all segments into a list attribute of the Line feature. Alternatively, it's also possible to create individual segments as Line features, store the strata type as their Trait, then connect them to form a Path feature.
How to resolve the problems, depends on the required data structure as the result.
Sorry, I forgot the fact that the LineBuilder won't connect points located at the same (x, y). However, you can use the CoordinateSwapper effectively to avoid the issue. Edited the procedure above.
>edit] In more correct, the LineBuiler won't create a Line, if the number of points was 4 or more and the start / end points located at the same 2D coordinates (x, y), even though z of them were different. [/edit]