int main(
int argc,
char * argv[])
{
if (argc != 14)
{
std::cerr << "Usage: " << argv[0];
std::cerr <<
" inputFileName outputFileName firstPixelComponent secondPixelComponent ";
std::cerr <<
"thirdPixelComponent fourthPixelComponent amplitudeThrehsold tolerance ";
std::cerr <<
"angularThreshold firstMeanDistanceThreshold secondMeanDistanceThreshold ";
std::cerr << "distanceThreshold" << std::endl;
return EXIT_FAILURE;
}
const unsigned int Dimension = 2;
typedef double InputPixelType;
typedef unsigned char OutputPixelType;
Dimension> PathType;
PathType> RoadExtractionFilterType;
InputImageType> DrawPathFilterType;
OutputImageType> RescalerType;
ReaderType::Pointer reader = ReaderType::New();
RoadExtractionFilterType::Pointer roadExtractionFilter
= RoadExtractionFilterType::New();
DrawPathFilterType::Pointer drawingFilter = DrawPathFilterType::New();
RescalerType::Pointer rescaleFilter = RescalerType::New();
WriterType::Pointer writer = WriterType::New();
reader->SetFileName(argv[1]);
InputVectorImageType::PixelType ReferencePixel;
ReferencePixel.SetSize(4);
ReferencePixel.SetElement(0, ::atof(argv[3]));
ReferencePixel.SetElement(1, ::atof(argv[4]));
ReferencePixel.SetElement(2, ::atof(argv[5]));
ReferencePixel.SetElement(3, ::atof(argv[6]));
roadExtractionFilter->SetReferencePixel(ReferencePixel);
roadExtractionFilter->SetAlpha(atof(argv[7]));
roadExtractionFilter->SetAmplitudeThreshold(atof(argv[8]));
roadExtractionFilter->SetTolerance(atof(argv[9]));
roadExtractionFilter->SetMaxAngle(atof(argv[10]));
roadExtractionFilter->SetAngularThreshold(atof(argv[10]));
roadExtractionFilter->SetFirstMeanDistanceThreshold(atof(argv[11]));
roadExtractionFilter->SetSecondMeanDistanceThreshold(atof(argv[12]));
roadExtractionFilter->SetDistanceThreshold(atof(argv[13]));
reader->GenerateOutputInformation();
InputImageType::Pointer blackBackground = InputImageType::New();
blackBackground->SetRegions(reader->GetOutput()->GetLargestPossibleRegion());
blackBackground->Allocate();
blackBackground->FillBuffer(0);
drawingFilter->UseInternalPathValueOn();
rescaleFilter->SetOutputMinimum(itk::NumericTraits<OutputPixelType>::min());
rescaleFilter->SetOutputMaximum(itk::NumericTraits<OutputPixelType>::max());
roadExtractionFilter->SetInput(reader->GetOutput());
drawingFilter->SetInput(blackBackground);
drawingFilter->SetInputPath(roadExtractionFilter->GetOutput());
rescaleFilter->SetInput(drawingFilter->GetOutput());
rescaleFilter->Update();
Dimension>
StructuringElementType;
StructuringElementType>
DilateFilterType;
OutputImageType>
InvertFilterType;
StructuringElementType se;
se.SetRadius(1);
se.CreateStructuringElement();
DilateFilterType::Pointer dilater = DilateFilterType::New();
dilater->SetInput(rescaleFilter->GetOutput());
dilater->SetKernel(se);
InvertFilterType::Pointer invertFilter = InvertFilterType::New();
invertFilter->SetInput(dilater->GetOutput());
writer->SetFileName(argv[2]);
writer->SetInput(invertFilter->GetOutput());
writer->Update();
return EXIT_SUCCESS;
}