Provided by: osmium-tool_1.7.1-1_amd64 bug

NAME

       osmium-extract - create geographical extracts from an OSM file

SYNOPSIS

       osmium extract --config CONFIG-FILE [OPTIONS] OSM-FILE
       osmium extract --bbox LEFT,BOTTOM,RIGHT,TOP [OPTIONS] OSM-FILE
       osmium extract --polygon POLYGON-FILE [OPTIONS] OSM-FILE

DESCRIPTION

       Create  geographical  extracts  from  an  OSM data file or an OSM history file.  The region (geographical
       extent) can be given as a bounding box or as a (multi)polygon.

       There are three ways of calling this command:

       • Specify a config file with the --config/-c option.  It can define any number of regions you want to cut
         out.  See the CONFIG FILE section for details.

       • Specify a bounding box to cut out with the --bbox/-b option.

       • Specify a (multi)polygon to cut out with the --polygon/-p option.

       The input file is assumed to be ordered in the usual order: nodes first, then ways, then relations.

       If the --with-history option is used, the command will work correctly for history files.  This  currently
       works  for  the  complete_ways  strategy  only.   The simple or smart strategies do not work with history
       files.  A history extract will contain every version of all objects with at  least  one  version  in  the
       region.  Generating a history extract is somewhat slower than a normal data extract.

       Osmium  will  make  sure  that  all  nodes  on  the vertices of the boundary of the region will be in the
       extract, but nodes that happen to be directly on the boundary, but between those vertices, might  end  up
       in the extract or not.  In almost all cases this will be good enough, but if you want to make really sure
       you got everything, use a small buffer around your region.

       By  default  no  bounds will be set in the header of the output file.  Use the --set-bounds option if you
       need this.

       Note that osmium extract will never clip any OSM objects, ie.  it will not remove node references outside
       the region from ways or unused relation members from relations.  This means you might  get  objects  that
       are not reference-complete.  It has the advantage that you can use osmium merge to merge several extracts
       without problems.

OPTIONS

       -b, --bbox=LEFT,BOTTOM,RIGHT,TOP
              Set  the  bounding  box  to  cut  out.   Can  not  be  used  with  --polygon/-p,  --config/-c,  or
              --directory/-d.

       -c, --config=FILE
              Set the name of the config file.  Can not be used with the --bbox/-b or --polygon/-p  option.   If
              this  is  set, the --output/-o and --output-format/-f options are ignored, because they are set in
              the config file.

       -d, --directory=DIRECTORY
              Output directory.  Output  file  names  in  the  config  file  are  relative  to  this  directory.
              Overwrites  the  setting  of  the  same  name in the config file.  This option is ignored when the
              --bbox/-b or --polygon/-p options are used, set the output directory and name with the --output/-o
              option in that case.

       -H, --with-history
              Specify that the input file is a history file.  The output file(s) will also be history file(s).

       -p, --polygon=POLYGON_FILE
              Set the polygon to cut out based on the contents of the file.  The file has to be a GeoJSON, poly,
              or OSM file as described in the (MULTI)POLYGON FILE FORMATS section.  It has  to  have  the  right
              suffix to be detected correctly.  Can not be used with --bbox/-b, --config/-c, or --directory/-d.

       -s, --strategy=STRATEGY
              Use  the given strategy to extract the region.  For possible values and details see the STRATEGIES
              section.  Default is "complete_ways".

       -S, --option=OPTION=VALUE
              Set a named option for the strategy.  If needed you can specify this option multiple times to  set
              several options.

       --set-bounds
              Set  the  bounds  field  in the header.  The bounds are set to the bbox or envelope of the polygon
              specified for the extract.  Note that strategies other than "simple" can put nodes  outside  those
              bounds into the output file.

COMMON OPTIONS

       -h, --help
              Show usage help.

       -v, --verbose
              Set verbose mode.  The program will output information about what it is doing to STDERR.

INPUT OPTIONS

       -F, --input-format=FORMAT
              The  format of the input file(s).  Can be used to set the input format if it can't be autodetected
              from the file name(s).  This will set the format for all input files, there is no way to  set  the
              format for some input files only.  See osmium-file-formats(5) or the libosmium manual for details.

OUTPUT OPTIONS

       -f, --output-format=FORMAT
              The  format  of  the  output  file.   Can  be  used  to  set the output file format if it can't be
              autodetected from the output file name.  See osmium-file-formats(5) or the  libosmium  manual  for
              details.

       --fsync
              Call fsync after writing the output file to force flushing buffers to disk.

       --generator=NAME
              The name and version of the program generating the output file.  It will be added to the header of
              the output file.  Default is "osmium/" and the version of osmium.

       -o, --output=FILE
              Name of the output file.  Default is '-' (STDOUT).

       -O, --overwrite
              Allow  an  existing  output  file to be overwritten.  Normally osmium will refuse to write over an
              existing file.

       --output-header=OPTION
              Add output header option.  This option can be given several times.  See the libosmium manual for a
              list of allowed header options.

