1. 13 Apr, 2018 1 commit
    • Chris Sullivan's avatar
      Add GPURuntimeContext and GPUPrimitiveEmitter to the gpu transformer (#837) · 026bede0
      Chris Sullivan authored
      * Begin prototype of cudnn_emitter.
      
      * Added GPURuntimeContext to gpu_external_function for passing through to JIT functions.
      
      * gpu_emitters now utilize gpu runtime context.
      
      * Moved cublas and cudnn handles into GPURuntimeContext pointer and out of callframe EntryPoint.
      
      * Added CUDNNEmitter, comparable to MKLDNNEmitter,
      which allows for cudnn kernels to be defined via
      lambda primitives that are emitted and
      subsequently called during graph execution.
      An example implementation is provided for op::Sum.
      
      * Added GPURuntimeContext to gpu_external_function for passing through to JIT functions.
      
      * gpu_emitters now utilize gpu runtime context.
      
      * Moved cublas and cudnn handles into GPURuntimeContext pointer and out of callframe EntryPoint.
      
      * GPURuntimeContext should be stored as unique_ptr in external function.
      
      * GPURuntimeContext should be stored as unique_ptr in external function.
      
      * Extract raw pointer from unique for cudnn_emitter.
      
      * Removing unrelated code from PR.
      
      * GPURuntimeContext needs to be a strict C interface in case
      the native compiler and clang are utilizing different glibc ABIs.
      Updated to reflect this.
      
      * Added cudnn::primitive typedef for better readability.
      
      * Moved allocation of CudaFunctionPool to external function
      so that it is available during gpu emission.
      
      * Fixed too-late initialization of cudart.
      
      * Fixed too-late initialization of cudart.
      
      * CUDNNEmitter moved into superset class GPUPrimitiveEmitter.
      The GPUPrimitiveEmitter handles the emission of all gpu primitives,
      including cudnn, cuda, and cublas. CUBLASEmitter support not yet included.
      
      * Added unordered_map for cacheing primitives in the gpu_emitter.
      
      * Added dtor to GPUPrimitiveEmitter to cleanup compiled functions.
      
      * Adding back a serialized model graph that was accidentally rem* Added a few additional helpers to use ngraph::row_major_strides.
      
      * added whitespace per @fengleitian's comment
      
      * added whitespace per @fengleitian's comment
      
      * Remove implicit type conversions from size_t to int.
      
      * Add op::MaxPool, op::MaxPoolBackprop and op::Pad to GPU transformer (#817)
      
      * Added pooling for 1 and 2dimensions. 1d uses a cuda kernel and 2d utilizes cudnn.
      Padding is not yet supported.
      
      * Normalized call signature on gpu emission for 1d max pool. Added a few comments.
      
      * Max pool backprop impl. inprogress. Amend this commit.
      
      * Max pool backprop implemented. Note that cuDNN
      requests the output tensor for the maxpool operation but it is not required for computation.
      
      * Formatting and invokation for maxpool changed.
      
      * Fixed too-late initialization of cudart.
      
      * Added padding kernel that is used with maxpool. Need to investigate remaining tests.
      
      * Changed dimensionality check to correctly
      determine if data is 1d or not.
      
      * Added 3d MaxPooling (forward), verified by forcing 2d case to use Nd pooling routines.
      
      * Added 3d MaxPooling (backward), verified by forcing 2d case to use Nd pooling routines.
      
      * Moved cudnn prologues for maxpool into ngraph runtime and out of primitive so
      that the only execution occuring on the JIT runtime is the evaluation of the op kernel.
      
      * Refactored forward and backward pooling into single CUDNNEmitter::build_pooling interface
      with a runtime switch to determine if the op is forward or backward propagation.
      
      * Cache preconstructed cudnn kernel for maxpool if it has already been constructed.
      
      * Forgot to add padding arrays back into cudnn kernel for MaxPool in the 2d case.
      
      * Fixed namespace issues and use join(...,'_')
      
      * Refactored 4d/Nd tensor descriptor builder into single function.
      
      * Changed conditionals and comments. Now throws if MaxPool on more than 3 spatial dimensions is requested.
      
      * Fixed forward declare for GPURuntimeContext (class -> struct).
      
      * Clang complains about missing braces on brace-initializer. Fixed implicit conversions.
      
      * Fixed implicit conversions (clang).
      
      * Reverting changes on autodiff test for maxpool. @Krovatkin will update later.
      026bede0
  2. 12 Apr, 2018 6 commits
    • Jaikrishnan Menon's avatar
      dfae57c1
    • Fenglei's avatar
      gpu slice (#843) · 041dd524
      Fenglei authored
      * add slice op, first version
      
      * change size to output size
      
      * fix bugs
      
      * working version
      
      * using exist function for join and strides
      
      * clang format
      
      * revert accidental change
      041dd524
    • Nick Korovaiko's avatar
      RecurrentGraphRewrite + tests (#833) · b14d5665
      Nick Korovaiko authored
      * add a getter for root node
      
      * recurrent graph rewrite
      
      * fix perms, rename match_root -> get_match_root
      
      * fix comp errors
      
      * make match_root return the topmost match; fix tests
      b14d5665
    • Fenglei's avatar
      gpu convolution support nd(n<4) (#824) · b9b7845c
      Fenglei authored
      * add convolution in progress
      
      * enable 1 test
      
      * convolution in progress
      
      * use filter descripter
      
      * filter discreptor bug fix
      
      * tensor format
      
      * add missed dimension calculator
      
      * forward convolution 4d without dilation and padding working
      
      * data dilation(deconvolution) and enable some test
      
      * add backprop convolution data and filter
      
      * backprop can compile
      
      * pass unit test, but still have problem on padding
      
      * 2d, symmtric padding, no data dilation works now
      
      * clean up code
      
      * extend gpu convolution to nd
      
      * fix some bugs
      
      * working version for upto 3d convolution, code format.
      
      * remove nunecessary changes
      
      * add restriction for data dilation and asymmetric padding
      
      * clang format
      
      * support upto 3D convolution for now
      
      * change comments to not implemented
      
      * change comments to not implemented
      
      * add quary for additional GPU workspace for convolution
      
      * clang format
      
      * code format
      
      * using row_major_strides
      
      * using join
      
      * fix bug for join
      
      * refactor dimension calculation
      b9b7845c
    • tsocha's avatar
      [Py] Enable ngraph-cpp ops in Python API (#820) · 9ffb5145
      tsocha authored
      * Enable BatchNorm op
      
      * Enable function call op
      
      * Enable get output element op
      9ffb5145
    • Jaikrishnan Menon's avatar
      CPU: Eliminate slices (#849) · eec19220
      Jaikrishnan Menon authored
      eec19220
  3. 10 Apr, 2018 6 commits
  4. 09 Apr, 2018 10 commits
  5. 08 Apr, 2018 1 commit
  6. 06 Apr, 2018 6 commits
  7. 05 Apr, 2018 7 commits
  8. 04 Apr, 2018 3 commits
    • DawnStone's avatar
      simplify contrib/docker Makefile and make targets (#797) · 86f88126
      DawnStone authored
      * saved a simplified contrib/docker/Makefile and helper scripts
      
      * fixed flow for make targets
      
      * restored original definition for setting the PARALLEL option on the command line per github comments
      
      * remove double build for make install targets
      
      * added a save for the ngraph_dist_gcc.tgz to maintain existing behavior
      
      * fixed passing the PARALLEL value to the make targets
      
      * integrated latest working build-ngraph-and-test script
      
      * integrated the latest working Makefile
      
      * removed reference to the THIRD_PARTY_CACHE_DIR (for future)
      
      * updated the contrib/docker/README.md file
      86f88126
    • Nick Korovaiko's avatar
      Support multi-output ops in Adjoints (#796) · 5f0e8dc3
      Nick Korovaiko authored
      * refactor Adjoints to support multi-output ops
      
      * passing tests
      
      * switch to generate_adjoints(deltas) and backprop_node
      
      * remove debugging code
      
      * fix error msg
      
      * fix typo adjoitns
      
      * fix comp errors in mnist_mlp
      5f0e8dc3
    • tsocha's avatar
      [Py]Fix problem with double set layout (#808) · 3e680b68
      tsocha authored
      * [Py]Fix problem with double set layout
      
      * Extend UT for coverage double set layout
      3e680b68