TIOVX User Guide
enums.py
1 #
2 # Copyright (c) 2017-2019 Texas Instruments Incorporated
3 #
4 # All rights reserved not granted herein.
5 #
6 # Limited License.
7 #
8 # Texas Instruments Incorporated grants a world-wide, royalty-free, non-exclusive
9 # license under copyrights and patents it now or hereafter owns or controls to make,
10 # have made, use, import, offer to sell and sell ("Utilize") this software subject to the
11 # terms herein. With respect to the foregoing patent license, such license is granted
12 # solely to the extent that any such patent is necessary to Utilize the software alone.
13 # The patent license shall not apply to any combinations which include this software,
14 # other than combinations with devices manufactured by or for TI ("TI Devices").
15 # No hardware patent is licensed hereunder.
16 #
17 # Redistributions must preserve existing copyright notices and reproduce this license
18 # (including the above copyright notice and the disclaimer and (if applicable) source
19 # code license limitations below) in the documentation and/or other materials provided
20 # with the distribution
21 #
22 # Redistribution and use in binary form, without modification, are permitted provided
23 # that the following conditions are met:
24 #
25 # No reverse engineering, decompilation, or disassembly of this software is
26 # permitted with respect to any software provided in binary form.
27 #
28 # any redistribution and use are licensed by TI for use only with TI Devices.
29 #
30 # Nothing shall obligate TI to provide you with source code for the software
31 # licensed and provided to you in object code.
32 #
33 # If software source code is provided to you, modification and redistribution of the
34 # source code are permitted provided that the following conditions are met:
35 #
36 # any redistribution and use of the source code, including any resulting derivative
37 # works, are licensed by TI for use only with TI Devices.
38 #
39 # any redistribution and use of any object code compiled from the source code
40 # and any resulting derivative works, are licensed by TI for use only with TI Devices.
41 #
42 # Neither the name of Texas Instruments Incorporated nor the names of its suppliers
43 #
44 # may be used to endorse or promote products derived from this software without
45 # specific prior written permission.
46 #
47 # DISCLAIMER.
48 #
49 # THIS SOFTWARE IS PROVIDED BY TI AND TI'S LICENSORS "AS IS" AND ANY EXPRESS
50 # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
51 # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
52 # IN NO EVENT SHALL TI AND TI'S LICENSORS BE LIABLE FOR ANY DIRECT, INDIRECT,
53 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
54 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
55 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
56 # OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
57 # OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
58 # OF THE POSSIBILITY OF SUCH DAMAGE.
59 #
60 #
61 
62 from enum import Enum
63 from . import *
64 
65 
66 
75 class Type(Enum):
76 
77  INVALID = 1
78 
79  CHAR = 2
80 
81  INT8 = 3
82 
83  UINT8 = 4
84 
85  INT16 = 5
86 
87  UINT16 = 6
88 
89  INT32 = 7
90 
91  UINT32 = 8
92 
93  INT64 = 9
94 
95  UINT64 = 10
96 
97  FLOAT32 = 11
98 
99  FLOAT64 = 12
100 
101  ENUM = 13
102 
103  SIZE = 14
104 
105  DF_IMAGE= 15
106 
107  BOOL = 16
108 
109  REFERENCE = 17
110 
111  CONTEXT = 18
112 
113  GRAPH = 19
114 
115  NODE = 20
116 
117  KERNEL = 21
118 
119  PARAMETER = 22
120 
121  DELAY = 23
122 
123  LUT = 24
124 
125  DISTRIBUTION = 25
126 
127  PYRAMID = 26
128 
129  THRESHOLD = 27
130 
131  MATRIX = 28
132 
133  CONVOLUTION = 29
134 
135  SCALAR = 30
136 
137  ARRAY = 31
138 
139  IMAGE = 32
140 
141  REMAP = 33
142 
143  ERROR = 34
144 
145  META_FORMAT = 35
146 
147  OBJECT_ARRAY = 36
148 
149  RECTANGLE = 37
150 
151  KEYPOINT = 38
152 
153  COORDINATES2D = 39
154 
155  COORDINATES3D = 40
156 
157  USER_DATA_OBJECT = 41
158 
159  RAW_IMAGE = 42
160 
161  TENSOR = 43
162 
163  NULL = 44
164 
165  def __lt__(self, other):
166  if self.__class__ is other.__class__:
167  return self.value < other.value
168  return NotImplemented
169 
170  def __gt__(self, other):
171  if self.__class__ is other.__class__:
172  return self.value > other.value
173  return NotImplemented
174 
175  def __eq__(self, other):
176  if self.__class__ is other.__class__:
177  return self.value == other.value
178  return NotImplemented
179 
180  def get_vx_enum_name(type) :
181  if type == Type.NULL :
182  return NULL
183  elif type == Type.RAW_IMAGE :
184  return "TIVX_TYPE_" + type.name
185  else :
186  return "VX_TYPE_" + type.name
187 
188  def get_vx_name(type) :
189  if type == Type.RAW_IMAGE :
190  return "tivx_" + type.name.lower()
191  else :
192  return "vx_" + type.name.lower()
193 
194  def is_scalar_type(type) :
195  if type > Type.INVALID and type < Type.REFERENCE :
196  return True
197  if type == Type.SCALAR :
198  return True
199  return False
200 
201  def is_array_type(type) :
202  if type > Type.INVALID and type < Type.REFERENCE :
203  return True
204  if type == Type.RECTANGLE :
205  return True
206  if type == Type.KEYPOINT :
207  return True
208  if type == Type.COORDINATES2D :
209  return True
210  if type == Type.COORDINATES3D :
211  return True
212  return False
213 
214  def get_obj_desc_name(type):
215  if Type.is_scalar_type(type) :
216  type = Type.SCALAR
217  return "tivx_obj_desc_" + type.name.lower() + "_t"
218 
219  def get_scalar_obj_desc_data_name(type) :
220  if Type.is_scalar_type(type) :
221  if type is Type.CHAR :
222  return "chr"
223  if type is Type.INT8 :
224  return "s08"
225  if type is Type.UINT8 :
226  return "u08"
227  if type is Type.INT16:
228  return "s16"
229  if type is Type.UINT16:
230  return "u16"
231  if type is Type.INT32:
232  return "s32"
233  if type is Type.UINT32:
234  return "u32"
235  if type is Type.INT64:
236  return "s64"
237  if type is Type.UINT64:
238  return "u64"
239  if type is Type.FLOAT32:
240  return "f32"
241  if type is Type.FLOAT64:
242  return "f64"
243  if type is Type.ENUM :
244  return "enm"
245  if type is Type.SIZE :
246  return "size"
247  if type is Type.DF_IMAGE:
248  return "fcc"
249  if type is Type.BOOL :
250  return "boolean"
251  return "invalid"
252  return "invalid"
253 
254 
263 class DfImage(Enum) :
264 
265  INVALID = 0
266 
267  VIRT = 1
268 
269  RGB = 2
270 
271  RGBX = 3
272 
273  NV12 = 4
274 
275  NV21 = 5
276 
277  UYVY = 6
278 
279  YUYV = 7
280 
281  IYUV = 8
282 
283  YUV4 = 9
284 
285  U8 = 10
286 
287  U16 = 11
288 
289  S16 = 12
290 
291  U32 = 13
292 
293  S32 = 14
294 
295  P12 = 15
296 
297  NV12_P12 = 16
298 
299  def get_vx_enum_name(df_format) :
300  if df_format == DfImage.P12 or df_format == DfImage.NV12_P12 :
301  return "TIVX_DF_IMAGE_" + df_format.name
302  else :
303  return "VX_DF_IMAGE_" + df_format.name
304 
305  def get_vx_name(df_format) :
306  if df_format == DfImage.P12 or df_format == DfImage.NV12_P12 :
307  return "tivx_df_image_e"
308  else :
309  return "vx_df_image_e"
310 
311  def get_df_enum_from_string(full_df_name) :
312  index = full_df_name.find("VX_DF_IMAGE_")
313  if index == 0 :
314  newstr = full_df_name.replace("VX_DF_IMAGE_", "")
315  if newstr in DfImage.__members__ :
316  return DfImage[newstr]
317  elif index == 2 :
318  newstr = full_df_name.replace("TIVX_DF_IMAGE_", "")
319  if newstr in DfImage.__members__ :
320  return DfImage[newstr]
321  return DfImage.INVALID
322 
323  def get_num_planes(df_format) :
324  if df_format == DfImage.NV12 or df_format == DfImage.NV21 or df_format == DfImage.NV12_P12 :
325  return 2
326  if df_format == DfImage.IYUV or df_format == DfImage.YUV4 :
327  return 3
328  return 1
329 
330 
339 class Channel(Enum) :
340 
341  C0 = 1
342 
343  C1 = 2
344 
345  C2 = 3
346 
347  C3 = 4
348 
349  R = 5
350 
351  G = 6
352 
353  B = 7
354 
355  A = 8
356 
357  Y = 9
358 
359  U = 10
360 
361  V = 11
362 
363  def get_vx_enum_name(type) :
364  if type == Channel.C0 :
365  return "VX_CHANNEL_0"
366  if type == Channel.C1 :
367  return "VX_CHANNEL_1"
368  if type == Channel.C2 :
369  return "VX_CHANNEL_2"
370  if type == Channel.C3 :
371  return "VX_CHANNEL_3"
372  return "VX_CHANNEL_" + type.name
373 
374  def get_vx_name(type) :
375  return "vx_channel_e"
376 
377 class Cpu(Enum) :
378  INVALID = 1
379  DSP1 = 2
380  DSP2 = 3
381  EVE1 = 4
382  EVE2 = 5
383  EVE3 = 6
384  EVE4 = 7
385  A15_0 = 8
386  IPU1_0 = 9
387  IPU1_1 = 10
388  IPU2 = 11
389  DSP_C7_1 = 12
390  A72_0 = 13
391 
392  def get_vx_enum_name(type) :
393  if type.name == "IPU2" :
394  return "TIVX_CPU_ID_IPU2_0"
395  else :
396  return "TIVX_CPU_ID_" + type.name
397 
398 
399 
410 class Target(Enum) :
411 
412  INVALID = 1
413 
414  DSP1 = 2
415 
416  DSP2 = 3
417 
418  EVE1 = 4
419 
420  EVE2 = 5
421 
422  EVE3 = 6
423 
424  EVE4 = 7
425 
426  A15_0 = 8
427 
428  IPU1_0 = 9
429 
430  IPU1_1 = 10
431 
432  IPU2 = 11
433 
435  VPAC_NF = 12
436 
437  VPAC_LDC1 = 13
438 
439  VPAC_LDC2 = 14
440 
441  VPAC_MSC1 = 15
442 
443  VPAC_MSC2 = 16
444 
445  DMPAC_SDE = 17
446 
447  DMPAC_DOF = 18
448 
449  VPAC_VISS1 = 19
450 
451  VDEC = 20
452 
453  DSP_C7_1 = 21
454 
455  A72_0 = 22
456 
458  DEFAULT = DSP1
459 
460  def get_vx_enum_name(type) :
461  return "TIVX_TARGET_" + type.name
462 
463  def get_target_folder_name(type) :
464  if target == Target.DSP1 :
465  return c66
466  if target == Target.DSP2 :
467  return c66
468  if target == Target.EVE1 :
469  return eve
470  if target == Target.EVE2 :
471  return eve
472  if target == Target.EVE3 :
473  return eve
474  if target == Target.EVE4 :
475  return eve
476  if target == Target.A15_0 :
477  return a15
478  if target == Target.IPU1_0 :
479  return ipu
480  if target == Target.IPU1_1 :
481  return ipu
482  if target == Target.IPU2 :
483  return ipu
484  if target == Target.VPAC_NF :
485  return "vpac_nf"
486  if target == Target.VPAC_LDC1 :
487  return "vpac_ldc"
488  if target == Target.VPAC_LDC2 :
489  return "vpac_ldc"
490  if target == Target.VPAC_MSC1 :
491  return "vpac_msc"
492  if target == Target.VPAC_MSC2 :
493  return "vpac_msc"
494  if target == Target.DMPAC_SDE :
495  return "dmpac_sde"
496  if target == Target.DMPAC_DOF :
497  return "dmpac_sde"
498  if target == Target.VPAC_VISS1 :
499  return "vpac_viss"
500  if target == Target.VDEC :
501  return "vdec"
502  if target == Target.DSP_C7_1 :
503  return "c7x"
504  if target == Target.A72_0 :
505  return "a72"
506  return None
507 
508  def is_j6_target(target) :
509  if target == Target.DSP1 :
510  return True
511  if target == Target.DSP2 :
512  return True
513  if target == Target.EVE1 :
514  return True
515  if target == Target.EVE2 :
516  return True
517  if target == Target.EVE3 :
518  return True
519  if target == Target.EVE4 :
520  return True
521  if target == Target.A15_0 :
522  return True
523  if target == Target.IPU1_0 :
524  return True
525  if target == Target.IPU1_1 :
526  return True
527  if target == Target.IPU2 :
528  return True
529 
530  return False
531 
532  def get_cpu(target) :
533  if target == Target.DSP1 :
534  return Cpu.DSP1
535  if target == Target.DSP2 :
536  return Cpu.DSP2
537  if target == Target.EVE1 :
538  return Cpu.EVE1
539  if target == Target.EVE2 :
540  return Cpu.EVE2
541  if target == Target.EVE3 :
542  return Cpu.EVE3
543  if target == Target.EVE4 :
544  return Cpu.EVE4
545  if target == Target.A15_0 :
546  return Cpu.A15_0
547  if target == Target.IPU1_0 :
548  return Cpu.IPU1_0
549  if target == Target.IPU1_1 :
550  return Cpu.IPU1_1
551  if target == Target.IPU2 :
552  return Cpu.IPU2
553  if target == Target.VPAC_NF :
554  return Cpu.IPU1_0
555  if target == Target.VPAC_LDC1 :
556  return Cpu.IPU1_0
557  if target == Target.VPAC_LDC2 :
558  return Cpu.IPU1_0
559  if target == Target.VPAC_MSC1 :
560  return Cpu.IPU1_0
561  if target == Target.VPAC_MSC2 :
562  return Cpu.IPU1_0
563  if target == Target.DMPAC_SDE :
564  return Cpu.IPU1_0
565  if target == Target.DMPAC_DOF :
566  return Cpu.IPU1_0
567  if target == Target.VPAC_VISS1 :
568  return Cpu.IPU1_0
569  if target == Target.VDEC :
570  return Cpu.IPU1_0
571  if target == Target.DSP_C7_1 :
572  return Cpu.DSP_C7_1
573  if target == Target.A72_0 :
574  return Cpu.A72_0
575  return Cpu.INVALID
576 
577 
586 class Policy(Enum) :
587 
588  WRAP = 1
589 
590  SATURATE = 2
591 
592  def get_vx_enum_name(type) :
593  return "VX_CONVERT_POLICY_" + type.name
594 
595  def get_vx_name(type) :
596  return "vx_convert_policy_e"
597 
598 
607 class Round(Enum) :
608 
609  TO_ZERO = 1
610 
611  TO_NEAREST_EVEN = 2
612 
613  def get_vx_enum_name(type) :
614  return "VX_ROUND_POLICY_" + type.name
615 
616  def get_vx_name(type) :
617  return "vx_round_policy_e"
618 
619 
628 class NonLinearFilter(Enum) :
629 
630  MEDIAN = 1
631 
632  MIN = 2
633 
634  MAX = 3
635 
636  def get_vx_enum_name(type) :
637  return "VX_NONLINEAR_FILTER_" + type.name
638 
639  def get_vx_name(type) :
640  return "vx_non_linear_filter_e"
641 
642 
651 class Pattern(Enum) :
652 
653  BOX = 1
654 
655  CROSS = 2
656 
657  DISK = 3
658 
659  OTHER = 4
660 
661  def get_vx_enum_name(type) :
662  return "VX_PATTERN_" + type.name
663 
664  def get_vx_name(type) :
665  return "vx_pattern_e"
666 
667 
676 class InterpolationType(Enum) :
677 
678  NEAREST_NEIGHBOR = 1
679 
680  BILINEAR = 2
681 
682  AREA = 3
683 
684  def get_vx_enum_name(type) :
685  return "VX_INTERPOLATION_" + type.name
686 
687  def get_vx_name(type) :
688  return "vx_interpolation_type_e"
689 
690 
699 class Bool(Enum) :
700 
701  FALSE = 0
702 
703  TRUE = 1
704 
705  def get_vx_enum_name(type) :
706  return "vx_" + type.name.lower() + "_e"
707 
708  def get_vx_name(type) :
709  return "vx_bool"
710 
711 
720 class Norm(Enum):
721 
722  L1 = 1
723 
724  L2 = 2
725 
726  def get_vx_enum_name(type) :
727  return "VX_NORM_" + type.name
728 
729  def get_vx_name(type) :
730  return "vx_norm_e"
731 
732 
741 class Direction(Enum):
742 
743  INPUT = 1
744 
745  OUTPUT = 2
746 
747  BIDIRECTIONAL = 3
748 
749  def get_vx_enum_name(type) :
750  return "VX_" + type.name
751 
752  def get_vx_name(type) :
753  return "vx_direction_e"
754 
755  def get_access_type(type) :
756  if type == Direction.INPUT:
757  return "VX_READ_ONLY"
758  if type == Direction.OUTPUT:
759  return "VX_WRITE_ONLY"
760  if type == Direction.BIDIRECTIONAL:
761  return "VX_READ_WRITE"
762  return "INVALID"
763 
764  def get_doxygen_name(type) :
765  if type == Direction.INPUT:
766  return "in"
767  if type == Direction.OUTPUT:
768  return "out"
769  if type == Direction.BIDIRECTIONAL:
770  return "in,out"
771  return "INVALID"
772 
773 
774 
783 class ParamState(Enum):
784 
785  REQUIRED = 1
786 
787  OPTIONAL = 2
788 
789  def get_vx_enum_name(type) :
790  return "VX_PARAMETER_STATE_" + type.name
791 
792  def get_vx_name(type) :
793  return "vx_parameter_state_e"
794 
795 
804 class PyramidScale(Enum):
805 
806  HALF = 1
807 
808  ORB = 2
809 
810  def get_vx_enum_name(type) :
811  return "VX_SCALE_PYRAMID_" + type.name
812 
813 
822 class ThresholdType(Enum):
823 
824  BINARY = 1
825 
826  RANGE = 2
827 
828  def get_vx_enum_name(type) :
829  return "VX_THRESHOLD_TYPE_" + type.name
830 
831  def get_vx_name(type) :
832  return "vx_threshold_type_e"
833 
834 
844 class TermCriteria(Enum):
845 
846  ITERATIONS = 1
847 
848  EPSILON = 2
849 
850  BOTH = 3
851 
852  def get_vx_enum_name(type) :
853  return "VX_TERM_CRITERIA_" + type.name
854 
855  def get_vx_name(type) :
856  return "vx_termination_criteria_e"
Image channel (OpenVX equivalent = vx_channel_e)
Definition: enums.py:339
Parameter state (OpenVX equivalent = vx_parameter_state_e)
Definition: enums.py:783
Interpolation type (OpenVX equivalent = vx_interpolation_type_e)
Definition: enums.py:676
Target on which to execute a node (TIOVX equivalent = TIVX_TARGET_xxxx)
Definition: enums.py:410
Image data format (OpenVX equivalent = vx_df_image_e)
Definition: enums.py:263
Termination Criteria (OpenVX equivalent = vx_termination_criteria_e)
Definition: enums.py:844
Threshold Type (OpenVX equivalent = vx_threshold_type_e)
Definition: enums.py:822
Boolean type (OpenVX equivalent = vx_bool)
Definition: enums.py:699
Pyramid Scale (OpenVX equivalent = VX_SCALE_PYRAMID_xxx)
Definition: enums.py:804
Normalization type (OpenVX equivalent = vx_norm_type_e)
Definition: enums.py:720
Non linear filter type (OpenVX equivalent = vx_non_linear_filter_e)
Definition: enums.py:628
Object/Data type (OpenVX equivalent = vx_type_e)
Definition: enums.py:75
Conversion Policy (OpenVX equivalent = vx_convert_policy_e)
Definition: enums.py:586
Parameter direction (OpenVX equivalent = vx_direction_e)
Definition: enums.py:741
Round Policy (OpenVX equivalent = vx_round_policy_e)
Definition: enums.py:607
Matrix Patterns (OpenVX equivalent = vx_pattern_e)
Definition: enums.py:651