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  VDEC1 = 20
452 
453  VDEC2 = 21
454 
455  VENC1 = 22
456 
457  VENC2 = 23
458 
459  DSP_C7_1 = 24
460 
461  A72_0 = 25
462 
464  DEFAULT = DSP1
465 
466  def get_vx_enum_name(type) :
467  return "TIVX_TARGET_" + type.name
468 
469  def get_target_folder_name(type) :
470  if target == Target.DSP1 :
471  return c66
472  if target == Target.DSP2 :
473  return c66
474  if target == Target.EVE1 :
475  return eve
476  if target == Target.EVE2 :
477  return eve
478  if target == Target.EVE3 :
479  return eve
480  if target == Target.EVE4 :
481  return eve
482  if target == Target.A15_0 :
483  return a15
484  if target == Target.IPU1_0 :
485  return ipu
486  if target == Target.IPU1_1 :
487  return ipu
488  if target == Target.IPU2 :
489  return ipu
490  if target == Target.VPAC_NF :
491  return "vpac_nf"
492  if target == Target.VPAC_LDC1 :
493  return "vpac_ldc"
494  if target == Target.VPAC_LDC2 :
495  return "vpac_ldc"
496  if target == Target.VPAC_MSC1 :
497  return "vpac_msc"
498  if target == Target.VPAC_MSC2 :
499  return "vpac_msc"
500  if target == Target.DMPAC_SDE :
501  return "dmpac_sde"
502  if target == Target.DMPAC_DOF :
503  return "dmpac_sde"
504  if target == Target.VPAC_VISS1 :
505  return "vpac_viss"
506  if target == Target.VDEC1 :
507  return "vdec"
508  if target == Target.VDEC2 :
509  return "vdec"
510  if target == Target.VENC1 :
511  return "venc"
512  if target == Target.VENC2 :
513  return "venc"
514  if target == Target.DSP_C7_1 :
515  return "c7x"
516  if target == Target.A72_0 :
517  return "a72"
518  return None
519 
520  def is_j6_target(target) :
521  if target == Target.DSP1 :
522  return True
523  if target == Target.DSP2 :
524  return True
525  if target == Target.EVE1 :
526  return True
527  if target == Target.EVE2 :
528  return True
529  if target == Target.EVE3 :
530  return True
531  if target == Target.EVE4 :
532  return True
533  if target == Target.A15_0 :
534  return True
535  if target == Target.IPU1_0 :
536  return True
537  if target == Target.IPU1_1 :
538  return True
539  if target == Target.IPU2 :
540  return True
541 
542  return False
543 
544  def get_cpu(target) :
545  if target == Target.DSP1 :
546  return Cpu.DSP1
547  if target == Target.DSP2 :
548  return Cpu.DSP2
549  if target == Target.EVE1 :
550  return Cpu.EVE1
551  if target == Target.EVE2 :
552  return Cpu.EVE2
553  if target == Target.EVE3 :
554  return Cpu.EVE3
555  if target == Target.EVE4 :
556  return Cpu.EVE4
557  if target == Target.A15_0 :
558  return Cpu.A15_0
559  if target == Target.IPU1_0 :
560  return Cpu.IPU1_0
561  if target == Target.IPU1_1 :
562  return Cpu.IPU1_1
563  if target == Target.IPU2 :
564  return Cpu.IPU2
565  if target == Target.VPAC_NF :
566  return Cpu.IPU1_0
567  if target == Target.VPAC_LDC1 :
568  return Cpu.IPU1_0
569  if target == Target.VPAC_LDC2 :
570  return Cpu.IPU1_0
571  if target == Target.VPAC_MSC1 :
572  return Cpu.IPU1_0
573  if target == Target.VPAC_MSC2 :
574  return Cpu.IPU1_0
575  if target == Target.DMPAC_SDE :
576  return Cpu.IPU1_0
577  if target == Target.DMPAC_DOF :
578  return Cpu.IPU1_0
579  if target == Target.VPAC_VISS1 :
580  return Cpu.IPU1_0
581  if target == Target.VDEC1 :
582  return Cpu.IPU1_0
583  if target == Target.VDEC2 :
584  return Cpu.IPU1_0
585  if target == Target.VENC1 :
586  return Cpu.IPU1_0
587  if target == Target.VENC2 :
588  return Cpu.IPU1_0
589  if target == Target.DSP_C7_1 :
590  return Cpu.DSP_C7_1
591  if target == Target.A72_0 :
592  return Cpu.A72_0
593  return Cpu.INVALID
594 
595 
604 class Policy(Enum) :
605 
606  WRAP = 1
607 
608  SATURATE = 2
609 
610  def get_vx_enum_name(type) :
611  return "VX_CONVERT_POLICY_" + type.name
612 
613  def get_vx_name(type) :
614  return "vx_convert_policy_e"
615 
616 
625 class Round(Enum) :
626 
627  TO_ZERO = 1
628 
629  TO_NEAREST_EVEN = 2
630 
631  def get_vx_enum_name(type) :
632  return "VX_ROUND_POLICY_" + type.name
633 
634  def get_vx_name(type) :
635  return "vx_round_policy_e"
636 
637 
646 class NonLinearFilter(Enum) :
647 
648  MEDIAN = 1
649 
650  MIN = 2
651 
652  MAX = 3
653 
654  def get_vx_enum_name(type) :
655  return "VX_NONLINEAR_FILTER_" + type.name
656 
657  def get_vx_name(type) :
658  return "vx_non_linear_filter_e"
659 
660 
669 class Pattern(Enum) :
670 
671  BOX = 1
672 
673  CROSS = 2
674 
675  DISK = 3
676 
677  OTHER = 4
678 
679  def get_vx_enum_name(type) :
680  return "VX_PATTERN_" + type.name
681 
682  def get_vx_name(type) :
683  return "vx_pattern_e"
684 
685 
694 class InterpolationType(Enum) :
695 
696  NEAREST_NEIGHBOR = 1
697 
698  BILINEAR = 2
699 
700  AREA = 3
701 
702  def get_vx_enum_name(type) :
703  return "VX_INTERPOLATION_" + type.name
704 
705  def get_vx_name(type) :
706  return "vx_interpolation_type_e"
707 
708 
717 class Bool(Enum) :
718 
719  FALSE = 0
720 
721  TRUE = 1
722 
723  def get_vx_enum_name(type) :
724  return "vx_" + type.name.lower() + "_e"
725 
726  def get_vx_name(type) :
727  return "vx_bool"
728 
729 
738 class Norm(Enum):
739 
740  L1 = 1
741 
742  L2 = 2
743 
744  def get_vx_enum_name(type) :
745  return "VX_NORM_" + type.name
746 
747  def get_vx_name(type) :
748  return "vx_norm_e"
749 
750 
759 class Direction(Enum):
760 
761  INPUT = 1
762 
763  OUTPUT = 2
764 
765  BIDIRECTIONAL = 3
766 
767  def get_vx_enum_name(type) :
768  return "VX_" + type.name
769 
770  def get_vx_name(type) :
771  return "vx_direction_e"
772 
773  def get_access_type(type) :
774  if type == Direction.INPUT:
775  return "VX_READ_ONLY"
776  if type == Direction.OUTPUT:
777  return "VX_WRITE_ONLY"
778  if type == Direction.BIDIRECTIONAL:
779  return "VX_READ_WRITE"
780  return "INVALID"
781 
782  def get_doxygen_name(type) :
783  if type == Direction.INPUT:
784  return "in"
785  if type == Direction.OUTPUT:
786  return "out"
787  if type == Direction.BIDIRECTIONAL:
788  return "in,out"
789  return "INVALID"
790 
791 
792 
801 class ParamState(Enum):
802 
803  REQUIRED = 1
804 
805  OPTIONAL = 2
806 
807  def get_vx_enum_name(type) :
808  return "VX_PARAMETER_STATE_" + type.name
809 
810  def get_vx_name(type) :
811  return "vx_parameter_state_e"
812 
813 
822 class PyramidScale(Enum):
823 
824  HALF = 1
825 
826  ORB = 2
827 
828  def get_vx_enum_name(type) :
829  return "VX_SCALE_PYRAMID_" + type.name
830 
831 
840 class ThresholdType(Enum):
841 
842  BINARY = 1
843 
844  RANGE = 2
845 
846  def get_vx_enum_name(type) :
847  return "VX_THRESHOLD_TYPE_" + type.name
848 
849  def get_vx_name(type) :
850  return "vx_threshold_type_e"
851 
852 
862 class TermCriteria(Enum):
863 
864  ITERATIONS = 1
865 
866  EPSILON = 2
867 
868  BOTH = 3
869 
870  def get_vx_enum_name(type) :
871  return "VX_TERM_CRITERIA_" + type.name
872 
873  def get_vx_name(type) :
874  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:801
Interpolation type (OpenVX equivalent = vx_interpolation_type_e)
Definition: enums.py:694
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:862
Threshold Type (OpenVX equivalent = vx_threshold_type_e)
Definition: enums.py:840
Boolean type (OpenVX equivalent = vx_bool)
Definition: enums.py:717
Pyramid Scale (OpenVX equivalent = VX_SCALE_PYRAMID_xxx)
Definition: enums.py:822
Normalization type (OpenVX equivalent = vx_norm_type_e)
Definition: enums.py:738
Non linear filter type (OpenVX equivalent = vx_non_linear_filter_e)
Definition: enums.py:646
Object/Data type (OpenVX equivalent = vx_type_e)
Definition: enums.py:75
Conversion Policy (OpenVX equivalent = vx_convert_policy_e)
Definition: enums.py:604
Parameter direction (OpenVX equivalent = vx_direction_e)
Definition: enums.py:759
Round Policy (OpenVX equivalent = vx_round_policy_e)
Definition: enums.py:625
Matrix Patterns (OpenVX equivalent = vx_pattern_e)
Definition: enums.py:669