| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  | #include <QtNetwork>
 | 
					
						
							| 
									
										
										
										
											2014-04-03 10:41:27 +02:00
										 |  |  |  | #include <QStringList>
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  | #include <octave/oct.h>
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include "riSettings.h"
 | 
					
						
							| 
									
										
										
										
											2014-04-15 14:16:35 +02:00
										 |  |  |  | #include "RiaSocketDataTransfer.cpp"  // NB! Include cpp-file to avoid linking of additional file in oct-compile configuration
 | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  | void getActiveCellCorners(NDArray& cellCornerValues, const QString &hostName, quint16 port, const qint32& caseId, const QString& porosityModel) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |     QString serverName = hostName; | 
					
						
							|  |  |  |  |     quint16 serverPort = port; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     QTcpSocket socket; | 
					
						
							|  |  |  |  |     socket.connectToHost(serverName, serverPort); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-12 11:38:09 +02:00
										 |  |  |  |     if (!socket.waitForConnected(riOctavePlugin::connectTimeOutMilliSecs)) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-11-03 12:25:15 +01:00
										 |  |  |  |         error("Connection: %s",socket.errorString().toLatin1().data()); | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |         return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     // Create command and send it:
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  |     QString command = QString("GetActiveCellCorners %1 %2").arg(caseId).arg(porosityModel); | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     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))) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-09-30 20:54:31 +02:00
										 |  |  |  |         if (!socket.waitForReadyRead(riOctavePlugin::longTimeOutMilliSecs)) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2020-11-03 12:25:15 +01:00
										 |  |  |  |             error("Waiting for header: %s",socket.errorString().toLatin1().data()); | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |             return; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     // Read timestep count and blocksize
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-24 08:48:36 +02:00
										 |  |  |  |     quint64 activeCellCount; | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     quint64 byteCount; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-24 08:48:36 +02:00
										 |  |  |  |     socketStream >> activeCellCount; | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     socketStream >> byteCount; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-24 08:48:36 +02:00
										 |  |  |  |     if (!(byteCount && activeCellCount)) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     { | 
					
						
							|  |  |  |  |         error ("Could not find the requested data in ResInsight"); | 
					
						
							|  |  |  |  |         return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-24 08:48:36 +02:00
										 |  |  |  |     dim_vector dv; | 
					
						
							|  |  |  |  |     dv.resize(3); | 
					
						
							|  |  |  |  |     dv(0) = activeCellCount; | 
					
						
							|  |  |  |  |     dv(1) = 8; | 
					
						
							|  |  |  |  |     dv(2) = 3; | 
					
						
							|  |  |  |  |     cellCornerValues.resize(dv); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-03 10:41:27 +02:00
										 |  |  |  |     double* internalMatrixData = cellCornerValues.fortran_vec(); | 
					
						
							|  |  |  |  |     QStringList errorMessages; | 
					
						
							| 
									
										
										
										
											2014-04-15 14:16:35 +02:00
										 |  |  |  |     if (!RiaSocketDataTransfer::readBlockDataFromSocket(&socket, (char*)(internalMatrixData), byteCount, errorMessages)) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2014-04-03 10:41:27 +02:00
										 |  |  |  |         for (int i = 0; i < errorMessages.size(); i++) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2020-11-03 12:25:15 +01:00
										 |  |  |  |             error("%s",errorMessages[i].toLatin1().data()); | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-03 10:41:27 +02:00
										 |  |  |  |         OCTAVE_QUIT; | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     return; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | DEFUN_DLD (riGetActiveCellCorners, args, nargout, | 
					
						
							|  |  |  |  |            "Usage:\n" | 
					
						
							|  |  |  |  |            "\n" | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  |            "   riGetActiveCellCorners([CaseId], [PorosityModel = <20>Matrix<69>|<7C>Fracture<72>] )\n" | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |            "\n" | 
					
						
							|  |  |  |  |            "This function returns the UTM coordinates (X, Y, Z) of the 8 corners of each of the active cells.\n" | 
					
						
							|  |  |  |  |            "If the CaseId is not defined, ResInsight<68>s Current Case is used.\n" | 
					
						
							|  |  |  |  |            ) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     if (nargout < 1) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         error("riGetActiveCellCorners: Missing output argument.\n"); | 
					
						
							|  |  |  |  |         print_usage(); | 
					
						
							|  |  |  |  |         return octave_value_list (); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     int nargin = args.length (); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  |     if (nargin > 2) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     { | 
					
						
							|  |  |  |  |         error("riGetActiveCellCorners: Too many arguments.\n"); | 
					
						
							|  |  |  |  |         print_usage(); | 
					
						
							|  |  |  |  |         return octave_value_list (); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     qint32 caseId = -1; | 
					
						
							|  |  |  |  |     std::string porosityModel = "Matrix"; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     if (nargin == 1) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-01-15 07:28:50 +01:00
										 |  |  |  |         if (riOctavePlugin::isOctaveValueNumeric(args(0))) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             caseId = args(0).uint_value(); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         else | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  |             porosityModel = args(0).string_value(); | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  |     else if (nargin == 2) | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-01-15 07:28:50 +01:00
										 |  |  |  |         if (riOctavePlugin::isOctaveValueNumeric(args(0))) | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             caseId        = args(0).uint_value(); | 
					
						
							|  |  |  |  |             porosityModel = args(1).string_value(); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         else | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             caseId        = args(1).uint_value(); | 
					
						
							|  |  |  |  |             porosityModel = args(0).string_value(); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     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 cellCornerValues; | 
					
						
							| 
									
										
										
										
											2013-05-24 09:54:32 +02:00
										 |  |  |  |     getActiveCellCorners(cellCornerValues, "127.0.0.1", 40001, caseId, porosityModel.c_str()); | 
					
						
							| 
									
										
										
										
											2013-05-23 11:02:10 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     return octave_value(cellCornerValues); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 |