//=============================================================================
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								//  Copyright (c) 2015-2020 Qualcomm Technologies, Inc.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  All Rights Reserved.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  Confidential and Proprietary - Qualcomm Technologies, Inc.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//=============================================================================
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# ifndef _ITENSOR_HPP_ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# define _ITENSOR_HPP_ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "ITensorItr.hpp" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "ITensorItrImpl.hpp" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "TensorShape.hpp" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "ZdlExportDefine.hpp" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <memory> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <ostream> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <cmath> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								namespace  zdl  { 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								namespace  DlSystem 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   class  ITensor ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} } 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								namespace  zdl  {  namespace  DlSystem 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/** @addtogroup c_plus_plus_apis C++
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@ {  */ 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Represents  a  tensor  which  holds  n - dimensional  data .  It  is  important  to 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  understand  how  the  tensor  data  is  represented  in  memory  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  relative  to  the  tensor  dimensions .  Tensors  store  data  in  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  memory  in  row - major  order  ( i . e .  the  last  tensor  dimension  is  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  the  fastest  varying  one ) .  For  example ,  if  you  have  a  two  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  dimensional  tensor  with  3  rows  and  2  columns  ( i . e .  the  tensor  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  dimensions  are  3 , 2  as  returned  in  tensor  dimension  vectors ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  with  the  following  data  in  terms  rows  and  columns :  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  |  1  2  |  < br / > 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  |  3  4  |  < br / > 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  |  5  6  |  < br / > 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  This  data  would  be  stored  in  memory  as  1 , 2 , 3 , 4 , 5 , 6.  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class  ZDL_EXPORT  ITensor  
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								public : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   typedef  zdl : : DlSystem : : ITensorItr < false >  iterator ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   typedef  zdl : : DlSystem : : ITensorItr < true >  const_iterator ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  ~ ITensor ( )  { } 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  Returns  a  tensor  iterator  pointing  to  the  beginning  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  of  the  data  in  the  tensor . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ return  A  tensor  iterator  that  points  to  the  first  data 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *          element  in  the  tensor . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  iterator  begin ( )  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  Returns  the  const  version  of  a  tensor  iterator  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  pointing  to  the  beginning  of  the  data  in  the  tensor . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ return  A  tensor  const  iterator  that  points  to  the  first  data 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *          element  in  the  tensor . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  const_iterator  cbegin ( )  const  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  Returns  a  tensor  iterator  pointing  to  the  end  of  the 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  data  in  the  tensor .  This  tensor  should  not  be 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  dereferenced . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ return  A  tensor  iterator  that  points  to  the  end  of  the  data  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *          ( one  past  the  last  element )  in  the  tensor . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  iterator  end ( )  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  Returns  the  const  version  of  a  tensor  iterator  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  pointing  to  the  end  of  the  data  in  the  tensor .  This 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  tensor  should  not  be  dereferenced . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ return  A  tensor  const  iterator  that  points  to  the  end  of  the 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *          data  ( one  past  the  last  element )  in  the  tensor . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  const_iterator  cend ( )  const  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ brief  Gets  the  shape  of  this  tensor . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *   
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  The  last  element  of  the  vector  represents  the  fastest  varying 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  dimension  and  the  zeroth  element  represents  the  slowest  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  varying  dimension ,  etc .  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ return  A  shape  class  holding  the  tensor  dimensions . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  TensorShape  getShape ( )  const  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  Returns  the  element  size  of  the  data  in  the  tensor  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  ( discounting  strides ) .  This  is  how  big  a  buffer  would 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  need  to  be  to  hold  the  tensor  data  contiguously  in 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  memory . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *   
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ return  The  size  of  the  tensor  ( in  elements ) . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  size_t  getSize ( )  const  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ brief  Serializes  the  tensor  to  an  output  stream . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ param [ in ]  output  The  output  stream  to  which  to  write  the  tensor  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *   
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ throw  std : : runtime_error  If  the  stream  is  ever  in  a  bad  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *         state  before  the  tensor  is  fully  serialized . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  void  serialize ( std : : ostream  & output )  const  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   friend  iterator ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   friend  const_iterator ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  bool  isQuantized ( )  { return  false ; } 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  float  GetDelta ( )  { return  NAN ; } ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  float  GetOffset ( )  { return  NAN ; } ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								protected : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   /**
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  Returns  the  tensor  iterator  implementation . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  @ return  A  pointer  to  the  tensor  iterator  implementation . 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    */ 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   virtual  std : : unique_ptr < : : DlSystem : : ITensorItrImpl >  getItrImpl ( )  const  =  0 ; 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} ; 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} } 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/** @} */  /* end_addtogroup c_plus_plus_apis C++ */ 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# endif