-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtest_replace_attribute_in_las.py
104 lines (79 loc) · 3.41 KB
/
test_replace_attribute_in_las.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import json
import os
import shutil
from collections import Counter
from test.test_standardize_format import assert_lasinfo_no_warning
from test.utils import EXPECTED_DIMS_BY_DATAFORMAT, get_pdal_infos_summary
from typing import Dict
import pytest
from pdaltools.count_occurences.count_occurences_for_attribute import (
compute_count_one_file,
)
from pdaltools.replace_attribute_in_las import (
parse_replacement_map_from_path_or_json_string,
replace_values,
replace_values_clean,
)
from pdaltools.standardize_format import get_writer_parameters
test_path = os.path.dirname(os.path.abspath(__file__))
tmp_path = os.path.join(test_path, "tmp")
input_dir = os.path.join(test_path, "data/classified_laz")
input_file = os.path.join(input_dir, "test_data_77050_627755_LA93_IGN69.laz")
output_file = os.path.join(tmp_path, "replaced.las")
attribute = "Classification"
input_counts = Counter(
{
"1": 2047,
"2": 21172,
"3": 226,
"4": 1227,
"5": 30392,
"6": 29447,
"0": 13,
}
)
colored_las_params = get_writer_parameters({"dataformat_id": 8})
expected_counts = Counter({"0": 13, "2": 226, "4": 1227, "5": 30392, "65": 29447, "201": 2047 + 21172})
replacement_map_fail = {
"201": ["1", "64"],
"6": ["64"],
} # has duplicate value to replace, so it should fail
replacement_map_success = {
"201": ["1", "2"],
"2": ["3"], # check that the replacement is correct when a value is both replaced and to replace
"65": ["6"], # check that values over 31 are interpreted correctly in las 1.4 output
}
# test replacement map parsing
input_parsing_correct = '{ "201" : ["1", "64"], "64": ["6"]}'
input_parsing_incorrect = '"201" : ["1", "64"], "64": ["6"]'
input_parsing_file = os.path.join(test_path, "data", "example_replacement_map.json")
def setup_module(module):
try:
shutil.rmtree(tmp_path)
except FileNotFoundError:
pass
os.mkdir(tmp_path)
def test_replace_values_ok():
replace_values(input_file, output_file, replacement_map_success, attribute, colored_las_params)
count = compute_count_one_file(output_file, attribute)
assert count == expected_counts
check_dimensions(input_file, output_file)
def test_replace_values_clean():
replace_values_clean(input_file, output_file, replacement_map_success, attribute, get_writer_parameters({}))
assert_lasinfo_no_warning(output_file)
def test_replace_values_duplicate_input():
with pytest.raises(ValueError):
replace_values(input_file, output_file, replacement_map_fail, attribute)
def check_dimensions(input_file, output_file):
output_summary = get_pdal_infos_summary(output_file)
output_dimensions = [s.strip() for s in output_summary["summary"]["dimensions"].split(",")]
print(sorted(output_dimensions))
print(sorted(EXPECTED_DIMS_BY_DATAFORMAT[8]))
assert set(output_dimensions) == set(EXPECTED_DIMS_BY_DATAFORMAT[8])
def test_parse_replacement_map_from_path_or_json_string_path_ok():
assert isinstance(parse_replacement_map_from_path_or_json_string(input_parsing_file), Dict)
def test_parse_replacement_map_from_path_or_json_string_json_ok():
assert isinstance(parse_replacement_map_from_path_or_json_string(input_parsing_correct), Dict)
def test_parse_replacement_map_from_path_or_json_string_other_nok():
with pytest.raises(json.decoder.JSONDecodeError):
parse_replacement_map_from_path_or_json_string(input_parsing_incorrect)