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  RGB565 = 17
300 
301  BGRX = 18
302 
303  def get_vx_enum_name(df_format) :
304  if df_format == DfImage.P12 or df_format == DfImage.NV12_P12 or df_format == DfImage.RGB565 or df_format == DfImage.BGRX :
305  return "TIVX_DF_IMAGE_" + df_format.name
306  else :
307  return "VX_DF_IMAGE_" + df_format.name
308 
309  def get_vx_name(df_format) :
310  if df_format == DfImage.P12 or df_format == DfImage.NV12_P12 or df_format == DfImage.RGB565 or df_format == DfImage.BGRX :
311  return "tivx_df_image_e"
312  else :
313  return "vx_df_image_e"
314 
315  def get_df_enum_from_string(full_df_name) :
316  index = full_df_name.find("VX_DF_IMAGE_")
317  if index == 0 :
318  newstr = full_df_name.replace("VX_DF_IMAGE_", "")
319  if newstr in DfImage.__members__ :
320  return DfImage[newstr]
321  elif index == 2 :
322  newstr = full_df_name.replace("TIVX_DF_IMAGE_", "")
323  if newstr in DfImage.__members__ :
324  return DfImage[newstr]
325  return DfImage.INVALID
326 
327  def get_num_planes(df_format) :
328  if df_format == DfImage.NV12 or df_format == DfImage.NV21 or df_format == DfImage.NV12_P12 :
329  return 2
330  if df_format == DfImage.IYUV or df_format == DfImage.YUV4 :
331  return 3
332  return 1
333 
334 
343 class Channel(Enum) :
344 
345  C0 = 1
346 
347  C1 = 2
348 
349  C2 = 3
350 
351  C3 = 4
352 
353  R = 5
354 
355  G = 6
356 
357  B = 7
358 
359  A = 8
360 
361  Y = 9
362 
363  U = 10
364 
365  V = 11
366 
367  def get_vx_enum_name(type) :
368  if type == Channel.C0 :
369  return "VX_CHANNEL_0"
370  if type == Channel.C1 :
371  return "VX_CHANNEL_1"
372  if type == Channel.C2 :
373  return "VX_CHANNEL_2"
374  if type == Channel.C3 :
375  return "VX_CHANNEL_3"
376  return "VX_CHANNEL_" + type.name
377 
378  def get_vx_name(type) :
379  return "vx_channel_e"
380 
381 class Cpu(Enum) :
382  INVALID = 1
383  DSP1 = 2
384  DSP2 = 3
385  EVE1 = 4
386  EVE2 = 5
387  EVE3 = 6
388  EVE4 = 7
389  A15_0 = 8
390  MCU2_0 = 9
391  MCU2_1 = 10
392  IPU2 = 11
393  DSP_C7_1 = 12
394  MPU_0 = 13
395 
396  def get_vx_enum_name(type) :
397  if type.name == "IPU2" :
398  return "TIVX_CPU_ID_IPU2_0"
399  else :
400  return "TIVX_CPU_ID_" + type.name
401 
402 
403 
414 class Target(Enum) :
415 
416  INVALID = 1
417 
418  DSP1 = 2
419 
420  DSP2 = 3
421 
422  EVE1 = 4
423 
424  EVE2 = 5
425 
426  EVE3 = 6
427 
428  EVE4 = 7
429 
430  A15_0 = 8
431 
432  MCU2_0 = 9
433 
434  MCU2_1 = 10
435 
436  IPU2 = 11
437 
439  VPAC_NF = 12
440 
441  VPAC_LDC1 = 13
442 
443  VPAC_LDC2 = 14
444 
445  VPAC_MSC1 = 15
446 
447  VPAC_MSC2 = 16
448 
449  DMPAC_SDE = 17
450 
451  DMPAC_DOF = 18
452 
453  VPAC_VISS1 = 19
454 
455  DSP_C7_1 = 24
456 
457  MPU_0 = 25
458 
460  DEFAULT = DSP1
461 
462  def get_vx_enum_name(type) :
463  return "TIVX_TARGET_" + type.name
464 
465  def get_target_folder_name(type) :
466  if target == Target.DSP1 :
467  return c66
468  if target == Target.DSP2 :
469  return c66
470  if target == Target.EVE1 :
471  return eve
472  if target == Target.EVE2 :
473  return eve
474  if target == Target.EVE3 :
475  return eve
476  if target == Target.EVE4 :
477  return eve
478  if target == Target.A15_0 :
479  return a15
480  if target == Target.MCU2_0 :
481  return ipu
482  if target == Target.MCU2_1 :
483  return ipu
484  if target == Target.IPU2 :
485  return ipu
486  if target == Target.VPAC_NF :
487  return "vpac_nf"
488  if target == Target.VPAC_LDC1 :
489  return "vpac_ldc"
490  if target == Target.VPAC_LDC2 :
491  return "vpac_ldc"
492  if target == Target.VPAC_MSC1 :
493  return "vpac_msc"
494  if target == Target.VPAC_MSC2 :
495  return "vpac_msc"
496  if target == Target.DMPAC_SDE :
497  return "dmpac_sde"
498  if target == Target.DMPAC_DOF :
499  return "dmpac_sde"
500  if target == Target.VPAC_VISS1 :
501  return "vpac_viss"
502  if target == Target.DSP_C7_1 :
503  return "c7x"
504  if target == Target.MPU_0 :
505  return "mpu"
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.MCU2_0 :
524  return True
525  if target == Target.MCU2_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.MCU2_0 :
548  return Cpu.MCU2_0
549  if target == Target.MCU2_1 :
550  return Cpu.MCU2_1
551  if target == Target.IPU2 :
552  return Cpu.IPU2
553  if target == Target.VPAC_NF :
554  return Cpu.MCU2_0
555  if target == Target.VPAC_LDC1 :
556  return Cpu.MCU2_0
557  if target == Target.VPAC_LDC2 :
558  return Cpu.MCU2_0
559  if target == Target.VPAC_MSC1 :
560  return Cpu.MCU2_0
561  if target == Target.VPAC_MSC2 :
562  return Cpu.MCU2_0
563  if target == Target.DMPAC_SDE :
564  return Cpu.MCU2_0
565  if target == Target.DMPAC_DOF :
566  return Cpu.MCU2_0
567  if target == Target.VPAC_VISS1 :
568  return Cpu.MCU2_0
569  if target == Target.DSP_C7_1 :
570  return Cpu.DSP_C7_1
571  if target == Target.MPU_0 :
572  return Cpu.MPU_0
573  return Cpu.INVALID
574 
575 
584 class Policy(Enum) :
585 
586  WRAP = 1
587 
588  SATURATE = 2
589 
590  def get_vx_enum_name(type) :
591  return "VX_CONVERT_POLICY_" + type.name
592 
593  def get_vx_name(type) :
594  return "vx_convert_policy_e"
595 
596 
605 class Round(Enum) :
606 
607  TO_ZERO = 1
608 
609  TO_NEAREST_EVEN = 2
610 
611  def get_vx_enum_name(type) :
612  return "VX_ROUND_POLICY_" + type.name
613 
614  def get_vx_name(type) :
615  return "vx_round_policy_e"
616 
617 
626 class NonLinearFilter(Enum) :
627 
628  MEDIAN = 1
629 
630  MIN = 2
631 
632  MAX = 3
633 
634  def get_vx_enum_name(type) :
635  return "VX_NONLINEAR_FILTER_" + type.name
636 
637  def get_vx_name(type) :
638  return "vx_non_linear_filter_e"
639 
640 
649 class Pattern(Enum) :
650 
651  BOX = 1
652 
653  CROSS = 2
654 
655  DISK = 3
656 
657  OTHER = 4
658 
659  def get_vx_enum_name(type) :
660  return "VX_PATTERN_" + type.name
661 
662  def get_vx_name(type) :
663  return "vx_pattern_e"
664 
665 
674 class InterpolationType(Enum) :
675 
676  NEAREST_NEIGHBOR = 1
677 
678  BILINEAR = 2
679 
680  AREA = 3
681 
682  def get_vx_enum_name(type) :
683  return "VX_INTERPOLATION_" + type.name
684 
685  def get_vx_name(type) :
686  return "vx_interpolation_type_e"
687 
688 
697 class Bool(Enum) :
698 
699  FALSE = 0
700 
701  TRUE = 1
702 
703  def get_vx_enum_name(type) :
704  return "vx_" + type.name.lower() + "_e"
705 
706  def get_vx_name(type) :
707  return "vx_bool"
708 
709 
718 class Norm(Enum):
719 
720  L1 = 1
721 
722  L2 = 2
723 
724  def get_vx_enum_name(type) :
725  return "VX_NORM_" + type.name
726 
727  def get_vx_name(type) :
728  return "vx_norm_e"
729 
730 
739 class Direction(Enum):
740 
741  INPUT = 1
742 
743  OUTPUT = 2
744 
745  BIDIRECTIONAL = 3
746 
747  def get_vx_enum_name(type) :
748  return "VX_" + type.name
749 
750  def get_vx_name(type) :
751  return "vx_direction_e"
752 
753  def get_access_type(type) :
754  if type == Direction.INPUT:
755  return "VX_READ_ONLY"
756  if type == Direction.OUTPUT:
757  return "VX_WRITE_ONLY"
758  if type == Direction.BIDIRECTIONAL:
759  return "VX_READ_WRITE"
760  return "INVALID"
761 
762  def get_doxygen_name(type) :
763  if type == Direction.INPUT:
764  return "in"
765  if type == Direction.OUTPUT:
766  return "out"
767  if type == Direction.BIDIRECTIONAL:
768  return "in,out"
769  return "INVALID"
770 
771 
772 
781 class ParamState(Enum):
782 
783  REQUIRED = 1
784 
785  OPTIONAL = 2
786 
787  def get_vx_enum_name(type) :
788  return "VX_PARAMETER_STATE_" + type.name
789 
790  def get_vx_name(type) :
791  return "vx_parameter_state_e"
792 
793 
802 class PyramidScale(Enum):
803 
804  HALF = 1
805 
806  ORB = 2
807 
808  def get_vx_enum_name(type) :
809  return "VX_SCALE_PYRAMID_" + type.name
810 
811 
820 class ThresholdType(Enum):
821 
822  BINARY = 1
823 
824  RANGE = 2
825 
826  def get_vx_enum_name(type) :
827  return "VX_THRESHOLD_TYPE_" + type.name
828 
829  def get_vx_name(type) :
830  return "vx_threshold_type_e"
831 
832 
842 class TermCriteria(Enum):
843 
844  ITERATIONS = 1
845 
846  EPSILON = 2
847 
848  BOTH = 3
849 
850  def get_vx_enum_name(type) :
851  return "VX_TERM_CRITERIA_" + type.name
852 
853  def get_vx_name(type) :
854  return "vx_termination_criteria_e"
Image channel (OpenVX equivalent = vx_channel_e)
Definition: enums.py:343
Parameter state (OpenVX equivalent = vx_parameter_state_e)
Definition: enums.py:781
Interpolation type (OpenVX equivalent = vx_interpolation_type_e)
Definition: enums.py:674
Target on which to execute a node (TIOVX equivalent = TIVX_TARGET_xxxx)
Definition: enums.py:414
Image data format (OpenVX equivalent = vx_df_image_e)
Definition: enums.py:263
Termination Criteria (OpenVX equivalent = vx_termination_criteria_e)
Definition: enums.py:842
Threshold Type (OpenVX equivalent = vx_threshold_type_e)
Definition: enums.py:820
Boolean type (OpenVX equivalent = vx_bool)
Definition: enums.py:697
Pyramid Scale (OpenVX equivalent = VX_SCALE_PYRAMID_xxx)
Definition: enums.py:802
Normalization type (OpenVX equivalent = vx_norm_type_e)
Definition: enums.py:718
Non linear filter type (OpenVX equivalent = vx_non_linear_filter_e)
Definition: enums.py:626
Object/Data type (OpenVX equivalent = vx_type_e)
Definition: enums.py:75
Conversion Policy (OpenVX equivalent = vx_convert_policy_e)
Definition: enums.py:584
Parameter direction (OpenVX equivalent = vx_direction_e)
Definition: enums.py:739
Round Policy (OpenVX equivalent = vx_round_policy_e)
Definition: enums.py:605
Matrix Patterns (OpenVX equivalent = vx_pattern_e)
Definition: enums.py:649