Writing numpy arrays to irregularly shaped, multiband raster The 2019 Stack Overflow Developer Survey Results Are In Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)Flipped (Y-axis) Raster from point cloudWriting numpy array to raster fileIterative raster calculation script using NumPy arrays breaks after ~10 rasters, returns: “TypeError: Cannot create raster for numpy array.”XYZ Clustering in Python and numpy arraysstack raster using GDAL and numpy dstackHandling an irregularly shaped elevation raster fileOverlapping Rasters as numpy arraysBuffering around raster using gdal and numpy?Generating a raster file using 1D numpy arraysWriting a raster file from multi-dimension array using PythonWriting numpy array to rasterio raster file generates empty file

Mortgage adviser recommends a longer term than necessary combined with overpayments

Are my PIs rude or am I just being too sensitive?

What information about me do stores get via my credit card?

Difference between "generating set" and free product?

What do you call a plan that's an alternative plan in case your initial plan fails?

What can I do if neighbor is blocking my solar panels intentionally?

Can smartphones with the same camera sensor have different image quality?

Why don't hard Brexiteers insist on a hard border to prevent illegal immigration after Brexit?

Would an alien lifeform be able to achieve space travel if lacking in vision?

Did the UK government pay "millions and millions of dollars" to try to snag Julian Assange?

What are these Gizmos at Izaña Atmospheric Research Center in Spain?

Can the DM override racial traits?

Didn't get enough time to take a Coding Test - what to do now?

system call string length limit

Button changing its text & action. Good or terrible?

Is there a writing software that you can sort scenes like slides in PowerPoint?

Is it ethical to upload a automatically generated paper to a non peer-reviewed site as part of a larger research?

Why can't devices on different VLANs, but on the same subnet, communicate?

Can a novice safely splice in wire to lengthen 5V charging cable?

Is a pteranodon too powerful as a beast companion for a beast master?

How do I add random spotting to the same face in cycles?

Why does the Event Horizon Telescope (EHT) not include telescopes from Africa, Asia or Australia?

What's the point in a preamp?

Python - Fishing Simulator



Writing numpy arrays to irregularly shaped, multiband raster



The 2019 Stack Overflow Developer Survey Results Are In
Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)Flipped (Y-axis) Raster from point cloudWriting numpy array to raster fileIterative raster calculation script using NumPy arrays breaks after ~10 rasters, returns: “TypeError: Cannot create raster for numpy array.”XYZ Clustering in Python and numpy arraysstack raster using GDAL and numpy dstackHandling an irregularly shaped elevation raster fileOverlapping Rasters as numpy arraysBuffering around raster using gdal and numpy?Generating a raster file using 1D numpy arraysWriting a raster file from multi-dimension array using PythonWriting numpy array to rasterio raster file generates empty file



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








1















I have the following numpy arrays:



predictions; type is float32; shape: (94, 1461)



lats; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



lons; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



  • 94 corresponds to the number of cells in the vector grid below

  • 1461 corresponds to the number of bands

I've looked at similar questions but most of them discuss exporting full (i.e. no missing, rectangular) rasters or single-band rasters. I was wondering how could I export a multi-band raster with multiple noData cells similar to the gridded vector layer here: this



Additional info:
spatial ref: epsg:4326, GTiff, cell size 0.0270



My attempt:



xmin,ymin,xmax,ymax = [lons.min(),lats.min(),lons.max(),lats.max()]
xres = 0.0270
yres = 0.0270
geotransform=(xmin,xres,0,ymax,0, -yres)
output_raster = gdal.GetDriverByName('GTiff').Create(output_file, 9, 17, 1461, gdal.GDT_Float32) # Open the file
output_raster.SetGeoTransform(geotransform)
for i in range(1461):
output_raster.GetRasterBand(i+1).WriteArray(predictions)
output_raster.GetRasterBand(i+1).SetNoDataValue(noData)
output_raster.FlushCache()


Throws a: line 229, output_raster.GetRasterBand(i+1).WriteArray(predictions)
ValueError: array larger than output file, or offset off edge










