BigInt implementation #81

Merged
pklimai merged 3 commits from big-int into dev 2020-04-26 20:08:32 +03:00
2 changed files with 1002 additions and 0 deletions

View File

@ -0,0 +1,459 @@
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
package scientifik.kmath.operations
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
import kotlin.math.log2
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
import kotlin.math.max
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
import kotlin.math.min
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
import kotlin.math.sign
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
/*
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
* Kotlin Multiplatform implementation of Big Integer numbers (KBigInteger).
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
* Initial version from https://github.com/robdrynkin/kotlin-big-integer
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
*/
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
@kotlin.ExperimentalUnsignedTypes
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
typealias Magnitude = UIntArray
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
@kotlin.ExperimentalUnsignedTypes
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
typealias TBase = ULong
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
object KBigIntegerRing: Ring<KBigInteger> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override val zero: KBigInteger = KBigInteger.ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override val one: KBigInteger = KBigInteger.ONE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override fun add(a: KBigInteger, b: KBigInteger): KBigInteger = a.plus(b)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override fun multiply(a: KBigInteger, k: Number): KBigInteger = a.times(k.toLong())
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override fun multiply(a: KBigInteger, b: KBigInteger): KBigInteger = a.times(b)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun String.unaryPlus(): KBigInteger = this.toKBigInteger()!!
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun String.unaryMinus(): KBigInteger = -this.toKBigInteger()!!
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
@kotlin.ExperimentalUnsignedTypes
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
class KBigInteger internal constructor(
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private val sign: Byte = 0,
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private val magnitude: Magnitude = Magnitude(0)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
): Comparable<KBigInteger> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
constructor(x: Int) : this(x.sign.toByte(), uintArrayOf(kotlin.math.abs(x).toUInt()))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
constructor(x: Long) : this(x.sign.toByte(), stripLeadingZeros(uintArrayOf(
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
(kotlin.math.abs(x).toULong() and BASE).toUInt(),
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
((kotlin.math.abs(x).toULong() shr BASE_SIZE) and BASE).toUInt())))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override fun compareTo(other: KBigInteger): Int {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
(this.sign == 0.toByte()) and (other.sign == 0.toByte()) -> 0
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this.sign < other.sign -> -1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this.sign > other.sign -> 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> this.sign * compareMagnitudes(this.magnitude, other.magnitude)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override fun equals(other: Any?): Boolean {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (other is KBigInteger) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return this.compareTo(other) == 0
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else error("Can't compare KBigInteger to a different type")
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override fun hashCode(): Int {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return magnitude.hashCode() + this.sign
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
fun abs(): KBigInteger = if (sign == 0.toByte()) this else KBigInteger(1, magnitude)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun unaryMinus(): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return if (this.sign == 0.toByte()) this else KBigInteger((-this.sign).toByte(), this.magnitude)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun plus(b: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
b.sign == 0.toByte() -> this
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this.sign == 0.toByte() -> b
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this == -b -> ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this.sign == b.sign -> KBigInteger(this.sign, addMagnitudes(this.magnitude, b.magnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val comp: Int = compareMagnitudes(this.magnitude, b.magnitude)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (comp == 1) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
KBigInteger(this.sign, subtractMagnitudes(this.magnitude, b.magnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
} else {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
KBigInteger((-this.sign).toByte(), subtractMagnitudes(b.magnitude, this.magnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun minus(b: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return this + (-b)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun times(b: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this.sign == 0.toByte() -> ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
b.sign == 0.toByte() -> ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
// TODO: Karatsuba
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> KBigInteger((this.sign * b.sign).toByte(), multiplyMagnitudes(this.magnitude, b.magnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun times(other: UInt): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this.sign == 0.toByte() -> ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
other == 0U -> ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> KBigInteger(this.sign, multiplyMagnitudeByUInt(this.magnitude, other))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun times(other: Int): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return if (other > 0)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this * kotlin.math.abs(other).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
-this * kotlin.math.abs(other).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun div(other: UInt): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return KBigInteger(this.sign, divideMagnitudeByUInt(this.magnitude, other))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun div(other: Int): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return KBigInteger((this.sign * other.sign).toByte(),
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
divideMagnitudeByUInt(this.magnitude, kotlin.math.abs(other).toUInt()))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private fun division(other: KBigInteger): Pair<KBigInteger, KBigInteger> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
// Long division algorithm:
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
// https://en.wikipedia.org/wiki/Division_algorithm#Integer_division_(unsigned)_with_remainder
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
// TODO: Implement more effective algorithm
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var q: KBigInteger = ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var r: KBigInteger = ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val bitSize = (BASE_SIZE * (this.magnitude.size - 1) + log2(this.magnitude.last().toFloat() + 1)).toInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in bitSize downTo 0) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
r = r shl 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
r = r or ((abs(this) shr i) and ONE)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (r >= abs(other)) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
r -= abs(other)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
q += (ONE shl i)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return Pair(KBigInteger((this.sign * other.sign).toByte(), q.magnitude), r)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun div(other: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return this.division(other).first
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
infix fun shl(i: Int): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (this == ZERO) return ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (i == 0) return this
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val fullShifts = i / BASE_SIZE + 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val relShift = i % BASE_SIZE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val shiftLeft = {x: UInt -> if (relShift >= 32) 0U else x shl relShift}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val shiftRight = {x: UInt -> if (BASE_SIZE - relShift >= 32) 0U else x shr (BASE_SIZE - relShift)}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val newMagnitude: Magnitude = Magnitude(this.magnitude.size + fullShifts)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (j in this.magnitude.indices) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[j + fullShifts - 1] = shiftLeft(this.magnitude[j])
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (j != 0) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[j + fullShifts - 1] = newMagnitude[j + fullShifts - 1] or shiftRight(this.magnitude[j - 1])
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[this.magnitude.size + fullShifts - 1] = shiftRight(this.magnitude.last())
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return KBigInteger(this.sign, stripLeadingZeros(newMagnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
infix fun shr(i: Int): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (this == ZERO) return ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (i == 0) return this
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val fullShifts = i / BASE_SIZE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val relShift = i % BASE_SIZE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val shiftRight = {x: UInt -> if (relShift >= 32) 0U else x shr relShift}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val shiftLeft = {x: UInt -> if (BASE_SIZE - relShift >= 32) 0U else x shl (BASE_SIZE - relShift)}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (this.magnitude.size - fullShifts <= 0) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val newMagnitude: Magnitude = Magnitude(this.magnitude.size - fullShifts)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (j in fullShifts until this.magnitude.size) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[j - fullShifts] = shiftRight(this.magnitude[j])
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (j != this.magnitude.size - 1) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[j - fullShifts] = newMagnitude[j - fullShifts] or shiftLeft(this.magnitude[j + 1])
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return KBigInteger(this.sign, stripLeadingZeros(newMagnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
infix fun or(other: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (this == ZERO) return other;
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (other == ZERO) return this;
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val resSize = max(this.magnitude.size, other.magnitude.size)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val newMagnitude: Magnitude = Magnitude(resSize)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in 0 until resSize) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (i < this.magnitude.size) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[i] = newMagnitude[i] or this.magnitude[i]
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (i < other.magnitude.size) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[i] = newMagnitude[i] or other.magnitude[i]
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return KBigInteger(1, stripLeadingZeros(newMagnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
infix fun and(other: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if ((this == ZERO) or (other == ZERO)) return ZERO;
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val resSize = min(this.magnitude.size, other.magnitude.size)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val newMagnitude: Magnitude = Magnitude(resSize)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in 0 until resSize) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
newMagnitude[i] = this.magnitude[i] and other.magnitude[i]
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return KBigInteger(1, stripLeadingZeros(newMagnitude))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun rem(other: Int): Int {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val res = this - (this / other) * other
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return if (res == ZERO) 0 else res.sign * res.magnitude[0].toInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
operator fun rem(other: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return this - (this / other) * other
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
fun modPow(exponent: KBigInteger, m: KBigInteger): KBigInteger {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
exponent == ZERO -> ONE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
exponent % 2 == 1 -> (this * modPow(exponent - ONE, m)) % m
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val sqRoot = modPow(exponent / 2, m)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
(sqRoot * sqRoot) % m
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
override fun toString(): String {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (this.sign == 0.toByte()) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return "0x0"
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var res: String = if (this.sign == (-1).toByte()) "-0x" else "0x"
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var numberStarted = false
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in this.magnitude.size - 1 downTo 0) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (j in BASE_SIZE / 4 - 1 downTo 0) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val curByte = (this.magnitude[i] shr 4 * j) and 0xfU
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (numberStarted or (curByte != 0U)) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
numberStarted = true
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
res += hexMapping[curByte]
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return res
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
companion object {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
const val BASE = 0xffffffffUL
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
const val BASE_SIZE: Int = 32
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val ZERO: KBigInteger = KBigInteger()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val ONE: KBigInteger = KBigInteger(1)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private val hexMapping: HashMap<UInt, String> =
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
hashMapOf(
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
0U to "0", 1U to "1", 2U to "2", 3U to "3",
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
4U to "4", 5U to "5", 6U to "6", 7U to "7",
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
8U to "8", 9U to "9", 10U to "a", 11U to "b",
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
12U to "c", 13U to "d", 14U to "e", 15U to "f"
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
internal fun stripLeadingZeros(mag: Magnitude): Magnitude {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (mag.isEmpty() || mag.last() != 0U) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return mag
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var resSize: Int = mag.size - 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
while (mag[resSize] == 0U) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (resSize == 0)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
break
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
resSize -= 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return mag.sliceArray(IntRange(0, resSize))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private fun compareMagnitudes(mag1: Magnitude, mag2: Magnitude): Int {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
mag1.size > mag2.size -> return 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
mag1.size < mag2.size -> return -1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in mag1.size - 1 downTo 0) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (mag1[i] > mag2[i]) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
} else if (mag1[i] < mag2[i]) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return -1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return 0
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private fun addMagnitudes(mag1: Magnitude, mag2: Magnitude): Magnitude {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val resultLength: Int = max(mag1.size, mag2.size) + 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val result = Magnitude(resultLength)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var carry: TBase = 0UL
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in 0 until resultLength - 1) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val res = when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
i >= mag1.size -> mag2[i].toULong() + carry
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
i >= mag2.size -> mag1[i].toULong() + carry
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> mag1[i].toULong() + mag2[i].toULong() + carry
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[i] = (res and BASE).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
carry = (res shr BASE_SIZE)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[resultLength - 1] = carry.toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return stripLeadingZeros(result)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private fun subtractMagnitudes(mag1: Magnitude, mag2: Magnitude): Magnitude {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val resultLength: Int = mag1.size
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val result = Magnitude(resultLength)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var carry = 0L
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in 0 until resultLength) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var res: Long =
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (i < mag2.size) mag1[i].toLong() - mag2[i].toLong() - carry
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else mag1[i].toLong() - carry
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
carry = if (res < 0) 1 else 0
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
res += carry * (BASE + 1UL).toLong()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[i] = res.toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return stripLeadingZeros(result)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private fun multiplyMagnitudeByUInt(mag: Magnitude, x: UInt): Magnitude {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val resultLength: Int = mag.size + 1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val result = Magnitude(resultLength)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var carry: ULong = 0UL
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in mag.indices) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val cur: ULong = carry + mag[i].toULong() * x.toULong()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[i] = (cur and BASE.toULong()).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
carry = cur shr BASE_SIZE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[resultLength - 1] = (carry and BASE).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return stripLeadingZeros(result)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private fun multiplyMagnitudes(mag1: Magnitude, mag2: Magnitude): Magnitude {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val resultLength: Int = mag1.size + mag2.size
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val result = Magnitude(resultLength)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in mag1.indices) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var carry: ULong = 0UL
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (j in mag2.indices) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val cur: ULong = result[i + j].toULong() + mag1[i].toULong() * mag2[j].toULong() + carry
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[i + j] = (cur and BASE.toULong()).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
carry = cur shr BASE_SIZE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[i + mag2.size] = (carry and BASE).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return stripLeadingZeros(result)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
private fun divideMagnitudeByUInt(mag: Magnitude, x: UInt): Magnitude {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val resultLength: Int = mag.size
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val result = Magnitude(resultLength)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var carry: ULong = 0UL
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (i in mag.size - 1 downTo 0) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val cur: ULong = mag[i].toULong() + (carry shl BASE_SIZE)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
result[i] = (cur / x).toUInt()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
carry = cur % x
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return stripLeadingZeros(result)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
@kotlin.ExperimentalUnsignedTypes
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
fun abs(x: KBigInteger): KBigInteger = x.abs()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
@kotlin.ExperimentalUnsignedTypes
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
// Can't put it as constructor in class due to platform declaration clash with KBigInteger(Int)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
fun KBigInteger(x: UInt): KBigInteger
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
= KBigInteger(1, uintArrayOf(x))
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
@kotlin.ExperimentalUnsignedTypes
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
// Can't put it as constructor in class due to platform declaration clash with KBigInteger(Long)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
fun KBigInteger(x: ULong): KBigInteger
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
= KBigInteger(1,
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
KBigInteger.stripLeadingZeros(uintArrayOf(
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
(x and KBigInteger.BASE).toUInt(),
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
((x shr KBigInteger.BASE_SIZE) and KBigInteger.BASE).toUInt())
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val hexChToInt = hashMapOf(
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
'0' to 0, '1' to 1, '2' to 2, '3' to 3,
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
'4' to 4, '5' to 5, '6' to 6, '7' to 7,
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
'8' to 8, '9' to 9, 'A' to 10, 'B' to 11,
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
'C' to 12, 'D' to 13, 'E' to 14, 'F' to 15
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
// Returns None if a valid number can not be read from a string
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
fun String.toKBigInteger(): KBigInteger? {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val sign: Int
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val sPositive: String
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
when {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this[0] == '+' -> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
sign = +1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
sPositive = this.substring(1)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
this[0] == '-' -> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
sign = -1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
sPositive = this.substring(1)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else -> {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
sPositive = this
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
sign = +1
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var res = KBigInteger.ZERO
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
var digitValue = KBigInteger.ONE
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val sPositiveUpper = sPositive.toUpperCase()
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (sPositiveUpper.startsWith("0X")) { // hex representation
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val sHex = sPositiveUpper.substring(2)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (ch in sHex.reversed()) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (ch == '_') continue
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
res += digitValue * (hexChToInt[ch] ?: return null)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
digitValue *= KBigInteger(16)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
else { // decimal representation
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
val sDecimal = sPositiveUpper
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
for (ch in sDecimal.reversed()) {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (ch == '_') continue
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
if (ch !in '0'..'9') {
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return null
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
res += digitValue * (ch.toInt() - '0'.toInt())
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
digitValue *= KBigInteger(10)
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
return res * sign
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)
}
altavir commented 2020-04-09 17:45:31 +03:00 (Migrated from github.com)
Review

Why use whole Int for simple three way flag? Could it be replaced by boolean? Enum?

Why use whole `Int` for simple three way flag? Could it be replaced by boolean? Enum?
altavir commented 2020-04-09 17:47:11 +03:00 (Migrated from github.com)
Review

Move to private constructor and move parameter checks to auxiliary builders.

Move to private constructor and move parameter checks to auxiliary builders.
altavir commented 2020-04-09 17:56:20 +03:00 (Migrated from github.com)
Review

Companion should be last declaration in the class

Companion should be last declaration in the class
altavir commented 2020-04-09 18:03:02 +03:00 (Migrated from github.com)
Review

Also all internal values must be marked as private

Also all internal values must be marked as private
altavir commented 2020-04-09 18:03:38 +03:00 (Migrated from github.com)
Review

should be virtual if it is not performance-critical

should be virtual if it is not performance-critical
altavir commented 2020-04-09 18:15:40 +03:00 (Migrated from github.com)
Review

It does not make sense to make it RingElement since all operations are already class members.

It does not make sense to make it RingElement since all operations are already class members.
altavir commented 2020-04-09 18:17:05 +03:00 (Migrated from github.com)
Review

Refactor to String.toBigInteger()

Refactor to String.toBigInteger()
pklimai commented 2020-04-15 20:37:04 +03:00 (Migrated from github.com)
Review

Now using Byte for that

Now using Byte for that
Shimuuar commented 2020-04-15 22:25:06 +03:00 (Migrated from github.com)
Review

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?

Even byte is wasteful. Especially considering that my eat whole word due to alignment. Why not use 2-complement?
pklimai commented 2020-04-15 22:42:14 +03:00 (Migrated from github.com)
Review

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

This may be a good idea, but I suspect (performance) problems with 2-complement will appear when we try to operate with numbers of different length. At least the classical Java BigInt implementation stores magnitude and signum separately (http://developer.classpath.org/doc/java/math/BigInteger-source.html)

View File

@ -0,0 +1,543 @@
package scientifik.kmath.operations
import kotlin.test.Test
import kotlin.test.assertTrue
import kotlin.test.assertEquals
@kotlin.ExperimentalUnsignedTypes
class KBigIntegerConstructorTest {
@Test
fun testConstructorZero() {
assertEquals(KBigInteger(0), KBigInteger(0, uintArrayOf()))
}
@Test
fun testConstructor8() {
assertEquals(KBigInteger(8), KBigInteger(1, uintArrayOf(8U)))
}
@Test
fun testConstructor_0xffffffffaL() {
val x = KBigInteger(-0xffffffffaL)
val y = KBigInteger(-1, uintArrayOf(0xfffffffaU, 0xfU))
assertEquals(x, y)
}
}
@kotlin.ExperimentalUnsignedTypes
class KBigIntegerCompareTest {
@Test
fun testCompare1_2() {
val x = KBigInteger(1)
val y = KBigInteger(2)
assertTrue { x < y }
}
@Test
fun testCompare0_0() {
val x = KBigInteger(0)
val y = KBigInteger(0)
assertEquals(x, y)
}
@Test
fun testCompare1__2() {
val x = KBigInteger(1)
val y = KBigInteger(-2)
assertTrue { x > y }
}
@Test
fun testCompare_1__2() {
val x = KBigInteger(-1)
val y = KBigInteger(-2)
assertTrue { x > y }
}
@Test
fun testCompare_2__1() {
val x = KBigInteger(-2)
val y = KBigInteger(-1)
assertTrue { x < y }
}
@Test
fun testCompare12345_12345() {
val x = KBigInteger(12345)
val y = KBigInteger(12345)
assertEquals(x, y)
}
@Test
fun testEqualsWithLong() {
val x = KBigInteger(12345)
assertTrue { x == KBigInteger(12345L) }
}
@Test
fun testEqualsWithULong() {
val x = KBigInteger(12345)
assertTrue { x == KBigInteger(12345UL) }
}
@Test
fun testCompareBigNumbersGreater() {
val x = KBigInteger(0xfffffffffL)
val y = KBigInteger(0xffffffffaL)
assertTrue { x > y }
}
@Test
fun testCompareBigNumbersEqual() {
val x = KBigInteger(0xffffffffaL)
val y = KBigInteger(0xffffffffaL)
assertEquals(x, y)
}
@Test
fun testCompareBigNumbersLess() {
val x = KBigInteger(-0xffffffffaL)
val y = KBigInteger(0xffffffffaL)
assertTrue { x < y }
}
}
@kotlin.ExperimentalUnsignedTypes
class KBigIntegerOperationsTest {
@Test
fun testPlus_1_1() {
val x = KBigInteger(1)
val y = KBigInteger(1)
val res = x + y
val sum = KBigInteger(2)
assertEquals(sum, res)
}
@Test
fun testPlusBigNumbers() {
val x = KBigInteger(0x7fffffff)
val y = KBigInteger(0x7fffffff)
val z = KBigInteger(0x7fffffff)
val res = x + y + z
val sum = KBigInteger(1, uintArrayOf(0x7ffffffdU, 0x1U))
assertEquals(sum, res)
}
@Test
fun testUnaryMinus() {
val x = KBigInteger(1234)
val y = KBigInteger(-1234)
assertEquals(-x, y)
}
@Test
fun testMinus_2_1() {
val x = KBigInteger(2)
val y = KBigInteger(1)
val res = x - y
val sum = KBigInteger(1)
assertEquals(sum, res)
}
@Test
fun testMinus__2_1() {
val x = KBigInteger(-2)
val y = KBigInteger(1)
val res = x - y
val sum = KBigInteger(-3)
assertEquals(sum, res)
}
@Test
fun testMinus___2_1() {
val x = KBigInteger(-2)
val y = KBigInteger(1)
val res = -x - y
val sum = KBigInteger(1)
assertEquals(sum, res)
}
@Test
fun testMinusBigNumbers() {
val x = KBigInteger(12345)
val y = KBigInteger(0xffffffffaL)
val res = x - y
val sum = KBigInteger(-0xfffffcfc1L)
assertEquals(sum, res)
}
@Test
fun testMultiply_2_3() {
val x = KBigInteger(2)
val y = KBigInteger(3)
val res = x * y
val prod = KBigInteger(6)
assertEquals(prod, res)
}
@Test
fun testMultiply__2_3() {
val x = KBigInteger(-2)
val y = KBigInteger(3)
val res = x * y
val prod = KBigInteger(-6)
assertEquals(prod, res)
}
@Test
fun testMultiply_0xfff123_0xfff456() {
val x = KBigInteger(0xfff123)
val y = KBigInteger(0xfff456)
val res = x * y
val prod = KBigInteger(0xffe579ad5dc2L)
assertEquals(prod, res)
}
@Test
fun testMultiplyUInt_0xfff123_0xfff456() {
val x = KBigInteger(0xfff123)
val y = 0xfff456U
val res = x * y
val prod = KBigInteger(0xffe579ad5dc2L)
assertEquals(prod, res)
}
@Test
fun testMultiplyInt_0xfff123__0xfff456() {
val x = KBigInteger(0xfff123)
val y = -0xfff456
val res = x * y
val prod = KBigInteger(-0xffe579ad5dc2L)
assertEquals(prod, res)
}
@Test
fun testMultiply_0xffffffff_0xffffffff() {
val x = KBigInteger(0xffffffffL)
val y = KBigInteger(0xffffffffL)
val res = x * y
val prod = KBigInteger(0xfffffffe00000001UL)
assertEquals(prod, res)
}
@Test
fun test_shr_20() {
val x = KBigInteger(20)
assertEquals(KBigInteger(10), x shr 1)
}
@Test
fun test_shl_20() {
val x = KBigInteger(20)
assertEquals(KBigInteger(40), x shl 1)
}
@Test
fun test_shl_1_0() {
assertEquals(KBigInteger.ONE, KBigInteger.ONE shl 0)
}
@Test
fun test_shl_1_32() {
assertEquals(KBigInteger(0x100000000UL), KBigInteger.ONE shl 32)
}
@Test
fun test_shl_1_33() {
assertEquals(KBigInteger(0x200000000UL), KBigInteger.ONE shl 33)
}
@Test
fun test_shr_1_33_33() {
assertEquals(KBigInteger.ONE, (KBigInteger.ONE shl 33) shr 33)
}
@Test
fun test_shr_1_32() {
assertEquals(KBigInteger.ZERO, KBigInteger.ONE shr 32)
}
@Test
fun test_and_123_456() {
val x = KBigInteger(123)
val y = KBigInteger(456)
assertEquals(KBigInteger(72), x and y)
}
@Test
fun test_or_123_456() {
val x = KBigInteger(123)
val y = KBigInteger(456)
assertEquals(KBigInteger(507), x or y)
}
@Test
fun test_asd() {
assertEquals(KBigInteger.ONE, KBigInteger.ZERO or ((KBigInteger(20) shr 4) and KBigInteger.ONE))
}
@Test
fun test_square_0x11223344U_0xad2ffffdU_0x17eU() {
val num = KBigInteger(-1, uintArrayOf(0x11223344U, 0xad2ffffdU, 0x17eU ))
println(num)
val res = num * num
assertEquals(res, KBigInteger(1, uintArrayOf(0xb0542a10U, 0xbbd85bc8U, 0x2a1fa515U, 0x5069e03bU, 0x23c09U)))
}
@Test
fun testDivision_6_3() {
val x = KBigInteger(6)
val y = 3U
val res = x / y
val div = KBigInteger(2)
assertEquals(div, res)
}
@Test
fun testBigDivision_6_3() {
val x = KBigInteger(6)
val y = KBigInteger(3)
val res = x / y
val div = KBigInteger(2)
assertEquals(div, res)
}
@Test
fun testDivision_20__3() {
val x = KBigInteger(20)
val y = -3
val res = x / y
val div = KBigInteger(-6)
assertEquals(div, res)
}
@Test
fun testBigDivision_20__3() {
val x = KBigInteger(20)
val y = KBigInteger(-3)
val res = x / y
val div = KBigInteger(-6)
assertEquals(div, res)
}
@Test
fun testDivision_0xfffffffe00000001_0xffffffff() {
val x = KBigInteger(0xfffffffe00000001UL)
val y = 0xffffffffU
val res = x / y
val div = KBigInteger(0xffffffffL)
assertEquals(div, res)
}
@Test
fun testBigDivision_0xfffffffeabcdef01UL_0xfffffffeabc() {
val res = KBigInteger(0xfffffffeabcdef01UL) / KBigInteger(0xfffffffeabc)
assertEquals(res, KBigInteger(0x100000))
}
@Test
fun testBigDivision_0xfffffffe00000001_0xffffffff() {
val x = KBigInteger(0xfffffffe00000001UL)
val y = KBigInteger(0xffffffffU)
val res = x / y
val div = KBigInteger(0xffffffffL)
assertEquals(div, res)
}
@Test
fun testMod_20_3() {
val x = KBigInteger(20)
val y = 3
val res = x % y
val mod = 2
assertEquals(mod, res)
}
@Test
fun testBigMod_20_3() {
val x = KBigInteger(20)
val y = KBigInteger(3)
val res = x % y
val mod = KBigInteger(2)
assertEquals(mod, res)
}
@Test
fun testMod_0xfffffffe00000001_12345() {
val x = KBigInteger(0xfffffffe00000001UL)
val y = 12345
val res = x % y
val mod = 1980
assertEquals(mod, res)
}
@Test
fun testBigMod_0xfffffffe00000001_12345() {
val x = KBigInteger(0xfffffffe00000001UL)
val y = KBigInteger(12345)
val res = x % y
val mod = KBigInteger(1980)
assertEquals(mod, res)
}
@Test
fun testModPow_3_10_17() {
val x = KBigInteger(3)
val exp = KBigInteger(10)
val mod = KBigInteger(17)
val res = KBigInteger(8)
return assertEquals(res, x.modPow(exp, mod))
}
@Test
fun testModPowBigNumbers() {
val x = KBigInteger(0xfffffffeabcdef01UL)
val exp = KBigInteger(2)
val mod = KBigInteger(0xfffffffeabcUL)
val res = KBigInteger(0xc2253cde01)
return assertEquals(res, x.modPow(exp, mod))
}
@Test
fun testModBigNumbers() {
val x = KBigInteger(0xfffffffeabcdef01UL)
val mod = KBigInteger(0xfffffffeabcUL)
val res = KBigInteger(0xdef01)
return assertEquals(res, x % mod)
}
}
@kotlin.ExperimentalUnsignedTypes
class KBigIntegerConversionsTest {
@Test
fun testToString0x10() {
val x = KBigInteger(0x10)
assertEquals("0x10", x.toString())
}
@Test
fun testToString0x17ffffffd() {
val x = KBigInteger(0x17ffffffdL)
assertEquals("0x17ffffffd", x.toString())
}
@Test
fun testToString_0x17ead2ffffd() {
val x = KBigInteger(-0x17ead2ffffdL)
assertEquals("-0x17ead2ffffd", x.toString())
}
@Test
fun testToString_0x17ead2ffffd11223344() {
val x = KBigInteger(-1, uintArrayOf(0x11223344U, 0xad2ffffdU, 0x17eU ))
assertEquals("-0x17ead2ffffd11223344", x.toString())
}
@Test
fun testFromString_0x17ead2ffffd11223344() {
val x = "0x17ead2ffffd11223344".toKBigInteger()
assertEquals( "0x17ead2ffffd11223344", x.toString())
}
@Test
fun testFromString_7059135710711894913860() {
val x = "-7059135710711894913860".toKBigInteger()
assertEquals("-0x17ead2ffffd11223344", x.toString())
}
}
class KBigIntegerRingTest {
@Test
fun testKBigIntegerRingSum() {
val res = KBigIntegerRing {
KBigInteger(1_000L) * KBigInteger(1_000L)
}
assertEquals(res, KBigInteger(1_000_000) )
}
@Test
fun testKBigIntegerRingSum_100_000_000__100_000_000() {
KBigIntegerRing {
val sum = +"100_000_000" + +"100_000_000"
assertEquals(sum, "200_000_000".toKBigInteger())
}
}
@Test
fun test_mul_3__4() {
KBigIntegerRing {
val prod = +"0x3000_0000_0000" * +"0x4000_0000_0000_0000_0000"
assertEquals(prod, "0xc00_0000_0000_0000_0000_0000_0000_0000".toKBigInteger())
}
}
@Test
fun test_div_big_1() {
KBigIntegerRing {
val res = +"1_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000" /
+"555_000_444_000_333_000_222_000_111_000_999_001"
assertEquals(res, +"1801800360360432432518919022699")
}
}
@Test
fun test_rem_big_1() {
KBigIntegerRing {
val res = +"1_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000_000" %
+"555_000_444_000_333_000_222_000_111_000_999_001"
assertEquals(res, +"324121220440768000291647788404676301")
}
}
}