saving a grid of heterogenous images in Python












2














How can I use something like below line to save images on a grid of 4x4 of heterogenous images? Imagine that images are identified by sample[i] and i takes 16 different values.



scipy.misc.imsave(str(img_index) + '.png', sample[1])


Similar to this answer but for 16 different images
https://stackoverflow.com/a/42041135/2414957



I am not biased towards the used method as long as it does the deed. Also, I am interested in saving images rather than showing them using plt.show() as I am using a remote server and dealing with CelebA image dataset which is a giant dataset. I just want to randomly select 16 images from my batch and save the results of DCGAN and see if it makes any sense or if it converges.



*Currently, I am saving images like below:



batch_no = random.randint(0, 63)


scipy.misc.imsave('sample_gan_images/iter_%d_epoch_%d_sample_%d.png' %(itr, epoch, batch_no), sample[batch_no])


and here, I have 25 epochs and 2000 iterations and batch size is 64.










share|improve this question




















  • 1




    @Panlantic82 What on earth was that???, That's not an answer, that's saying some bad stuff, don't ever do that again, that's very nasty, Your violating the site, see the Code of Conduct (formerly called "Be nice policy")
    – U9-Forward
    Nov 12 at 3:07






  • 1




    Wait, so what's wrong with the answer you linked to? It seems to do everything you want. To save instead of show, just use plt.savefig in place of plt.show
    – tel
    Nov 12 at 3:53






  • 2




    @U9-Forward That's a lot of commas. It's a lot simpler to just flag for moderator attention and explain the situation. They'll determine the best way to discipline the user. I've done so.
    – coldspeed
    Nov 12 at 4:06










  • @coldspeed thanks for letting me know, but where to flag?
    – U9-Forward
    Nov 12 at 4:50






  • 1




    @U9-Forward If the answer has already been deleted, you will need to wait till you have 10k rep to see deleted content.
    – coldspeed
    Nov 12 at 4:54
















2














How can I use something like below line to save images on a grid of 4x4 of heterogenous images? Imagine that images are identified by sample[i] and i takes 16 different values.



scipy.misc.imsave(str(img_index) + '.png', sample[1])


Similar to this answer but for 16 different images
https://stackoverflow.com/a/42041135/2414957



I am not biased towards the used method as long as it does the deed. Also, I am interested in saving images rather than showing them using plt.show() as I am using a remote server and dealing with CelebA image dataset which is a giant dataset. I just want to randomly select 16 images from my batch and save the results of DCGAN and see if it makes any sense or if it converges.



*Currently, I am saving images like below:



batch_no = random.randint(0, 63)


scipy.misc.imsave('sample_gan_images/iter_%d_epoch_%d_sample_%d.png' %(itr, epoch, batch_no), sample[batch_no])


and here, I have 25 epochs and 2000 iterations and batch size is 64.










share|improve this question




















  • 1




    @Panlantic82 What on earth was that???, That's not an answer, that's saying some bad stuff, don't ever do that again, that's very nasty, Your violating the site, see the Code of Conduct (formerly called "Be nice policy")
    – U9-Forward
    Nov 12 at 3:07






  • 1




    Wait, so what's wrong with the answer you linked to? It seems to do everything you want. To save instead of show, just use plt.savefig in place of plt.show
    – tel
    Nov 12 at 3:53






  • 2




    @U9-Forward That's a lot of commas. It's a lot simpler to just flag for moderator attention and explain the situation. They'll determine the best way to discipline the user. I've done so.
    – coldspeed
    Nov 12 at 4:06










  • @coldspeed thanks for letting me know, but where to flag?
    – U9-Forward
    Nov 12 at 4:50






  • 1




    @U9-Forward If the answer has already been deleted, you will need to wait till you have 10k rep to see deleted content.
    – coldspeed
    Nov 12 at 4:54














2












2








2







How can I use something like below line to save images on a grid of 4x4 of heterogenous images? Imagine that images are identified by sample[i] and i takes 16 different values.



scipy.misc.imsave(str(img_index) + '.png', sample[1])


Similar to this answer but for 16 different images
https://stackoverflow.com/a/42041135/2414957



I am not biased towards the used method as long as it does the deed. Also, I am interested in saving images rather than showing them using plt.show() as I am using a remote server and dealing with CelebA image dataset which is a giant dataset. I just want to randomly select 16 images from my batch and save the results of DCGAN and see if it makes any sense or if it converges.



*Currently, I am saving images like below:



batch_no = random.randint(0, 63)


