mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			151 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <QtNetwork>
 | ||
| #include <QStringList>
 | ||
| 
 | ||
| #include <octave/oct.h>
 | ||
| 
 | ||
| #include "riSettings.h"
 | ||
| #include "RiaSocketDataTransfer.cpp"  // NB! Include cpp-file to avoid linking of additional file in oct-compile configuration
 | ||
| 
 | ||
| 
 | ||
| void getActiveCellCenters(NDArray& cellCenterValues, const QString &hostName, quint16 port, const qint32& caseId, const QString& porosityModel)
 | ||
| {
 | ||
|     QString serverName = hostName;
 | ||
|     quint16 serverPort = port;
 | ||
| 
 | ||
|     QTcpSocket socket;
 | ||
|     socket.connectToHost(serverName, serverPort);
 | ||
| 
 | ||
|     if (!socket.waitForConnected(riOctavePlugin::connectTimeOutMilliSecs))
 | ||
|     {
 | ||
|         error((("Connection: ") + socket.errorString()).toLatin1().data());
 | ||
|         return;
 | ||
|     }
 | ||
| 
 | ||
|     // Create command and send it:
 | ||
| 
 | ||
|     QString command = QString("GetActiveCellCenters %1 %2").arg(caseId).arg(porosityModel);
 | ||
|     QByteArray cmdBytes = command.toLatin1();
 | ||
| 
 | ||
|     QDataStream socketStream(&socket);
 | ||
|     socketStream.setVersion(riOctavePlugin::qtDataStreamVersion);
 | ||
| 
 | ||
|     socketStream << (qint64)(cmdBytes.size());
 | ||
|     socket.write(cmdBytes);
 | ||
| 
 | ||
|     // Get response. First wait for the header
 | ||
| 
 | ||
|     while (socket.bytesAvailable() < (int)(2 * sizeof(quint64)))
 | ||
|     {
 | ||
|         if (!socket.waitForReadyRead(riOctavePlugin::longTimeOutMilliSecs))
 | ||
|         {
 | ||
|             error((("Waiting for header: ") + socket.errorString()).toLatin1().data());
 | ||
|             return;
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     // Read timestep count and blocksize
 | ||
| 
 | ||
|     quint64 activeCellCount;
 | ||
|     quint64 byteCount;
 | ||
| 
 | ||
|     socketStream >> activeCellCount;
 | ||
|     socketStream >> byteCount;
 | ||
| 
 | ||
|     if (!(byteCount && activeCellCount))
 | ||
|     {
 | ||
|         error ("Could not find the requested data in ResInsight");
 | ||
|         return;
 | ||
|     }
 | ||
| 
 | ||
|     dim_vector dv;
 | ||
|     dv.resize(2);
 | ||
|     dv(0) = activeCellCount;
 | ||
|     dv(1) = 3;
 | ||
| 
 | ||
|     cellCenterValues.resize(dv);
 | ||
| 
 | ||
|     double* internalMatrixData = cellCenterValues.fortran_vec();
 | ||
|     QStringList errorMessages;
 | ||
| 
 | ||
|     if (!RiaSocketDataTransfer::readBlockDataFromSocket(&socket, (char*)(internalMatrixData), byteCount, errorMessages))
 | ||
|     {
 | ||
|         for (int i = 0; i < errorMessages.size(); i++)
 | ||
|         {
 | ||
|             error(errorMessages[i].toLatin1().data());
 | ||
|         }
 | ||
| 
 | ||
|         OCTAVE_QUIT;
 | ||
|     }
 | ||
| 
 | ||
|     return;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| DEFUN_DLD (riGetActiveCellCenters, args, nargout,
 | ||
|            "Usage:\n"
 | ||
|            "\n"
 | ||
|            "   riGetActiveCellCenters([CaseId], [PorosityModel = <20>Matrix<69>|<7C>Fracture<72>] )\n"
 | ||
|            "\n"
 | ||
|            "This function returns the UTM coordinates (X, Y, Z) of the center point of all the cells in the grid.\n"
 | ||
|            "If the CaseId is not defined, ResInsight<68>s Current Case is used.\n"
 | ||
|            )
 | ||
| {
 | ||
| 
 | ||
|     if (nargout < 1)
 | ||
|     {
 | ||
|         error("riGetActiveCellCenters: Missing output argument.\n");
 | ||
|         print_usage();
 | ||
|         return octave_value_list ();
 | ||
|     }
 | ||
| 
 | ||
|     int nargin = args.length ();
 | ||
|     if (nargin > 2)
 | ||
|     {
 | ||
|         error("riGetActiveCellCenters: Too many arguments.\n");
 | ||
|         print_usage();
 | ||
|         return octave_value_list ();
 | ||
|     }
 | ||
| 
 | ||
|     qint32 caseId = -1;
 | ||
|     std::string porosityModel = "Matrix";
 | ||
| 
 | ||
|     if (nargin == 1)
 | ||
|     {
 | ||
|         if (args(0).is_numeric_type())
 | ||
|         {
 | ||
|             caseId = args(0).uint_value();
 | ||
|         }
 | ||
|         else
 | ||
|         {
 | ||
|             porosityModel = args(0).string_value();
 | ||
|         }
 | ||
|     }
 | ||
|     else if (nargin == 2)
 | ||
|     {
 | ||
|         if (args(0).is_numeric_type())
 | ||
|         {
 | ||
|             caseId        = args(0).uint_value();
 | ||
|             porosityModel = args(1).string_value();
 | ||
|         }
 | ||
|         else
 | ||
|         {
 | ||
|             caseId        = args(1).uint_value();
 | ||
|             porosityModel = args(0).string_value();
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     if (porosityModel != "Matrix" && porosityModel != "Fracture")
 | ||
|     {
 | ||
|         error("riGetActiveCellProperty: The value for \"PorosityModel\" is unknown. Please use either \"Matrix\" or \"Fracture\"\n");
 | ||
|         print_usage();
 | ||
|         return octave_value_list ();
 | ||
|     }
 | ||
| 
 | ||
|     NDArray cellCenterValues;
 | ||
|     getActiveCellCenters(cellCenterValues, "127.0.0.1", 40001, caseId, porosityModel.c_str());
 | ||
| 
 | ||
|     return octave_value(cellCenterValues);
 | ||
| }
 | ||
| 
 |