implementing conv2d in fourier domain using np.einsum --> ValueError: einstein sum subscripts string contains too many subscripts for operand 0 The Next CEO of Stack Overflow2019 Community Moderator ElectionValueError: Input contains NaN, infinity or a value too large for dtype('float32')Approaches for implementing Domain specific Question answering SystemValueError: Input contains NaN, infinity or a value too large for dtype('float64')Text representation using TFIDF .toarray() freezes my computer. Too many features to handle?Converting video into frames using openCVHow can I solve it? : <ValueError: Input contains NaN, infinity or a value too large for dtype('float64').>Keras/TF: Making sure image training data shape is accurate for Time Distributed CNN+LSTMFeature selection using a filter for multiclass problem: What if many features are strongly predictive of few classes?

Airplane gently rocking its wings during whole flight

Spaces in which all closed sets are regular closed

Why is the US ranked as #45 in Press Freedom ratings, despite its extremely permissive free speech laws?

Won the lottery - how do I keep the money?

Could a dragon use its wings to swim?

Why do we say 'Un seul M' and not 'Une seule M' even though M is a "consonne"

Is there such a thing as a proper verb, like a proper noun?

How do I fit a non linear curve?

Is there an equivalent of cd - for cp or mv

IC has pull-down resistors on SMBus lines?

Is it ok to trim down a tube patch?

How to use ReplaceAll on an expression that contains a rule

If Nick Fury and Coulson already knew about aliens (Kree and Skrull) why did they wait until Thor's appearance to start making weapons?

What steps are necessary to read a Modern SSD in Medieval Europe?

Yu-Gi-Oh cards in Python 3

Is it okay to majorly distort historical facts while writing a fiction story?

Is it professional to write unrelated content in an almost-empty email?

How do you define an element with an ID attribute using LWC?

Getting Stale Gas Out of a Gas Tank w/out Dropping the Tank

how one can write a nice vector parser, something that does pgfvecparseA=B-C; D=E x F;

What CSS properties can the br tag have?

Do I need to write [sic] when including a quotation with a number less than 10 that isn't written out?

Would a grinding machine be a simple and workable propulsion system for an interplanetary spacecraft?

Are the names of these months realistic?



implementing conv2d in fourier domain using np.einsum --> ValueError: einstein sum subscripts string contains too many subscripts for operand 0



The Next CEO of Stack Overflow
2019 Community Moderator ElectionValueError: Input contains NaN, infinity or a value too large for dtype('float32')Approaches for implementing Domain specific Question answering SystemValueError: Input contains NaN, infinity or a value too large for dtype('float64')Text representation using TFIDF .toarray() freezes my computer. Too many features to handle?Converting video into frames using openCVHow can I solve it? : <ValueError: Input contains NaN, infinity or a value too large for dtype('float64').>Keras/TF: Making sure image training data shape is accurate for Time Distributed CNN+LSTMFeature selection using a filter for multiclass problem: What if many features are strongly predictive of few classes?










0












$begingroup$


According to the convolution theorem, convolution operation changes to pointwise multiplication in fourier domain - here I have 'fft_x' of shape (batchsize, height, width, in_channels) which is the fft of input data and similarly 'fft_kernel' of shape (height, width, in_channels, out_channels) which is fft of the kernel after being padded to image size. To get pointwise multiplication of these in efficient way, I was using einsum in the following way -



...
print(fft_x)
print(fft_kernel)
output = 0
n=int(self.no_of_kernels/2)+1 # n = out_channels here
for i in range(n):
output += np.einsum('ijkl,jkl->ijk', fft_x, fft_kernel[i])
return output
...


It gives the following output and error-



Tensor("input_11:0", shape=(?, 28, 28, 1), dtype=complex64)
Tensor("fourier__conv2d_11/transpose:0", shape=(28, 28, 1, 17), dtype=complex64)
...
...
ValueError: einstein sum subscripts string contains too many subscripts for operand 0


Could anyone please explain why this error is arising? Thanks in advance for any help.










share|improve this question