scipy.misc.imsave('sample_gan_images/iter_%d_epoch_%d_sample_%d.png' %(itr, epoch, batch_no), sample[batch_no])


and here, I have 25 epochs and 2000 iterations and batch size is 64.










share|improve this question















How can I use something like below line to save images on a grid of 4x4 of heterogenous images? Imagine that images are identified by sample[i] and i takes 16 different values.



scipy.misc.imsave(str(img_index) + '.png', sample[1])


Similar to this answer but for 16 different images
https://stackoverflow.com/a/42041135/2414957



I am not biased towards the used method as long as it does the deed. Also, I am interested in saving images rather than showing them using plt.show() as I am using a remote server and dealing with CelebA image dataset which is a giant dataset. I just want to randomly select 16 images from my batch and save the results of DCGAN and see if it makes any sense or if it converges.



*Currently, I am saving images like below:



batch_no = random.randint(0, 63)


scipy.misc.imsave('sample_gan_images/iter_%d_epoch_%d_sample_%d.png' %(itr, epoch, batch_no), sample[batch_no])


and here, I have 25 epochs and 2000 iterations and batch size is 64.







python image numpy matplotlib scipy






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 12 at 3:21

























asked Nov 12 at 2:57









Mona Jalal

7,85426108208




7,85426108208








  • 1




    @Panlantic82 What on earth was that???, That's not an answer, that's saying some bad stuff, don't ever do that again, that's very nasty, Your violating the site, see the Code of Conduct (formerly called "Be nice policy")
    – U9-Forward
    Nov 12 at 3:07






  • 1




    Wait, so what's wrong with the answer you linked to? It seems to do everything you want. To save instead of show, just use plt.savefig in place of plt.show
    – tel
    Nov 12 at 3:53






  • 2




    @U9-Forward That's a lot of commas. It's a lot simpler to just flag for moderator attention and explain the situation. They'll determine the best way to discipline the user. I've done so.
    – coldspeed
    Nov 12 at 4:06










  • @coldspeed thanks for letting me know, but where to flag?
    – U9-Forward
    Nov 12 at 4:50






  • 1




    @U9-Forward If the answer has already been deleted, you will need to wait till you have 10k rep to see deleted content.
    – coldspeed
    Nov 12 at 4:54














  • 1




    @Panlantic82 What on earth was that???, That's not an answer, that's saying some bad stuff, don't ever do that again, that's very nasty, Your violating the site, see the Code of Conduct (formerly called "Be nice policy")
    – U9-Forward
    Nov 12 at 3:07






  • 1




    Wait, so what's wrong with the answer you linked to? It seems to do everything you want. To save instead of show, just use plt.savefig in place of plt.show
    – tel
    Nov 12 at 3:53






  • 2




    @U9-Forward That's a lot of commas. It's a lot simpler to just flag for moderator attention and explain the situation. They'll determine the best way to discipline the user. I've done so.
    – coldspeed
    Nov 12 at 4:06










  • @coldspeed thanks for letting me know, but where to flag?
    – U9-Forward
    Nov 12 at 4:50






  • 1




    @U9-Forward If the answer has already been deleted, you will need to wait till you have 10k rep to see deleted content.
    – coldspeed
    Nov 12 at 4:54








1




1




@Panlantic82 What on earth was that???, That's not an answer, that's saying some bad stuff, don't ever do that again, that's very nasty, Your violating the site, see the Code of Conduct (formerly called "Be nice policy")
– U9-Forward
Nov 12 at 3:07




@Panlantic82 What on earth was that???, That's not an answer, that's saying some bad stuff, don't ever do that again, that's very nasty, Your violating the site, see the Code of Conduct (formerly called "Be nice policy")
– U9-Forward
Nov 12 at 3:07




1




1




Wait, so what's wrong with the answer you linked to? It seems to do everything you want. To save instead of show, just use plt.savefig in place of plt.show
– tel
Nov 12 at 3:53




Wait, so what's wrong with the answer you linked to? It seems to do everything you want. To save instead of show, just use plt.savefig in place of plt.show
– tel
Nov 12 at 3:53




2




2




@U9-Forward That's a lot of commas. It's a lot simpler to just flag for moderator attention and explain the situation. They'll determine the best way to discipline the user. I've done so.
– coldspeed
Nov 12 at 4:06




@U9-Forward That's a lot of commas. It's a lot simpler to just flag for moderator attention and explain the situation. They'll determine the best way to discipline the user. I've done so.
– coldspeed
Nov 12 at 4:06












