-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathrename_labels.json
96 lines (96 loc) · 4.09 KB
/
rename_labels.json
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
{
"id": "rename_labels",
"summary": "Rename dimension labels",
"description": "Renames the labels of the specified dimension in the data cube from `source` to `target`.\n\nIf the array for the source labels is empty (the default), the dimension labels are expected to be enumerated with zero-based numbering (0,1,2,3,...) so that the dimension labels directly map to the indices of the array specified for the parameter `target`. Otherwise, the number of the source and target labels must be equal. If none of these requirements is fulfilled, the `LabelMismatch` exception is thrown.\n\nThis process doesn't change the order of the labels and their corresponding data.",
"categories": [
"cubes"
],
"parameters": [
{
"name": "data",
"description": "The data cube.",
"schema": {
"type": "object",
"subtype": "datacube"
}
},
{
"name": "dimension",
"description": "The name of the dimension to rename the labels for.",
"schema": {
"type": "string"
}
},
{
"name": "target",
"description": "The new names for the labels.\n\nIf a target dimension label already exists in the data cube, a `LabelExists` exception is thrown.",
"schema": {
"type": "array",
"items": {
"type": [
"number",
"string"
]
}
}
},
{
"name": "source",
"description": "The original names of the labels to be renamed to corresponding array elements in the parameter `target`. It is allowed to only specify a subset of labels to rename, as long as the `target` and `source` parameter have the same length. The order of the labels doesn't need to match the order of the dimension labels in the data cube. By default, the array is empty so that the dimension labels in the data cube are expected to be enumerated.\n\nIf the dimension labels are not enumerated and the given array is empty, the `LabelsNotEnumerated` exception is thrown. If one of the source dimension labels doesn't exist, the `LabelNotAvailable` exception is thrown.",
"schema": {
"type": "array",
"items": {
"type": [
"number",
"string"
]
}
},
"default": [],
"optional": true
}
],
"returns": {
"description": "The data cube with the same dimensions. The dimension properties (name, type, labels, reference system and resolution) remain unchanged, except that for the given dimension the labels change. The old labels can not be referred to any longer. The number of labels remains the same.",
"schema": {
"type": "object",
"subtype": "datacube"
}
},
"exceptions": {
"LabelsNotEnumerated": {
"message": "The dimension labels are not enumerated."
},
"LabelMismatch": {
"message": "The number of labels in the parameters `source` and `target` don't match."
},
"LabelNotAvailable": {
"message": "A label with the specified name does not exist."
},
"LabelExists": {
"message": "A label with the specified name exists."
}
},
"examples": [
{
"title": "Rename named labels",
"description": "Renaming the bands from `B1` to `red`, from `B2` to `green` and from `B3` to `blue`.",
"arguments": {
"data": {
"from_parameter": "data"
},
"dimension": "bands",
"source": [
"B1",
"B2",
"B3"
],
"target": [
"red",
"green",
"blue"
]
}
}
]
}