TensorFlow 2.4.0
Release 2.4.0
Major Features and Improvements
- 
tf.distributeintroduces experimental support for asynchronous training of models via thetf.distribute.experimental.ParameterServerStrategyAPI. Please see the tutorial to learn more.
- 
MultiWorkerMirroredStrategyis now a stable API and is no longer considered experimental. Some of the major improvements involve handling peer failure and many bug fixes. Please check out the detailed tutorial on Multi-worker training with Keras.
- 
Introduces experimental support for a new module named tf.experimental.numpywhich is a NumPy-compatible API for writing TF programs. See the detailed guide to learn more. Additional details below.
- 
Adds Support for 
 TensorFloat-32 on Ampere based GPUs. TensorFloat-32, or TF32 for short, is a math mode for NVIDIA Ampere based GPUs and is enabled by default.
- 
A major refactoring of the internals of the Keras Functional API has been completed, that should improve the reliability, stability, and performance of constructing Functional models. 
- 
Keras mixed precision API tf.keras.mixed_precisionis no longer experimental and allows the use of 16-bit floating point formats during training, improving performance by up to 3x on GPUs and 60% on TPUs. Please see below for additional details.
- 
TensorFlow Profiler now supports profiling MultiWorkerMirroredStrategyand tracing multiple workers using the sampling mode API.
- 
TFLite Profiler for Android is available. See the detailed guide to learn more. 
- 
TensorFlow pip packages are now built with CUDA11 and cuDNN 8.0.2. 
Breaking Changes
- 
TF Core: - Certain float32 ops run in lower precsion on Ampere based GPUs, including  matmuls and convolutions, due to the use of TensorFloat-32. Specifically, inputs to such ops are rounded from 23 bits of precision to 10
 bits of precision. This is unlikely to cause issues in practice for deep learning models. In some cases, TensorFloat-32 is also used for complex64 ops.
 TensorFloat-32 can be disabled by runningtf.config.experimental.enable_tensor_float_32_execution(False).
- The byte layout for string tensors across the C-API has been updated to match TF Core/C++; i.e., a contiguous array of tensorflow::tstring/TF_TStrings.
- C-API functions TF_StringDecode,TF_StringEncode, andTF_StringEncodedSizeare no longer relevant and have been removed; seecore/platform/ctstring.hfor string access/modification in C.
- tensorflow.python,- tensorflow.coreand- tensorflow.compilermodules are now hidden. These modules are not part of TensorFlow public API.
- tf.raw_ops.Maxand- tf.raw_ops.Minno longer accept inputs of type- tf.complex64or- tf.complex128, because the behavior of these ops is not well defined for complex types.
- XLA:CPU and XLA:GPU devices are no longer registered by default. Use TF_XLA_FLAGS=--tf_xla_enable_xla_devicesif you really need them, but this flag will eventually be removed in subsequent releases.
 
- Certain float32 ops run in lower precsion on Ampere based GPUs, including  matmuls and convolutions, due to the use of TensorFloat-32. Specifically, inputs to such ops are rounded from 23 bits of precision to 10
- 
tf.keras:- The steps_per_executionargument inmodel.compile()is no longer experimental; if you were passingexperimental_steps_per_execution, rename it tosteps_per_executionin your code. This argument controls the number of batches to run during eachtf.functioncall when callingmodel.fit(). Running multiple batches inside a singletf.functioncall can greatly improve performance on TPUs or small models with a large Python overhead.
- A major refactoring of the internals of the Keras Functional API may affect code that
 is relying on certain internal details:- Code that uses isinstance(x, tf.Tensor)instead oftf.is_tensorwhen checking Keras symbolic inputs/outputs should switch to usingtf.is_tensor.
