2018-05-18 14:40:41 +00:00
|
|
|
#!/usr/bin/env python3
|
2022-02-10 22:07:11 +00:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2018-05-18 14:40:41 +00:00
|
|
|
|
|
|
|
import argparse
|
|
|
|
import os
|
2022-08-01 08:57:18 +00:00
|
|
|
import pathlib
|
2018-05-18 14:40:41 +00:00
|
|
|
import shlex
|
|
|
|
import shutil
|
|
|
|
import subprocess
|
|
|
|
import sys
|
2022-06-24 11:45:18 +00:00
|
|
|
from pathlib import Path
|
2018-05-18 14:40:41 +00:00
|
|
|
|
2020-10-02 00:10:01 +00:00
|
|
|
|
2018-05-18 14:40:41 +00:00
|
|
|
def setup():
|
|
|
|
import bpy
|
|
|
|
|
2019-05-10 21:20:32 +00:00
|
|
|
for scene in bpy.data.scenes:
|
|
|
|
scene.render.engine = 'BLENDER_EEVEE'
|
|
|
|
|
2018-05-18 14:40:41 +00:00
|
|
|
# Enable Eevee features
|
|
|
|
scene = bpy.context.scene
|
|
|
|
eevee = scene.eevee
|
|
|
|
|
2019-08-16 19:28:32 +00:00
|
|
|
eevee.use_soft_shadows = True
|
|
|
|
|
2018-05-26 09:54:25 +00:00
|
|
|
eevee.use_ssr = True
|
|
|
|
eevee.use_ssr_refraction = True
|
2019-08-16 19:28:32 +00:00
|
|
|
|
2018-05-26 09:54:25 +00:00
|
|
|
eevee.use_gtao = True
|
2019-08-16 19:28:32 +00:00
|
|
|
eevee.gtao_distance = 1
|
2018-05-26 09:54:25 +00:00
|
|
|
|
|
|
|
eevee.use_volumetric_shadows = True
|
2018-05-18 14:40:41 +00:00
|
|
|
eevee.volumetric_tile_size = '2'
|
|
|
|
|
|
|
|
for mat in bpy.data.materials:
|
2019-08-16 19:28:32 +00:00
|
|
|
# This needs to be enabled case by case,
|
|
|
|
# otherwise we loose SSR and GTAO everywhere.
|
|
|
|
# mat.use_screen_refraction = True
|
2019-05-05 16:31:49 +00:00
|
|
|
mat.use_sss_translucency = True
|
2018-05-18 14:40:41 +00:00
|
|
|
|
2019-09-06 21:07:21 +00:00
|
|
|
cubemap = None
|
|
|
|
grid = None
|
|
|
|
# Does not work in edit mode
|
|
|
|
try:
|
|
|
|
# Simple probe setup
|
|
|
|
bpy.ops.object.lightprobe_add(type='CUBEMAP', location=(0.5, 0, 1.5))
|
|
|
|
cubemap = bpy.context.selected_objects[0]
|
|
|
|
cubemap.scale = (2.5, 2.5, 1.0)
|
|
|
|
cubemap.data.falloff = 0
|
|
|
|
cubemap.data.clip_start = 2.4
|
|
|
|
|
|
|
|
bpy.ops.object.lightprobe_add(type='GRID', location=(0, 0, 0.25))
|
|
|
|
grid = bpy.context.selected_objects[0]
|
|
|
|
grid.scale = (1.735, 1.735, 1.735)
|
|
|
|
grid.data.grid_resolution_x = 3
|
|
|
|
grid.data.grid_resolution_y = 3
|
|
|
|
grid.data.grid_resolution_z = 2
|
|
|
|
except:
|
|
|
|
pass
|
2019-08-16 19:28:32 +00:00
|
|
|
|
|
|
|
try:
|
|
|
|
# Try to only include the plane in reflections
|
|
|
|
plane = bpy.data.objects['Plane']
|
|
|
|
|
|
|
|
collection = bpy.data.collections.new("Reflection")
|
|
|
|
collection.objects.link(plane)
|
|
|
|
# Add all lights to light the plane
|
2022-04-26 05:03:04 +00:00
|
|
|
if not invert:
|
2019-08-16 19:28:32 +00:00
|
|
|
for light in bpy.data.objects:
|
|
|
|
if light.type == 'LIGHT':
|
|
|
|
collection.objects.link(light)
|
|
|
|
|
|
|
|
# Add collection to the scene
|
|
|
|
scene.collection.children.link(collection)
|
|
|
|
|
|
|
|
cubemap.data.visibility_collection = collection
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
|
|
|
|
eevee.gi_diffuse_bounces = 1
|
|
|
|
eevee.gi_cubemap_resolution = '128'
|
|
|
|
eevee.gi_visibility_resolution = '16'
|
|
|
|
eevee.gi_irradiance_smoothing = 0
|
|
|
|
|
2020-03-13 23:30:55 +00:00
|
|
|
bpy.ops.scene.light_cache_bake()
|
2019-08-16 19:28:32 +00:00
|
|
|
|
2018-07-03 05:12:24 +00:00
|
|
|
|
2018-05-18 14:40:41 +00:00
|
|
|
# When run from inside Blender, render and exit.
|
|
|
|
try:
|
|
|
|
import bpy
|
|
|
|
inside_blender = True
|
|
|
|
except ImportError:
|
|
|
|
inside_blender = False
|
|
|
|
|
|
|
|
if inside_blender:
|
|
|
|
try:
|
|
|
|
setup()
|
|
|
|
except Exception as e:
|
|
|
|
print(e)
|
|
|
|
sys.exit(1)
|
|
|
|
|
2022-08-03 21:41:03 +00:00
|
|
|
|
2022-08-01 08:57:18 +00:00
|
|
|
def get_gpu_device_type(blender):
|
|
|
|
command = [
|
|
|
|
blender,
|
|
|
|
"-noaudio",
|
|
|
|
"--background"
|
|
|
|
"--factory-startup",
|
|
|
|
"--python",
|
|
|
|
str(pathlib.Path(__file__).parent / "gpu_info.py")
|
|
|
|
]
|
|
|
|
try:
|
|
|
|
completed_process = subprocess.run(command, stdout=subprocess.PIPE)
|
|
|
|
for line in completed_process.stdout.read_text():
|
|
|
|
if line.startswith("GPU_DEVICE_TYPE:"):
|
|
|
|
vendor = line.split(':')[1]
|
|
|
|
return vendor
|
|
|
|
except BaseException as e:
|
|
|
|
return None
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
2019-05-10 21:00:35 +00:00
|
|
|
def get_arguments(filepath, output_filepath):
|
|
|
|
return [
|
2018-05-18 14:40:41 +00:00
|
|
|
"--background",
|
|
|
|
"-noaudio",
|
|
|
|
"--factory-startup",
|
2019-05-16 13:48:30 +00:00
|
|
|
"--enable-autoexec",
|
2020-08-26 20:02:02 +00:00
|
|
|
"--debug-memory",
|
|
|
|
"--debug-exit-on-error",
|
2019-05-16 13:48:30 +00:00
|
|
|
filepath,
|
|
|
|
"-E", "BLENDER_EEVEE",
|
|
|
|
"-P",
|
|
|
|
os.path.realpath(__file__),
|
|
|
|
"-o", output_filepath,
|
|
|
|
"-F", "PNG",
|
|
|
|
"-f", "1"]
|
2018-05-18 14:40:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
def create_argparse():
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument("-blender", nargs="+")
|
|
|
|
parser.add_argument("-testdir", nargs=1)
|
|
|
|
parser.add_argument("-outdir", nargs=1)
|
|
|
|
parser.add_argument("-idiff", nargs=1)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
parser = create_argparse()
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
2019-05-10 21:00:35 +00:00
|
|
|
blender = args.blender[0]
|
2018-05-18 14:40:41 +00:00
|
|
|
test_dir = args.testdir[0]
|
|
|
|
idiff = args.idiff[0]
|
|
|
|
output_dir = args.outdir[0]
|
|
|
|
|
2022-08-01 08:57:18 +00:00
|
|
|
gpu_device_type = get_gpu_device_type(blender)
|
|
|
|
reference_override_dir = None
|
|
|
|
if gpu_device_type == "AMD":
|
|
|
|
reference_override_dir = "eevee_renders/amd"
|
|
|
|
|
2018-05-18 14:40:41 +00:00
|
|
|
from modules import render_report
|
2019-06-25 17:48:14 +00:00
|
|
|
report = render_report.Report("Eevee", output_dir, idiff)
|
2018-05-18 14:40:41 +00:00
|
|
|
report.set_pixelated(True)
|
|
|
|
report.set_reference_dir("eevee_renders")
|
2022-08-01 08:57:18 +00:00
|
|
|
report.set_reference_override_dir(reference_override_dir)
|
2020-12-07 15:27:23 +00:00
|
|
|
report.set_compare_engine('cycles', 'CPU')
|
2022-06-24 11:45:18 +00:00
|
|
|
|
|
|
|
test_dir_name = Path(test_dir).name
|
|
|
|
if test_dir_name.startswith('image'):
|
|
|
|
report.set_fail_threshold(0.051)
|
|
|
|
|
2019-05-10 21:00:35 +00:00
|
|
|
ok = report.run(test_dir, blender, get_arguments, batch=True)
|
2018-05-18 14:40:41 +00:00
|
|
|
|
|
|
|
sys.exit(not ok)
|
|
|
|
|
|
|
|
|
|
|
|
if not inside_blender and __name__ == "__main__":
|
|
|
|
main()
|