@coldspeed thanks for letting me know, but where to flag?
– U9-Forward
Nov 12 at 4:50




@coldspeed thanks for letting me know, but where to flag?
– U9-Forward
Nov 12 at 4:50




1




1




@U9-Forward If the answer has already been deleted, you will need to wait till you have 10k rep to see deleted content.
– coldspeed
Nov 12 at 4:54




@U9-Forward If the answer has already been deleted, you will need to wait till you have 10k rep to see deleted content.
– coldspeed
Nov 12 at 4:54












2 Answers
2






active

oldest

votes


















1














Personally, I tend to use matplotlib.pyplot.subplots for these kinds of situations. If your images are really heterogenous it might be a better choice than the image concatenation based approach in the answer you linked to.



import matplotlib.pyplot as plt
from scipy.misc import face

x = 4
y = 4

fig,axarr = plt.subplots(x,y)
ims = [face() for i in range(x*y)]

for ax,im in zip(axarr.ravel(), ims):
ax.imshow(im)

fig.savefig('faces.png')


default plt.subplots behavior



My big complaint about subplots is the quantity of whitespace in the resulting figure. As well, for your application you may not want the axes ticks/frames. Here's a wrapper function that deals with those issues:



import matplotlib.pyplot as plt

def savegrid(ims, rows=None, cols=None, fill=True, showax=False):
if rows is None != cols is None:
raise ValueError("Set either both rows and cols or neither.")

if rows is None:
rows = len(ims)
cols = 1

gridspec_kw = {'wspace': 0, 'hspace': 0} if fill else {}
fig,axarr = plt.subplots(rows, cols, gridspec_kw=gridspec_kw)

if fill:
bleed = 0
fig.subplots_adjust(left=bleed, bottom=bleed, right=(1 - bleed), top=(1 - bleed))

for ax,im in zip(axarr.ravel(), ims):
ax.imshow(im)
if not showax:
ax.set_axis_off()

kwargs = {'pad_inches': .01} if fill else {}
fig.savefig('faces.png', **kwargs)


Running savegrid(ims, 4, 4) on the same set of images as used earlier yields:



output of savegrid wrapper



If you use savegrid, if you want each individual image to take up less space, pass the fill=False keyword arg. If you want to show the axes ticks/frames, pass showax=True.