- Code that is overly dependent on the exact names attached to symbolic tensors (e.g. assumes there will be ":0" at the end of the inputs, treats names as unique identifiers instead of using tensor.ref(), etc.) may break.
- Code that uses full path for get_concrete_functionto trace Keras symbolic inputs directly should switch to building matchingtf.TensorSpecs directly and tracing theTensorSpecobjects.
- Code that relies on the exact number and names of the op layers that TensorFlow operations were converted into may have changed.
- Code that uses tf.map_fn/tf.cond/tf.while_loop/control flow as op layers and happens to work before TF 2.4. These will explicitly be unsupported now. Converting these ops to Functional API op layers was unreliable before TF 2.4, and prone to erroring incomprehensibly or being silently buggy.
- Code that directly asserts on a Keras symbolic value in cases where ops like tf.rankused to return a static or symbolic value depending on if the input had a fully static shape or not. Now these ops always return symbolic values.
- Code already susceptible to leaking tensors outside of graphs becomes slightly more likely to do so now.
- Code that tries directly getting gradients with respect to symbolic Keras inputs/outputs. Use GradientTapeon the actual Tensors passed to the already-constructed model instead.
- Code that requires very tricky shape manipulation via converted op layers in order to work, where the Keras symbolic shape inference proves insufficient.
- Code that tries manually walking a tf.keras.Modellayer by layer and assumes layers only ever have one positional argument. This assumption doesn't hold true before TF 2.4 either, but is more likely to cause issues now.
- Code that manually enters keras.backend.get_graph()before building a functional model is no longer needed.
- Start enforcing input shape assumptions when calling Functional API Keras models. This may potentially break some users, in case there is a mismatch             between the shape used when creating Inputobjects in a Functional model, and the shape of the data passed to that model. You can fix this mismatch by either calling the model with correctly-shaped data, or by relaxingInputshape assumptions (note that you can pass shapes withNoneentries for axes
 that are meant to be dynamic). You can also disable the input checking entirely by settingmodel.input_spec = None.
 
- Code that uses 
- Several changes have been made to tf.keras.mixed_precision.experimental. Note that it is now recommended to use the non-experimentaltf.keras.mixed_precisionAPI.
- AutoCastVariable.dtypenow refers to the actual variable dtype, not the dtype it will be casted to.
- When mixed precision is enabled, tf.keras.layers.Embeddingnow outputs a float16 or bfloat16 tensor instead of a float32 tensor.
- The property tf.keras.mixed_precision.experimental.LossScaleOptimizer.loss_scaleis now a tensor, not aLossScaleobject. This means to get a loss scale of aLossScaleOptimizeras a tensor, you must now callopt.loss_scaleinstead ofopt.loss_scale().
- The property should_cast_variableshas been removed fromtf.keras.mixed_precision.experimental.Policy
- When passing a tf.mixed_precision.experimental.DynamicLossScaletotf.keras.mixed_precision.experimental.LossScaleOptimizer, theDynamicLossScale's multiplier must be 2.
- When passing a tf.mixed_precision.experimental.DynamicLossScaletotf.keras.mixed_precision.experimental.LossScaleOptimizer, the weights of
 theDynanmicLossScaleare copied into theLossScaleOptimizerinstead of being reused. This means modifying the weights of theDynamicLossScalewill no longer affect the weights of the LossScaleOptimizer, and vice versa.
- The global policy can no longer be set to a non-floating point policy in tf.keras.mixed_precision.experimental.set_policy
- In Layer.call,AutoCastVariables will no longer be casted withinMirroredStrategy.runorReplicaContext.merge_call. This is because a thread local variable is used to determine whetherAutoCastVariables are casted, and those two functions run with a different thread. Note this only applies if one of these two functions is called withinLayer.call; if one of those two functions callsLayer.call,AutoCastVariables will still be casted.
 
- The 
- 
tf.data:- tf.data.experimental.service.DispatchServernow takes a config tuple instead of individual arguments. Usages should be updated to- tf.data.experimental.service.DispatchServer(dispatcher_config).
- tf.data.experimental.service.WorkerServernow takes a config tuple instead of individual arguments. Usages should be updated to- tf.data.experimental.service.WorkerServer(worker_config).
 
