Version 10 (modified by wja, 6 years ago) (diff) |
---|
Generating Photogrammetry Products
This page aims to guide a user through photogrammetry processing using Agisoft PhotoScan.
Refer to ~arsf/doc/photoscan_processing/ for a step by step guide using a PhotoScan GUI.
Processing using PhotoScan
Overview:
The following files comprise the arf_photoscan library:
arf_photoscan/ | |
init.py | |
ps_export.py | |
ps_processing.py | |
ps_tools.py | |
ps_tools.pyc | |
ps_ortho_processing_after_input_gcp.py | |
ps_ortho_processing_before_input_gcp.py | |
README.md | |
templates/ | |
ps_workflow.cfg |
The arf_photoscan library currently contains two scripts for automating PhotoScan processing of NERC-ARF data:
ps_ortho_processing_before_input_gcp.py will set up a PhotoScan project and align photographs. If Ground Control Points (GCPs) are available, then the script will stop and prompt you to manually locate them in the PhotoScan project. If no GCPs are available, the script will complete the whole PhotoScan processing workflow without (obviously accuracy of data is significantly reduced). This step is not automated. ps_ortho_processing_after_input_gcp.py is run after the and placement of Ground Control Points.
Ground Control Points
Coordinates of GCPs in CSV format can be added to PhotoScan. The user will then need to 'drag and drop' the marker locations to their locations visible in the photographs input. This needs to be done for all photographs each GCP is visible in.
Note: once a couple of GCPs have been located in multiple respective photographs; the 'reproject' button (looks like a recycling symbol) will automatically place the remaining photo. These will still need to be accurately places, but will save a lot of time nevertheless.
Running a script:
- Update config file (template is located in /templates/ps_workflow.cfg).
- As airborne, in the rsg-photoscan virtual machine, run:
/opt/photoscan/photoscan.sh -r ps_ortho_processing_before_input_gcp.py -c [CONFIG]
- If no GCPs have been input in config file, (gcp_csv_path = None) or if gcp_csv_path does not exist, then ps_ortho_processing_before_input_gcp.py will run through the whole PhotoScan workflow without GCPs.
- If a path to GCP CSV has been input into the config file, these GCP coordinates will need to be manually positioned to their correct locations on the aligned photographs. Once this has been achieved, the second script can be run:
/opt/photoscan/photoscan.sh -r ps_ortho_processing_before_after_gcp.py -c [CONFIG]
Config Information
The same config template is used.
The project directory (defined in config file) is the location of the PhotoScan project file (*.psx) and other data produced whilst processing.
The output directory (also defined in config) is where the Point Cloud, DEM and/or Orthomosaic is exported, if the associated parameters are True in config file. If the output directory does not exist, then it will be created.
Creating Delivery
This additional processing service will be delivered as additional items in the otherwise conventional digital camera delivery using the following structure:
Dirs | Sub dir | Example Files | Comments |
ES17_126-2017_170.kml | Google earth file containing Fenix/Owl/camera positions | ||
Read_Me-20171018.pdf | Instructions for use and description of dataset, plus any problems encountered | ||
Read_Me-20180222_orthomosaic.pdf | Instructions for use and description of photogrammetry products | ||
dem | Digital Surface Model(s) produced from PhotoScan. | ||
PHASEONE-IXU-ES17_126-2017170_dsm-utm30n.dem | Digital Surface Model in ENVI format | ||
PHASEONE-IXU-ES17_126-2017170_dsm-utm30n.hdr | Header for accompanying Digital Surface Model in ENVI format | ||
doc | Useful documents | ||
camera_data_quality_report2012.pdf | Camera data quality report | ||
ES17_126-2017170_ground_gps_points_composite.csv | Ground control point (supplied by PI) used during PhotoScan Processing | ||
PHASEONE-IXU-ES17_126-2017170_photoscan_processing_report_20180222.pdf | Agisoft PhotoScan generated processing report. | ||
RCD105_SN21_Calibration_Certificate.pdf | Camera Calibration Certificate | ||
eventfile | PHASEONE-IXU-ES17_126-2017170-ImageEvents.csv | CSV file containing pos/att info per photograph event (may be missing if camera crashed) | |
orthomosaic | PHASEONE-IXU-ES17_126-2017170_mosaic-utm30n.tif | Orthorectified mosaic of photographs in GTiff format | |
photographs | photographs/PHASEONE-IXU-ES17_126-2017170-00001.tif | Tagged tif files of each photograph in area of interest | |
point_cloud | Exports of the 'Dense Cloud' generated in PhotoScan | ||
ascii | PHASEONE-IXU-ES17_126-2017170_point_cloud.txt | Point cloud in ASCII format | |
las1.2 | PHASEONE-IXU-ES17_126-2017170_point_cloud.laz | Point cloud in LAS 1.2 format | |
thumbnails | photographs/PHASEONE-IXU-ES17_126-2017170-00001.jpg | JPEG thumbnails of each photograph in area of interest |