$endgroup$
















    0












    $begingroup$


    According to the convolution theorem, convolution operation changes to pointwise multiplication in fourier domain - here I have 'fft_x' of shape (batchsize, height, width, in_channels) which is the fft of input data and similarly 'fft_kernel' of shape (height, width, in_channels, out_channels) which is fft of the kernel after being padded to image size. To get pointwise multiplication of these in efficient way, I was using einsum in the following way -



    ...
    print(fft_x)
    print(fft_kernel)
    output = 0
    n=int(self.no_of_kernels/2)+1 # n = out_channels here
    for i in range(n):
    output += np.einsum('ijkl,jkl->ijk', fft_x, fft_kernel[i])
    return output
    ...


    It gives the following output and error-



    Tensor("input_11:0", shape=(?, 28, 28, 1), dtype=complex64)
    Tensor("fourier__conv2d_11/transpose:0", shape=(28, 28, 1, 17), dtype=complex64)
    ...
    ...
    ValueError: einstein sum subscripts string contains too many subscripts for operand 0


    Could anyone please explain why this error is arising? Thanks in advance for any help.










    share|improve this question









    $endgroup$














      0












      0








      0





      $begingroup$


      According to the convolution theorem, convolution operation changes to pointwise multiplication in fourier domain - here I have 'fft_x' of shape (batchsize, height, width, in_channels) which is the fft of input data and similarly 'fft_kernel' of shape (height, width, in_channels, out_channels) which is fft of the kernel after being padded to image size. To get pointwise multiplication of these in efficient way, I was using einsum in the following way -



      ...
      print(fft_x)
      print(fft_kernel)
      output = 0
      n=int(self.no_of_kernels/2)+1 # n = out_channels here
      for i in range(n):
      output += np.einsum('ijkl,jkl->ijk', fft_x, fft_kernel[i])
      return output
      ...


      It gives the following output and error-



      Tensor("input_11:0", shape=(?, 28, 28, 1), dtype=complex64)
      Tensor("fourier__conv2d_11/transpose:0", shape=(28, 28, 1, 17), dtype=complex64)
      ...
      ...
      ValueError: einstein sum subscripts string contains too many subscripts for operand 0


      Could anyone please explain why this error is arising? Thanks in advance for any help.










      share|improve this question









      $endgroup$




      According to the convolution theorem, convolution operation changes to pointwise multiplication in fourier domain - here I have 'fft_x' of shape (batchsize, height, width, in_channels) which is the fft of input data and similarly 'fft_kernel' of shape (height, width, in_channels, out_channels) which is fft of the kernel after being padded to image size. To get pointwise multiplication of these in efficient way, I was using einsum in the following way -



      ...
      print(fft_x)
      print(fft_kernel)
      output = 0
      n=int(self.no_of_kernels/2)+1 # n = out_channels here
      for i in range(n):
      output += np.einsum('ijkl,jkl->ijk', fft_x, fft_kernel[i])
      return output
      ...


      It gives the following output and error-



      Tensor("input_11:0", shape=(?, 28, 28, 1), dtype=complex64)
      Tensor("fourier__conv2d_11/transpose:0", shape=(28, 28, 1, 17), dtype=complex64)
      ...
      ...
      ValueError: einstein sum subscripts string contains too many subscripts for operand 0


      Could anyone please explain why this error is arising? Thanks in advance for any help.







      python tensorflow numpy






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked 26 mins ago









      psjpsj

      112




      112




















          0






          active

          oldest

          votes












          Your Answer





          StackExchange.ifUsing("editor", function ()
          return StackExchange.using("mathjaxEditing", function ()
          StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
          StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
          );
          );
          , "mathjax-editing");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "557"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdatascience.stackexchange.com%2fquestions%2f48326%2fimplementing-conv2d-in-fourier-domain-using-np-einsum-valueerror-einstein-s%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Data Science Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          Use MathJax to format equations. MathJax reference.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdatascience.stackexchange.com%2fquestions%2f48326%2fimplementing-conv2d-in-fourier-domain-using-np-einsum-valueerror-einstein-s%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          ValueError: Error when checking input: expected conv2d_13_input to have shape (3, 150, 150) but got array with shape (150, 150, 3)2019 Community Moderator ElectionError when checking : expected dense_1_input to have shape (None, 5) but got array with shape (200, 1)Error 'Expected 2D array, got 1D array instead:'ValueError: Error when checking input: expected lstm_41_input to have 3 dimensions, but got array with shape (40000,100)ValueError: Error when checking target: expected dense_1 to have shape (7,) but got array with shape (1,)ValueError: Error when checking target: expected dense_2 to have shape (1,) but got array with shape (0,)Keras exception: ValueError: Error when checking input: expected conv2d_1_input to have shape (150, 150, 3) but got array with shape (256, 256, 3)Steps taking too long to completewhen checking input: expected dense_1_input to have shape (13328,) but got array with shape (317,)ValueError: Error when checking target: expected dense_3 to have shape (None, 1) but got array with shape (7715, 40000)Keras exception: Error when checking input: expected dense_input to have shape (2,) but got array with shape (1,)

          Ружовы пелікан Змест Знешні выгляд | Пашырэнне | Асаблівасці біялогіі | Літаратура | НавігацыяДагледжаная версіяправерана1 зменаДагледжаная версіяправерана1 змена/ 22697590 Сістэматыкана ВіківідахВыявына Вікісховішчы174693363011049382

          Illegal assignment from SObject to ContactFetching String, Id from Map - Illegal Assignment Id to Field / ObjectError: Compile Error: Illegal assignment from String to BooleanError: List has no rows for assignment to SObjectError on Test Class - System.QueryException: List has no rows for assignment to SObjectRemote action problemDML requires SObject or SObject list type error“Illegal assignment from List to List”Test Class Fail: Batch Class: System.QueryException: List has no rows for assignment to SObjectMapping to a user'List has no rows for assignment to SObject' Mystery