You are now following this question
- You will see updates in your followed content feed.
- You may receive emails, depending on your communication preferences.
External program is not creating output
3 views (last 30 days)
Show older comments
Hello,
I am using Matlab R2013a and I want to run an external interactive program as non-interactive from within a matlab-script by piping the Input either through echoing a string or through a text-file. The Input consists of a string and 2 numbers. If I call
echo -e " 'String' \n 1 \n 2.2" | myFotran
in the unix shell, it creates an Output file as expected. Doing the same in matlab with
unix('echo -e " ''String'' \n 1 \n 2.2" | myFotran')
is not generating the Output-file. Why? Can someone help me? I can't change the external program, since it is not mine.
29 Comments
Rik
on 23 May 2017
I have next to no experience with running commandline programs from Matlab, but I generally use system to do that. Confusingly enough, there seems to be no difference between system, dos and unix.
I see no reason why your code shouldn't work, so I'd be interested in the solution as well.
Matthias Otten
on 23 May 2017
Edited: Matthias Otten
on 23 May 2017
@Rik Wisselink: That's why I am so perplexed myself. @Jan Simon: I checked every Folder in my path as well as the Desktop - no Output-file created. I navigate with the Shell into my Project Folder and there I start matlab. It is also where my matlab and external script is saved. I don't know why matlab/myFortran is behaving that way. If I run the fortran program while in the Directory it creates the Output file just fine.
Walter Roberson
on 23 May 2017
Please cross-check that you are getting the same shell at the command line as you are getting through unix():
echo "$SHELL"
I am wondering whether perhaps you are hitting a situation where the echo you are reaching through unix() is a version that does not support the -e option.
Matthias Otten
on 24 May 2017
Edited: Matthias Otten
on 24 May 2017
running
echo $SHELL
in the unix Shell yields /bin/bash and so does
unix('echo $SHELL ; command')
with command being 'echo -e " ''String'' \n 1 \n 2.2" | myFotran'. It returns a 0 for properly executed command as well.
@Walter Roberson: I tried it with an input-file that works in the Linux Shell, but it also does not create an Output-file when started from within Matlab, although Matlab testifies it worked ( 0 Output).
Walter Roberson
on 24 May 2017
Matthias Otten
on 24 May 2017
@Walter Roberson: Unfortunately I don't know how the external program was compiled. I read and implemented the presented solution in the linked thread, but to no avail. The Output File was not created.
Jan
on 24 May 2017
@Matthias: Did you try to provide an absolut path name for the file?
I do not understand:
I tried it with an input-file that works in the Linux Shell,
but it also does not create an Output-file when started from
within Matlab, although Matlab testifies it worked ( 0 Output).
As far as I understand the shown command pipes the 'String' and the 2 numbers to the command myFotran. But where do you expect the output file to be created?
Matthias Otten
on 31 May 2017
After the holiday interruption, I tried providing a path
system('/path/.../myfortran < Input.txt')
Now an error occurs within myfortran, because it does not receive the Input at all. Using that exact same line in the Shell works. @Walter: Trying
System('#!bash/path/.../myfortran < Input.txt')
yielded only my original result (Seems to be working, but no Output). How do I tell Matlab to operate & save the Output in that /path/.../ Folder?
Matthias Otten
on 31 May 2017
I also tried
unix('/bin/bash','-echo')
/path/.../myfortran < Input.txt
but here also, myfortran is not getting any Input
Jan
on 31 May 2017
Are you aware that the original question contains "myFotran" repeatedly instead of "myFortran"? Note that Matlab is case-sensitive, such that "System(..." must fail. This is not nitpicking, but such typos in the code could let you think, that the code fails. Unix is case sensitive also, and the "myFotran", "myfortran" and "myFortran" are different things.
If an error occurres, please post a copy of the message. Do not let us guess, what happens.
You still do not get the point I meant:
system('/path/.../myFortran < /path/to/your/folder/Input.txt')
"Input.txt" is searched in the current folder and I'm not sure if the current folder is the same what you run system() or when you open a command shell and run the code there.
Matthias Otten
on 1 Jun 2017
Edited: Matthias Otten
on 1 Jun 2017
I am aware that it is case sensitive, but I went back and double-checked. I'll provide an example of the error: The path of Matlab as given above the Matlab Command Window is /path1/XYZ. There I do the following
unix('/bin/bash','-echo')
path1/XYZ$ /path2/XYZ/myfortran < /path1/XYZ/Input.txt
At line 123 of file myfortran.f
Fortran runtime error: End of file
When I was experiencing in the Unix-Shell how to pipe the Input into my program I got the same error, but with the command in my first post it works just fine. I am fairly new to running anything out of Matlab, I usually write and use scripts & functions within matlab.
Is it possible that Matlab blocks the Information piped into the program myfortran?
Walter Roberson
on 1 Jun 2017
Does the line
path1/XYZ$ /path2/XYZ/myfortran < /path1/XYZ/Input.txt
indicate that you invoked an interactive shell from MATLAB, and in that shell, your prompt was path1/XYZ$ and you typed in the command
/path2/XYZ/myfortran < /path1/XYZ/Input.txt
?
Matthias Otten
on 1 Jun 2017
Yes, that is how I did it
Walter Roberson
on 1 Jun 2017
And is it correct that if you do that
/path2/XYZ/myfortran < /path1/XYZ/Input.txt
in a shell outside MATLAB, that the command works?
I am confused as to whether the problem is occurring on MS Windows or on Linux ?
Matthias Otten
on 1 Jun 2017
It is correct. I am working in a Linux-Environment using Matlab R2013a
Matthias Otten
on 1 Jun 2017
What happens in "line 123 of file myfortran.f"?
I do not have access to the code, but it expects a string there, for example 'String', to name the project-file. Some lines later it expects a 1, 2 or 3 to calculate a certain szenario
Jan
on 1 Jun 2017
You do not know the code, but you know, what happens some lines later. "It expects a string there", but the message is "End of file".
Do I understand correctly that the currently discussed problem does not concern the original question "program is not creating output" anymore, but meanwhile the input is not working?
Matthias Otten
on 1 Jun 2017
Yes AND no. Apparently the input never worked in the beginning. Running it as described at the very top, yields no error, biut also no output. Providing absolute paths for program and input, as suggested, yields errors. Apparently here, matlab is not piping the input. Should I open a new question or rename this then?
Walter Roberson
on 1 Jun 2017
I still think it might be to do with the units. See https://www.mathworks.com/matlabcentral/answers/44388-or-system-or-unix-input-redirection
Matthias Otten
on 6 Jun 2017
@Walter Roberson: it works with the bash Operator now, but it did not with unix() or System(); Thanks!
Walter Roberson
on 6 Jun 2017
Did you find a way to get it to work from inside MATLAB? If so please post what you found.
Matthias Otten
on 6 Jun 2017
the following did it for me. Setting STDOUT was not necessary
setenv('GFORTRAN_STDIN_UNIT', '5')
setenv('GFORTRAN_STDOUT_UNIT', '6')
setenv('GFORTRAN_STDERR_UNIT', '0')
!myfortran < Input.txt
setenv('GFORTRAN_STDIN_UNIT', '-1')
setenv('GFORTRAN_STDOUT_UNIT', '-1')
setenv('GFORTRAN_STDERR_UNIT', '-1')
The next step is to somehow "suppress" the graphic Output, so I can iterate
Matthias Otten
on 7 Jun 2017
I tried it back then, but only with echoing the Information and I re-tried it now. Echoing does not work, input-file does. I am sorry that I caused you unnecessary trouble
Walter Roberson
on 8 Jun 2017
The shell echo does not use the fortran unit numbers, so I would not have expected the behavior to change for an echo test.
Accepted Answer
Matthias Otten
on 8 Jun 2017
Edited: Matthias Otten
on 8 Jun 2017
the following did it for me. Setting STDOUT was not necessary
setenv('GFORTRAN_STDIN_UNIT', '5')
setenv('GFORTRAN_STDOUT_UNIT', '6')
setenv('GFORTRAN_STDERR_UNIT', '0')
!myfortran < Input.txt
setenv('GFORTRAN_STDIN_UNIT', '-1')
setenv('GFORTRAN_STDOUT_UNIT', '-1')
setenv('GFORTRAN_STDERR_UNIT', '-1')
The following threads contain the needed Information. Thank you Walter Roberson and Jan Simon. https://fr.mathworks.com/matlabcentral/answers/44388-or-system-or-unix-input-redirection https://fr.mathworks.com/matlabcentral/answers/91919-why-does-the-output-of-my-fortran-script-not-show-up-in-the-matlab-command-window-when-i-execute-it
More Answers (0)
See Also
Categories
Find more on Logical in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!An Error Occurred
Unable to complete the action because of changes made to the page. Reload the page to see its updated state.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom(English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)