Tensorflow - Iterate over two Tensors










1















I have two similar tensors; one has all the found valid boxes, and the other has all of the indexes where they belonged.



Tensor("valid_boxes:0", shape=(?, 9), dtype=float32)



Tensor("valid_boxes_indexes:0", shape=(?, 4), dtype=int64)



I need a map_fun which access both variables. I tried this:



operation = tf.map_fn(lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2], grid_h, grid_w, anchors), (valid_boxes, valid_boxes_indexes))


Tensorflow gave me the following:




ValueError: The two structures don't have the same nested structure.



First structure: type=tuple str=(tf.float32, tf.int64)



Second structure: type=Tensor str=Tensor("map_14/while/stack:0",
shape=(5,), dtype=float32)



More specifically: Substructure "type=tuple str=(tf.float32,
tf.int64)" is a sequence, while substructure "type=Tensor
str=Tensor("map_14/while/stack:0", shape=(5,), dtype=float32)" is not




Is there any way to do this properly?



Thanks!










share|improve this question




























    1















    I have two similar tensors; one has all the found valid boxes, and the other has all of the indexes where they belonged.



    Tensor("valid_boxes:0", shape=(?, 9), dtype=float32)



    Tensor("valid_boxes_indexes:0", shape=(?, 4), dtype=int64)



    I need a map_fun which access both variables. I tried this:



    operation = tf.map_fn(lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2], grid_h, grid_w, anchors), (valid_boxes, valid_boxes_indexes))


    Tensorflow gave me the following:




    ValueError: The two structures don't have the same nested structure.



    First structure: type=tuple str=(tf.float32, tf.int64)



    Second structure: type=Tensor str=Tensor("map_14/while/stack:0",
    shape=(5,), dtype=float32)



    More specifically: Substructure "type=tuple str=(tf.float32,
    tf.int64)" is a sequence, while substructure "type=Tensor
    str=Tensor("map_14/while/stack:0", shape=(5,), dtype=float32)" is not




    Is there any way to do this properly?



    Thanks!










    share|improve this question


























      1












      1








      1








      I have two similar tensors; one has all the found valid boxes, and the other has all of the indexes where they belonged.



      Tensor("valid_boxes:0", shape=(?, 9), dtype=float32)



      Tensor("valid_boxes_indexes:0", shape=(?, 4), dtype=int64)



      I need a map_fun which access both variables. I tried this:



      operation = tf.map_fn(lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2], grid_h, grid_w, anchors), (valid_boxes, valid_boxes_indexes))


      Tensorflow gave me the following:




      ValueError: The two structures don't have the same nested structure.



      First structure: type=tuple str=(tf.float32, tf.int64)



      Second structure: type=Tensor str=Tensor("map_14/while/stack:0",
      shape=(5,), dtype=float32)



      More specifically: Substructure "type=tuple str=(tf.float32,
      tf.int64)" is a sequence, while substructure "type=Tensor
      str=Tensor("map_14/while/stack:0", shape=(5,), dtype=float32)" is not




      Is there any way to do this properly?



      Thanks!










      share|improve this question
















      I have two similar tensors; one has all the found valid boxes, and the other has all of the indexes where they belonged.



      Tensor("valid_boxes:0", shape=(?, 9), dtype=float32)



      Tensor("valid_boxes_indexes:0", shape=(?, 4), dtype=int64)



      I need a map_fun which access both variables. I tried this:



      operation = tf.map_fn(lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2], grid_h, grid_w, anchors), (valid_boxes, valid_boxes_indexes))


      Tensorflow gave me the following:




      ValueError: The two structures don't have the same nested structure.



      First structure: type=tuple str=(tf.float32, tf.int64)



      Second structure: type=Tensor str=Tensor("map_14/while/stack:0",
      shape=(5,), dtype=float32)



      More specifically: Substructure "type=tuple str=(tf.float32,
      tf.int64)" is a sequence, while substructure "type=Tensor
      str=Tensor("map_14/while/stack:0", shape=(5,), dtype=float32)" is not




      Is there any way to do this properly?



      Thanks!







      python tensorflow






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 14 '18 at 16:19









      Joel

      1,5686719




      1,5686719










      asked Nov 14 '18 at 16:13









      RodsnjrRodsnjr

      276




      276






















          1 Answer
          1






          active

          oldest

          votes


















          1














          You need to specify a dtype when the input and output values do not have the same structure. From the documentation of tf.map_fn:




          Furthermore, fn may emit a different structure than its input. For example, fn may look like: fn = lambda t1: return (t1 + 1, t1 - 1). In this case, the dtype parameter is not optional: dtype must be a type or (possibly nested) tuple of types matching the output of fn.




          Try with this:



          operation = tf.map_fn(
          lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2],
          grid_h, grid_w, anchors),
          (valid_boxes, valid_boxes_indexes)
          dtype=tf.float32)





          share|improve this answer






















            Your Answer






            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "1"
            ;
            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: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            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%2fstackoverflow.com%2fquestions%2f53304490%2ftensorflow-iterate-over-two-tensors%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            1














            You need to specify a dtype when the input and output values do not have the same structure. From the documentation of tf.map_fn:




            Furthermore, fn may emit a different structure than its input. For example, fn may look like: fn = lambda t1: return (t1 + 1, t1 - 1). In this case, the dtype parameter is not optional: dtype must be a type or (possibly nested) tuple of types matching the output of fn.




            Try with this:



            operation = tf.map_fn(
            lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2],
            grid_h, grid_w, anchors),
            (valid_boxes, valid_boxes_indexes)
            dtype=tf.float32)





            share|improve this answer



























              1














              You need to specify a dtype when the input and output values do not have the same structure. From the documentation of tf.map_fn:




              Furthermore, fn may emit a different structure than its input. For example, fn may look like: fn = lambda t1: return (t1 + 1, t1 - 1). In this case, the dtype parameter is not optional: dtype must be a type or (possibly nested) tuple of types matching the output of fn.




              Try with this:



              operation = tf.map_fn(
              lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2],
              grid_h, grid_w, anchors),
              (valid_boxes, valid_boxes_indexes)
              dtype=tf.float32)





              share|improve this answer

























                1












                1








                1







                You need to specify a dtype when the input and output values do not have the same structure. From the documentation of tf.map_fn:




                Furthermore, fn may emit a different structure than its input. For example, fn may look like: fn = lambda t1: return (t1 + 1, t1 - 1). In this case, the dtype parameter is not optional: dtype must be a type or (possibly nested) tuple of types matching the output of fn.




                Try with this:



                operation = tf.map_fn(
                lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2],
                grid_h, grid_w, anchors),
                (valid_boxes, valid_boxes_indexes)
                dtype=tf.float32)





                share|improve this answer













                You need to specify a dtype when the input and output values do not have the same structure. From the documentation of tf.map_fn:




                Furthermore, fn may emit a different structure than its input. For example, fn may look like: fn = lambda t1: return (t1 + 1, t1 - 1). In this case, the dtype parameter is not optional: dtype must be a type or (possibly nested) tuple of types matching the output of fn.




                Try with this:



                operation = tf.map_fn(
                lambda x: generate_bounding_box(x[0], x[1][1], x[1][0], x[1][2],
                grid_h, grid_w, anchors),
                (valid_boxes, valid_boxes_indexes)
                dtype=tf.float32)






                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Nov 14 '18 at 16:37









                jdehesajdehesa

                24.7k43554




                24.7k43554





























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Stack Overflow!


                    • 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.

                    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%2fstackoverflow.com%2fquestions%2f53304490%2ftensorflow-iterate-over-two-tensors%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







                    這個網誌中的熱門文章

                    How to read a connectionString WITH PROVIDER in .NET Core?

                    In R, how to develop a multiplot heatmap.2 figure showing key labels successfully

                    Museum of Modern and Contemporary Art of Trento and Rovereto