- 
tf.distribute:- Removes tf.distribute.Strategy.experimental_make_numpy_dataset. Please usetf.data.Dataset.from_tensor_slicesinstead.
- Renames experimental_hintsintf.distribute.StrategyExtended.reduce_to,tf.distribute.StrategyExtended.batch_reduce_to,tf.distribute.ReplicaContext.all_reducetooptions.
- Renames tf.distribute.experimental.CollectiveHintstotf.distribute.experimental.CommunicationOptions.
- Renames tf.distribute.experimental.CollectiveCommunicationtotf.distribute.experimental.CommunicationImplementation.
- Renames tf.distribute.Strategy.experimental_distribute_datasets_from_functiontodistribute_datasets_from_functionas it is no longer experimental.
- Removes tf.distribute.Strategy.experimental_run_v2method, which was deprecated in TF 2.2.
 
- Removes 
- 
tf.lite:- tf.quantization.quantize_and_dequantize_v2has been introduced, which updates the gradient definition for quantization which is outside the range
 to be 0. To simulate the V1 the behavior of- tf.quantization.quantize_and_dequantize(...)use- tf.grad_pass_through(tf.quantization.quantize_and_dequantize_v2)(...).
 
- 
Building TensorFlow: - Windows platform builds: TensorFlow on Windows under MSVC is now built with --copt=/experimental:preprocessor --host_copt=/experimental:preprocessor(see.bazelrcfor more details). Builds including TensorFlow may fail with unexpected syntax errors if these flags are absent. See also this thread on SIG Build.
 
- Windows platform builds: TensorFlow on Windows under MSVC is now built with 
Known Caveats
- tf.keras.mixed_precision- When using mixed precision, calling RMSprop.apply_gradientsorNadam.apply_gradientsoutside atf.functiondoes not work and will raise the AttributeError "Tensor.op is meaningless when eager execution is enabled". See this issue for details and a workaround.
 
- When using mixed precision, calling 
Bug Fixes and Other Changes
TF Core:
- Introduces experimental support for a new module named tf.experimental.numpy, which
 is a NumPy-compatible API for writing TF programs. This module provides classndarray, which mimics thendarrayclass in NumPy, and wraps an immutabletf.Tensorunder the hood. A subset of NumPy functions (e.g.numpy.add) are provided. Their inter-operation with TF facilities is seamless in most cases.
 See tensorflow/python/ops/numpy_ops/README.md
 for details of what operations are supported and what are the differences from NumPy.
- tf.types.experimental.TensorLikeis a new- Uniontype that can be used as type annotation for variables representing a Tensor or a value
 that can be converted to Tensor by- tf.convert_to_tensor.
- Calling ops with a python constants or numpy values is now consistent with tf.convert_to_tensor behavior. This avoids operations like
 tf.reshape truncating inputs such as from int64 to int32.