share|improve this answer































    1














    I found this on github, also sharing it:



    import matplotlib.pyplot as plt

    def merge_images(image_batch, size):
    h,w = image_batch.shape[1], image_batch.shape[2]
    c = image_batch.shape[3]
    img = np.zeros((int(h*size[0]), w*size[1], c))
    for idx, im in enumerate(image_batch):
    i = idx % size[1]
    j = idx // size[1]
    img[j*h:j*h+h, i*w:i*w+w,:] = im
    return img

    im_merged = merge_images(sample, [8,8])
    plt.imsave('sample_gan_images/im_merged.png', im_merged )


    enter image description here






    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%2f53255432%2fsaving-a-grid-of-heterogenous-images-in-python%23new-answer', 'question_page');
      }
      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      1














      Personally, I tend to use matplotlib.pyplot.subplots for these kinds of situations. If your images are really heterogenous it might be a better choice than the image concatenation based approach in the answer you linked to.



      import matplotlib.pyplot as plt
      from scipy.misc import face

      x = 4
      y = 4

      fig,axarr = plt.subplots(x,y)
      ims = [face() for i in range(x*y)]

      for ax,im in zip(axarr.ravel(), ims):
      ax.imshow(im)

      fig.savefig('faces.png')


      default plt.subplots behavior



      My big complaint about subplots is the quantity of whitespace in the resulting figure. As well, for your application you may not want the axes ticks/frames. Here's a wrapper function that deals with those issues:



      import matplotlib.pyplot as plt

      def savegrid(ims, rows=None, cols=None, fill=True, showax=False):
      if rows is None != cols is None:
      raise ValueError("Set either both rows and cols or neither.")

      if rows is None:
      rows = len(ims)
      cols = 1

      gridspec_kw = {'wspace': 0, 'hspace': 0} if fill else {}
      fig,axarr = plt.subplots(rows, cols, gridspec_kw=gridspec_kw)

      if fill:
      bleed = 0
      fig.subplots_adjust(left=bleed, bottom=bleed, right=(1 - bleed), top=(1 - bleed))

      for ax,im in zip(axarr.ravel(), ims):
      ax.imshow(im)
      if not showax:
      ax.set_axis_off()

      kwargs = {'pad_inches': .01} if fill else {}
      fig.savefig('faces.png', **kwargs)


      Running savegrid(ims, 4, 4) on the same set of images as used earlier yields:



      output of savegrid wrapper



      If you use savegrid, if you want each individual image to take up less space, pass the fill=False keyword arg. If you want to show the axes ticks/frames, pass showax=True.






      share|improve this answer




























        1














        Personally, I tend to use matplotlib.pyplot.subplots for these kinds of situations. If your images are really heterogenous it might be a better choice than the image concatenation based approach in the answer you linked to.



        import matplotlib.pyplot as plt
        from scipy.misc import face

        x = 4
        y = 4

        fig,axarr = plt.subplots(x,y)
        ims = [face() for i in range(x*y)]

        for ax,im in zip(axarr.ravel(), ims):
        ax.imshow(im)

        fig.savefig('faces.png')


        default plt.subplots behavior



        My big complaint about subplots is the quantity of whitespace in the resulting figure. As well, for your application you may not want the axes ticks/frames. Here's a wrapper function that deals with those issues:



        import matplotlib.pyplot as plt

        def savegrid(ims, rows=None, cols=None, fill=True, showax=False):
        if rows is None != cols is None:
        raise ValueError("Set either both rows and cols or neither.")

        if rows is None:
        rows = len(ims)
        cols = 1

        gridspec_kw = {'wspace': 0, 'hspace': 0} if fill else {}
        fig,axarr = plt.subplots(rows, cols, gridspec_kw=gridspec_kw)

        if fill:
        bleed = 0
        fig.subplots_adjust(left=bleed, bottom=bleed, right=(1 - bleed), top=(1 - bleed))

        for ax,im in zip(axarr.ravel(), ims):
        ax.imshow(im)
        if not showax:
        ax.set_axis_off()

        kwargs = {'pad_inches': .01} if fill else {}
        fig.savefig('faces.png', **kwargs)


        Running savegrid(ims, 4, 4) on the same set of images as used earlier yields:



        output of savegrid wrapper



        If you use savegrid, if you want each individual image to take up less space, pass the fill=False keyword arg. If you want to show the axes ticks/frames, pass showax=True.






        share|improve this answer


























          1












          1








          1






          Personally, I tend to use matplotlib.pyplot.subplots for these kinds of situations. If your images are really heterogenous it might be a better choice than the image concatenation based approach in the answer you linked to.



          import matplotlib.pyplot as plt
          from scipy.misc import face

          x = 4
          y = 4

          fig,axarr = plt.subplots(x,y)
          ims = [face() for i in range(x*y)]

          for ax,im in zip(axarr.ravel(), ims):
          ax.imshow(im)

          fig.savefig('faces.png')


          default plt.subplots behavior



          My big complaint about subplots is the quantity of whitespace in the resulting figure. As well, for your application you may not want the axes ticks/frames. Here's a wrapper function that deals with those issues:



          import matplotlib.pyplot as plt

          def savegrid(ims, rows=None, cols=None, fill=True, showax=False):
          if rows is None != cols is None:
          raise ValueError("Set either both rows and cols or neither.")

          if rows is None:
          rows = len(ims)
          cols = 1

          gridspec_kw = {'wspace': 0, 'hspace': 0} if fill else {}
          fig,axarr = plt.subplots(rows, cols, gridspec_kw=gridspec_kw)

          if fill:
          bleed = 0
          fig.subplots_adjust(left=bleed, bottom=bleed, right=(1 - bleed), top=(1 - bleed))

          for ax,im in zip(axarr.ravel(), ims):
          ax.imshow(im)
          if not showax:
          ax.set_axis_off()

          kwargs = {'pad_inches': .01} if fill else {}
          fig.savefig('faces.png', **kwargs)


          Running savegrid(ims, 4, 4) on the same set of images as used earlier yields:



          output of savegrid wrapper



          If you use savegrid, if you want each individual image to take up less space, pass the fill=False keyword arg. If you want to show the axes ticks/frames, pass showax=True.






          share|improve this answer














          Personally, I tend to use matplotlib.pyplot.subplots for these kinds of situations. If your images are really heterogenous it might be a better choice than the image concatenation based approach in the answer you linked to.



          import matplotlib.pyplot as plt
          from scipy.misc import face

          x = 4
          y = 4

          fig,axarr = plt.subplots(x,y)
          ims = [face() for i in range(x*y)]

          for ax,im in zip(axarr.ravel(), ims):
          ax.imshow(im)

          fig.savefig('faces.png')


          default plt.subplots behavior



          My big complaint about subplots is the quantity of whitespace in the resulting figure. As well, for your application you may not want the axes ticks/frames. Here's a wrapper function that deals with those issues:



          import matplotlib.pyplot as plt

          def savegrid(ims, rows=None, cols=None, fill=True, showax=False):
          if rows is None != cols is None:
          raise ValueError("Set either both rows and cols or neither.")

          if rows is None:
          rows = len(ims)
          cols = 1

          gridspec_kw = {'wspace': 0, 'hspace': 0} if fill else {}
          fig,axarr = plt.subplots(rows, cols, gridspec_kw=gridspec_kw)

          if fill:
          bleed = 0
          fig.subplots_adjust(left=bleed, bottom=bleed, right=(1 - bleed), top=(1 - bleed))

          for ax,im in zip(axarr.ravel(), ims):
          ax.imshow(im)
          if not showax:
          ax.set_axis_off()

          kwargs = {'pad_inches': .01} if fill else {}
          fig.savefig('faces.png', **kwargs)


          Running savegrid(ims, 4, 4) on the same set of images as used earlier yields:



          output of savegrid wrapper



          If you use savegrid, if you want each individual image to take up less space, pass the fill=False keyword arg. If you want to show the axes ticks/frames, pass showax=True.







          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited Nov 12 at 4:43

























          answered Nov 12 at 4:13









          tel

          6,07011430




          6,07011430

























              1














              I found this on github, also sharing it:



              import matplotlib.pyplot as plt

              def merge_images(image_batch, size):
              h,w = image_batch.shape[1], image_batch.shape[2]
              c = image_batch.shape[3]
              img = np.zeros((int(h*size[0]), w*size[1], c))
              for idx, im in enumerate(image_batch):
              i = idx % size[1]
              j = idx // size[1]
              img[j*h:j*h+h, i*w:i*w+w,:] = im
              return img

              im_merged = merge_images(sample, [8,8])
              plt.imsave('sample_gan_images/im_merged.png', im_merged )


              enter image description here






              share|improve this answer


























                1














                I found this on github, also sharing it:



                import matplotlib.pyplot as plt

                def merge_images(image_batch, size):
                h,w = image_batch.shape[1], image_batch.shape[2]
                c = image_batch.shape[3]
                img = np.zeros((int(h*size[0]), w*size[1], c))
                for idx, im in enumerate(image_batch):
                i = idx % size[1]
                j = idx // size[1]
                img[j*h:j*h+h, i*w:i*w+w,:] = im
                return img

                im_merged = merge_images(sample, [8,8])
                plt.imsave('sample_gan_images/im_merged.png', im_merged )


                enter image description here






                share|improve this answer
























                  1












                  1








                  1






                  I found this on github, also sharing it:



                  import matplotlib.pyplot as plt

                  def merge_images(image_batch, size):
                  h,w = image_batch.shape[1], image_batch.shape[2]
                  c = image_batch.shape[3]
                  img = np.zeros((int(h*size[0]), w*size[1], c))
                  for idx, im in enumerate(image_batch):
                  i = idx % size[1]
                  j = idx // size[1]
                  img[j*h:j*h+h, i*w:i*w+w,:] = im
                  return img

                  im_merged = merge_images(sample, [8,8])
                  plt.imsave('sample_gan_images/im_merged.png', im_merged )


                  enter image description here






                  share|improve this answer












                  I found this on github, also sharing it:



                  import matplotlib.pyplot as plt

                  def merge_images(image_batch, size):
                  h,w = image_batch.shape[1], image_batch.shape[2]
                  c = image_batch.shape[3]
                  img = np.zeros((int(h*size[0]), w*size[1], c))
                  for idx, im in enumerate(image_batch):
                  i = idx % size[1]
                  j = idx // size[1]
                  img[j*h:j*h+h, i*w:i*w+w,:] = im
                  return img

                  im_merged = merge_images(sample, [8,8])
                  plt.imsave('sample_gan_images/im_merged.png', im_merged )


                  enter image description here







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 12 at 7:05









                  Mona Jalal

                  7,85426108208




                  7,85426108208






























                      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.





                      Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                      Please pay close attention to the following guidance:


                      • 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%2f53255432%2fsaving-a-grid-of-heterogenous-images-in-python%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

                      Florida Star v. B. J. F.

                      Danny Elfman

                      Lugert, Oklahoma