Skip to content

Commit

Permalink
Photrim has been refactored to be callable; old Makefile tests have b…
Browse files Browse the repository at this point in the history
…een converted to gtests and removed. (DOI-USGS#5582)

* Photrim has been converted to a callable app. Corresponding Makefile tests have been converted to gtests and removed. Addresses DOI-USGS#5581.

* Tweaks to FunctionalTestsPhotrim.cpp. Addresses DOI-USGS#5581.
  • Loading branch information
kledmundson authored and chkim-usgs committed Nov 26, 2024
1 parent e512001 commit 2ed706c
Show file tree
Hide file tree
Showing 11 changed files with 462 additions and 154 deletions.
95 changes: 11 additions & 84 deletions isis/src/base/apps/photrim/main.cpp
Original file line number Diff line number Diff line change
@@ -1,93 +1,20 @@
#include "Isis.h"
#include "Camera.h"
#include "ProcessByLine.h"
#include "SpecialPixel.h"
/** This is free and unencumbered software released into the public domain.
using namespace std;
using namespace Isis;
The authors of ISIS do not claim copyright on the contents of this file.
For more details about the LICENSE terms and the AUTHORS, you will
find files of those names at the top level of this repository. **/

// Global variables
Camera *cam;
Cube *icube;
bool usedem;
double minPhase;
double maxPhase;
double minEmission;
double maxEmission;
double minIncidence;
double maxIncidence;
int lastBand;
/* SPDX-License-Identifier: CC0-1.0 */

void photrim(Buffer &in, Buffer &out);
#include "Isis.h"

void IsisMain() {
// We will be processing by line
ProcessByLine p;
#include "photrim.h"

// Setup the input and get the camera model
icube = p.SetInputCube("FROM");
cam = icube->camera();
#include "Application.h"

// Create the output cube
p.SetOutputCube("TO");
using namespace Isis;

// Get the trim angles
void IsisMain() {
UserInterface &ui = Application::GetUserInterface();

minPhase = ui.GetDouble("MINPHASE");
maxPhase = ui.GetDouble("MAXPHASE");
minEmission = ui.GetDouble("MINEMISSION");
maxEmission = ui.GetDouble("MAXEMISSION");
minIncidence = ui.GetDouble("MININCIDENCE");
maxIncidence = ui.GetDouble("MAXINCIDENCE");

usedem = ui.GetBoolean("USEDEM");

if (!usedem) {
cam->IgnoreElevationModel(true);

}

// Start the processing
lastBand = 0;
p.StartProcess(photrim);
p.EndProcess();
}


// Line processing routine
void photrim(Buffer &in, Buffer &out) {
// See if there is a change in band which would change the camera model
if (in.Band() != lastBand) {
lastBand = in.Band();
cam->SetBand(icube->physicalBand(lastBand));
}

// Loop for each pixel in the line.
double samp, phase, emission, incidence;
double line = in.Line();
for (int i = 0; i < in.size(); i++) {
samp = in.Sample(i);
cam->SetImage(samp, line);
if (cam->HasSurfaceIntersection()) {
if (((phase = cam->PhaseAngle()) < minPhase) || (phase > maxPhase)) {
out[i] = Isis::NULL8;
}
else if (((emission = cam->EmissionAngle()) < minEmission) ||
(emission > maxEmission)) {
out[i] = Isis::NULL8;
}
else if (((incidence = cam->IncidenceAngle()) < minIncidence) ||
(incidence > maxIncidence)) {
out[i] = Isis::NULL8;
}
else {
out[i] = in[i];
}
}
// Trim outerspace
else {
out[i] = Isis::NULL8;
}
}
photrim(ui);
}
115 changes: 115 additions & 0 deletions isis/src/base/apps/photrim/photrim.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
/** This is free and unencumbered software released into the public domain.
The authors of ISIS do not claim copyright on the contents of this file.
For more details about the LICENSE terms and the AUTHORS, you will
find files of those names at the top level of this repository. **/

/* SPDX-License-Identifier: CC0-1.0 */

#include "photrim.h"

#include "Camera.h"
#include "ProcessByLine.h"
#include "SpecialPixel.h"

namespace Isis {

/*
* The photrim program trims pixels outside of the phase, incidence,
* and emission angles by setting them to "null" within all bands of
* the cube. A user can either trim using the program's default method
* or the USEDEM method.
*
* @param ui UserInterface object containing parameters
*/
void photrim(UserInterface &ui) {

// open input cube
Cube icube;
icube.open(ui.GetCubeName("FROM"));

photrim(&icube, ui);
}


/*
* The photrim program trims pixels outside of the phase, incidence,
* and emission angles by setting them to "null" within all bands of
* the cube. A user can either trim using the program's default method
* or the USEDEM method.
*
* @param iCube Input cube
* @param ui UserInterface object containing parameters
*/
void photrim(Cube *icube, UserInterface &ui) {
// processing by line
ProcessByLine p;

// Setup input cube and get the camera model
p.SetInputCube(icube);

Camera* cam = icube->camera();

// Create the output cube
QString fname = ui.GetCubeName("TO");
CubeAttributeOutput &atts = ui.GetOutputAttribute("TO");
p.SetOutputCube(fname, atts);

// Get the trim angles
double minPhase = ui.GetDouble("MINPHASE");
double maxPhase = ui.GetDouble("MAXPHASE");
double minEmission = ui.GetDouble("MINEMISSION");
double maxEmission = ui.GetDouble("MAXEMISSION");
double minIncidence = ui.GetDouble("MININCIDENCE");
double maxIncidence = ui.GetDouble("MAXINCIDENCE");

bool usedem = ui.GetBoolean("USEDEM");

if (!usedem) {
cam->IgnoreElevationModel(true);
}

// Start the processing
int lastBand = 0;

// lambda function with captures to process by line
auto photrimLineProcess = [&](Buffer &in, Buffer &out)->void {
// See if there is a change in band which would change the camera model
if (in.Band() != lastBand) {
lastBand = in.Band();
cam->SetBand(icube->physicalBand(lastBand));
}

// Loop for each pixel in the line.
double samp, phase, emission, incidence;
double line = in.Line();
for (int i = 0; i < in.size(); i++) {
samp = in.Sample(i);
cam->SetImage(samp, line);
if (cam->HasSurfaceIntersection()) {
if (((phase = cam->PhaseAngle()) < minPhase) || (phase > maxPhase)) {
out[i] = Isis::NULL8;
}
else if (((emission = cam->EmissionAngle()) < minEmission) ||
(emission > maxEmission)) {
out[i] = Isis::NULL8;
}
else if (((incidence = cam->IncidenceAngle()) < minIncidence) ||
(incidence > maxIncidence)) {
out[i] = Isis::NULL8;
}
else {
out[i] = in[i];
}
}
// Trim outerspace
else {
out[i] = Isis::NULL8;
}
}
};

p.StartProcess(photrimLineProcess);
p.EndProcess();
}
}
19 changes: 19 additions & 0 deletions isis/src/base/apps/photrim/photrim.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
/** This is free and unencumbered software released into the public domain.
The authors of ISIS do not claim copyright on the contents of this file.
For more details about the LICENSE terms and the AUTHORS, you will
find files of those names at the top level of this repository. **/

/* SPDX-License-Identifier: CC0-1.0 */

#ifndef photrim_h
#define photrim_h

#include "UserInterface.h"

namespace Isis{
extern void photrim(UserInterface &ui);
extern void photrim(Cube *icube, UserInterface &ui);
}

#endif
3 changes: 3 additions & 0 deletions isis/src/base/apps/photrim/photrim.xml
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,9 @@
<change name="Marjorie Hahn" date="2016-08-05">
Added the option to use the digital elevation model when trimming the image.
Created examples for using the DEM and not using the DEM. Fixes #4181.
<change name="Ken Edmundson" date="2024-08-09">
Converted to callable app and converted Makefile tests to gtests.
</change>
</change>
</history>

Expand Down
4 changes: 0 additions & 4 deletions isis/src/base/apps/photrim/tsts/Makefile

This file was deleted.

13 changes: 0 additions & 13 deletions isis/src/base/apps/photrim/tsts/base/Makefile

This file was deleted.

13 changes: 0 additions & 13 deletions isis/src/base/apps/photrim/tsts/emission/Makefile

This file was deleted.

13 changes: 0 additions & 13 deletions isis/src/base/apps/photrim/tsts/incidence/Makefile

This file was deleted.

13 changes: 0 additions & 13 deletions isis/src/base/apps/photrim/tsts/phase/Makefile

This file was deleted.

14 changes: 0 additions & 14 deletions isis/src/base/apps/photrim/tsts/usedem/Makefile

This file was deleted.

Loading

0 comments on commit 2ed706c

Please sign in to comment.