You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					204 lines
				
				4.7 KiB
			
		
		
			
		
	
	
					204 lines
				
				4.7 KiB
			| 
											6 years ago
										 | //=============================================================================
 | ||
|  | //
 | ||
|  | //  Copyright (c) 2016 Qualcomm Technologies, Inc.
 | ||
|  | //  All Rights Reserved.
 | ||
|  | //  Confidential and Proprietary - Qualcomm Technologies, Inc.
 | ||
|  | //
 | ||
|  | //=============================================================================
 | ||
|  | #include <initializer_list>
 | ||
|  | #include <cstdio>
 | ||
|  | #include <memory>
 | ||
|  | #include <vector>
 | ||
|  | #include "ZdlExportDefine.hpp"
 | ||
|  | 
 | ||
|  | #ifndef DL_SYSTEM_TENSOR_SHAPE_HPP
 | ||
|  | #define DL_SYSTEM_TENSOR_SHAPE_HPP
 | ||
|  | 
 | ||
|  | namespace DlSystem
 | ||
|  | {
 | ||
|  |    // Forward declaration of tensor shape implementation.
 | ||
|  |    class TensorShapeImpl;
 | ||
|  | }
 | ||
|  | 
 | ||
|  | namespace zdl
 | ||
|  | {
 | ||
|  | namespace DlSystem
 | ||
|  | {
 | ||
|  | 
 | ||
|  | /** @addtogroup c_plus_plus_apis C++
 | ||
|  | @{ */
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief .
 | ||
|  |  *
 | ||
|  |  * Convenient typedef to represent dimension
 | ||
|  |  */
 | ||
|  | using Dimension = size_t;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |   * @brief .
 | ||
|  |   *
 | ||
|  |   * A class representing the shape of tensor. It is used at the
 | ||
|  |   * time of creation of tensor.
 | ||
|  |   */
 | ||
|  | class ZDL_EXPORT TensorShape final
 | ||
|  | {
 | ||
|  | public:
 | ||
|  | 
 | ||
|  |     /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Creates a new shape with a list of dims specified in
 | ||
|  |     * initializer list fashion.
 | ||
|  |     *
 | ||
|  |     * @param[in] dims The dimensions are specified in which the last
 | ||
|  |     * element of the vector represents the fastest varying
 | ||
|  |     * dimension and the zeroth element represents the slowest
 | ||
|  |     * varying, etc.
 | ||
|  |     *
 | ||
|  |     */
 | ||
|  |    TensorShape(std::initializer_list<Dimension> dims);
 | ||
|  | 
 | ||
|  |    /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Creates a new shape with a list of dims specified in array
 | ||
|  |     *
 | ||
|  |     * @param[in] dims The dimensions are specified in which the last
 | ||
|  |     * element of the vector represents the fastest varying
 | ||
|  |     * dimension and the zeroth element represents the slowest
 | ||
|  |     * varying, etc.
 | ||
|  |     *
 | ||
|  |     * @param[in] size Size of the array.
 | ||
|  |     *
 | ||
|  |     */
 | ||
|  |    TensorShape(const Dimension *dims, size_t size);
 | ||
|  | 
 | ||
|  |     /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Creates a new shape with a vector of dims specified in
 | ||
|  |     * vector fashion.
 | ||
|  |     *
 | ||
|  |     * @param[in] dims The dimensions are specified in which the last
 | ||
|  |     * element of the vector represents the fastest varying
 | ||
|  |     * dimension and the zeroth element represents the slowest
 | ||
|  |     * varying, etc.
 | ||
|  |     * 
 | ||
|  |     */   
 | ||
|  |    TensorShape(std::vector<Dimension> dims);
 | ||
|  | 
 | ||
|  |    /**
 | ||
|  |    * @brief .
 | ||
|  |    *   
 | ||
|  |    * copy constructor.
 | ||
|  |    * @param[in] other object to copy. 
 | ||
|  |    */   
 | ||
|  |    TensorShape(const TensorShape& other);
 | ||
|  | 
 | ||
|  |    /**
 | ||
|  |     * @brief .
 | ||
|  |     *  
 | ||
|  |     * assignment operator. 
 | ||
|  |     */   
 | ||
|  |    TensorShape& operator=(const TensorShape& other);
 | ||
|  | 
 | ||
|  |     /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Creates a new shape with no dims. It can be extended later
 | ||
|  |     * by invoking concatenate.
 | ||
|  |     */
 | ||
|  |    TensorShape();
 | ||
|  | 
 | ||
|  |   /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Concatenates additional dimensions specified in 
 | ||
|  |     * initializer list fashion to the existing dimensions. 
 | ||
|  |     *
 | ||
|  |     * @param[in] dims The dimensions are specified in which the last
 | ||
|  |     * element of the vector represents the fastest varying
 | ||
|  |     * dimension and the zeroth element represents the slowest
 | ||
|  |     * varying, etc.
 | ||
|  |     *
 | ||
|  |    */
 | ||
|  |    void concatenate(std::initializer_list<Dimension> dims);
 | ||
|  | 
 | ||
|  |    /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Concatenates additional dimensions specified in 
 | ||
|  |     * the array to the existing dimensions. 
 | ||
|  |     *
 | ||
|  |     * @param[in] dims The dimensions are specified in which the last
 | ||
|  |     * element of the vector represents the fastest varying
 | ||
|  |     * dimension and the zeroth element represents the slowest
 | ||
|  |     * varying, etc.
 | ||
|  |     * 
 | ||
|  |     * @param[in] size Size of the array.
 | ||
|  |     *
 | ||
|  |    */
 | ||
|  |    void concatenate(const Dimension *dims, size_t size);
 | ||
|  | 
 | ||
|  |   /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Concatenates an additional dimension to the existing
 | ||
|  |     * dimensions.
 | ||
|  |     *
 | ||
|  |     * @param[in] dim The dimensions are specified in which the last element
 | ||
|  |     * of the vector represents the fastest varying dimension and the
 | ||
|  |     * zeroth element represents the slowest varying, etc.
 | ||
|  |     *
 | ||
|  |    */
 | ||
|  |    void concatenate(const Dimension &dim);
 | ||
|  | 
 | ||
|  |   /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Retrieves a single dimension, based on its index.
 | ||
|  |     *
 | ||
|  |     * @return The value of dimension
 | ||
|  |     *
 | ||
|  |     * @throws std::out_of_range if the index is >= the number of
 | ||
|  |     * dimensions (or rank).
 | ||
|  |     */
 | ||
|  |    Dimension& operator[](size_t index);
 | ||
|  |    Dimension& operator[](size_t index) const;
 | ||
|  | 
 | ||
|  |   /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Retrieves the rank i.e. number of dimensions.
 | ||
|  |     *
 | ||
|  |     * @return The rank
 | ||
|  |     */
 | ||
|  |    size_t rank() const;
 | ||
|  | 
 | ||
|  |   /**
 | ||
|  |     * @brief .
 | ||
|  |     *
 | ||
|  |     * Retrieves a pointer to the first dimension of shape
 | ||
|  |     *
 | ||
|  |     * @return nullptr if no dimension exists; otherwise, points to
 | ||
|  |     * the first dimension. 
 | ||
|  |     *
 | ||
|  |     */
 | ||
|  |    const Dimension* getDimensions() const;
 | ||
|  | 
 | ||
|  |    ~TensorShape();
 | ||
|  | 
 | ||
|  | private:
 | ||
|  |    void swap(const TensorShape &other);
 | ||
|  |    std::unique_ptr<::DlSystem::TensorShapeImpl> m_TensorShapeImpl;
 | ||
|  | };
 | ||
|  | 
 | ||
|  | } // DlSystem namespace
 | ||
|  | } // zdl namespace
 | ||
|  | 
 | ||
|  | /** @} */ /* end_addtogroup c_plus_plus_apis C++ */
 | ||
|  | 
 | ||
|  | #endif // DL_SYSTEM_TENSOR_SHAPE_HPP
 | ||
|  | 
 |