Provided by: osmium-tool_1.11.1-1build2_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/-H  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=LONG1,LAT1,LONG2,LAT2
              Set  the  bounding  box  to  cut  out.   Can  not  be  used  with  --polygon/-p,  --config/-c,  or
              --directory/-d.  The coordinates  LONG1,LAT1  are  from  one  arbitrary  corner,  the  coordinates
              LONG2,LAT2 are from the opposite corner.

       -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=VALUE
              Add output header option.  This command line option can  be  used  multiple  times  for  different
              OPTIONs.   See the libosmium manual for a list of available header options.  For some commands you
              can use the special format “OPTION!” (ie.  an exclamation mark after the OPTION and no value  set)
              to set the value to the same as in the input file.

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",
                      "bbox": ...
                  },
                  {
                      "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:

       bbox:

       A  bounding box in one of two formats.  The first is a simple array with four real numbers, the first two
       specifying the coordinates of an arbitrary corner, the second  two  specifying  the  coordinates  of  the
       opposite corner.

              {
                  "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  Feature  of  type   Polygon   or   MultiPolygon,   or   a
              FeatureCollection  with  the first Feature of type Polygon or MultiPolygon.  Everything except the
              actual geometry (of the first Feature) 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 https://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.

       The smart strategy allows  another  option  “-S  complete-partial-relations=X”.   If  this  is  set,  all
       relations  that have more than X percent of their members already in the extract will have their full set
       of members in the extract.  So this allows completing almost complete relations.  It can  be  useful  for
       instance  to make sure a boundary relation is complete even if some of it is outside the polygon used for
       extraction.

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.

       If you want to split a large file into many extracts, do this in several  steps.   First  create  several
       larger extracts and then split them again and again into smaller pieces.

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 extract -p karlsruhe-boundary.osm.bz2 germany-latest.osm.pbf \
                  -o karlsruhe.osm.pbf

       Extract the city of Munich using a bounding box:

              osmium extract -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 (https://osmcode.org/osmium-tool/)

COPYRIGHT

       Copyright (C) 2013-2019 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 https://osmcode.org/contact.html

AUTHORS

       Jochen Topf <jochen@topf.org>.

                                                     1.11.1                                    OSMIUM-EXTRACT(1)