CONFIG FILE

       The config file mainly specifies the file names and the regions of the extracts that should be created.

       The config file is in JSON format.  The top-level is an object which  contains  at  least  an  "extracts"
       array.  It can also contain a "directory" entry which names the directory where all the output files will
       be created:

              {
                  "extracts": [...],
                  "directory": "/tmp/"
              }

       The  extracts  array  specifies the extracts that should be created.  Each item in the array is an object
       with at least a name "output" naming the output file and a region  defined  in  a  "bbox",  "polygon"  or
       "multipolygon"  name.  An optional "description" can be added, it will not be used by the program but can
       help with documenting the file contents.  You can add an optional "output_format" if the format  can  not
       be  detected from the "output" file name.  Run "osmium help file-formats" to get a description of allowed
       formats.  The optional "output_header" allows you to set additional OSM file header settings such as  the
       "generator".

              "extracts": [
                  {
                      "output": "hamburg.osm.pbf",
                      "output_format": "pbf",
                      "description": "optional description",
                      "box": ...
                  },
                  {
                      "output": "berlin.osm.pbf",
                      "description": "optional description",
                      "polygon": ...
                  },
                  {
                      "output": "munich.osm.pbf",
                      "output_header": {
                          "generator": "MyExtractor/1.0"
                      },
                      "description": "optional description",
                      "multipolygon": ...
                  }
              ]

       There are several formats for specifying the regions:

       box:

       A  bounding box in one of two formats.  The first is a simple array with four real numbers specifying the
       left, bottom, right, and top boundary (in that order):

              {
                  "output": "munich.osm.pbf",
                  "description": "Bounding box specified in array format",
                  "bbox": [11.35, 48.05, 11.73, 48.25]
              }

       The second format uses an object instead of an array:

              {
                  "output": "dresden.osm.pbf",
                  "description": "Bounding box specified in object format",
                  "bbox": {
                      "left": 13.57,
                      "right": 13.97,
                      "top": 51.18,
                      "bottom": 50.97
                  }
              }

       polygon:

       A polygon, either specified inline  in  the  config  file  or  read  from  an  external  file.   See  the
       (MULTI)POLYGON  FILE FORMATS section for external files.  If specified inline this is a nested array, the
       outer array defining the polygon, the next array the rings and  the  innermost  arrays  the  coordinates.
       This format is the same as in GeoJSON files.

       In this example there is only one outer ring:

              "polygon": [[
                  [9.613465, 53.58071],
                  [9.647599, 53.59655],
                  [9.649288, 53.61059],
                  [9.613465, 53.58071]
              ]]

       In each ring, the last set of coordinates should be the same as the first set, closing the ring.

       multipolygon:

       A  multipolygon,  either  specified  inline  in  the  config file or read from an external file.  See the
       (MULTI)POLYGON FILE FORMATS section for external files.  If specified inline this is a nested array,  the
       outer  array defining the multipolygon, the next array the polygons, the next the rings and the innermost
       arrays the coordinates.  This format is the same as in GeoJSON files.

       In this example there is one outer and one inner ring:

              "multipolygon": [[[
                  [6.847, 50.987],
                  [6.910, 51.007],
                  [7.037, 50.953],
                  [6.967, 50.880],
                  [6.842, 50.925],
                  [6.847, 50.987]
              ],[
                  [6.967, 50.954],
                  [6.969, 50.920],
                  [6.932, 50.928],
                  [6.934, 50.950],
                  [6.967, 50.954]
              ]]]

       In each ring, the last set of coordinates should be the same as the first set, closing the ring.

       Osmium must check each and every node in the  input  data  and  find  out  in  which  bounding  boxes  or
       (multi)polygons  this  node  is.   This  is  very  cheap  for  bounding  boxes,  but  more  expensive for
       (multi)polygons.  And it becomes more expensive the more vertices the (multi)polyon  has.   Use  bounding
       boxes or simplified polygons where possible.

       Note  that  bounding  boxes  or (multi)polygons are not allowed to span the -180/180 degree line.  If you
       need this, cut out the regions on each side and use osmium merge to join the resulting files.

