(introductory data to make it clearer: Corona 11, Corona 12, 3ds Max 2024, RAM from 32 to 128 GB, no problems or errors occur when rendering from 3ds Max directly, as well as when sending a scene to rendering via SMTD script)
Greetings to all. I had a very strange case with 3ds Max and deadlinecommand
, which I can’t repeat and debug.
I have a custom pipeline for sending 3D scenes to rendering using deadlinecommand
. Until today, everything was more or less stable, but the other day I received a scene from one of my mates to render, which broke everything. The scene itself is quite ordinary, it’s an interior bathroom project, no more than 2 million polygons and simple geometry.
Now to the problem. If I send this scene for rendering in my manual way via deadlinecommand
, then I get this error:
(Error: RenderTask: Unexpected exception (Trapped SEH Exception in RenderFrame(): Access Violation)
It appears immediately after this point:
And in the case of the working scene, the following should appear in the logs and rendering will begin:
I started looking for reasons on the Internet with similar errors, but either I came across unresolved cases, or they did not suit me for reasons. One of the reasons I found here on the forum is that the problem may be in RAM. But this is not my case at all, as I tested this scene on several completely different computers with different amount of RAM.
Not finding an answer, I went to check the scene by clicking something in the Render Setup dialog in 3ds Max, but I didn’t change anything. I decided to send the same scene again, and somehow, miraculously, it decided to render, even though absolutely nothing had been changed in the scene.
I thought maybe the problem was with geometry or something, but the fact is that even if you REMOVE ABSOLUTELY ALL GEOMETRY AND MATERIALS (in the material editor) FROM the scene, it still won’t render and will give the same error.
The sequence was as follows:
- I deleted absolutely everything from the scene by pressing CTRL+A then DEL button (materials in Material Editor as well)
- I recreated the camera from the same window in the viewport
- I archived the scene through the internal 3ds Max Archive function and sent this scene for rendering via
deadlinecommand
, having previously unpacked this archive with the scene
Thus, at the moment I have absolutely identical scenes in terms of parameters, one of which is broken and the other is not. I’ll attach them below and maybe you’ll be able to debug correctly and understand what the problem might be. I specially cleaned them so that you don’t have to download a large file and so that you understand that the scenes are literally empty, but one wants to render, and the other refuses with an error
broken.zip (57.7 KB)
notbroken.zip (57.7 KB)
Now I want to list the actions that I took to debug and try to find the cause of the error:
- I compared each parameter in the rendering settings for the broken and notbroken scenes;
- changed the cameras and their sequence;
- specified the path of saving the file of the final render image and did not specify;
- converted all geometry into Editable Poly
- I studied the 3ds Max logs, but there is nothing useful in them, since 3ds Max doesn’t have time to initialize normally for rendering, since Deadline completes the Task.
- I studied the lightning.dlx log
- and a lot more, but I want to focus on two very interesting points that at least had a bit of an impact:
-
I decided to enable logging via Python at each stage in order to understand what is happening at that moment before Deadline throws the same error. It looks like this:
I couldn’t extract any clear answer from this, since the logs lead to the lightning.dlx file, which, as I understand it, is directly related to the functionality of 3ds Max and Deadline, but I don’t know how to open it and understand what function it gets stuck on and refuses to continue performing the task. -
The second method partially solved the problem. If you remove all the render elements from the corresponding menu in the Render Setup dialog, then everything will work fine. Also, if you delete all the render elements, but leave only the CMasking_ID and Interactive_LightMix, then everything will work fine too. But this doesn’t answer the question of why in the same scene, in which nothing is deleted, the rendering is still working properly.
So, at the moment, I understand that the problem is kind of floating and how to track down the culprit is not clear. Apparently, the 3ds Max is not to blame, it is the Deadline that prevents it from moving further through the code in order to properly start rendering. Maybe I’m wrong, but then why does everything work as it should when manually rendering directly via 3ds Max or when sending the same scene via SMTD?
Therefore, I ask you to help me, please, maybe you have other ways of debugging or you can tell me how I can check all this sufficiently to find the culprit.
Deadline logs of the broken and notbroken scene (can’t attach .txt files for some reason):
logs.zip (23.9 KB)