[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [TRNSYS-users] TRNSYS 18 : type 169 python



Hi Antoine,

Are you having trouble recompiling the Type169 DLL? The files TRNDll64.dll (or the TRNDll64.lib file you'd want to link to if recompiling Type169.dll) are available in the TRNSYS18\Exe directory.  

In order to compile the type, I used what may not be the most elegant solution, and just copied the following files to the directory containing my modified Type169 source code:
 "...\TRNSYS18\SourceCode\Templates\TRNSYS.h"
"...\TRNSYS18\Exe\TRNDll64.lib"
" C:\ProgramData\Anaconda3\libs\python37.lib"

I then built the DLL using the GNU C++ compiler with the following commands:

g++ -c -IC:\ProgramData\Anaconda3\include Type169_modified.cpp
g++ -shared -o Type169.dll Type169_modified.o -Wl,TRNDll64.lib,python37.lib

(Note that the Python install directory I used to get the python37.lib file and during compilation will be unique to your specific installation, "C:\ProgramData\Anaconda3" just happens to be the path for me.)  

Backing up the old Type169.dll in the "...\TRNSYS18\UserLib\ReleaseDLLs" folder and replacing it with this one based on my source code modifications mentioned before allows me to use Type169 with Python scripts as desired.

Best of luck!
-Brandon


On Wed, Jul 1, 2020 at 1:12 PM Armandine Les Landes Antoine <A.ArmandineLesLandes@brgm.fr> wrote:

Hi Brandon,

 

Thank you very much for your reply !

I just tried to add the complete path to my script file as you mentionned but nothing changes…

 

Now I was looking on the dependency of Type 169.dll and it seems that one dependency is missing (TRNDLL64.DLL)…. ?

I guess that’s the reason why the type 169 does not work.

 

Best regards

Antoine

 

De : Brandon Hathaway <brandon.hathaway@sunvapor.net>
Envoyé : mercredi 1 juillet 2020 19:14
À : TRNSYS users mailing list at OneBuilding.org <trnsys-users@lists.onebuilding.org>
Cc : Armandine Les Landes Antoine <A.ArmandineLesLandes@brgm.fr>
Objet : Re: [TRNSYS-users] TRNSYS 18 : type 169 python

 

Hi Antoine,

 

I experienced the same behavior, and was able to trace down the cause with some digging into the Type169 source code.  In my case, it seemed that specifying the name of the Python script alone, rather than the complete path, was causing an issue when the code attempts to strip the script name and script path into separate variables.  The variable "scriptPath" contained just the name of the script, causing an undesired result when the Type169 code attempts to execute a "sys.path.append()" command through Python, resulting in the inability to Import the script.

 

I suspect that if you just specify the complete path to your script file in the entry box within the TRNSYS Type169 Special Cards configuration tab, rather than only the filename, the Type169 should work.  (However, the fix I ended up using since I was already into the source code is described below just in case anyone finds it helpful.)

 

In my case, I fixed the issue in the source code by commenting out the existing line that executes the above mentioned command around line 267:

// PyRun_SimpleString(scriptPath.c_str());

 

Then I added the following two lines which (1) import the OS module in the Python session then (2) use that module to get the current working directory and append it to the path:

PyRun_SimpleString("import os");
PyRun_SimpleString("sys.path.append(os.getcwd())");

 

After making those changes and recompiling the Type169.dll, my issue was resolved when specifying just the name of a script within the current working directory.  (Note, this makes it so that the script must ALWAYS be within the current working directory, as the path/filename stripping part of the code is now ignored.)

 

As for the TRNSYSpy module, it isn't a file, but is created within the Type169 program and appended to the Inittab just before python is initialized, which you'll see if you open the C++ source code around lines 262-264, so don't worry about that portion.


Best regards,
-Brandon

 

On Wed, Jul 1, 2020 at 4:12 AM Armandine Les Landes Antoine via TRNSYS-users <trnsys-users@lists.onebuilding.org> wrote:

Hello all,

 

I am trying to use the python with the Type 169.

 

Note that :

-        Python 3 (3.7) is correclty installed and it is accessible from the cmd line.

-        TRNSYS is installed to the root of C :

-        Python is in the Windows path

-       

 

I do not understand why nothing happen when I perform a simulation…

 

I can not find anywhere the TRNSyspy module ??

 

Could you provide an example of TRNSys using the Type 169 ? there is no example in TRNSYS18/Examples/.  such as Calling_Python ? that could help…

 

Thank you for you help !

Best regards,

Antoine

 

_______________________________________________
TRNSYS-users mailing list
TRNSYS-users@lists.onebuilding.org
http://lists.onebuilding.org/listinfo.cgi/trnsys-users-onebuilding.org