(MULTI)POLYGON FILE FORMATS

       External files describing a (multi)polygon are specified in the config file  using  the  "file_name"  and
       "file_type" properties on the "polygon" or "multipolygon" object:

              "polygon": {
                  "file_name": "berlin.geojson",
                  "file_type": "geojson"
              }

       If  file  names  don't  start  with a slash (/), they are interpreted relative to the directory where the
       config file is.  If the "file_type" is missing, Osmium will try to autodetect it from the suffix  of  the
       "file_name".

       The following file types are supported:

       geojson
              GeoJSON  file  containing  exactly  one  polygon  or  multipolygon.   Everything except the actual
              geometry is ignored.

       poly   A poly file as described in https://wiki.openstreetmap.org/wiki/Osmosis/Polygon_Filter_File_Format
              .  This wiki page also mentions several sources for such poly files.

       osm    An OSM file containing one or more multipolygon or boundary relation together with all  the  nodes
              and  ways  needed.   Any OSM file format (XML, PBF, ...) supported by Osmium can be used here, but
              the correct suffix must be used, so the file format is detected correctly.   Files  for  this  can
              easily be obtained by searching for the area on OSM and then downloading the full relation using a
              URL  like  http://www.openstreetmap.org/api/0.6/relation/RELATION-ID/full .  Or you can use osmium
              getid -r to get a specific relation from an OSM file.  Note that both these approaches can get you
              very detailed boundaries which can take quite a  while  to  cut  out.   Consider  simplifying  the
              boundary before use.

       If  there  are  several  (multi)polygons  in  a  poly  file  or  OSM  file,  they  will  be  merged.  The
       (multi)polygons must not overlap, otherwise the result is undefined.

STRATEGIES

       osmium extract can use different strategies  for  creating  the  extracts.   Depending  on  the  strategy
       different  objects  will  end up in the extracts.  The strategies differ in how much memory they need and
       how often they need to read the input file.  The choice of strategy depends on how you want  to  use  the
       generated extracts and how much memory and time you have.

       The default strategy is complete_ways.

       Strategy simple
              Runs  in  a  single  pass.   The  extract  will  contain  all nodes inside the region and all ways
              referencing those nodes as well as all relations referencing any nodes or ways  already  included.
              Ways  crossing  the  region  boundary  will  not  be  reference-complete.   Relations  will not be
              reference-complete.  This strategy is fast, because it reads the input only once, but  the  result
              is  not  enough  for  most  use cases.  It is the only strategy that will work when reading from a
              socket or pipe.  This strategy will not work for history files.

       Strategy complete_ways
              Runs in two passes.  The extract will contain all nodes inside the region and all ways referencing
              those nodes as well as all nodes referenced by those ways.  The  extract  will  also  contain  all
              relations  referenced  by nodes inside the region or ways already included and, recursively, their
              parent relations.  The ways are reference-complete, but the relations are not.

       Strategy smart
              Runs in three passes.  The extract  will  contain  all  nodes  inside  the  region  and  all  ways
              referencing  those  nodes  as  well  as all nodes referenced by those ways.  The extract will also
              contain all relations referenced by  nodes  inside  the  region  or  ways  already  included  and,
              recursively,  their  parent  relations.  The extract will also contain all nodes and ways (and the
              nodes they reference) referenced by relations tagged "type=multipolygon" directly referencing  any
              nodes in the region or ways referencing nodes in the region.  The ways are reference-complete, and
              all  multipolygon relations referencing nodes in the regions or ways that have nodes in the region
              are reference-complete.  Other relations are not reference-complete.

       For the smart strategy you can change the types of relations that should be reference-complete.   Instead
       of  just  relations  tagged "type=multipolygon", you can either get all relations (use "-S types=any") or
       give a list of types to the -S option: "-S  types=multipolygon,route".   Note  that  especially  boundary
       relations can be huge, so if you include them, be aware your result might be huge.

DIAGNOSTICS

       osmium extract exits with exit code

       0      if everything went alright,

       1      if there was an error processing the data, or

       2      if there was a problem with the command line arguments, config file or polygon files.

MEMORY USAGE

       Memory  usage  of  osmium  extract  depends  on the number of extracts and on the strategy used.  For the
       simple strategy it will at least be the number of extracts times the highest node ID used divided  by  8.
       For the complete_ways twice that and for the smart strategy a bit more.

EXAMPLES

       See the example config files in the extract-example-config directory.  To try it:

              osmium extract -v -c extract-example-config/extracts.json \
                  germany-latest.osm.pbf

       Extract the city of Karlsruhe using a boundary polygon:

              osmium -p karlsruhe-boundary.osm.bz2 germany-latest.osm.pbf \
                  -o karlsruhe.osm.pbf

       Extract the city of Munich using a bounding box:

              osmium -b 11.35,48.05,11.73,48.25 germany-latest.osm.pbf \
                  -o munich.osm.pbf

SEE ALSO

osmium(1), osmium-file-formats(5), osmium-getid(1), osmium-merge(1)

       • Osmium website (http://osmcode.org/osmium-tool/)

COPYRIGHT

       Copyright (C) 2013-2017 Jochen Topf <jochen@topf.org>.

       License  GPLv3+:  GNU GPL version 3 or later <https://gnu.org/licenses/gpl.html>.  This is free software:
       you are free to change and redistribute it.  There is NO WARRANTY, to the extent permitted by law.

CONTACT

       If you have any questions or want to report a bug, please go to http://osmcode.org/contact.html

AUTHORS

       Jochen Topf <jochen@topf.org>.

                                                      1.7.1                                    OSMIUM-EXTRACT(1)