HISE Logo Forum
    • Categories
    • Register
    • Login

    Issues with for loop?

    Scheduled Pinned Locked Moved Scripting
    29 Posts 6 Posters 1.1k Views
    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.
    • VirtualVirginV
      VirtualVirgin
      last edited by VirtualVirgin

      Just trying to use a for loop to print out the elements at every index of an array,
      but the "i" variable in the code inside the loop is not working.

      Am I writing something wrong here? It just tells me that "i" is an undefined parameter.

      Screenshot 2024-11-07 at 10.57.12 AM.png

      You can listen to my orchestral mockups here:
      https://www.virtualvirgin.net/

      Matt_SFM LindonL 2 Replies Last reply Reply Quote 0
      • Matt_SFM
        Matt_SF @VirtualVirgin
        last edited by

        @VirtualVirgin that means that your noteOnOffState array doesn't contain 128 values

        Develop branch
        Win10 & VS17 / Ventura & Xcode 14. 3

        VirtualVirginV 1 Reply Last reply Reply Quote 0
        • d.healeyD
          d.healey
          last edited by

          Is noteOnOffState a MIDI list?

          Free HISE Bootcamp Full Course for beginners.
          YouTube Channel - Public HISE tutorials
          My Patreon - HISE tutorials

          VirtualVirginV 1 Reply Last reply Reply Quote 0
          • VirtualVirginV
            VirtualVirgin @d.healey
            last edited by

            @d-healey said in Issues with for loop?:

            Is noteOnOffState a MIDI list?

            Not in this case, just an array.

            You can listen to my orchestral mockups here:
            https://www.virtualvirgin.net/

            d.healeyD 1 Reply Last reply Reply Quote 0
            • LindonL
              Lindon @VirtualVirgin
              last edited by Lindon

              @VirtualVirgin try doing this instead:

              function onController()
              {
                   Console.print(trace(noteOnOffState));
              
              }
              

              but it may well be that noteOnOffState isnt defined or visible to your call back.

              HISE Development for hire.
              www.channelrobot.com

              VirtualVirginV 1 Reply Last reply Reply Quote 0
              • d.healeyD
                d.healey @VirtualVirgin
                last edited by

                @VirtualVirgin said in Issues with for loop?:

                Not in this case, just an array.

                In that case instead of using 128 you can use noteOnOffState.length and then the loop will never exceed the number of elements in the array.

                Free HISE Bootcamp Full Course for beginners.
                YouTube Channel - Public HISE tutorials
                My Patreon - HISE tutorials

                VirtualVirginV 1 Reply Last reply Reply Quote 0
                • VirtualVirginV
                  VirtualVirgin @d.healey
                  last edited by

                  @d-healey said in Issues with for loop?:

                  @VirtualVirgin said in Issues with for loop?:

                  Not in this case, just an array.

                  In that case instead of using 128 you can use noteOnOffState.length and then the loop will never exceed the number of elements in the array.

                  I just tried that while you were tying this, but I still get an error:
                  Screenshot 2024-11-07 at 11.37.01 AM.png

                  Here is the array declaration:
                  Screenshot 2024-11-07 at 11.36.22 AM.png

                  You can listen to my orchestral mockups here:
                  https://www.virtualvirgin.net/

                  d.healeyD 1 Reply Last reply Reply Quote 0
                  • d.healeyD
                    d.healey @VirtualVirgin
                    last edited by

                    @VirtualVirgin Don't use global, use const.

                    Free HISE Bootcamp Full Course for beginners.
                    YouTube Channel - Public HISE tutorials
                    My Patreon - HISE tutorials

                    VirtualVirginV 1 Reply Last reply Reply Quote 0
                    • VirtualVirginV
                      VirtualVirgin @Lindon
                      last edited by

                      @Lindon said in Issues with for loop?:

                      @VirtualVirgin try doing this instead:

                      function onController()
                      {
                           Console.print(trace(noteOnOffState));
                      
                      }
                      

                      but it may well be that noteOnOffState isnt defined or visible to your call back.

                      I did use that earlier, but I don't know how to append it to use strings in between each returned index value.

                      You can listen to my orchestral mockups here:
                      https://www.virtualvirgin.net/

                      1 Reply Last reply Reply Quote 0
                      • VirtualVirginV
                        VirtualVirgin @d.healey
                        last edited by VirtualVirgin

                        @d-healey said in Issues with for loop?:

                        @VirtualVirgin Don't use global, use const.

                        Well somehow it works now once I added the
                        i + ": "
                        to the print command.
                        Screenshot 2024-11-07 at 11.45.59 AM.png

                        I didn't change the variable type yet.

                        const variable will be available across the different callback scripts?

                        You can listen to my orchestral mockups here:
                        https://www.virtualvirgin.net/

                        d.healeyD 2 Replies Last reply Reply Quote 0
                        • d.healeyD
                          d.healey @VirtualVirgin
                          last edited by

                          @VirtualVirgin A const will be available throughout the MIDI processor in which it is declared. It won't be accessible from other MIDI processors.

                          Free HISE Bootcamp Full Course for beginners.
                          YouTube Channel - Public HISE tutorials
                          My Patreon - HISE tutorials

                          VirtualVirginV 1 Reply Last reply Reply Quote 0
                          • d.healeyD
                            d.healey @VirtualVirgin
                            last edited by

                            @VirtualVirgin It's still saying undefined for that variable. You haven't solved the problem.

                            Where are you populating the array?

                            Free HISE Bootcamp Full Course for beginners.
                            YouTube Channel - Public HISE tutorials
                            My Patreon - HISE tutorials

                            VirtualVirginV 1 Reply Last reply Reply Quote 0
                            • VirtualVirginV
                              VirtualVirgin @d.healey
                              last edited by

                              @d-healey said in Issues with for loop?:

                              @VirtualVirgin A const will be available throughout the MIDI processor in which it is declared. It won't be accessible from other MIDI processors.

                              And does the scope of a global include the other MIDI processors (out of curiosity)?

                              You can listen to my orchestral mockups here:
                              https://www.virtualvirgin.net/

                              d.healeyD 1 Reply Last reply Reply Quote 0
                              • d.healeyD
                                d.healey @VirtualVirgin
                                last edited by

                                @VirtualVirgin said in Issues with for loop?:

                                And does the scope of a global include the other MIDI processors (out of curiosity)?

                                Yes, but there is usually a better method. Global variables lead to less modular code, which is more difficult to maintain and debug. I have yet to use them in any project.

                                Free HISE Bootcamp Full Course for beginners.
                                YouTube Channel - Public HISE tutorials
                                My Patreon - HISE tutorials

                                1 Reply Last reply Reply Quote 1
                                • VirtualVirginV
                                  VirtualVirgin @d.healey
                                  last edited by

                                  @d-healey said in Issues with for loop?:

                                  @VirtualVirgin It's still saying undefined for that variable. You haven't solved the problem.

                                  Where are you populating the array?

                                  No, no! It is working properly.
                                  Those "undefined" indexes are not written to yet.
                                  Only those which have been written to have a value (1 or 0 here).

                                  If you see, index 60 has a value of 1, meaning that middle C has note on.

                                  If it matters later, I could initialize the array with all 0s, but I don't know that I need that data yet.

                                  You can listen to my orchestral mockups here:
                                  https://www.virtualvirgin.net/

                                  d.healeyD 1 Reply Last reply Reply Quote 0
                                  • d.healeyD
                                    d.healey @VirtualVirgin
                                    last edited by

                                    @VirtualVirgin said in Issues with for loop?:

                                    Those "undefined" indexes are not written to yet.

                                    The error you created this thread for is caused by the values being undefined

                                    98ed9d22-c4b6-439a-8a73-cd005108c445-image.png

                                    In this situation you need to filter out undefined values, this can be done with a simple if inside the loop.

                                    if (!isDefined(noteOnOffState[i])
                                        continue;
                                    

                                    If you're just storing a 1 or 0 in the array then you should probably use a MIDI list.

                                    Free HISE Bootcamp Full Course for beginners.
                                    YouTube Channel - Public HISE tutorials
                                    My Patreon - HISE tutorials

                                    VirtualVirginV 1 Reply Last reply Reply Quote 0
                                    • VirtualVirginV
                                      VirtualVirgin @d.healey
                                      last edited by

                                      @d-healey said in Issues with for loop?:

                                      @VirtualVirgin said in Issues with for loop?:

                                      Those "undefined" indexes are not written to yet.

                                      The error you created this thread for is caused by the values being undefined

                                      98ed9d22-c4b6-439a-8a73-cd005108c445-image.png

                                      In this situation you need to filter out undefined values, this can be done with a simple if inside the loop.

                                      if (!isDefined(noteOnOffState[i])
                                          continue;
                                      

                                      If you're just storing a 1 or 0 in the array then you should probably use a MIDI list.

                                      That error was coming up for trying to print from the loop.
                                      That error disappeared when I added
                                      i + ": "
                                      to the Console.print()

                                      The console is printing the loop and the error is no longer in the console.

                                      You can listen to my orchestral mockups here:
                                      https://www.virtualvirgin.net/

                                      1 Reply Last reply Reply Quote 0
                                      • VirtualVirginV
                                        VirtualVirgin
                                        last edited by

                                        Without
                                        i + ": " +

                                        Screenshot 2024-11-07 at 12.11.57 PM.png

                                        With

                                        Screenshot 2024-11-07 at 12.14.09 PM.png

                                        You can listen to my orchestral mockups here:
                                        https://www.virtualvirgin.net/

                                        Oli UllmannO 1 Reply Last reply Reply Quote 0
                                        • d.healeyD
                                          d.healey
                                          last edited by

                                          The error is telling you that the thing you are trying to print is undefined. When you add i + ": " + then you are no longer printing something that is entirely undefined. - However as you can see from the console output the array part of it is still undefined.

                                          Free HISE Bootcamp Full Course for beginners.
                                          YouTube Channel - Public HISE tutorials
                                          My Patreon - HISE tutorials

                                          VirtualVirginV 1 Reply Last reply Reply Quote 0
                                          • Oli UllmannO
                                            Oli Ullmann @VirtualVirgin
                                            last edited by

                                            @VirtualVirgin
                                            If you do not want to initialize your array with 0 or 1, you could also initialize it with -1.

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

                                            10

                                            Online

                                            2.0k

                                            Users

                                            12.7k

                                            Topics

                                            110.5k

                                            Posts