File: PythonNumpyTest.py

package info (click to toggle)
otb 5.8.0%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 38,496 kB
  • ctags: 40,282
  • sloc: cpp: 306,573; ansic: 3,575; python: 450; sh: 214; perl: 74; java: 72; makefile: 70
file content (64 lines) | stat: -rw-r--r-- 2,147 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# -*- coding: utf-8 -*-
# Author: Rashad Kanavath <rashad.kanavath@c-s.fr>
#
# Copyright: (c) CS Systemes d'information. All rights reserved
#
#  Example on testing numpy
#


import os
#from scipy import misc

import numpy as np

def test(otbApplication, argv):
	#from PIL import Image as PILImage

	inFile  = argv[1]
	outFile = argv[2]
	# pilimage = PILImage.open(inFile)
	# npimage = np.asarray(pilimage)
	# print npimage.dtype

	ExtractROI = otbApplication.Registry.CreateApplication("ExtractROI")
	ExtractROI.SetParameterString("in", inFile)
	ExtractROI.SetParameterInt("startx", 10)
	ExtractROI.SetParameterInt("starty", 10)
	ExtractROI.SetParameterInt("sizex", 250)
	ExtractROI.SetParameterInt("sizey", 250)

	#Bug or Design ?.
	#Anyway below two is needed only for ExtractROI application
	ExtractROI.SetParameterUserValue("sizex", True)
	ExtractROI.SetParameterUserValue("sizey", True)
	ExtractROI.Execute()

	ExtractROIOut = ExtractROI.GetVectorImageAsNumpyArray("out", 'float')

	#write RGB image to file via python
	#misc.imsave('ExtractROIOut.jpg', ExtractROIOut)

	Rescale = otbApplication.Registry.CreateApplication("Rescale")
	#take numpy array from ExtractROI and feed into Rescale
	Rescale.SetVectorImageFromNumpyArray("in", ExtractROIOut)
	Rescale.SetParameterFloat("outmin", 50, True)
	Rescale.SetParameterFloat("outmax", 100, True)
	Rescale.Execute()

	RescaleOut = Rescale.GetVectorImageAsNumpyArray("out", 'float')
	# misc.imsave('RescaleOut.jpg', RescaleOut)

	Convert = otbApplication.Registry.CreateApplication("Convert")
	# take numpy output from Rescale application and feed into Convert
	Convert.SetVectorImageFromNumpyArray("in", RescaleOut)
	Convert.SetParameterString("out", "ConvertOut.png")
	Convert.ExecuteAndWriteOutput()
	ConvertOut = Convert.GetVectorImageAsNumpyArray("out", 'float')

	Smoothing = otbApplication.Registry.CreateApplication("Smoothing")
	# take numpy output from Convert application and feed into Smoothing
	Smoothing.SetVectorImageFromNumpyArray("in", ConvertOut)
	Smoothing.SetParameterString("type", 'anidif')
	Smoothing.SetParameterString("out", outFile)
	Smoothing.ExecuteAndWriteOutput()