share|improve this question









New contributor




plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.


























    1















    I have the following numpy arrays:



    predictions; type is float32; shape: (94, 1461)



    lats; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



    lons; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



    • 94 corresponds to the number of cells in the vector grid below

    • 1461 corresponds to the number of bands

    I've looked at similar questions but most of them discuss exporting full (i.e. no missing, rectangular) rasters or single-band rasters. I was wondering how could I export a multi-band raster with multiple noData cells similar to the gridded vector layer here: this



    Additional info:
    spatial ref: epsg:4326, GTiff, cell size 0.0270



    My attempt:



    xmin,ymin,xmax,ymax = [lons.min(),lats.min(),lons.max(),lats.max()]
    xres = 0.0270
    yres = 0.0270
    geotransform=(xmin,xres,0,ymax,0, -yres)
    output_raster = gdal.GetDriverByName('GTiff').Create(output_file, 9, 17, 1461, gdal.GDT_Float32) # Open the file
    output_raster.SetGeoTransform(geotransform)
    for i in range(1461):
    output_raster.GetRasterBand(i+1).WriteArray(predictions)
    output_raster.GetRasterBand(i+1).SetNoDataValue(noData)
    output_raster.FlushCache()


    Throws a: line 229, output_raster.GetRasterBand(i+1).WriteArray(predictions)
    ValueError: array larger than output file, or offset off edge










    share|improve this question









    New contributor




    plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.






















      1












      1








      1








      I have the following numpy arrays:



      predictions; type is float32; shape: (94, 1461)



      lats; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



      lons; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



      • 94 corresponds to the number of cells in the vector grid below

      • 1461 corresponds to the number of bands

      I've looked at similar questions but most of them discuss exporting full (i.e. no missing, rectangular) rasters or single-band rasters. I was wondering how could I export a multi-band raster with multiple noData cells similar to the gridded vector layer here: this



      Additional info:
      spatial ref: epsg:4326, GTiff, cell size 0.0270



      My attempt:



      xmin,ymin,xmax,ymax = [lons.min(),lats.min(),lons.max(),lats.max()]
      xres = 0.0270
      yres = 0.0270
      geotransform=(xmin,xres,0,ymax,0, -yres)
      output_raster = gdal.GetDriverByName('GTiff').Create(output_file, 9, 17, 1461, gdal.GDT_Float32) # Open the file
      output_raster.SetGeoTransform(geotransform)
      for i in range(1461):
      output_raster.GetRasterBand(i+1).WriteArray(predictions)
      output_raster.GetRasterBand(i+1).SetNoDataValue(noData)
      output_raster.FlushCache()


      Throws a: line 229, output_raster.GetRasterBand(i+1).WriteArray(predictions)
      ValueError: array larger than output file, or offset off edge










      share|improve this question









      New contributor




      plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.












      I have the following numpy arrays:



      predictions; type is float32; shape: (94, 1461)



      lats; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



      lons; float32; shape: (94,); centroid of cell in vector layer, decimal degs.



      • 94 corresponds to the number of cells in the vector grid below

      • 1461 corresponds to the number of bands

      I've looked at similar questions but most of them discuss exporting full (i.e. no missing, rectangular) rasters or single-band rasters. I was wondering how could I export a multi-band raster with multiple noData cells similar to the gridded vector layer here: this



      Additional info:
      spatial ref: epsg:4326, GTiff, cell size 0.0270



      My attempt:



      xmin,ymin,xmax,ymax = [lons.min(),lats.min(),lons.max(),lats.max()]
      xres = 0.0270
      yres = 0.0270
      geotransform=(xmin,xres,0,ymax,0, -yres)
      output_raster = gdal.GetDriverByName('GTiff').Create(output_file, 9, 17, 1461, gdal.GDT_Float32) # Open the file
      output_raster.SetGeoTransform(geotransform)
      for i in range(1461):
      output_raster.GetRasterBand(i+1).WriteArray(predictions)
      output_raster.GetRasterBand(i+1).SetNoDataValue(noData)
      output_raster.FlushCache()


      Throws a: line 229, output_raster.GetRasterBand(i+1).WriteArray(predictions)
      ValueError: array larger than output file, or offset off edge







      python raster gdal numpy






      share|improve this question









      New contributor




      plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question









      New contributor




      plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question








      edited Apr 7 at 19:47







      plummms













      New contributor




      plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked Apr 7 at 19:10









      plummmsplummms

      84




      84




      New contributor




      plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      plummms is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.




















          1 Answer
          1






          active

          oldest

          votes


















          0














          You can't, you have to generate a regularly shaped array.



          i.e.



          import math

          from osgeo import gdal
          import numpy as np

          xres = 0.0270
          yres = 0.0270
          nrows = 17
          ncols = 9
          nbands = 1461
          nodata = -9999
          ncells = 94

          # ======= Make some dummy data =======
          output_file = '/tmp/test.tif'
          xmin, ymin = 120, -30
          cells = np.random.choice(np.arange(nrows*ncols), ncells, replace=False)

          lats = np.arange(ymin, ymin+nrows*yres, yres)
          lons = np.arange(xmin, xmin+ncols*xres, xres)
          lats, lons = np.meshgrid(lats, lons)
          lats = lats.ravel()[cells]
          lons = lons.ravel()[cells]

          predictions = np.random.random((nbands, ncells))
          # ======= End make some dummy data =======

          # Make an empty 1 band array to fill with predictions
          array = np.empty((nrows, ncols), dtype=np.float32)

          xmin,ymin,xmax,ymax = [lons.min(), lats.min(),lons.max(), lats.max()]
          geotransform=(xmin, xres, 0, ymax, 0, -yres)

          output_raster = gdal.GetDriverByName('GTiff').Create(output_file, ncols, nrows, nbands, gdal.GDT_Float32) # Open the file
          output_raster.SetGeoTransform(geotransform)

          # Loop bands
          for i in range(nbands):

          # Init array with nodata
          array[:] = nodata

          # Loop lat/lons inc. index j
          for j, (lon, lat) in enumerate(zip(lons, lats)):
          # Calc x, y pixel index
          x = math.floor((lon - xmin) / xres)
          y = math.floor((lat - ymin) / xres)

          # Fill the array at y, x with the value from predictions at band i, index j
          array[y, x] = predictions[i, j]

          output_raster.GetRasterBand(i+1).WriteArray(array)
          output_raster.GetRasterBand(i+1).SetNoDataValue(nodata)

          del output_raster





          share|improve this answer























          • Thank you so much!!! I followed your sample code and managed to make it (with 1 problem...) I did have to change: xmin,ymin,xmax,ymax = [lons.min()-xres/2, lats.min()-yres/2,lons.max()+xres/2, lats.max()+yres/2] since the coords were centroids; and array[y, x] = preds[j, i] since the shape was (94,1461).

            – plummms
            Apr 8 at 6:01












          • The 1 problem: The final raster is inverted on the y-axis

            – plummms
            Apr 8 at 6:02












          • Solved my problem by adding np.flipud(array) before the WriteArray(array) line. Source

            – plummms
            Apr 8 at 6:31











          Your Answer








          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "79"
          ;
          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: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          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
          );



          );






          plummms is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fgis.stackexchange.com%2fquestions%2f318050%2fwriting-numpy-arrays-to-irregularly-shaped-multiband-raster%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









          0














          You can't, you have to generate a regularly shaped array.



          i.e.



          import math

          from osgeo import gdal
          import numpy as np

          xres = 0.0270
          yres = 0.0270
          nrows = 17
          ncols = 9
          nbands = 1461
          nodata = -9999
          ncells = 94

          # ======= Make some dummy data =======
          output_file = '/tmp/test.tif'
          xmin, ymin = 120, -30
          cells = np.random.choice(np.arange(nrows*ncols), ncells, replace=False)

          lats = np.arange(ymin, ymin+nrows*yres, yres)
          lons = np.arange(xmin, xmin+ncols*xres, xres)
          lats, lons = np.meshgrid(lats, lons)
          lats = lats.ravel()[cells]
          lons = lons.ravel()[cells]

          predictions = np.random.random((nbands, ncells))
          # ======= End make some dummy data =======

          # Make an empty 1 band array to fill with predictions
          array = np.empty((nrows, ncols), dtype=np.float32)

          xmin,ymin,xmax,ymax = [lons.min(), lats.min(),lons.max(), lats.max()]
          geotransform=(xmin, xres, 0, ymax, 0, -yres)

          output_raster = gdal.GetDriverByName('GTiff').Create(output_file, ncols, nrows, nbands, gdal.GDT_Float32) # Open the file
          output_raster.SetGeoTransform(geotransform)

          # Loop bands
          for i in range(nbands):

          # Init array with nodata
          array[:] = nodata

          # Loop lat/lons inc. index j
          for j, (lon, lat) in enumerate(zip(lons, lats)):
          # Calc x, y pixel index
          x = math.floor((lon - xmin) / xres)
          y = math.floor((lat - ymin) / xres)

          # Fill the array at y, x with the value from predictions at band i, index j
          array[y, x] = predictions[i, j]

          output_raster.GetRasterBand(i+1).WriteArray(array)
          output_raster.GetRasterBand(i+1).SetNoDataValue(nodata)

          del output_raster





          share|improve this answer























          • Thank you so much!!! I followed your sample code and managed to make it (with 1 problem...) I did have to change: xmin,ymin,xmax,ymax = [lons.min()-xres/2, lats.min()-yres/2,lons.max()+xres/2, lats.max()+yres/2] since the coords were centroids; and array[y, x] = preds[j, i] since the shape was (94,1461).

            – plummms
            Apr 8 at 6:01












          • The 1 problem: The final raster is inverted on the y-axis

            – plummms
            Apr 8 at 6:02












          • Solved my problem by adding np.flipud(array) before the WriteArray(array) line. Source

            – plummms
            Apr 8 at 6:31















          0














          You can't, you have to generate a regularly shaped array.



          i.e.



          import math

          from osgeo import gdal
          import numpy as np

          xres = 0.0270
          yres = 0.0270
          nrows = 17
          ncols = 9
          nbands = 1461
          nodata = -9999
          ncells = 94

          # ======= Make some dummy data =======
          output_file = '/tmp/test.tif'
          xmin, ymin = 120, -30
          cells = np.random.choice(np.arange(nrows*ncols), ncells, replace=False)

          lats = np.arange(ymin, ymin+nrows*yres, yres)
          lons = np.arange(xmin, xmin+ncols*xres, xres)
          lats, lons = np.meshgrid(lats, lons)
          lats = lats.ravel()[cells]
          lons = lons.ravel()[cells]

          predictions = np.random.random((nbands, ncells))
          # ======= End make some dummy data =======

          # Make an empty 1 band array to fill with predictions
          array = np.empty((nrows, ncols), dtype=np.float32)

          xmin,ymin,xmax,ymax = [lons.min(), lats.min(),lons.max(), lats.max()]
          geotransform=(xmin, xres, 0, ymax, 0, -yres)

          output_raster = gdal.GetDriverByName('GTiff').Create(output_file, ncols, nrows, nbands, gdal.GDT_Float32) # Open the file
          output_raster.SetGeoTransform(geotransform)

          # Loop bands
          for i in range(nbands):

          # Init array with nodata
          array[:] = nodata

          # Loop lat/lons inc. index j
          for j, (lon, lat) in enumerate(zip(lons, lats)):
          # Calc x, y pixel index
          x = math.floor((lon - xmin) / xres)
          y = math.floor((lat - ymin) / xres)

          # Fill the array at y, x with the value from predictions at band i, index j
          array[y, x] = predictions[i, j]

          output_raster.GetRasterBand(i+1).WriteArray(array)
          output_raster.GetRasterBand(i+1).SetNoDataValue(nodata)

          del output_raster





          share|improve this answer























          • Thank you so much!!! I followed your sample code and managed to make it (with 1 problem...) I did have to change: xmin,ymin,xmax,ymax = [lons.min()-xres/2, lats.min()-yres/2,lons.max()+xres/2, lats.max()+yres/2] since the coords were centroids; and array[y, x] = preds[j, i] since the shape was (94,1461).

            – plummms
            Apr 8 at 6:01












          • The 1 problem: The final raster is inverted on the y-axis

            – plummms
            Apr 8 at 6:02












          • Solved my problem by adding np.flipud(array) before the WriteArray(array) line. Source

            – plummms
            Apr 8 at 6:31













          0












          0








          0







          You can't, you have to generate a regularly shaped array.



          i.e.



          import math

          from osgeo import gdal
          import numpy as np

          xres = 0.0270
          yres = 0.0270
          nrows = 17
          ncols = 9
          nbands = 1461
          nodata = -9999
          ncells = 94

          # ======= Make some dummy data =======
          output_file = '/tmp/test.tif'
          xmin, ymin = 120, -30
          cells = np.random.choice(np.arange(nrows*ncols), ncells, replace=False)

          lats = np.arange(ymin, ymin+nrows*yres, yres)
          lons = np.arange(xmin, xmin+ncols*xres, xres)
          lats, lons = np.meshgrid(lats, lons)
          lats = lats.ravel()[cells]
          lons = lons.ravel()[cells]

          predictions = np.random.random((nbands, ncells))
          # ======= End make some dummy data =======

          # Make an empty 1 band array to fill with predictions
          array = np.empty((nrows, ncols), dtype=np.float32)

          xmin,ymin,xmax,ymax = [lons.min(), lats.min(),lons.max(), lats.max()]
          geotransform=(xmin, xres, 0, ymax, 0, -yres)

          output_raster = gdal.GetDriverByName('GTiff').Create(output_file, ncols, nrows, nbands, gdal.GDT_Float32) # Open the file
          output_raster.SetGeoTransform(geotransform)

          # Loop bands
          for i in range(nbands):

          # Init array with nodata
          array[:] = nodata

          # Loop lat/lons inc. index j
          for j, (lon, lat) in enumerate(zip(lons, lats)):
          # Calc x, y pixel index
          x = math.floor((lon - xmin) / xres)
          y = math.floor((lat - ymin) / xres)

          # Fill the array at y, x with the value from predictions at band i, index j
          array[y, x] = predictions[i, j]

          output_raster.GetRasterBand(i+1).WriteArray(array)
          output_raster.GetRasterBand(i+1).SetNoDataValue(nodata)

          del output_raster





          share|improve this answer













          You can't, you have to generate a regularly shaped array.



          i.e.



          import math

          from osgeo import gdal
          import numpy as np

          xres = 0.0270
          yres = 0.0270
          nrows = 17
          ncols = 9
          nbands = 1461
          nodata = -9999
          ncells = 94

          # ======= Make some dummy data =======
          output_file = '/tmp/test.tif'
          xmin, ymin = 120, -30
          cells = np.random.choice(np.arange(nrows*ncols), ncells, replace=False)

          lats = np.arange(ymin, ymin+nrows*yres, yres)
          lons = np.arange(xmin, xmin+ncols*xres, xres)
          lats, lons = np.meshgrid(lats, lons)
          lats = lats.ravel()[cells]
          lons = lons.ravel()[cells]

          predictions = np.random.random((nbands, ncells))
          # ======= End make some dummy data =======

          # Make an empty 1 band array to fill with predictions
          array = np.empty((nrows, ncols), dtype=np.float32)

          xmin,ymin,xmax,ymax = [lons.min(), lats.min(),lons.max(), lats.max()]
          geotransform=(xmin, xres, 0, ymax, 0, -yres)

          output_raster = gdal.GetDriverByName('GTiff').Create(output_file, ncols, nrows, nbands, gdal.GDT_Float32) # Open the file
          output_raster.SetGeoTransform(geotransform)

          # Loop bands
          for i in range(nbands):

          # Init array with nodata
          array[:] = nodata

          # Loop lat/lons inc. index j
          for j, (lon, lat) in enumerate(zip(lons, lats)):
          # Calc x, y pixel index
          x = math.floor((lon - xmin) / xres)
          y = math.floor((lat - ymin) / xres)

          # Fill the array at y, x with the value from predictions at band i, index j
          array[y, x] = predictions[i, j]

          output_raster.GetRasterBand(i+1).WriteArray(array)
          output_raster.GetRasterBand(i+1).SetNoDataValue(nodata)

          del output_raster






          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Apr 8 at 3:21









          user2856user2856

          31k258106




          31k258106












          • Thank you so much!!! I followed your sample code and managed to make it (with 1 problem...) I did have to change: xmin,ymin,xmax,ymax = [lons.min()-xres/2, lats.min()-yres/2,lons.max()+xres/2, lats.max()+yres/2] since the coords were centroids; and array[y, x] = preds[j, i] since the shape was (94,1461).

            – plummms
            Apr 8 at 6:01












          • The 1 problem: The final raster is inverted on the y-axis

            – plummms
            Apr 8 at 6:02












          • Solved my problem by adding np.flipud(array) before the WriteArray(array) line. Source

            – plummms
            Apr 8 at 6:31

















          • Thank you so much!!! I followed your sample code and managed to make it (with 1 problem...) I did have to change: xmin,ymin,xmax,ymax = [lons.min()-xres/2, lats.min()-yres/2,lons.max()+xres/2, lats.max()+yres/2] since the coords were centroids; and array[y, x] = preds[j, i] since the shape was (94,1461).

            – plummms
            Apr 8 at 6:01












          • The 1 problem: The final raster is inverted on the y-axis

            – plummms
            Apr 8 at 6:02












          • Solved my problem by adding np.flipud(array) before the WriteArray(array) line. Source

            – plummms
            Apr 8 at 6:31
















          Thank you so much!!! I followed your sample code and managed to make it (with 1 problem...) I did have to change: xmin,ymin,xmax,ymax = [lons.min()-xres/2, lats.min()-yres/2,lons.max()+xres/2, lats.max()+yres/2] since the coords were centroids; and array[y, x] = preds[j, i] since the shape was (94,1461).

          – plummms
          Apr 8 at 6:01






          Thank you so much!!! I followed your sample code and managed to make it (with 1 problem...) I did have to change: xmin,ymin,xmax,ymax = [lons.min()-xres/2, lats.min()-yres/2,lons.max()+xres/2, lats.max()+yres/2] since the coords were centroids; and array[y, x] = preds[j, i] since the shape was (94,1461).

          – plummms
          Apr 8 at 6:01














          The 1 problem: The final raster is inverted on the y-axis

          – plummms
          Apr 8 at 6:02






          The 1 problem: The final raster is inverted on the y-axis

          – plummms
          Apr 8 at 6:02














          Solved my problem by adding np.flipud(array) before the WriteArray(array) line. Source

          – plummms
          Apr 8 at 6:31





          Solved my problem by adding np.flipud(array) before the WriteArray(array) line. Source

          – plummms
          Apr 8 at 6:31










          plummms is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          plummms is a new contributor. Be nice, and check out our Code of Conduct.












          plummms is a new contributor. Be nice, and check out our Code of Conduct.











          plummms is a new contributor. Be nice, and check out our Code of Conduct.














          Thanks for contributing an answer to Geographic Information Systems Stack Exchange!


          • 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%2fgis.stackexchange.com%2fquestions%2f318050%2fwriting-numpy-arrays-to-irregularly-shaped-multiband-raster%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

          Romeo and Juliet ContentsCharactersSynopsisSourcesDate and textThemes and motifsCriticism and interpretationLegacyScene by sceneSee alsoNotes and referencesSourcesExternal linksNavigation menu"Consumer Price Index (estimate) 1800–"10.2307/28710160037-3222287101610.1093/res/II.5.31910.2307/45967845967810.2307/2869925286992510.1525/jams.1982.35.3.03a00050"Dada Masilo: South African dancer who breaks the rules"10.1093/res/os-XV.57.1610.2307/28680942868094"Sweet Sorrow: Mann-Korman's Romeo and Juliet Closes Sept. 5 at MN's Ordway"the original10.2307/45957745957710.1017/CCOL0521570476.009"Ram Leela box office collections hit massive Rs 100 crore, pulverises prediction"Archived"Broadway Revival of Romeo and Juliet, Starring Orlando Bloom and Condola Rashad, Will Close Dec. 8"Archived10.1075/jhp.7.1.04hon"Wherefore art thou, Romeo? To make us laugh at Navy Pier"the original10.1093/gmo/9781561592630.article.O006772"Ram-leela Review Roundup: Critics Hail Film as Best Adaptation of Romeo and Juliet"Archived10.2307/31946310047-77293194631"Romeo and Juliet get Twitter treatment""Juliet's Nurse by Lois Leveen""Romeo and Juliet: Orlando Bloom's Broadway Debut Released in Theaters for Valentine's Day"Archived"Romeo and Juliet Has No Balcony"10.1093/gmo/9781561592630.article.O00778110.2307/2867423286742310.1076/enst.82.2.115.959510.1080/00138380601042675"A plague o' both your houses: error in GCSE exam paper forces apology""Juliet of the Five O'Clock Shadow, and Other Wonders"10.2307/33912430027-4321339124310.2307/28487440038-7134284874410.2307/29123140149-661129123144728341M"Weekender Guide: Shakespeare on The Drive""balcony"UK public library membership"romeo"UK public library membership10.1017/CCOL9780521844291"Post-Zionist Critique on Israel and the Palestinians Part III: Popular Culture"10.2307/25379071533-86140377-919X2537907"Capulets and Montagues: UK exam board admit mixing names up in Romeo and Juliet paper"Istoria Novellamente Ritrovata di Due Nobili Amanti2027/mdp.390150822329610820-750X"GCSE exam error: Board accidentally rewrites Shakespeare"10.2307/29176390149-66112917639"Exam board apologises after error in English GCSE paper which confused characters in Shakespeare's Romeo and Juliet""From Mariotto and Ganozza to Romeo and Guilietta: Metamorphoses of a Renaissance Tale"10.2307/37323537323510.2307/2867455286745510.2307/28678912867891"10 Questions for Taylor Swift"10.2307/28680922868092"Haymarket Theatre""The Zeffirelli Way: Revealing Talk by Florentine Director""Michael Smuin: 1938-2007 / Prolific dance director had showy career"The Life and Art of Edwin BoothRomeo and JulietRomeo and JulietRomeo and JulietRomeo and JulietEasy Read Romeo and JulietRomeo and Julieteeecb12003684p(data)4099369-3n8211610759dbe00d-a9e2-41a3-b2c1-977dd692899302814385X313670221313670221

          Creating closest line along the point''s azimuth using PostgreSQL Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?Drawing line between points at specific distance in PostGIS?How to efficiently find the closest point over the dateline?How to find the nearest point by using PostGIS function?PostGIS nearest point with LATERAL JOIN in PostgreSQL 9.3+Creating a table and inserting selected streets using plpgsql functionsCreating a table that stores Distances and other columnSaving select query results (year wise) from PostgreSQL/PostGIS to text filesWhat is the information behind this geometry?How to give start and end vertex ids dynamically in pgr_dijkstra?Point to Polygon nearest distance DS_distance is not using geography index & knn <-> or <#> does not give result in orderLine to point conversion with start point and end point detection?

          Crop image to path created in TikZ? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)Crop an inserted image?TikZ pictures does not appear in posterImage behind and beyond crop marks?Tikz picture as large as possible on A4 PageTransparency vs image compression dilemmaHow to crop background from image automatically?Image does not cropTikzexternal capturing crop marks when externalizing pgfplots?How to include image path that contains a dollar signCrop image with left size given