• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 230
  • Last Modified:

Help with stop - start of a loop

Hi All

I have the following attached loop that runs through 300+ mil loops generated from 3 Lists of string.

District, inner & ending

Is there any way to save the current position from the "For each .. as string in .." and then load the position back in ? Just that I have an estimated run time of 500+ hours and would like to be able to resume from a stored position should I have to.

I am also opened to other ideas aswell :-)

Many Thanks
Steve

Dim District, Inner, Ending As New List(Of String)
 
        District = DistrictList()
        Inner = InnerList()
        Ending = EndingList()
 
        For Each d1 As String In District
            s1 = d1
            For Each i1 As String In Inner
                s2 = s1 & i1
                For Each e1 As String In Ending
                    s3 = s2 & " " & e1
 
                    While pauseLoop
                        System.Threading.Thread.Sleep(100)
                        Application.DoEvents()
                    End While
 
                    Application.DoEvents()
 
                Next
            Next
        Next

Open in new window

0
Stephen Manderson
Asked:
Stephen Manderson
  • 3
  • 2
2 Solutions
 
Guy Hengel [angelIII / a3]Billing EngineerCommented:
let's assume that the Distrinctlist, InnerList and EndingList are sorted (if not, that will be "required")

then, you have only to check if the loop's control variable is after the starting value OR if the outer loops are on the next level (in which case all inner loops have to be processed)
Dim District, Inner, Ending As List(Of String)
 
Dim startDistrict As String = "" 'set the district to start processing from, leave empty to do it all
Dim startInner As String = "" 'idem
Dim startEnding As String = "" 'idem
 
        District = DistrictList()
        Inner = InnerList()
        Ending = EndingList()
 
        For Each d1 As String In District
         If d1 >= startDistrict Then
            s1 = d1
            For Each i1 As String In Inner
              if i1 >= startInner OR d1 > startDistrict then
                s2 = s1 & i1
                For Each e1 As String In Ending
                  if e1 >= startEnding or d1 > startDistrict or i1 > startInner then
                    s3 = s2 & " " & e1
 
                    While pauseLoop
                        System.Threading.Thread.Sleep(100)
                        Application.DoEvents()
                    End While
 
                    Application.DoEvents()
                  end if 'if e1 >= startEnding or d1 > startDistrict or i1 > startInner then
                Next 'e1 As String In Ending
              End if ' if i1 >= startInner OR d1 > startDistrict then
            Next 'i1 As String In Inner
          End if ' If d1 >= startDistrict Then
        Next 'd1 As String In District

Open in new window

0
 
SanclerCommented:
Or use an index rather than for each and store the indices.  Something like this

Private Sub ProcessLists(dStart As Long, iStart As Long, eStart As Long)
  Dim dIndex, iIndex, eIndex, dEnd, iEnd, eEnd As Long
  dEnd = District.Count - 1
  iEnd = Inner.Count - 1
  eEnd = Ending.Count - 1
  For dIndex = dStart to dEnd
      s1 = District(dIndex)
      For iIndex = iStart to iEnd
          s2 = s1 & Inner(iIndex)
          For eIndex = eStart to eEnd
              s3 = s2 & " " & Ending(eIndex)
              'do stuff
              If stopping Then
                 'save dIndex, iIndex, eIndex + 1
                 'may need to check if eIndex = eEnd and, if so
                 'save iIndex + 1 and 0 for eIndex
                 Exit Sub
              End If
          Next
          eStart = 0
      Next
      iStart = 0
  Next
End Sub

At the beginning call the sub with 0,0,0.  On restarting call it with the saved values.

Roger
0
 
Guy Hengel [angelIII / a3]Billing EngineerCommented:
>Sancler
your code has the flaw that when you start with 0,5,0, it will skip the values for the second loop from 0..4 for ALL the value of the first loop... which is no good :)
0
Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

 
SanclerCommented:
angelIII

What about the third line from the end

     iStart = 0

Before dIndex goes from 0 to 1, iStart is reset to 0.

I must admit I haven't tested it, though.  Do you still reckon there's a flaw?

Roger
0
 
Guy Hengel [angelIII / a3]Billing EngineerCommented:
oooops, I overlooked that! I stand corrected!
0
 
Stephen MandersonSoftware EngineerAuthor Commented:
Thanks
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

  • 3
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now