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  RGBA = 19
304 
305  def get_vx_enum_name(df_format) :
306  if df_format == DfImage.P12 or df_format == DfImage.NV12_P12 or df_format == DfImage.RGB565 or df_format == DfImage.BGRX :
307  return "TIVX_DF_IMAGE_" + df_format.name
308  else :
309  return "VX_DF_IMAGE_" + df_format.name
310 
311  def get_vx_name(df_format) :
312  if df_format == DfImage.P12 or df_format == DfImage.NV12_P12 or df_format == DfImage.RGB565 or df_format == DfImage.BGRX :
313  return "tivx_df_image_e"
314  else :
315  return "vx_df_image_e"
316 
317  def get_df_enum_from_string(full_df_name) :
318  index = full_df_name.find("VX_DF_IMAGE_")
319  if index == 0 :
320  newstr = full_df_name.replace("VX_DF_IMAGE_", "")
321  if newstr in DfImage.__members__ :
322  return DfImage[newstr]
323  elif index == 2 :
324  newstr = full_df_name.replace("TIVX_DF_IMAGE_", "")
325  if newstr in DfImage.__members__ :
326  return DfImage[newstr]
327  return DfImage.INVALID
328 
329  def get_num_planes(df_format) :
330  if df_format == DfImage.NV12 or df_format == DfImage.NV21 or df_format == DfImage.NV12_P12 :
331  return 2
332  if df_format == DfImage.IYUV or df_format == DfImage.YUV4 :
333  return 3
334  return 1
335 
336 
345 class Channel(Enum) :
346 
347  C0 = 1
348 
349  C1 = 2
350 
351  C2 = 3
352 
353  C3 = 4
354 
355  R = 5
356 
357  G = 6
358 
359  B = 7
360 
361  A = 8
362 
363  Y = 9
364 
365  U = 10
366 
367  V = 11
368 
369  def get_vx_enum_name(type) :
370  if type == Channel.C0 :
371  return "VX_CHANNEL_0"
372  if type == Channel.C1 :
373  return "VX_CHANNEL_1"
374  if type == Channel.C2 :
375  return "VX_CHANNEL_2"
376  if type == Channel.C3 :
377  return "VX_CHANNEL_3"
378  return "VX_CHANNEL_" + type.name
379 
380  def get_vx_name(type) :
381  return "vx_channel_e"
382 
383 class Cpu(Enum) :
384  INVALID = 1
385  DSP1 = 2
386  DSP2 = 3
387  EVE1 = 4
388  EVE2 = 5
389  EVE3 = 6
390  EVE4 = 7
391  A15_0 = 8
392  MCU2_0 = 9
393  MCU2_1 = 10
394  IPU2 = 11
395  DSP_C7_1 = 12
396  MPU_0 = 13
397 
398  def get_vx_enum_name(type) :
399  if type.name == "IPU2" :
400  return "TIVX_CPU_ID_IPU2_0"
401  else :
402  return "TIVX_CPU_ID_" + type.name
403 
404 
405 
416 class Target(Enum) :
417 
418  INVALID = 1
419 
420  DSP1 = 2
421 
422  DSP2 = 3
423 
424  EVE1 = 4
425 
426  EVE2 = 5
427 
428  EVE3 = 6
429 
430  EVE4 = 7
431 
432  A15_0 = 8
433 
434  MCU2_0 = 9
435 
436  MCU2_1 = 10
437 
438  IPU2 = 11
439 
441  VPAC_NF = 12
442 
443  VPAC_LDC1 = 13
444 
445  VPAC_LDC2 = 14
446 
447  VPAC_MSC1 = 15
448 
449  VPAC_MSC2 = 16
450 
451  DMPAC_SDE = 17
452 
453  DMPAC_DOF = 18
454 
455  VPAC_VISS1 = 19
456 
457  DSP_C7_1 = 24
458 
459  MPU_0 = 25
460 
462  DEFAULT = DSP1
463 
464  def get_vx_enum_name(type) :
465  return "TIVX_TARGET_" + type.name
466 
467  def get_target_folder_name(type) :
468  if target == Target.DSP1 :
469  return c66
470  if target == Target.DSP2 :
471  return c66
472  if target == Target.EVE1 :
473  return eve
474  if target == Target.EVE2 :
475  return eve
476  if target == Target.EVE3 :
477  return eve
478  if target == Target.EVE4 :
479  return eve
480  if target == Target.A15_0 :
481  return a15
482  if target == Target.MCU2_0 :
483  return ipu
484  if target == Target.MCU2_1 :
485  return ipu
486  if target == Target.IPU2 :
487  return ipu
488  if target == Target.VPAC_NF :
489  return "vpac_nf"
490  if target == Target.VPAC_LDC1 :
491  return "vpac_ldc"
492  if target == Target.VPAC_LDC2 :
493  return "vpac_ldc"
494  if target == Target.VPAC_MSC1 :
495  return "vpac_msc"
496  if target == Target.VPAC_MSC2 :
497  return "vpac_msc"
498  if target == Target.DMPAC_SDE :
499  return "dmpac_sde"
500  if target == Target.DMPAC_DOF :
501  return "dmpac_sde"
502  if target == Target.VPAC_VISS1 :
503  return "vpac_viss"
504  if target == Target.DSP_C7_1 :
505  return "c7x"
506  if target == Target.MPU_0 :
507  return "mpu"
508  return None
509 
510  def is_j6_target(target) :
511  if target == Target.DSP1 :
512  return True
513  if target == Target.DSP2 :
514  return True
515  if target == Target.EVE1 :
516  return True
517  if target == Target.EVE2 :
518  return True
519  if target == Target.EVE3 :
520  return True
521  if target == Target.EVE4 :
522  return True
523  if target == Target.A15_0 :
524  return True
525  if target == Target.MCU2_0 :
526  return True
527  if target == Target.MCU2_1 :
528  return True
529  if target == Target.IPU2 :
530  return True
531 
532  return False
533 
534  def get_cpu(target) :
535  if target == Target.DSP1 :
536  return Cpu.DSP1
537  if target == Target.DSP2 :
538  return Cpu.DSP2
539  if target == Target.EVE1 :
540  return Cpu.EVE1
541  if target == Target.EVE2 :
542  return Cpu.EVE2
543  if target == Target.EVE3 :
544  return Cpu.EVE3
545  if target == Target.EVE4 :
546  return Cpu.EVE4
547  if target == Target.A15_0 :
548  return Cpu.A15_0
549  if target == Target.MCU2_0 :
550  return Cpu.MCU2_0
551  if target == Target.MCU2_1 :
552  return Cpu.MCU2_1
553  if target == Target.IPU2 :
554  return Cpu.IPU2
555  if target == Target.VPAC_NF :
556  return Cpu.MCU2_0
557  if target == Target.VPAC_LDC1 :
558  return Cpu.MCU2_0
559  if target == Target.VPAC_LDC2 :
560  return Cpu.MCU2_0
561  if target == Target.VPAC_MSC1 :
562  return Cpu.MCU2_0
563  if target == Target.VPAC_MSC2 :
564  return Cpu.MCU2_0
565  if target == Target.DMPAC_SDE :
566  return Cpu.MCU2_0
567  if target == Target.DMPAC_DOF :
568  return Cpu.MCU2_0
569  if target == Target.VPAC_VISS1 :
570  return Cpu.MCU2_0
571  if target == Target.DSP_C7_1 :
572  return Cpu.DSP_C7_1
573  if target == Target.MPU_0 :
574  return Cpu.MPU_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:345
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:416
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