X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROData%2Ftest_HYDROData_Bathymetry.cxx;h=9901c8ea7eb99f4b9ad775419754fba72a302a5c;hb=e7225e329739e01faed6682de0bc83cf84c28de6;hp=51f61efae7ee3325ad4b0ddcaff56d7ecefc7a0f;hpb=bab0e234b3be26dfe1b99e9ba43cc39bed79133a;p=modules%2Fhydro.git diff --git a/src/HYDROData/test_HYDROData_Bathymetry.cxx b/src/HYDROData/test_HYDROData_Bathymetry.cxx index 51f61efa..9901c8ea 100755 --- a/src/HYDROData/test_HYDROData_Bathymetry.cxx +++ b/src/HYDROData/test_HYDROData_Bathymetry.cxx @@ -11,6 +11,33 @@ #include #include +#include + +void generateOne( QTextStream& theStream, + double theFirstX, double theFirstY, + double theLastX, double theLastY ) +{ + const int aNbPoints = 50; + + double aComDist = gp_Pnt2d( theFirstX, theFirstY ).Distance( gp_Pnt2d( theLastX, theLastY ) ); + double aStep = aComDist / (double)aNbPoints; + + double aStepZ = -5; + double aCurDist = 0.0; + for ( int i = 0; i <= aNbPoints; ++i ) + { + double aRatio = ( aCurDist / ( aComDist - aCurDist ) ); + + double anX = ( theFirstX + aRatio * theLastX ) / ( 1 + aRatio ); + double anY = ( theFirstY + aRatio * theLastY ) / ( 1 + aRatio ); + double aZ = aStepZ * aStepZ + sin( (float)rand() ); + theStream << anX << " " << anY << " " << aZ << " \n"; + + aCurDist += aStep; + aStepZ += 0.2; + } +} + bool test_HYDROData_Bathymetry::createTestFile( const QString& theFileName ) { QFile aTmpFile( theFileName ); @@ -19,31 +46,54 @@ bool test_HYDROData_Bathymetry::createTestFile( const QString& theFileName ) { QTextStream anOutStream( &aTmpFile ); - - anOutStream << "0 0 0 \n"; - anOutStream << "0 1 10 \n"; - anOutStream << "0 2 20 \n"; - anOutStream << "0 3 30 \n"; - - anOutStream << "1 0 0 \n"; - anOutStream << "1 1 10 \n"; - anOutStream << "1 2 20 \n"; - anOutStream << "1 3 30 \n"; - - anOutStream << "2 1 10 \n"; - anOutStream << "2 2 20 \n"; - anOutStream << "2 3 30 \n"; - anOutStream << "2 4 40 \n"; - - anOutStream << "3 0 0 \n"; - anOutStream << "3 1 10 \n"; - anOutStream << "3 2 20 \n"; - anOutStream << "3 3 30 \n"; - - anOutStream << "4 0 0 \n"; - anOutStream << "4 1 10 \n"; - anOutStream << "4 2 20 \n"; - anOutStream << "4 3 30 \n"; + + srand( 4587 ); + generateOne( anOutStream, 0, 5, 0, -5 ); + generateOne( anOutStream, 10, 5, 10, -5 ); + generateOne( anOutStream, 20, 5, 20, -5 ); + generateOne( anOutStream, 30, 5, 30, -5 ); + generateOne( anOutStream, 40, 5, 40, -5 ); + generateOne( anOutStream, 45.833271, 6.703101, 50.85397, -3.794724 ); + generateOne( anOutStream, 50.85397, 11.267372, 56.787525, 2.367043 ); + generateOne( anOutStream, 52.67968, 16.516285, 62.721077, 10.354518 ); + generateOne( anOutStream, 55.190029, 23.819118, 65.23143, 17.657352 ); + generateOne( anOutStream, 58.385021, 31.806595, 68.198204, 23.819118 ); + generateOne( anOutStream, 65.916069, 38.653004, 75.044609, 27.470537 ); + generateOne( anOutStream, 76.870323, 41.847992, 82.575661, 28.38339 ); + generateOne( anOutStream, 92.845276, 40.022282, 91.932419, 26.557682 ); + generateOne( anOutStream, 106.081657, 35.686226, 98.778824, 21.99341 ); + generateOne( anOutStream, 119.774475, 29.980886, 106.994514, 14.91879 ); + generateOne( anOutStream, 133.239075, 26.785896, 115.666634, 5.790246 ); + generateOne( anOutStream, 150.811523, 20.167702, 125.47982, -4.707579 ); + generateOne( anOutStream, 163.591476, 13.777717, 135.977631, -12.92327 ); + generateOne( anOutStream, 183.446045, 11.267367, 151.496155, -24.105736 ); + generateOne( anOutStream, 197.367081, 8.98523100, 172.720016, -31.180355 ); + generateOne( anOutStream, 214.026672, 9.669872, 197.823502, -38.483189 ); + generateOne( anOutStream, 235.706985, 9.89809100, 220.873108, -47.155304 ); + generateOne( anOutStream, 266.744019, 9.213447, 248.715134, -58.565987 ); + generateOne( anOutStream, 307.366028, 10.354514, 278.611145, -67.922737 ); + generateOne( anOutStream, 342.510925, 7.159524, 316.951019, -84.81053 ); + generateOne( anOutStream, 384.659393, -4.55408, 350.913635, -100.02983 ); + generateOne( anOutStream, 443.097107, -21.015415, 391.243927, -118.960365 ); + generateOne( anOutStream, 500.711792, -34.184483, 440.62793, -147.7677 ); + generateOne( anOutStream, 547.626587, -52.291954, 482.604309, -169.990509 ); + generateOne( anOutStream, 589.603027, -68.753288, 534.45752, -193.8594 ); + generateOne( anOutStream, 633.225525, -97.560631, 569.026306, -206.205444 ); + generateOne( anOutStream, 673.555786, -120.606499, 601.948975, -224.312912 ); + generateOne( anOutStream, 719.647522, -148.590775, 654.625305, -248.181854 ); + generateOne( anOutStream, 770.677673, -183.982635, 708.947693, -278.635315 ); + generateOne( anOutStream, 824.177002, -225.959045, 742.69342, -314.027191 ); + generateOne( anOutStream, 855.937317, -260.368958, 793.05932, -341.853638 ); + generateOne( anOutStream, 884.168213, -294.37439, 838.6137700, -355.969116 ); + generateOne( anOutStream, 915.607178, -327.096588, 875.185669, -366.234894 ); + generateOne( anOutStream, 940.630066, -348.269775, 903.416565, -381.633575 ); + generateOne( anOutStream, 963.728088, -370.726166, 936.780396, -397.032257 ); + generateOne( anOutStream, 983.618042, -390.61615, 959.878418, -411.789337 ); + generateOne( anOutStream, 999.658325, -407.939667, 978.485107, -425.904785 ); + generateOne( anOutStream, 1018.265076, -422.696716, 996.450256, -443.228302 ); + generateOne( anOutStream, 1040.079834, -441.303467, 1017.623413, -459.9102175 ); + generateOne( anOutStream, 1055.478516, -456.060547, 1034.946899, -475.9505 ); + generateOne( anOutStream, 1074.085327, -474.025665, 1058.044922, -493.274017 ); } aTmpFile.close(); @@ -62,10 +112,10 @@ void test_HYDROData_Bathymetry::testFileImport() if ( !createTestFile( aFileName ) ) return; // No file has been created - CPPUNIT_ASSERT( aBathymetry->ImportFromFile( aFileName ) ); + CPPUNIT_ASSERT( aBathymetry->ImportFromFile( aFileName.toStdString().c_str() ) ); HYDROData_Bathymetry::AltitudePoints anAltitudePoints = aBathymetry->GetAltitudePoints(); - CPPUNIT_ASSERT( anAltitudePoints.length() == 20 ); + CPPUNIT_ASSERT( anAltitudePoints.Length() == 20 ); gp_XY aTestPoint( 1, 1 ); double anAltitude = aBathymetry->GetAltitudeForPoint( aTestPoint ); @@ -108,10 +158,10 @@ void test_HYDROData_Bathymetry::testCopy() if ( anIsFileCreated ) { - CPPUNIT_ASSERT( aBathymetry1->ImportFromFile( aFileName ) ); + CPPUNIT_ASSERT( aBathymetry1->ImportFromFile( aFileName.toStdString().c_str() ) ); HYDROData_Bathymetry::AltitudePoints anAltitudePoints = aBathymetry1->GetAltitudePoints(); - CPPUNIT_ASSERT( anAltitudePoints.length() == 20 ); + CPPUNIT_ASSERT( anAltitudePoints.Length() == 20 ); } Handle(HYDROData_Bathymetry) aBathymetry2 = @@ -122,7 +172,7 @@ void test_HYDROData_Bathymetry::testCopy() if ( anIsFileCreated ) { HYDROData_Bathymetry::AltitudePoints anAltitudePoints = aBathymetry2->GetAltitudePoints(); - CPPUNIT_ASSERT( anAltitudePoints.length() == 20 ); + CPPUNIT_ASSERT( anAltitudePoints.Length() == 20 ); } aDoc->Close();