- Adds tf.sparse.map_valuesto apply a function to the.values ofSparseTensorarguments.
- The Python bitwise operators for Tensor(__and__,__or__,__xor__and__invert__now support non-boolarguments and apply
 the corresponding bitwise ops.boolarguments continue to be supported and dispatch to logical ops. This brings them more in line with
 Python and NumPy behavior.
- Adds tf.SparseTensor.with_values. This returns a new SparseTensor with the same sparsity pattern, but with new provided values. It is
 similar to thewith_valuesfunction ofRaggedTensor.
- Adds StatelessCaseop, and uses it if none of case branches has stateful ops.
- Adds tf.config.experimental.get_memory_usageto return total memory usage of the device.
- Adds gradients for RaggedTensorToVariantandRaggedTensorFromVariant.
- Improve shape inference of nested function calls by supporting constant folding across Arg nodes which makes more static values available to shape inference functions.
- tf.debugging:- tf.debugging.assert_shapes()now works on- SparseTensors (Fixes #36268).
 
- GPU
- Adds Support for TensorFloat-32 on Ampere based GPUs.
 TensorFloat-32, or TF32 for short, is a math mode for NVIDIA Ampere based GPUs which causes certain float32 ops, such as matrix
 multiplications and convolutions, to run much faster on Ampere GPUs but with reduced precision. This reduced precision has not been found
 to effect convergence quality of deep learning models in practice. TensorFloat-32 is enabled by default, but can be disabled withtf.config.experimental.enable_tensor_float_32_execution.
 
- Adds Support for TensorFloat-32 on Ampere based GPUs.
- tf.math:- Adds tf.math.erfcinv, the inverse totf.math.erfc.
 
- Adds 
- tf.nn:- tf.nn.max_pool2dnow supports explicit padding.
 
- tf.image:- Adds deterministic tf.image.stateless_random_*functions for eachtf.image.random_*function. Added a new opstateless_sample_distorted_bounding_boxwhich is a deterministic version ofsample_distorted_bounding_boxop. Given the same seed, these stateless functions/ops produce the same results independent of how many times the function is called, and independent of global seed settings.
- Adds deterministic tf.image.resizebackprop CUDA kernels formethod=ResizeMethod.BILINEAR(the default method). Enable by setting the environment variableTF_DETERMINISTIC_OPSto"true"or"1".
 
- Adds deterministic 
- tf.print:- Bug fix in tf.print()withOrderedDictwhere if anOrderedDictdidn't have the keys sorted, the keys and values were not being printed
 in accordance with their correct mapping.
 
- Bug fix in 
- tf.train.Checkpoint:- Now accepts a rootargument in the initialization, which generates a checkpoint with a root object. This allows users to create aCheckpointobject that is compatible with Kerasmodel.save_weights()andmodel.load_weights. The checkpoint is also compatible with the checkpoint saved in thevariables/folder in the SavedModel.
- When restoring, save_pathcan be a path to a SavedModel. The function will automatically find the checkpoint in the SavedModel.
 
- Now accepts a 
tf.data:
- Adds new tf.data.experimental.service.register_datasetandtf.data.experimental.service.from_dataset_idAPIs to enable one
 process to register a dataset with the tf.data service, and another process to consume data from the dataset.
- Adds support for dispatcher fault tolerance. To enable fault tolerance, configure a work_dirwhen running your dispatcher server and set
 dispatcher_fault_tolerance=True. The dispatcher will store its state towork_dir, so that on restart it can continue from its previous
 state after restart.
- Adds support for sharing dataset graphs via shared filesystem instead of over RPC. This reduces load on the dispatcher, improving performance
 of distributing datasets. For this to work, the dispatcher'swork_dirmust be accessible from workers. If the worker fails to read from the
 work_dir, it falls back to using RPC for dataset graph transfer.
- Adds support for a new "distributed_epoch" processing mode. This processing mode distributes a dataset across all tf.data workers,
 instead of having each worker process the full dataset. See the tf.data service docs to learn more.
- Adds optional exclude_colsparameter to CsvDataset. This parameter is the complement ofselect_cols; at most one of these should be specified.
- We have implemented an optimization which reorders data-discarding transformations such as takeandshardto happen earlier in the dataset when it is safe to do so. The optimization can be disabled via theexperimental_optimization.reorder_data_discarding_opsdataset option.
- tf.data.Optionswere previously immutable and can now be overridden.
- tf.data.Dataset.from_generatornow supports Ragged and Sparse tensors with a new- output_signatureargument, which allows- from_generatorto
 produce any type describable by a- tf.TypeSpec.
- tf.data.experimental.AUTOTUNEis now available in the core API as- tf.data.AUTOTUNE.
tf.distribute:
- Introduces experimental support for asynchronous training of models via tf.distribute.experimental.ParameterServerStrategy:- Replaces the existing tf.distribute.experimental.ParameterServerStrategysymbol with a new class that is for parameter server training in TF2. Usage of
 the old symbol, usually with Estimator API, should be replaced with [tf.compat.v1.distribute.experimental.ParameterServerStrategy].
- Added tf.distribute.experimental.coordinator.*namespace, including the main APIClusterCoordinatorfor coordinating the training cluster, the related data structureRemoteValueandPerWorkerValue.
 
- Replaces the existing 
- MultiWorkerMirroredStrategy](https://www.tensorflow.org/api_docs/python/tf/distribute/MultiWorkerMirroredStrategy) is now a stable API and is no longer considered experimental. Some of the major improvements involve handling peer failure and many bug fixes. Please check out the detailed tutorial on
 Multi-worer training with Keras.
- Adds tf.distribute.Strategy.gatherandtf.distribute.ReplicaContext.all_gatherAPIs to support gathering dense distributed values.
- Fixes various issues with saving a distributed model.
tf.keras:
- Improvements from the Functional API refactoring:
- Functional model construction does not need to maintain a global workspace graph, removing memory leaks especially when building many
 models or very large models.
- Functional model construction should be ~8-10% faster on average.
- Functional models can now contain non-symbolic values in their call inputs inside of the first positional argument.
- Several classes of TF ops that were not reliably converted to Keras layers during functional API construction should now work, e.g.
 tf.image.ssim_multiscale
- Error messages when Functional API construction goes wrong (and when ops cannot be converted to Keras layers automatically) should be
 clearer and easier to understand.
 
- Functional model construction does not need to maintain a global workspace graph, removing memory leaks especially when building many
- Optimizer.minimizecan now accept a loss- Tensorand a- GradientTapeas an alternative to accepting a- callableloss.
- Adds betahyperparameter to FTRL optimizer classes (Keras and others) to match FTRL paper.
- Optimizer.__init__now accepts a- gradient_aggregatorto allow for customization of how gradients are aggregated across devices, as well as- gradients_transformersto allow for custom gradient transformations (such as gradient clipping).
- Improvements to Keras preprocessing layers:
- TextVectorization can now accept a vocabulary list or file as an init arg.
- Normalization can now accept mean and variance values as init args.
 
- In AttentionandAdditiveAttentionlayers, thecall()method now accepts areturn_attention_scoresargument. When set to
 True, the layer returns the attention scores as an additional output argument.
- Adds tf.metrics.log_coshandtf.metrics.logcoshAPI entrypoints with the same implementation as theirtf.lossesequivalent.
- For Keras model, the individual call of Model.evaluateuses no cached data for evaluation, whileModel.fituses cached data whenvalidation_dataarg is provided for better performance.
- Adds a save_tracesargument tomodel.save/tf.keras.models.save_modelwhich determines whether the SavedModel format stores the Keras model/layer call functions. The traced functions allow Keras to revive custom models and layers without the original class definition, but if this isn't required the tracing can be disabled with the added option.
- The tf.keras.mixed_precisionAPI is now non-experimental. The non-experimental API differs from the experimental API in several ways.- tf.keras.mixed_precision.Policyno longer takes in a- tf.mixed_precision.experimental.LossScalein the constructor, and no longer has a- LossScaleassociated with it. Instead,- Model.compilewill automatically wrap the optimizer with a- LossScaleOptimizerusing dynamic loss scaling if- Policy.nameis "mixed_float16".
- tf.keras.mixed_precision.LossScaleOptimizer's constructor takes in different arguments. In particular, it no longer takes in a- LossScale, and there is no longer a- LossScaleassociated with the- LossScaleOptimizer. Instead,- LossScaleOptimizerdirectly implements fixed or dynamic loss scaling. See the documentation of- tf.keras.mixed_precision.experimental.LossScaleOptimizerfor details on the differences between the experimental- LossScaleOptimizerand the new non-experimental- LossScaleOptimizer.
- tf.mixed_precision.experimental.LossScaleand its subclasses are deprecated, as all of its functionality now exists within- tf.keras.mixed_precision.LossScaleOptimizer
 
tf.lite:
- TFLiteConverter:- Support optional flags inference_input_typeandinference_output_typefor full integer quantized models. This allows users to modify the model input and output type to integer types (tf.int8,tf.uint8) instead of defaulting to float type (tf.float32).
 
- Support optional flags 
- NNAPI
- Adds NNAPI Delegation support for requantization use cases by converting the operation into a dequantize-quantize pair.
- Removes deprecated Interpreter.setUseNNAPI(boolean)Java API. UseInterpreter.Options.setUseNNAPIinstead.
- Deprecates Interpreter::UseNNAPI(bool)C++ API. UseNnApiDelegate()and related delegate configuration methods directly.
- Deprecates Interpreter::SetAllowFp16PrecisionForFp32(bool)C++ API. Prefer controlling this via delegate options, e.g.tflite::StatefulNnApiDelegate::Options::allow_fp16' orTfLiteGpuDelegateOptionsV2::is_precision_loss_allowed`.
 
- GPU
- GPU acceleration now supports quantized models by default
 
- DynamicBuffer::AddJoinedString()will now add a separator if the first string to be joined is empty.
- Adds support for cumulative sum (cumsum), both as builtin op and MLIR conversion.
TensorRT
- Issues a warning when the session_configparameter for the TF1 converter is used or therewrite_config_templatefield in the TF2
 converter parameter object is used.
TPU Enhancements:
- Adds support for the betaparameter of the FTRL optimizer for TPU embeddings. Users of other TensorFlow platforms can implement equivalent
 behavior by adjusting thel2parameter.
XLA Support:
- xla.experimental.compile is deprecated, use tf.function(experimental_compile=True)instead.
- Adds tf.function.experimental_get_compiler_irwhich returns compiler IR (currently 'hlo' and 'optimized_hlo') for given input for given function.
Security:
- Fixes an undefined behavior causing a segfault in tf.raw_ops.Switch, (CVE-2020-15190)
- Fixes three vulnerabilities in conversion to DLPack format
- Fixes two vulnerabilities in SparseFillEmptyRowsGrad
- Fixes several vulnerabilities in RaggedCountSparseOutputandSparseCountSparseOutputoperations
- Fixes an integer truncation vulnerability in code using the work sharder API, (CVE-2020-15202)
- Fixes a format string vulnerability in tf.strings.as_string, (CVE-2020-15203)
- Fixes segfault raised by calling session-only ops in eager mode, (CVE-2020-15204)
- Fixes data leak and potential ASLR violation from tf.raw_ops.StringNGrams, (CVE-2020-15205)
- Fixes segfaults caused by incomplete SavedModelvalidation, (CVE-2020-15206)
- Fixes a data corruption due to a bug in negative indexing support in TFLite, (CVE-2020-15207)
- Fixes a data corruption due to dimension mismatch in TFLite, (CVE-2020-15208)
- Fixes several vulnerabilities in TFLite saved model format
- Fixes several vulnerabilities in TFLite implementation of segment sum
- Fixes a segfault in tf.quantization.quantize_and_dequantize, (CVE-2020-15265)
- Fixes an undefined behavior float cast causing a crash, (CVE-2020-15266)
- Fixes a lack of validation in tf.raw_ops.DataFormatVecPermuteandtf.raw_ops.DataFormatDimMapwhich can cause uninitialized memory access, read outside bounds of arrays, data corruption and segmentation faults (CVE-2020-26267)
- Fixes a crash caused by writing to read only memory region (CVE-2020-26268)
- Fixes a heap out of bounds access in filesystem globbing implementation (CVE-2020-26269)
Other:
- We have replaced uses of "whitelist" and "blacklist" with "allowlist" and "denylist" where possible. Please see this list for more context.
- Adds tf.config.experimental.mlir_bridge_rolloutwhich will help us rollout the new MLIR TPU bridge.
- Adds tf.experimental.register_filesystem_pluginto load modular filesystem plugins from Python
Thanks to our Contributors
This release contains contributions from many people at Google as well as the following external contributors:
8bitmp3, aaa.jq, Abhineet Choudhary, Abolfazl Shahbazi, acxz, Adam Hillier, Adrian Garcia Badaracco, Ag Ramesh, ahmedsabie, Alan Anderson, Alexander Grund, Alexandre Lissy, Alexey Ivanov, Amedeo Cavallo, anencore94, Aniket Kumar Singh, Anthony Platanios, Ashwin Phadke, Balint Cristian, Basit Ayantunde, bbbboom, Ben Barsdell, Benjamin Chetioui, Benjamin Peterson, bhack, Bhanu Prakash Bandaru Venkata, Biagio Montaruli, Brent M. Spell, bubblebooy, bzhao, cfRod, Cheng Chen, Cheng(Kit) Chen, Chris Tessum, Christian, chuanqiw, codeadmin_peritiae, COTASPAR, CuiYifeng, danielknobe, danielyou0230, dannyfriar, daria, DarrenZhang01, Denisa Roberts, dependabot[bot], Deven Desai, Dmitry Volodin, Dmitry Zakharov, drebain, Duncan Riach, Eduard Feicho, Ehsan Toosi, Elena Zhelezina, emlaprise2358, Eugene Kuznetsov, Evaderan-Lab, Evgeniy Polyakov, Fausto Morales, Felix Johnny, fo40225, Frederic Bastien, Fredrik Knutsson, fsx950223, Gaurav Singh, Gauri1 Deshpande, George Grzegorz Pawelczak, gerbauz, Gianluca Baratti, Giorgio Arena, Gmc2, Guozhong Zhuang, Hannes Achleitner, Harirai, HarisWang, Harsh188, hedgehog91, Hemal Mamtora, Hideto Ueno, Hugh Ku, Ian Beauregard, Ilya Persky, jacco, Jakub Beránek, Jan Jongboom, Javier Montalt Tordera, Jens Elofsson, Jerry Shih, jerryyin, jgehw, Jinjing Zhou, jma, jmsmdy, Johan Nordström, John Poole, Jonah Kohn, Jonathan Dekhtiar, jpodivin, Jung Daun, Kai Katsumata, Kaixi Hou, Kamil Rakoczy, Kaustubh Maske Patil, Kazuaki Ishizaki, Kedar Sovani, Koan-Sin Tan, Koki Ibukuro, Krzysztof Laskowski, Kushagra Sharma, Kushan Ahmadian, Lakshay Tokas, Leicong Li, levinxo, Lukas Geiger, Maderator, Mahmoud Abuzaina, Mao Yunfei, Marius Brehler, markf, Martin Hwasser, Martin Kubovčík, Matt Conley, Matthias, mazharul, mdfaijul, Michael137, MichelBr, Mikhail Startsev, Milan Straka, Ml-0, Myung-Hyun Kim, Måns Nilsson, Nathan Luehr, ngc92, nikochiko, Niranjan Hasabnis, nyagato_00, Oceania2018, Oleg Guba, Ongun Kanat, OscarVanL, Patrik Laurell, Paul Tanger, Peter Sobot, Phil Pearl, PlusPlusUltra, Poedator, Prasad Nikam, Rahul-Kamat, Rajeshwar Reddy T, redwrasse, Rickard, Robert Szczepanski, Rohan Lekhwani, Sam Holt, Sami Kama, Samuel Holt, Sandeep Giri, sboshin, Sean Settle, settle, Sharada Shiddibhavi, Shawn Presser, ShengYang1, Shi,Guangyong, Shuxiang Gao, Sicong Li, Sidong-Wei, Srihari Humbarwadi, Srinivasan Narayanamoorthy, Steenu Johnson, Steven Clarkson, stjohnso98, Tamas Bela Feher, Tamas Nyiri, Tarandeep Singh, Teng Lu, Thibaut Goetghebuer-Planchon, Tim Bradley, Tomasz Strejczek, Tongzhou Wang, Torsten Rudolf, Trent Lo, Ty Mick, Tzu-Wei Sung, Varghese, Jojimon, Vignesh Kothapalli, Vishakha Agrawal, Vividha, Vladimir Menshakov, Vladimir Silyaev, VoVAllen, Võ Văn Nghĩa, wondertx, xiaohong1031, Xiaoming (Jason) Cui, Xinan Jiang, Yair Ehrenwald, Yasir Modak, Yasuhiro Matsumoto, Yimei Sun, Yiwen Li, Yixing, Yoav Ramon, Yong Tang, Yong Wu, yuanbopeng, Yunmo Koo, Zhangqiang, Zhou Peng, ZhuBaohe, zilinzhu, zmx