2014-07-08 03:11:14 -04:00
# pragma once
# include "EmberCommon.h"
/// <summary>
/// EmberOptionEntry and EmberOptions classes.
/// </summary>
2014-12-05 21:30:46 -05:00
static const char * DescriptionString = " Ember - Fractal flames C++ port and enhancement with OpenCL GPU support " ;
2014-07-08 03:11:14 -04:00
/// <summary>
/// Enum for specifying which command line programs an option is meant to be used with.
/// If an option is used with multiple programs, their values are ORed together.
/// </summary>
2016-01-04 19:50:15 -05:00
enum class eOptionUse : et
2014-07-08 03:11:14 -04:00
{
OPT_USE_RENDER = 1 ,
OPT_USE_ANIMATE = 1 < < 1 ,
OPT_USE_GENOME = 1 < < 2 ,
2016-01-04 19:50:15 -05:00
OPT_RENDER_ANIM = et ( eOptionUse : : OPT_USE_RENDER ) | et ( eOptionUse : : OPT_USE_ANIMATE ) ,
OPT_ANIM_GENOME = et ( eOptionUse : : OPT_USE_ANIMATE ) | et ( eOptionUse : : OPT_USE_GENOME ) ,
OPT_USE_ALL = et ( eOptionUse : : OPT_USE_RENDER ) | et ( eOptionUse : : OPT_USE_ANIMATE ) | et ( eOptionUse : : OPT_USE_GENOME )
2014-07-08 03:11:14 -04:00
} ;
/// <summary>
/// Unique identifiers for every available option across all programs.
/// </summary>
2016-01-04 19:50:15 -05:00
enum class eOptionIDs : et
2014-07-08 03:11:14 -04:00
{
//Diagnostic args.
OPT_HELP ,
OPT_VERSION ,
OPT_VERBOSE ,
OPT_DEBUG ,
OPT_DUMP_ARGS ,
OPT_PROGRESS ,
OPT_DUMP_OPENCL_INFO ,
//Boolean args.
OPT_OPENCL ,
OPT_EARLYCLIP ,
2014-08-06 00:50:52 -04:00
OPT_POS_Y_UP ,
2014-07-08 03:11:14 -04:00
OPT_TRANSPARENCY ,
OPT_NAME_ENABLE ,
OPT_INT_PALETTE ,
OPT_HEX_PALETTE ,
OPT_INSERT_PALETTE ,
OPT_JPEG_COMMENTS ,
OPT_PNG_COMMENTS ,
OPT_WRITE_GENOME ,
2015-01-19 11:39:50 -05:00
OPT_THREADED_WRITE ,
2014-07-08 03:11:14 -04:00
OPT_ENCLOSED ,
OPT_NO_EDITS ,
OPT_UNSMOOTH_EDGE ,
OPT_LOCK_ACCUM ,
OPT_DUMP_KERNEL ,
//Value args.
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
OPT_SEED , //Int value args.
2014-07-08 03:11:14 -04:00
OPT_NTHREADS ,
OPT_STRIPS ,
2014-08-06 00:50:52 -04:00
OPT_SUPERSAMPLE ,
2014-07-08 03:11:14 -04:00
OPT_BITS ,
OPT_BPC ,
OPT_SBS ,
OPT_PRINT_EDIT_DEPTH ,
OPT_JPEG ,
OPT_BEGIN ,
OPT_END ,
OPT_FRAME ,
OPT_TIME ,
OPT_DTIME ,
OPT_NFRAMES ,
OPT_SYMMETRY ,
OPT_SHEEP_GEN ,
OPT_SHEEP_ID ,
OPT_REPEAT ,
OPT_TRIES ,
OPT_MAX_XFORMS ,
2015-05-31 01:14:34 -04:00
OPT_PRIORITY ,
2014-07-08 03:11:14 -04:00
OPT_SS , //Float value args.
OPT_QS ,
OPT_PIXEL_ASPECT ,
OPT_STAGGER ,
OPT_AVG_THRESH ,
OPT_BLACK_THRESH ,
OPT_WHITE_LIMIT ,
OPT_SPEED ,
OPT_OFFSETX ,
OPT_OFFSETY ,
OPT_USEMEM ,
2015-07-06 07:06:20 -04:00
OPT_LOOPS ,
2014-07-08 03:11:14 -04:00
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
OPT_OPENCL_DEVICE , //String value args.
OPT_ISAAC_SEED ,
2014-07-08 03:11:14 -04:00
OPT_IN ,
OPT_OUT ,
OPT_PREFIX ,
OPT_SUFFIX ,
OPT_FORMAT ,
OPT_PALETTE_FILE ,
2014-10-27 17:21:06 -04:00
//OPT_PALETTE_IMAGE,
2014-07-08 03:11:14 -04:00
OPT_ID ,
OPT_URL ,
OPT_NICK ,
OPT_COMMENT ,
OPT_TEMPLATE ,
OPT_CLONE ,
OPT_CLONE_ALL ,
OPT_CLONE_ACTION ,
OPT_ANIMATE ,
OPT_MUTATE ,
OPT_CROSS0 ,
OPT_CROSS1 ,
OPT_METHOD ,
OPT_INTER ,
OPT_ROTATE ,
OPT_STRIP ,
OPT_SEQUENCE ,
OPT_USE_VARS ,
OPT_DONT_USE_VARS ,
OPT_EXTRAS
} ;
class EmberOptions ;
/// <summary>
/// A single option.
2014-12-06 00:05:09 -05:00
/// Template argument expected to be bool, int, uint, double or string.
2014-07-08 03:11:14 -04:00
/// </summary>
template < typename T >
class EmberOptionEntry
{
2016-01-04 19:50:15 -05:00
friend class EmberOptions ;
2014-07-08 03:11:14 -04:00
private :
/// <summary>
/// Default constructor. This should never be used, instead use the one that takes arguments.
/// </summary>
EmberOptionEntry ( )
{
2016-01-04 19:50:15 -05:00
m_OptionUse = eOptionUse : : OPT_USE_ALL ;
2014-07-08 03:11:14 -04:00
m_Option . nArgType = SO_NONE ;
m_Option . nId = 0 ;
2014-12-05 21:30:46 -05:00
m_Option . pszArg = _T ( " --fillmein " ) ;
2014-07-08 03:11:14 -04:00
m_DocString = " Dummy doc " ;
}
public :
/// <summary>
/// Constructor that takes arguments.
/// </summary>
/// <param name="optUsage">The specified program usage</param>
/// <param name="optId">The option identifier enum</param>
/// <param name="arg">The command line argument (--arg)</param>
/// <param name="defaultVal">The default value to use the option was not given on the command line</param>
/// <param name="argType">The format the argument should be given in</param>
/// <param name="docString">The documentation string describing what the argument means</param>
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
EmberOptionEntry ( eOptionUse optUsage , eOptionIDs optId , const CharT * arg , T defaultVal , ESOArgType argType , const string & docString )
2014-07-08 03:11:14 -04:00
{
m_OptionUse = optUsage ;
2014-12-07 02:51:44 -05:00
m_Option . nId = int ( optId ) ;
2014-07-08 03:11:14 -04:00
m_Option . pszArg = arg ;
m_Option . nArgType = argType ;
m_DocString = docString ;
m_NameWithoutDashes = Trim ( string ( arg ) , ' - ' ) ;
2014-12-07 02:51:44 -05:00
m_Val = Arg < T > ( const_cast < char * > ( m_NameWithoutDashes . c_str ( ) ) , defaultVal ) ;
2014-07-08 03:11:14 -04:00
}
/// <summary>
/// Copy constructor.
/// </summary>
/// <param name="entry">The EmberOptionEntry object to copy</param>
EmberOptionEntry ( const EmberOptionEntry & entry )
{
* this = entry ;
}
2014-12-05 21:30:46 -05:00
2015-01-19 11:39:50 -05:00
/// <summary>
/// Default assignment operator.
/// </summary>
/// <param name="entry">The EmberOptionEntry object to copy</param>
EmberOptionEntry < T > & operator = ( const EmberOptionEntry < T > & entry )
{
if ( this ! = & entry )
{
m_OptionUse = entry . m_OptionUse ;
m_Option = entry . m_Option ;
m_DocString = entry . m_DocString ;
m_NameWithoutDashes = entry . m_NameWithoutDashes ;
m_Val = entry . m_Val ;
}
return * this ;
}
2014-07-08 03:11:14 -04:00
/// <summary>
/// Functor accessors.
/// </summary>
inline T operator ( ) ( void ) { return m_Val ; }
2015-01-19 11:39:50 -05:00
inline void operator ( ) ( T t ) { m_Val = t ; }
2014-07-08 03:11:14 -04:00
private :
eOptionUse m_OptionUse ;
CSimpleOpt : : SOption m_Option ;
string m_DocString ;
string m_NameWithoutDashes ;
T m_Val ;
} ;
/// <summary>
/// Macros for setting up and parsing various option types.
/// </summary>
//Bool.
# define Eob EmberOptionEntry<bool>
# define INITBOOLOPTION(member, option) \
2016-01-04 19:50:15 -05:00
member = option ; \
m_BoolArgs . push_back ( & member )
2014-07-08 03:11:14 -04:00
2016-01-04 19:50:15 -05:00
# define PARSEBOOLOPTION(e, member) \
case ( e ) : \
{ \
if ( member . m_Option . nArgType = = SO_OPT ) \
2015-01-19 11:39:50 -05:00
{ \
2016-01-04 19:50:15 -05:00
member ( ! strcmp ( args . OptionArg ( ) , " true " ) ) ; \
2015-01-19 11:39:50 -05:00
} \
2016-01-04 19:50:15 -05:00
else \
{ \
member ( true ) ; \
} \
} \
break
2014-07-08 03:11:14 -04:00
//Int.
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
# define Eoi EmberOptionEntry<intmax_t>
2014-07-08 03:11:14 -04:00
# define INITINTOPTION(member, option) \
2016-01-04 19:50:15 -05:00
member = option ; \
m_IntArgs . push_back ( & member )
2014-07-08 03:11:14 -04:00
2016-01-04 19:50:15 -05:00
# define PARSEINTOPTION(e, member) \
case ( e ) : \
sscanf_s ( args . OptionArg ( ) , " %ld " , & member . m_Val ) ; \
break
2014-07-08 03:11:14 -04:00
//Uint.
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
# define Eou EmberOptionEntry<size_t>
2014-07-08 03:11:14 -04:00
# define INITUINTOPTION(member, option) \
2016-01-04 19:50:15 -05:00
member = option ; \
m_UintArgs . push_back ( & member )
2014-07-08 03:11:14 -04:00
2016-01-04 19:50:15 -05:00
# define PARSEUINTOPTION(e, member) \
case ( e ) : \
sscanf_s ( args . OptionArg ( ) , " %lu " , & member . m_Val ) ; \
break
2014-07-08 03:11:14 -04:00
//Double.
# define Eod EmberOptionEntry<double>
# define INITDOUBLEOPTION(member, option) \
2016-01-04 19:50:15 -05:00
member = option ; \
m_DoubleArgs . push_back ( & member )
2014-07-08 03:11:14 -04:00
2016-01-04 19:50:15 -05:00
# define PARSEDOUBLEOPTION(e, member) \
case ( e ) : \
sscanf_s ( args . OptionArg ( ) , " %lf " , & member . m_Val ) ; \
break
2014-07-08 03:11:14 -04:00
//String.
# define Eos EmberOptionEntry<string>
# define INITSTRINGOPTION(member, option) \
2016-01-04 19:50:15 -05:00
member = option ; \
m_StringArgs . push_back ( & member )
2014-07-08 03:11:14 -04:00
2016-01-04 19:50:15 -05:00
# define PARSESTRINGOPTION(e, member) \
case ( e ) : \
member . m_Val = args . OptionArg ( ) ; \
break
2014-07-08 03:11:14 -04:00
/// <summary>
/// Class for holding all available options across all command line programs.
/// Some are used only for a single program, while others are used for more than one.
/// This prevents having to keep separate documentation strings around for different programs.
/// </summary>
class EmberOptions
{
public :
/// <summary>
/// Constructor that populates all available options.
/// </summary>
EmberOptions ( )
{
m_BoolArgs . reserve ( 25 ) ;
m_IntArgs . reserve ( 25 ) ;
m_UintArgs . reserve ( 25 ) ;
m_DoubleArgs . reserve ( 25 ) ;
m_StringArgs . reserve ( 35 ) ;
//Diagnostic bools.
2016-01-04 19:50:15 -05:00
INITBOOLOPTION ( Help , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_HELP , _T ( " --help " ) , false , SO_NONE , " \t --help Show this screen. \n " ) ) ;
INITBOOLOPTION ( Version , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_VERSION , _T ( " --version " ) , false , SO_NONE , " \t --version Show version. \n " ) ) ;
INITBOOLOPTION ( Verbose , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_VERBOSE , _T ( " --verbose " ) , false , SO_NONE , " \t --verbose Verbose output. \n " ) ) ;
INITBOOLOPTION ( Debug , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_DEBUG , _T ( " --debug " ) , false , SO_NONE , " \t --debug Debug output. \n " ) ) ;
INITBOOLOPTION ( DumpArgs , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_DUMP_ARGS , _T ( " --dumpargs " ) , false , SO_NONE , " \t --dumpargs Print all arguments entered from either the command line or environment variables. \n " ) ) ;
INITBOOLOPTION ( DoProgress , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_PROGRESS , _T ( " --progress " ) , false , SO_NONE , " \t --progress Display progress. This will slow down processing by about 10%%. \n " ) ) ;
INITBOOLOPTION ( OpenCLInfo , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_DUMP_OPENCL_INFO , _T ( " --openclinfo " ) , false , SO_NONE , " \t --openclinfo Display platforms and devices for OpenCL. \n " ) ) ;
2014-12-05 21:30:46 -05:00
//Execution bools.
2016-01-04 19:50:15 -05:00
INITBOOLOPTION ( EmberCL , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_OPENCL , _T ( " --opencl " ) , false , SO_NONE , " \t --opencl Use OpenCL renderer (EmberCL) for rendering [default: false]. \n " ) ) ;
INITBOOLOPTION ( EarlyClip , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_EARLYCLIP , _T ( " --earlyclip " ) , false , SO_NONE , " \t --earlyclip Perform clipping of RGB values before spatial filtering for better antialiasing and resizing [default: false]. \n " ) ) ;
INITBOOLOPTION ( YAxisUp , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_POS_Y_UP , _T ( " --yaxisup " ) , false , SO_NONE , " \t --yaxisup Orient the image with the positive y axis pointing up [default: false]. \n " ) ) ;
INITBOOLOPTION ( Transparency , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_TRANSPARENCY , _T ( " --transparency " ) , false , SO_NONE , " \t --transparency Include alpha channel in final output [default: false except for PNG]. \n " ) ) ;
INITBOOLOPTION ( NameEnable , Eob ( eOptionUse : : OPT_USE_RENDER , eOptionIDs : : OPT_NAME_ENABLE , _T ( " --name_enable " ) , false , SO_NONE , " \t --name_enable Use the name attribute contained in the xml as the output filename [default: false]. \n " ) ) ;
INITBOOLOPTION ( IntPalette , Eob ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_INT_PALETTE , _T ( " --intpalette " ) , false , SO_NONE , " \t --intpalette Force palette RGB values to be integers [default: false (float)]. \n " ) ) ;
INITBOOLOPTION ( HexPalette , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_HEX_PALETTE , _T ( " --hex_palette " ) , true , SO_OPT , " \t --hex_palette Force palette RGB values to be hex [default: true]. \n " ) ) ;
INITBOOLOPTION ( InsertPalette , Eob ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_INSERT_PALETTE , _T ( " --insert_palette " ) , false , SO_NONE , " \t --insert_palette Insert the palette into the image for debugging purposes [default: false]. \n " ) ) ;
INITBOOLOPTION ( JpegComments , Eob ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_JPEG_COMMENTS , _T ( " --enable_jpeg_comments " ) , true , SO_OPT , " \t --enable_jpeg_comments Enables comments in the jpeg header [default: true]. \n " ) ) ;
INITBOOLOPTION ( PngComments , Eob ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_PNG_COMMENTS , _T ( " --enable_png_comments " ) , true , SO_OPT , " \t --enable_png_comments Enables comments in the png header [default: true]. \n " ) ) ;
INITBOOLOPTION ( WriteGenome , Eob ( eOptionUse : : OPT_USE_ANIMATE , eOptionIDs : : OPT_WRITE_GENOME , _T ( " --write_genome " ) , false , SO_NONE , " \t --write_genome Write out flame associated with center of motion blur window [default: false]. \n " ) ) ;
INITBOOLOPTION ( ThreadedWrite , Eob ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_THREADED_WRITE , _T ( " --threaded_write " ) , true , SO_OPT , " \t --threaded_write Use a separate thread to write images to disk. This gives better performance, but doubles the memory required for the final output buffer. [default: true]. \n " ) ) ;
INITBOOLOPTION ( Enclosed , Eob ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_ENCLOSED , _T ( " --enclosed " ) , true , SO_OPT , " \t --enclosed Use enclosing XML tags [default: true]. \n " ) ) ;
INITBOOLOPTION ( NoEdits , Eob ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_NO_EDITS , _T ( " --noedits " ) , false , SO_NONE , " \t --noedits Exclude edit tags when writing Xml [default: false]. \n " ) ) ;
INITBOOLOPTION ( UnsmoothEdge , Eob ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_UNSMOOTH_EDGE , _T ( " --unsmoother " ) , false , SO_NONE , " \t --unsmoother Do not use smooth blending for sheep edges [default: false]. \n " ) ) ;
INITBOOLOPTION ( LockAccum , Eob ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_LOCK_ACCUM , _T ( " --lock_accum " ) , false , SO_NONE , " \t --lock_accum Lock threads when accumulating to the histogram using the CPU. This will drop performance to that of single threading [default: false]. \n " ) ) ;
INITBOOLOPTION ( DumpKernel , Eob ( eOptionUse : : OPT_USE_RENDER , eOptionIDs : : OPT_DUMP_KERNEL , _T ( " --dump_kernel " ) , false , SO_NONE , " \t --dump_kernel Print the iteration kernel string when using OpenCL (ignored for CPU) [default: false]. \n " ) ) ;
2014-07-08 03:11:14 -04:00
//Int.
2016-01-04 19:50:15 -05:00
INITINTOPTION ( Symmetry , Eoi ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_SYMMETRY , _T ( " --symmetry " ) , 0 , SO_REQ_SEP , " \t --symmetry=<val> Set symmetry of result [default: 0]. \n " ) ) ;
INITINTOPTION ( SheepGen , Eoi ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_SHEEP_GEN , _T ( " --sheep_gen " ) , - 1 , SO_REQ_SEP , " \t --sheep_gen=<val> Sheep generation of this flame [default: -1]. \n " ) ) ;
INITINTOPTION ( SheepId , Eoi ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_SHEEP_ID , _T ( " --sheep_id " ) , - 1 , SO_REQ_SEP , " \t --sheep_id=<val> Sheep ID of this flame [default: -1]. \n " ) ) ;
2015-06-17 23:05:53 -04:00
# ifdef _WIN32
2016-01-04 19:50:15 -05:00
INITINTOPTION ( Priority , Eoi ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_PRIORITY , _T ( " --priority " ) , int ( eThreadPriority : : NORMAL ) , SO_REQ_SEP , " \t --priority=<val> The priority of the CPU rendering threads from -2 - 2. This does not apply to OpenCL rendering. \n " ) ) ;
2015-06-17 23:05:53 -04:00
# else
2016-01-04 19:50:15 -05:00
INITINTOPTION ( Priority , Eoi ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_PRIORITY , _T ( " --priority " ) , int ( eThreadPriority : : NORMAL ) , SO_REQ_SEP , " \t --priority=<val> The priority of the CPU rendering threads, 1, 25, 50, 75, 99. This does not apply to OpenCL rendering. \n " ) ) ;
2015-06-17 23:05:53 -04:00
# endif
//Uint.
2016-01-04 19:50:15 -05:00
INITUINTOPTION ( Seed , Eou ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_SEED , _T ( " --seed " ) , 0 , SO_REQ_SEP , " \t --seed=<val> Integer seed to use for the random number generator [default: random]. \n " ) ) ;
INITUINTOPTION ( ThreadCount , Eou ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_NTHREADS , _T ( " --nthreads " ) , 0 , SO_REQ_SEP , " \t --nthreads=<val> The number of threads to use [default: use all available cores]. \n " ) ) ;
INITUINTOPTION ( Strips , Eou ( eOptionUse : : OPT_USE_RENDER , eOptionIDs : : OPT_STRIPS , _T ( " --nstrips " ) , 1 , SO_REQ_SEP , " \t --nstrips=<val> The number of fractions to split a single render frame into. Useful for print size renders or low memory systems [default: 1]. \n " ) ) ;
INITUINTOPTION ( Supersample , Eou ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_SUPERSAMPLE , _T ( " --supersample " ) , 0 , SO_REQ_SEP , " \t --supersample=<val> The supersample value used to override the one specified in the file [default: 0 (use value from file)]. \n " ) ) ;
INITUINTOPTION ( BitsPerChannel , Eou ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_BPC , _T ( " --bpc " ) , 8 , SO_REQ_SEP , " \t --bpc=<val> Bits per channel. 8 or 16 for PNG, 8 for all others [default: 8]. \n " ) ) ;
INITUINTOPTION ( SubBatchSize , Eou ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_SBS , _T ( " --sub_batch_size " ) , DEFAULT_SBS , SO_REQ_SEP , " \t --sub_batch_size=<val> The chunk size that iterating will be broken into [default: 10k]. \n " ) ) ;
INITUINTOPTION ( Bits , Eou ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_BITS , _T ( " --bits " ) , 33 , SO_REQ_SEP , " \t --bits=<val> Determines the types used for the histogram and accumulator [default: 33]. \n "
" \t \t \t \t \t 32: Histogram: float, Accumulator: float. \n "
" \t \t \t \t \t 33: Histogram: float, Accumulator: float. \n " //This differs from the original which used an int hist for bits 33.
" \t \t \t \t \t 64: Histogram: double, Accumulator: double. \n " ) ) ;
INITUINTOPTION ( PrintEditDepth , Eou ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_PRINT_EDIT_DEPTH , _T ( " --print_edit_depth " ) , 0 , SO_REQ_SEP , " \t --print_edit_depth=<val> Depth to truncate <edit> tag structure when converting a flame to xml. 0 prints all <edit> tags [default: 0]. \n " ) ) ;
INITUINTOPTION ( JpegQuality , Eou ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_JPEG , _T ( " --jpeg " ) , 95 , SO_REQ_SEP , " \t --jpeg=<val> Jpeg quality 0-100 for compression [default: 95]. \n " ) ) ;
INITUINTOPTION ( FirstFrame , Eou ( eOptionUse : : OPT_USE_ANIMATE , eOptionIDs : : OPT_BEGIN , _T ( " --begin " ) , UINT_MAX , SO_REQ_SEP , " \t --begin=<val> Time of first frame to render [default: first time specified in file]. \n " ) ) ;
INITUINTOPTION ( LastFrame , Eou ( eOptionUse : : OPT_USE_ANIMATE , eOptionIDs : : OPT_END , _T ( " --end " ) , UINT_MAX , SO_REQ_SEP , " \t --end=<val> Time of last frame to render [default: last time specified in the input file]. \n " ) ) ;
INITUINTOPTION ( Time , Eou ( eOptionUse : : OPT_ANIM_GENOME , eOptionIDs : : OPT_TIME , _T ( " --time " ) , 0 , SO_REQ_SEP , " \t --time=<val> Time of first and last frame (ie do one frame). \n " ) ) ;
INITUINTOPTION ( Frame , Eou ( eOptionUse : : OPT_ANIM_GENOME , eOptionIDs : : OPT_FRAME , _T ( " --frame " ) , 0 , SO_REQ_SEP , " \t --frame=<val> Synonym for \" time \" . \n " ) ) ;
INITUINTOPTION ( Dtime , Eou ( eOptionUse : : OPT_USE_ANIMATE , eOptionIDs : : OPT_DTIME , _T ( " --dtime " ) , 1 , SO_REQ_SEP , " \t --dtime=<val> Time between frames [default: 1]. \n " ) ) ;
INITUINTOPTION ( Frames , Eou ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_NFRAMES , _T ( " --nframes " ) , 20 , SO_REQ_SEP , " \t --nframes=<val> Number of frames for each stage of the animation [default: 20]. \n " ) ) ;
INITUINTOPTION ( Repeat , Eou ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_REPEAT , _T ( " --repeat " ) , 1 , SO_REQ_SEP , " \t --repeat=<val> Number of new flames to create. Ignored if sequence, inter or rotate were specified [default: 1]. \n " ) ) ;
INITUINTOPTION ( Tries , Eou ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_TRIES , _T ( " --tries " ) , 10 , SO_REQ_SEP , " \t --tries=<val> Number times to try creating a flame that meets the specified constraints. Ignored if sequence, inter or rotate were specified [default: 10]. \n " ) ) ;
INITUINTOPTION ( MaxXforms , Eou ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_MAX_XFORMS , _T ( " --maxxforms " ) , UINT_MAX , SO_REQ_SEP , " \t --maxxforms=<val> The maximum number of xforms allowed in the final output. \n " ) ) ;
2014-07-08 03:11:14 -04:00
//Double.
2016-01-04 19:50:15 -05:00
INITDOUBLEOPTION ( SizeScale , Eod ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_SS , _T ( " --ss " ) , 1 , SO_REQ_SEP , " \t --ss=<val> Size scale. All dimensions are scaled by this amount [default: 1.0]. \n " ) ) ;
INITDOUBLEOPTION ( QualityScale , Eod ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_QS , _T ( " --qs " ) , 1 , SO_REQ_SEP , " \t --qs=<val> Quality scale. All quality values are scaled by this amount [default: 1.0]. \n " ) ) ;
INITDOUBLEOPTION ( AspectRatio , Eod ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_PIXEL_ASPECT , _T ( " --pixel_aspect " ) , 1 , SO_REQ_SEP , " \t --pixel_aspect=<val> Aspect ratio of pixels (width over height), eg. 0.90909 for NTSC [default: 1.0]. \n " ) ) ;
INITDOUBLEOPTION ( Stagger , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_STAGGER , _T ( " --stagger " ) , 0 , SO_REQ_SEP , " \t --stagger=<val> Affects simultaneity of xform interpolation during flame interpolation. \n "
" \t Represents how 'separate' the xforms are interpolated. Set to 1 for each \n "
" \t xform to be interpolated individually, fractions control interpolation overlap [default: 0]. \n " ) ) ;
INITDOUBLEOPTION ( AvgThresh , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_AVG_THRESH , _T ( " --avg " ) , 20.0 , SO_REQ_SEP , " \t --avg=<val> Minimum average pixel channel sum (r + g + b) threshold from 0 - 765. Ignored if sequence, inter or rotate were specified [default: 20]. \n " ) ) ;
INITDOUBLEOPTION ( BlackThresh , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_BLACK_THRESH , _T ( " --black " ) , 0.01 , SO_REQ_SEP , " \t --black=<val> Minimum number of allowed black pixels as a percentage from 0 - 1. Ignored if sequence, inter or rotate were specified [default: 0.01]. \n " ) ) ;
INITDOUBLEOPTION ( WhiteLimit , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_WHITE_LIMIT , _T ( " --white " ) , 0.05 , SO_REQ_SEP , " \t --white=<val> Maximum number of allowed white pixels as a percentage from 0 - 1. Ignored if sequence, inter or rotate were specified [default: 0.05]. \n " ) ) ;
INITDOUBLEOPTION ( Speed , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_SPEED , _T ( " --speed " ) , 0.1 , SO_REQ_SEP , " \t --speed=<val> Speed as a percentage from 0 - 1 that the affine transform of an existing flame mutates with the new flame. Ignored if sequence, inter or rotate were specified [default: 0.1]. \n " ) ) ;
INITDOUBLEOPTION ( OffsetX , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_OFFSETX , _T ( " --offsetx " ) , 0.0 , SO_REQ_SEP , " \t --offsetx=<val> Amount to jitter each flame horizontally when applying genome tools [default: 0]. \n " ) ) ;
INITDOUBLEOPTION ( OffsetY , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_OFFSETY , _T ( " --offsety " ) , 0.0 , SO_REQ_SEP , " \t --offsety=<val> Amount to jitter each flame vertically when applying genome tools [default: 0]. \n " ) ) ;
INITDOUBLEOPTION ( UseMem , Eod ( eOptionUse : : OPT_USE_RENDER , eOptionIDs : : OPT_USEMEM , _T ( " --use_mem " ) , 0.0 , SO_REQ_SEP , " \t --use_mem=<val> Number of bytes of memory to use [default: max system memory]. \n " ) ) ;
INITDOUBLEOPTION ( Loops , Eod ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_LOOPS , _T ( " --loops " ) , 1.0 , SO_REQ_SEP , " \t --loops=<val> Number of times to rotate each control point in sequence [default: 1]. \n " ) ) ;
2014-07-08 03:11:14 -04:00
//String.
2016-01-04 19:50:15 -05:00
INITSTRINGOPTION ( Device , Eos ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_OPENCL_DEVICE , _T ( " --device " ) , " 0 " , SO_REQ_SEP , " \t --device The comma-separated OpenCL device indices to use. Single device: 0 Multi device: 0,1,3,4 [default: 0]. \n " ) ) ;
INITSTRINGOPTION ( IsaacSeed , Eos ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_ISAAC_SEED , _T ( " --isaac_seed " ) , " " , SO_REQ_SEP , " \t --isaac_seed=<val> Character-based seed for the random number generator [default: random]. \n " ) ) ;
INITSTRINGOPTION ( Input , Eos ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_IN , _T ( " --in " ) , " " , SO_REQ_SEP , " \t --in=<val> Name of the input file. \n " ) ) ;
INITSTRINGOPTION ( Out , Eos ( eOptionUse : : OPT_USE_RENDER , eOptionIDs : : OPT_OUT , _T ( " --out " ) , " " , SO_REQ_SEP , " \t --out=<val> Name of a single output file. Not recommended when rendering more than one image. \n " ) ) ;
INITSTRINGOPTION ( Prefix , Eos ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_PREFIX , _T ( " --prefix " ) , " " , SO_REQ_SEP , " \t --prefix=<val> Prefix to prepend to all output files. \n " ) ) ;
INITSTRINGOPTION ( Suffix , Eos ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_SUFFIX , _T ( " --suffix " ) , " " , SO_REQ_SEP , " \t --suffix=<val> Suffix to append to all output files. \n " ) ) ;
INITSTRINGOPTION ( Format , Eos ( eOptionUse : : OPT_RENDER_ANIM , eOptionIDs : : OPT_FORMAT , _T ( " --format " ) , " png " , SO_REQ_SEP , " \t --format=<val> Format of the output file. Valid values are: bmp, jpg, png, ppm [default: jpg]. \n " ) ) ;
INITSTRINGOPTION ( PalettePath , Eos ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_PALETTE_FILE , _T ( " --flam3_palettes " ) , " flam3-palettes.xml " , SO_REQ_SEP , " \t --flam3_palettes=<val> Path and name of the palette file [default: flam3-palettes.xml]. \n " ) ) ;
//INITSTRINGOPTION(PaletteImage, Eos(eOptionUse::OPT_USE_ALL, eOptionIDs::OPT_PALETTE_IMAGE, _T("--image"), "", SO_REQ_SEP, "\t--image=<val> Replace palette with png, jpg, or ppm image.\n"));
INITSTRINGOPTION ( Id , Eos ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_ID , _T ( " --id " ) , " " , SO_REQ_SEP , " \t --id=<val> ID to use in <edit> tags / image comments. \n " ) ) ;
INITSTRINGOPTION ( Url , Eos ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_URL , _T ( " --url " ) , " " , SO_REQ_SEP , " \t --url=<val> URL to use in <edit> tags / image comments. \n " ) ) ;
INITSTRINGOPTION ( Nick , Eos ( eOptionUse : : OPT_USE_ALL , eOptionIDs : : OPT_NICK , _T ( " --nick " ) , " " , SO_REQ_SEP , " \t --nick=<val> Nickname to use in <edit> tags / image comments. \n " ) ) ;
INITSTRINGOPTION ( Comment , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_COMMENT , _T ( " --comment " ) , " " , SO_REQ_SEP , " \t --comment=<val> Comment to use in <edit> tags. \n " ) ) ;
INITSTRINGOPTION ( TemplateFile , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_TEMPLATE , _T ( " --template " ) , " " , SO_REQ_SEP , " \t --template=<val> Apply defaults based on this flame. \n " ) ) ;
INITSTRINGOPTION ( Clone , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_CLONE , _T ( " --clone " ) , " " , SO_REQ_SEP , " \t --clone=<val> Clone random flame in input. \n " ) ) ;
INITSTRINGOPTION ( CloneAll , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_CLONE_ALL , _T ( " --clone_all " ) , " " , SO_REQ_SEP , " \t --clone_all=<val> Clones all flames in the input file. Useful for applying template to all flames. \n " ) ) ;
INITSTRINGOPTION ( CloneAction , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_CLONE_ACTION , _T ( " --clone_action " ) , " " , SO_REQ_SEP , " \t --clone_action=<val> A description of the clone action taking place. \n " ) ) ;
INITSTRINGOPTION ( Animate , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_ANIMATE , _T ( " --animate " ) , " " , SO_REQ_SEP , " \t --animate=<val> Interpolates between all flames in the input file, using times specified in file. \n " ) ) ;
INITSTRINGOPTION ( Mutate , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_MUTATE , _T ( " --mutate " ) , " " , SO_REQ_SEP , " \t --mutate=<val> Randomly mutate a random flame from the input file. \n " ) ) ;
INITSTRINGOPTION ( Cross0 , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_CROSS0 , _T ( " --cross0 " ) , " " , SO_REQ_SEP , " \t --cross0=<val> Randomly select one flame from the input file to genetically cross... \n " ) ) ;
INITSTRINGOPTION ( Cross1 , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_CROSS1 , _T ( " --cross1 " ) , " " , SO_REQ_SEP , " \t --cross1=<val> ...with one flame from this file. \n " ) ) ;
INITSTRINGOPTION ( Method , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_METHOD , _T ( " --method " ) , " " , SO_REQ_SEP , " \t --method=<val> Method used for genetic cross: alternate, interpolate, or union. For mutate: all_vars, one_xform, add_symmetry, post_xforms, color_palette, delete_xform, all_coefs [default: random]. \n " ) ) ; //Original ommitted this important documentation for mutate!
INITSTRINGOPTION ( Inter , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_INTER , _T ( " --inter " ) , " " , SO_REQ_SEP , " \t --inter=<val> Interpolate the input file. \n " ) ) ;
INITSTRINGOPTION ( Rotate , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_ROTATE , _T ( " --rotate " ) , " " , SO_REQ_SEP , " \t --rotate=<val> Rotate the input file. \n " ) ) ;
INITSTRINGOPTION ( Strip , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_STRIP , _T ( " --strip " ) , " " , SO_REQ_SEP , " \t --strip=<val> Break strip out of each flame in the input file. \n " ) ) ;
INITSTRINGOPTION ( Sequence , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_SEQUENCE , _T ( " --sequence " ) , " " , SO_REQ_SEP , " \t --sequence=<val> 360 degree rotation 'loops' times of each control point in the input file plus rotating transitions. \n " ) ) ;
INITSTRINGOPTION ( UseVars , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_USE_VARS , _T ( " --use_vars " ) , " " , SO_REQ_SEP , " \t --use_vars=<val> Comma separated list of variation #'s to use when generating a random flame. \n " ) ) ;
INITSTRINGOPTION ( DontUseVars , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_DONT_USE_VARS , _T ( " --dont_use_vars " ) , " " , SO_REQ_SEP , " \t --dont_use_vars=<val> Comma separated list of variation #'s to NOT use when generating a random flame. \n " ) ) ;
INITSTRINGOPTION ( Extras , Eos ( eOptionUse : : OPT_USE_GENOME , eOptionIDs : : OPT_EXTRAS , _T ( " --extras " ) , " " , SO_REQ_SEP , " \t --extras=<val> Extra attributes to place in the flame section of the Xml. \n " ) ) ;
2014-07-08 03:11:14 -04:00
}
/// <summary>
/// Parse and populate the supplied command line options for the specified program usage.
/// If --help or --version were specified, information will be printed
/// and parsing will cease.
/// </summary>
/// <param name="argc">The number of command line arguments passed</param>
/// <param name="argv">The command line arguments passed</param>
/// <param name="optUsage">The program for which these options are to be parsed and used.</param>
/// <returns>True if --help or --version specified, else false</returns>
bool Populate ( int argc , _TCHAR * argv [ ] , eOptionUse optUsage )
{
EmberOptions options ;
vector < CSimpleOpt : : SOption > sOptions = options . GetSimpleOptions ( ) ;
CSimpleOpt args ( argc , argv , sOptions . data ( ) ) ;
//Process args.
while ( args . Next ( ) )
{
ESOError errorCode = args . LastError ( ) ;
if ( errorCode = = SO_SUCCESS )
{
2016-01-04 19:50:15 -05:00
eOptionIDs e = eOptionIDs ( args . OptionId ( ) ) ;
switch ( e )
2014-07-08 03:11:14 -04:00
{
2016-01-04 19:50:15 -05:00
case eOptionIDs : : OPT_HELP : //Bool args.
2014-07-08 03:11:14 -04:00
{
ShowUsage ( optUsage ) ;
return true ;
}
2016-01-04 19:50:15 -05:00
case eOptionIDs : : OPT_VERSION :
2014-07-08 03:11:14 -04:00
{
cout < < EmberVersion ( ) < < endl ;
return true ;
}
2016-01-04 19:50:15 -05:00
PARSEBOOLOPTION ( eOptionIDs : : OPT_VERBOSE , Verbose ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_DEBUG , Debug ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_DUMP_ARGS , DumpArgs ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_PROGRESS , DoProgress ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_DUMP_OPENCL_INFO , OpenCLInfo ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_OPENCL , EmberCL ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_EARLYCLIP , EarlyClip ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_POS_Y_UP , YAxisUp ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_TRANSPARENCY , Transparency ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_NAME_ENABLE , NameEnable ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_INT_PALETTE , IntPalette ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_HEX_PALETTE , HexPalette ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_INSERT_PALETTE , InsertPalette ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_JPEG_COMMENTS , JpegComments ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_PNG_COMMENTS , PngComments ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_WRITE_GENOME , WriteGenome ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_THREADED_WRITE , ThreadedWrite ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_ENCLOSED , Enclosed ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_NO_EDITS , NoEdits ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_UNSMOOTH_EDGE , UnsmoothEdge ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_LOCK_ACCUM , LockAccum ) ;
PARSEBOOLOPTION ( eOptionIDs : : OPT_DUMP_KERNEL , DumpKernel ) ;
PARSEINTOPTION ( eOptionIDs : : OPT_SYMMETRY , Symmetry ) ; //Int args
PARSEINTOPTION ( eOptionIDs : : OPT_SHEEP_GEN , SheepGen ) ;
PARSEINTOPTION ( eOptionIDs : : OPT_SHEEP_ID , SheepId ) ;
PARSEINTOPTION ( eOptionIDs : : OPT_PRIORITY , Priority ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_SEED , Seed ) ; //uint args.
PARSEUINTOPTION ( eOptionIDs : : OPT_NTHREADS , ThreadCount ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_STRIPS , Strips ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_SUPERSAMPLE , Supersample ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_BITS , Bits ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_BPC , BitsPerChannel ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_SBS , SubBatchSize ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_PRINT_EDIT_DEPTH , PrintEditDepth ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_JPEG , JpegQuality ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_BEGIN , FirstFrame ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_END , LastFrame ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_FRAME , Frame ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_TIME , Time ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_DTIME , Dtime ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_NFRAMES , Frames ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_REPEAT , Repeat ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_TRIES , Tries ) ;
PARSEUINTOPTION ( eOptionIDs : : OPT_MAX_XFORMS , MaxXforms ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_SS , SizeScale ) ; //Float args.
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_QS , QualityScale ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_PIXEL_ASPECT , AspectRatio ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_STAGGER , Stagger ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_AVG_THRESH , AvgThresh ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_BLACK_THRESH , BlackThresh ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_WHITE_LIMIT , WhiteLimit ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_SPEED , Speed ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_OFFSETX , OffsetX ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_OFFSETY , OffsetY ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_USEMEM , UseMem ) ;
PARSEDOUBLEOPTION ( eOptionIDs : : OPT_LOOPS , Loops ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_OPENCL_DEVICE , Device ) ; //String args.
PARSESTRINGOPTION ( eOptionIDs : : OPT_ISAAC_SEED , IsaacSeed ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_IN , Input ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_OUT , Out ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_PREFIX , Prefix ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_SUFFIX , Suffix ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_FORMAT , Format ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_PALETTE_FILE , PalettePath ) ;
//PARSESTRINGOPTION(eOptionIDs::OPT_PALETTE_IMAGE, PaletteImage);
PARSESTRINGOPTION ( eOptionIDs : : OPT_ID , Id ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_URL , Url ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_NICK , Nick ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_COMMENT , Comment ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_TEMPLATE , TemplateFile ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_CLONE , Clone ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_CLONE_ALL , CloneAll ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_CLONE_ACTION , CloneAction ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_ANIMATE , Animate ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_MUTATE , Mutate ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_CROSS0 , Cross0 ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_CROSS1 , Cross1 ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_METHOD , Method ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_INTER , Inter ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_ROTATE , Rotate ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_STRIP , Strip ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_SEQUENCE , Sequence ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_USE_VARS , UseVars ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_DONT_USE_VARS , DontUseVars ) ;
PARSESTRINGOPTION ( eOptionIDs : : OPT_EXTRAS , Extras ) ;
2014-12-05 21:30:46 -05:00
default :
{
break ; //Do nothing.
}
2014-07-08 03:11:14 -04:00
}
}
else
{
cout < < " Invalid argument: " < < args . OptionText ( ) < < endl ;
cout < < " \t Reason: " < < GetLastErrorText ( errorCode ) < < endl ;
}
}
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
auto strings = Split ( Device ( ) , ' , ' ) ;
if ( ! strings . empty ( ) )
{
for ( auto & s : strings )
{
size_t device = 0 ;
istringstream istr ( s ) ;
istr > > device ;
if ( ! istr . bad ( ) & & ! istr . fail ( ) )
m_Devices . push_back ( device ) ;
else
cout < < " Failed to parse device index " < < s ;
}
}
2014-07-08 03:11:14 -04:00
return false ;
}
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
/// <summary>
/// Return a const ref to m_Devices.
/// </summary>
/// <returns>A const ref to the vector of absolute device indices to be used</returns>
const vector < size_t > & Devices ( )
{
return m_Devices ;
}
2014-07-08 03:11:14 -04:00
/// <summary>
/// Return a vector of all available options for the specified program.
/// </summary>
/// <param name="optUsage">The specified program usage</param>
/// <returns>A vector of all available options for the specified program</returns>
2016-01-04 19:50:15 -05:00
vector < CSimpleOpt : : SOption > GetSimpleOptions ( eOptionUse optUsage = eOptionUse : : OPT_USE_ALL )
2014-07-08 03:11:14 -04:00
{
vector < CSimpleOpt : : SOption > entries ;
CSimpleOpt : : SOption endOption = SO_END_OF_OPTIONS ;
entries . reserve ( 75 ) ;
2016-01-04 19:50:15 -05:00
for ( auto entry : m_BoolArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) entries . push_back ( entry - > m_Option ) ;
for ( auto entry : m_IntArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) entries . push_back ( entry - > m_Option ) ;
for ( auto entry : m_UintArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) entries . push_back ( entry - > m_Option ) ;
for ( auto entry : m_DoubleArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) entries . push_back ( entry - > m_Option ) ;
for ( auto entry : m_StringArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) entries . push_back ( entry - > m_Option ) ;
2014-07-08 03:11:14 -04:00
entries . push_back ( endOption ) ;
return entries ;
}
/// <summary>
/// Return a string with the descriptions of all available options for the specified program.
/// </summary>
/// <param name="optUsage">The specified program usage</param>
/// <returns>A string with the descriptions of all available options for the specified program</returns>
2016-01-04 19:50:15 -05:00
string GetUsage ( eOptionUse optUsage = eOptionUse : : OPT_USE_ALL )
2014-07-08 03:11:14 -04:00
{
ostringstream os ;
2016-01-04 19:50:15 -05:00
for ( auto entry : m_BoolArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_DocString < < endl ;
for ( auto entry : m_IntArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_DocString < < endl ;
for ( auto entry : m_UintArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_DocString < < endl ;
for ( auto entry : m_DoubleArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_DocString < < endl ;
for ( auto entry : m_StringArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_DocString < < endl ;
2014-07-08 03:11:14 -04:00
return os . str ( ) ;
}
/// <summary>
/// Return a string with all of the names and values for all available options for the specified program.
/// </summary>
/// <param name="optUsage">The specified program usage</param>
/// <returns>A string with all of the names and values for all available options for the specified program</returns>
2016-01-04 19:50:15 -05:00
string GetValues ( eOptionUse optUsage = eOptionUse : : OPT_USE_ALL )
2014-07-08 03:11:14 -04:00
{
ostringstream os ;
os < < std : : boolalpha ;
2016-01-04 19:50:15 -05:00
for ( auto entry : m_BoolArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_NameWithoutDashes < < " : " < < ( * entry ) ( ) < < endl ;
for ( auto entry : m_IntArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_NameWithoutDashes < < " : " < < ( * entry ) ( ) < < endl ;
for ( auto entry : m_UintArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_NameWithoutDashes < < " : " < < ( * entry ) ( ) < < endl ;
for ( auto entry : m_DoubleArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_NameWithoutDashes < < " : " < < ( * entry ) ( ) < < endl ;
for ( auto entry : m_StringArgs ) if ( et ( entry - > m_OptionUse ) & et ( optUsage ) ) os < < entry - > m_NameWithoutDashes < < " : " < < ( * entry ) ( ) < < endl ;
2014-07-08 03:11:14 -04:00
return os . str ( ) ;
}
/// <summary>
/// Print description string, version and description of all available options for the specified program.
/// </summary>
/// <param name="optUsage">The specified program usage</param>
void ShowUsage ( eOptionUse optUsage )
{
cout < < DescriptionString < < " version " < < EmberVersion ( ) < < endl < < endl ;
2016-01-04 19:50:15 -05:00
if ( optUsage = = eOptionUse : : OPT_USE_RENDER )
2014-07-08 03:11:14 -04:00
{
cout < < " Usage: \n "
2016-01-04 19:50:15 -05:00
" \t EmberRender.exe --in=test.flam3 [--out=outfile --format=png --verbose --progress --opencl] \n " < < endl ;
2014-07-08 03:11:14 -04:00
}
2016-01-04 19:50:15 -05:00
else if ( optUsage = = eOptionUse : : OPT_USE_ANIMATE )
2014-07-08 03:11:14 -04:00
{
cout < < " Usage: \n "
2016-01-04 19:50:15 -05:00
" \t EmberAnimate.exe --in=sequence.flam3 [--format=png --verbose --progress --opencl] \n " < < endl ;
2014-07-08 03:11:14 -04:00
}
2016-01-04 19:50:15 -05:00
else if ( optUsage = = eOptionUse : : OPT_USE_GENOME )
2014-07-08 03:11:14 -04:00
{
cout < < " Usage: \n "
2016-01-04 19:50:15 -05:00
" \t EmberGenome.exe --sequence=test.flam3 > sequenceout.flam3 \n " < < endl ;
2014-07-08 03:11:14 -04:00
}
cout < < GetUsage ( optUsage ) < < endl ;
}
/// <summary>
/// Return the last option parsing error text as a string.
/// </summary>
/// <param name="errorCode">The code of the last parsing error</param>
/// <returns>The last option parsing error text as a string</returns>
string GetLastErrorText ( int errorCode )
{
switch ( errorCode )
{
case SO_SUCCESS : return " Success " ;
2016-01-04 19:50:15 -05:00
2014-07-08 03:11:14 -04:00
case SO_OPT_INVALID : return " Unrecognized option " ;
2016-01-04 19:50:15 -05:00
2014-07-08 03:11:14 -04:00
case SO_OPT_MULTIPLE : return " Option matched multiple strings " ;
2016-01-04 19:50:15 -05:00
2014-07-08 03:11:14 -04:00
case SO_ARG_INVALID : return " Option does not accept argument " ;
2016-01-04 19:50:15 -05:00
2014-07-08 03:11:14 -04:00
case SO_ARG_INVALID_TYPE : return " Invalid argument format " ;
2016-01-04 19:50:15 -05:00
2014-07-08 03:11:14 -04:00
case SO_ARG_MISSING : return " Required argument is missing " ;
2016-01-04 19:50:15 -05:00
2014-07-08 03:11:14 -04:00
case SO_ARG_INVALID_DATA : return " Invalid argument data " ;
2016-01-04 19:50:15 -05:00
2014-07-08 03:11:14 -04:00
default : return " Unknown error " ;
}
}
//Break from the usual m_* notation for members here because
//each of these is a functor, so it looks nicer and is less typing
//to just say opt.Member().
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
Eob Help ; //Diagnostic bool.
Eob Version ;
Eob Verbose ;
Eob Debug ;
Eob DumpArgs ;
Eob DoProgress ;
Eob OpenCLInfo ;
Eob EmberCL ; //Value bool.
Eob EarlyClip ;
Eob YAxisUp ;
Eob Transparency ;
Eob NameEnable ;
Eob IntPalette ;
Eob HexPalette ;
Eob InsertPalette ;
Eob JpegComments ;
Eob PngComments ;
Eob WriteGenome ;
Eob ThreadedWrite ;
Eob Enclosed ;
Eob NoEdits ;
Eob UnsmoothEdge ;
Eob LockAccum ;
Eob DumpKernel ;
Eoi Symmetry ; //Value int.
Eoi SheepGen ;
Eoi SheepId ;
Eoi Priority ;
Eou Seed ; //Value uint.
Eou ThreadCount ;
Eou Strips ;
Eou Supersample ;
Eou BitsPerChannel ;
Eou SubBatchSize ;
Eou Bits ;
Eou PrintEditDepth ;
Eou JpegQuality ;
Eou FirstFrame ;
Eou LastFrame ;
Eou Frame ;
Eou Time ;
Eou Dtime ;
Eou Frames ;
Eou Repeat ;
Eou Tries ;
Eou MaxXforms ;
Eod SizeScale ; //Value double.
Eod QualityScale ;
Eod AspectRatio ;
Eod Stagger ;
Eod AvgThresh ;
Eod BlackThresh ;
Eod WhiteLimit ;
Eod Speed ;
Eod OffsetX ;
Eod OffsetY ;
Eod UseMem ;
Eod Loops ;
Eos Device ; //Value string.
Eos IsaacSeed ;
Eos Input ;
Eos Out ;
Eos Prefix ;
Eos Suffix ;
Eos Format ;
Eos PalettePath ;
//Eos PaletteImage;
Eos Id ;
Eos Url ;
Eos Nick ;
Eos Comment ;
Eos TemplateFile ;
Eos Clone ;
Eos CloneAll ;
Eos CloneAction ;
Eos Animate ;
Eos Mutate ;
Eos Cross0 ;
Eos Cross1 ;
Eos Method ;
Eos Inter ;
Eos Rotate ;
Eos Strip ;
Eos Sequence ;
Eos UseVars ;
Eos DontUseVars ;
Eos Extras ;
2014-07-08 03:11:14 -04:00
private :
--User changes
-Add support for multiple GPU devices.
--These options are present in the command line and in Fractorium.
-Change scheme of specifying devices from platform,device to just total device index.
--Single number on the command line.
--Change from combo boxes for device selection to a table of all devices in Fractorium.
-Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Bug fixes
-EmberAnimate, EmberRender, FractoriumSettings, FinalRenderDialog: Fix wrong order of arguments to Clamp() when assigning thread priority.
-VariationsDC.h: Fix NVidia OpenCL compilation error in DCTriangleVariation.
-FractoriumXformsColor.cpp: Checking for null pixmap pointer is not enough, must also check if the underlying buffer is null via call to QPixmap::isNull().
--Code changes
-Ember.h: Add case for FLAME_MOTION_NONE and default in ApplyFlameMotion().
-EmberMotion.h: Call base constructor.
-EmberPch.h: #pragma once only on Windows.
-EmberToXml.h:
--Handle different types of exceptions.
--Add default cases to ToString().
-Isaac.h: Remove unused variable in constructor.
-Point.h: Call base constructor in Color().
-Renderer.h/cpp:
--Add bool to Alloc() to only allocate memory for the histogram. Needed for multi-GPU.
--Make CoordMap() return a const ref, not a pointer.
-SheepTools.h:
--Use 64-bit types like the rest of the code already does.
--Fix some comment misspellings.
-Timing.h: Make BeginTime(), EndTime(), ElapsedTime() and Format() be const functions.
-Utils.h:
--Add new functions Equal() and Split().
--Handle more exception types in ReadFile().
--Get rid of most legacy blending of C and C++ argument parsing.
-XmlToEmber.h:
--Get rid of most legacy blending of C and C++ code from flam3.
--Remove some unused variables.
-EmberAnimate:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--If a render fails, exit since there is no point in continuing an animation with a missing frame.
--Pass variables to threaded save better, which most likely fixes a very subtle bug that existed before.
--Remove some unused variables.
-EmberGenome, EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
-EmberRender:
--Support multi-GPU processing that alternates full frames between devices.
--Use OpenCLInfo instead of OpenCLWrapper for --openclinfo option.
--Remove bucketT template parameter, and hard code float in its place.
--Only print values when not rendering with OpenCL, since they're always 0 in that case.
-EmberCLPch.h:
--#pragma once only on Windows.
--#include <atomic>.
-IterOpenCLKernelCreator.h: Add new kernel for summing two histograms. This is needed for multi-GPU.
-OpenCLWrapper.h:
--Move all OpenCL info related code into its own class OpenCLInfo.
--Add members to cache the values of global memory size and max allocation size.
-RendererCL.h/cpp:
--Redesign to accomodate multi-GPU.
--Constructor now takes a vector of devices.
--Remove DumpErrorReport() function, it's handled in the base.
--ClearBuffer(), ReadPoints(), WritePoints(), ReadHist() and WriteHist() now optionally take a device index as a parameter.
--MakeDmap() override and m_DmapCL member removed because it no longer applies since the histogram is always float since the last commit.
--Add new function SumDeviceHist() to sum histograms from two devices by first copying to a temporary on the host, then a temporary on the device, then summing.
--m_Calls member removed, as it's now per-device.
--OpenCLWrapper removed.
--m_Seeds member is now a vector of vector of seeds, to accomodate a separate and different array of seeds for each device.
--Added member m_Devices, a vector of unique_ptr of RendererCLDevice.
-EmberCommon.h
--Added Devices() function to convert from a vector of device indices to a vector of platform,device indices.
--Changed CreateRenderer() to accept a vector of devices to create a single RendererCL which will split work across multiple devices.
--Added CreateRenderers() function to accept a vector of devices to create multiple RendererCL, each which will render on a single device.
--Add more comments to some existing functions.
-EmberCommonPch.h: #pragma once only on Windows.
-EmberOptions.h:
--Remove --platform option, it's just sequential device number now with the --device option.
--Make --out be OPT_USE_RENDER instead of OPT_RENDER_ANIM since it's an error condition when animating. It makes no sense to write all frames to a single image.
--Add Devices() function to parse comma separated --device option string and return a vector of device indices.
--Make int and uint types be 64-bit, so intmax_t and size_t.
--Make better use of macros.
-JpegUtils.h: Make string parameters to WriteJpeg() and WritePng() be const ref.
-All project files: Turn off buffer security check option in Visual Studio (/Gs-)
-deployment.pri: Remove the line OTHER_FILES +=, it's pointless and was causing problems.
-Ember.pro, EmberCL.pro: Add CONFIG += plugin, otherwise it wouldn't link.
-EmberCL.pro: Add new files for multi-GPU support.
-build_all.sh: use -j4 and QMAKE=${QMAKE:/usr/bin/qmake}
-shared_settings.pri:
-Add version string.
-Remove old DESTDIR definitions.
-Add the following lines or else nothing would build:
CONFIG(release, debug|release) {
CONFIG += warn_off
DESTDIR = ../../../Bin/release
}
CONFIG(debug, debug|release) {
DESTDIR = ../../../Bin/debug
}
QMAKE_POST_LINK += $$quote(cp --update ../../../Data/flam3-palettes.xml $${DESTDIR}$$escape_expand(\n\t))
LIBS += -L/usr/lib -lpthread
-AboutDialog.ui: Another futile attempt to make it look correct on Linux.
-FinalRenderDialog.h/cpp:
--Add support for multi-GPU.
--Change from combo boxes for device selection to a table of all devices.
--Ensure device selection makes sense.
--Remove "FinalRender" prefix of various function names, it's implied given the context.
-FinalRenderEmberController.h/cpp:
--Add support for multi-GPU.
--Change m_FinishedImageCount to be atomic.
--Move CancelRender() from the base to FinalRenderEmberController<T>.
--Refactor RenderComplete() to omit any progress related functionality or image saving since it can be potentially ran in a thread.
--Consolidate setting various renderer fields into SyncGuiToRenderer().
-Fractorium.cpp: Allow for resizing of the options dialog to show the entire device table.
-FractoriumCommon.h: Add various functions to handle a table showing the available OpenCL devices on the system.
-FractoriumEmberController.h/cpp: Remove m_FinalImageIndex, it's no longer needed.
-FractoriumRender.cpp: Scale the interactive sub batch count and quality by the number of devices used.
-FractoriumSettings.h/cpp:
--Temporal samples defaults to 100 instead of 1000 which was needless overkill.
--Add multi-GPU support, remove old device,platform pair.
-FractoriumToolbar.cpp: Disable OpenCL toolbar button if there are no devices present on the system.
-FractoriumOptionsDialog.h/cpp:
--Add support for multi-GPU.
--Consolidate more assignments in DataToGui().
--Enable/disable CPU/OpenCL items in response to OpenCL checkbox event.
-Misc: Convert almost everything to size_t for unsigned, intmax_t for signed.
2015-09-12 21:33:45 -04:00
vector < size_t > m_Devices ;
vector < Eob * > m_BoolArgs ;
vector < Eoi * > m_IntArgs ;
vector < Eou * > m_UintArgs ;
vector < Eod * > m_DoubleArgs ;
vector < Eos * > m_StringArgs ;
2014-07-08 03:11:14 -04:00
} ;