Skip to content

Commit

Permalink
Fix SerializationUtils clone issue of QuantizedTensor (intel-analytic…
Browse files Browse the repository at this point in the history
…s#3088)

* update get extra param

* add test

* add check

* fix clone parameter

* fix test

* fix test

* update clone quantizedtensor

* update
  • Loading branch information
jenniew authored Dec 2, 2020
1 parent fa9be7f commit 472422e
Showing 1 changed file with 25 additions and 2 deletions.
27 changes: 25 additions & 2 deletions dl/src/main/scala/com/intel/analytics/bigdl/common/Util.scala
Original file line number Diff line number Diff line change
Expand Up @@ -298,8 +298,31 @@ object Util {
val param = parameters(i)
param.getTensorType match {
case QuantizedType =>
retParams(i) = SerializationUtils.clone(param).asInstanceOf[QuantizedTensor[T]]
case _ =>
val quantizedTensor = param.asInstanceOf[QuantizedTensor[T]]
val storage = new Array[Byte](quantizedTensor.nElement())
System.arraycopy(quantizedTensor.getStorage, 0,
storage, 0, quantizedTensor.nElement())

val sizeLength = quantizedTensor.size.length
val size = new Array[Int](sizeLength)
System.arraycopy(quantizedTensor.size, 0, size, 0, sizeLength)

val params = quantizedTensor.params.copy()

val length = quantizedTensor.maxOfRow.length
val maxOfRow = new Array[T](length)
System.arraycopy(quantizedTensor.maxOfRow, 0, maxOfRow, 0, length)

val minOfRow = new Array[T](length)
System.arraycopy(quantizedTensor.minOfRow, 0, minOfRow, 0, length)

val sumOfRow = new Array[T](length)
System.arraycopy(quantizedTensor.sumOfRow, 0, sumOfRow, 0, length)

retParams(i) = QuantizedTensor[T](storage, maxOfRow, minOfRow, sumOfRow, size,
params)

case _ =>
retParams(i) = if (isCompacted) {
Tensor[T](resultStorage, param.storageOffset(), param.size(), param.stride())
} else {
Expand Down

0 comments on commit 472422e

Please sign in to comment.