Hide menu
Loading...
Searching...
No Matches
wall_thickness/analyzer/analyzer.java

Refer to the Wall Thickness Analyzer Example

// ****************************************************************************
// $Id$
//
// Copyright (C) 2008-2014, Roman Lygin. All rights reserved.
// Copyright (C) 2014-2025, CADEX. All rights reserved.
//
// This file is part of the Manufacturing Toolkit software.
//
// You may use this file under the terms of the BSD license as follows:
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
//
// ****************************************************************************
import cadex.*;
import cadex.ModelData.*;
public class analyzer {
static {
try {
System.loadLibrary("CadExMTK");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String[] args) {
String aKey = MTKLicenseKey.Value();
// Activate the license (the key must be defined in MTKLicenseKey.java)
if (!LicenseManager.Activate(aKey)) {
System.out.println("Failed to activate Manufacturing Toolkit license.");
System.exit(1);
}
if (args.length < 1 || args.length > 2) {
System.out.println("Usage: " + " <input_file> <input_resolution>, where:");
System.out.println(" <input_file> is a name of the file to be read");
System.out.print(" <input_resolution> is an optional argument that determine accuracy");
System.out.print(" of wall thickness calculation.");
System.out.print(" The larger the value, the higher the accuracy of the calculations,");
System.out.print("but greatly increase computation time and memory usage.");
System.out.println("Should be at least 100.");
System.exit(1);
}
String aSource = args[0];
int aResolution = 1000;
if (args.length == 2) {
aResolution = Integer.parseInt(args[1]);
}
if (aResolution < 100) {
System.out.format("WARNING: Input resolution \"%d\" < 100. Will be used default resolution.\n\n", aResolution);
aResolution = 1000;
}
Model aModel = new Model();
ModelReader aReader = new ModelReader();
// Reading the file
if (!aReader.Read(new UTF16String(aSource), aModel)) {
System.out.println("Failed to read the file " + aSource);
System.exit(1);
}
System.out.format("Model: %s\n\n", aModel.Name());
PartProcessor aPartProcessor = new PartProcessor();
aPartProcessor.Resolution = aResolution;
ModelElementUniqueVisitor aVisitor = new ModelElementUniqueVisitor(aPartProcessor);
aModel.Accept(aVisitor);
}
static class PartProcessor extends SolidProcessor
{
public PartProcessor()
{
myAnalyzer = new WallThickness_Analyzer();
}
@Override
public void ProcessSolid(Solid theSolid)
{
WallThickness_Data aWTData = myAnalyzer.Perform(theSolid, Resolution);
PrintWTData(aWTData);
}
void PrintWTData(WallThickness_Data theData)
{
if (!theData.IsEmpty())
{
System.out.format(" Min thickness = %f mm\n", theData.MinThickness());
System.out.format(" Max thickness = %f mm\n", theData.MaxThickness());
}
else
{
System.out.println(" Failed to analyze the wall thickness of this entity.");
}
}
public long Resolution = 1000;
private WallThickness_Analyzer myAnalyzer;
}
}
Defines classes, types, enums, and functions related to topological entities and scene graph elements...
Defines classes, namespaces, enums, types, and global functions related to Manufacturing Toolkit.
Definition LicenseManager_LicenseError.hxx:30