logo hyperPad Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Login

    Understanding Sequence of Behaviours: In Search of Speed!

    Scheduled Pinned Locked Moved
    Help and Support
    5
    45
    2.1k
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • D
      Deeeds
      last edited by

      I'm trying to get my head around the firing order of behaviours.

      See the below attachment.

      Do behaviours get run down their branches before heading across to the next branch to the right?

      0_1511309910483_Image-1.jpg

      1 Reply Last reply Reply Quote 0
      • Aidan_FireA
        Aidan_Fire
        last edited by Aidan_Fire

        I’m pretty sure with what you have there, the far left branch will all happen before the next branch, which will all happen before the next branch.

        D 1 Reply Last reply Reply Quote 0
        • D
          Deeeds @Aidan_Fire
          last edited by

          @Aidan-Oxley Good. In this situation that's definitely what appears to be happening and what I want happening.

          Are there faster ways? Any concurrency on offer?

          Aidan_FireA 1 Reply Last reply Reply Quote 0
          • Aidan_FireA
            Aidan_Fire @Deeeds
            last edited by Aidan_Fire

            @Deeeds I don’t really think any way of arranging behaviours is faster, it just depends on how you like it to look. I’m a little bit crazy, I let all my behaviours sit in a giant horizontal line under the event triggering them all. I’m also obsessed with double tapping event behaviours to make everything under them automatically neaten themselves.

            D 1 Reply Last reply Reply Quote 0
            • D
              Deeeds @Aidan_Fire
              last edited by

              @Aidan-Oxley If, as I'm suggesting and you're saying, it's down the branches then left to right, why does "Behaviour Bundle" exist?

              It seems to do much the same thing.

              Aidan_FireA 1 Reply Last reply Reply Quote 0
              • Aidan_FireA
                Aidan_Fire @Deeeds
                last edited by

                @Deeeds Behaviour bundle does nothing other than make behaviours look a bit neater while not affecting performance. My 3D project actually uses this because if I didn’t, my maths to calculate 3D points would be so long I wouldn’t be able to join them to the event even if I zoomed out to max.

                D 1 Reply Last reply Reply Quote 1
                • D
                  Deeeds @Aidan_Fire
                  last edited by

                  @Aidan-Oxley Is there anywhere discussing the relative differences between:

                  Getting a Value Behaviours 'value'
                  Getting a Box Container's 'value'
                  Getting an Array's 'value' by index
                  Getting an Attribute's 'value'

                  And all the other means of getting (and setting/storing) values in terms of performance?

                  I'm assuming that Attribute value gets are slowest, then Box Containers, then it's probably close to a tie between Array elements and Values.

                  But I don't know. Just guessing.

                  Aidan_FireA 1 Reply Last reply Reply Quote 0
                  • Aidan_FireA
                    Aidan_Fire @Deeeds
                    last edited by Aidan_Fire

                    @Deeeds I think the fastest way to store and use a value is through Box Containers or maybe Values. I’ve never actually used the Value behaviour though. Attributes are for having a value easily accessible to other objects, arrays are for storing lots of values as one group of text.

                    D 1 Reply Last reply Reply Quote 0
                    • D
                      Deeeds @Aidan_Fire
                      last edited by

                      @Aidan-Oxley said in Understanding Sequence of Behaviours: In Search of Speed!:

                      arrays are for storing lots of values as one group of text.

                      You keep saying this.

                      Arrays, in the rest of the world, aren't this.

                      They can have text, sure. But that's not their benefits/purpose/way.

                      Is this how they are, exclusively, in hyperPad?

                      The way @hamed optimises things, and makes a very concerted effort for efficiency and performance, I find it highly unlikely that he's doing this to real world Arrays when they offer SO many benefits in their real world way of being.

                      ie arrays of types based on the content type.

                      Aidan_FireA 1 Reply Last reply Reply Quote 0
                      • Aidan_FireA
                        Aidan_Fire @Deeeds
                        last edited by Aidan_Fire

                        @Deeeds An array (at least as I know it, in hyperPad) is a bunch of text that means something. Kinda like words. A bunch of text that stores as many values as you like in a specific format.

                        D 1 Reply Last reply Reply Quote 0
                        • D
                          Deeeds @Aidan_Fire
                          last edited by

                          @Aidan-Oxley Again, this is a way of thinking about arrays, but it's not actually what they are, nor how they work.

                          Where do you get this idea from?

                          What you're describing is the use of a massive string with stored separators that would require some kind of index for the division of each element, or some other kind of separator. Which, again, isn't an array.

                          That's how CSV works, but they still need a type, too.

                          Aidan_FireA 1 Reply Last reply Reply Quote 0
                          • Aidan_FireA
                            Aidan_Fire @Deeeds
                            last edited by Aidan_Fire

                            @Deeeds I got this idea from the fact that I can display it as text, modify the text etc. The formatting uses symbols to separate values. Clearly I think about arrays (at least hyperPad version of arrays?) differently to you.

                            D Jack8680J 2 Replies Last reply Reply Quote 0
                            • D
                              Deeeds @Aidan_Fire
                              last edited by

                              @Aidan-Oxley yes, like I've said before, this can be how an Array is represented to you, and can be thought of, but it's not what it actually is. You're being gifted a slightly abstracted view and experience with them.

                              1 Reply Last reply Reply Quote 0
                              • Jack8680J
                                Jack8680 @Aidan_Fire
                                last edited by

                                I'm guessing array values are stored in separate memory addresses in a way that they can quickly be accessed by index, but they can be converted to and from plain text json for use in non-array operations (which I think most languages do). I might be completely wrong.

                                This would make accessing an array value the same as accessing a box container.

                                Running a modify array behaviour replacing an existing array should then also be the same as using set input field on a box container, but appending or prepending is probably less efficient.

                                I don't know how memory allocation would work for attributes, but because they can be accessed on spawned objects I expect they'd be least efficient.

                                Keep in mind I have no idea what I'm talking about and might be completely wrong, perhaps arrays store a list of memory addresses instead, which means accessing two addresses per reference.

                                D 1 Reply Last reply Reply Quote 0
                                • D
                                  Deeeds @Jack8680
                                  last edited by

                                  @Jack8680 Can you explain what a Value container is, in words different from the docs?

                                  I can't figure out what these are representative of, or... well, anything about them.

                                  I thought I knew, then I tried a few things and couldn't work out what was going on.

                                  Much like my cooking.

                                  Jack8680J 1 Reply Last reply Reply Quote 0
                                  • Jack8680J
                                    Jack8680 @Deeeds
                                    last edited by

                                    @Deeeds the value behaviour updates its output when it is run. You can for example get the value of the output of a while touching behaviour once, and then reference it in that state later after the output of the while touching behaviour has changed. It's basically declaring a new variable that takes the value of another variable but not as a pointer.

                                    D 2 Replies Last reply Reply Quote 0
                                    • D
                                      Deeeds @Jack8680
                                      last edited by

                                      @Jack8680 said in Understanding Sequence of Behaviours: In Search of Speed!:

                                      the value behaviour updates its output when it is run.

                                      Sorry to be pedantic: Do you mean when its branch has completed running? Like a late update or willSet in Swift?

                                      1 Reply Last reply Reply Quote 0
                                      • D
                                        Deeeds @Jack8680
                                        last edited by

                                        @Jack8680 The rest I don't understand what you're saying.

                                        It's making a new variable? Not overwriting it later?

                                        I'm more confused than before. Sorry!

                                        Jack8680J 1 Reply Last reply Reply Quote 0
                                        • Jack8680J
                                          Jack8680 @Deeeds
                                          last edited by

                                          @Deeeds the value behaviour is basically like saying

                                          Var value = input
                                          

                                          It's not a pointer, so if you reference the value elsewhere it will have the value of the input when the value behaviour is activated.

                                          It is different to a box container because a box container is a pointer when you drag a behaviour output in, so referencing a box container will reference the value of what is selected in the box container.

                                          You can't use set input field on a box container that has a behaviour output selected as its value, so there's no reason to use them this way as you can just reference the behaviour output directly.

                                          Using set input field on a box container that isn't a reference to another behaviour output acts the same as using a value behaviour, but it can be set from multiple places.

                                          D 1 Reply Last reply Reply Quote 1
                                          • D
                                            Deeeds @Jack8680
                                            last edited by

                                            @Jack8680 said in Understanding Sequence of Behaviours: In Search of Speed!:

                                            It's not a pointer, so if you reference the value elsewhere it will have the value of the input when the value behaviour is activated.

                                            Reading this I'm doubting I understand how behaviours actually work.

                                            I'm missing something.

                                            Can you give a concrete example of where and when you'd have to use a Value container for its benefits (and ways of being) versus somewhere a Box container could only provide the desired results?

                                            Jack8680J 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post