blob: a39ee44c2cc068a8716da35f757c7db8849ee7fb [file] [log] [blame] [edit]
/*
* Copyright 2012 ZXing authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#import "ZXModulusGF.h"
#import "ZXModulusPoly.h"
#import "ZXPDF417Common.h"
@interface ZXModulusGF ()
@property (nonatomic, strong) NSMutableArray *expTable;
@property (nonatomic, strong) NSMutableArray *logTable;
@property (nonatomic, assign) int modulus;
@end
@implementation ZXModulusGF
+ (ZXModulusGF *)PDF417_GF {
return [[ZXModulusGF alloc] initWithModulus:ZXPDF417_NUMBER_OF_CODEWORDS generator:3];
}
- (id)initWithModulus:(int)modulus generator:(int)generator {
if (self = [super init]) {
_modulus = modulus;
_expTable = [NSMutableArray arrayWithCapacity:self.modulus];
_logTable = [NSMutableArray arrayWithCapacity:self.modulus];
int x = 1;
for (int i = 0; i < modulus; i++) {
[_expTable addObject:@(x)];
x = (x * generator) % modulus;
}
for (int i = 0; i < self.size; i++) {
[_logTable addObject:@0];
}
for (int i = 0; i < self.size - 1; i++) {
_logTable[[_expTable[i] intValue]] = @(i);
}
// logTable[0] == 0 but this should never be used
int zeroInt = 0;
_zero = [[ZXModulusPoly alloc] initWithField:self coefficients:&zeroInt coefficientsLen:1];
int oneInt = 1;
_one = [[ZXModulusPoly alloc] initWithField:self coefficients:&oneInt coefficientsLen:1];
}
return self;
}
- (ZXModulusPoly *)buildMonomial:(int)degree coefficient:(int)coefficient {
if (degree < 0) {
[NSException raise:NSInvalidArgumentException format:@"Degree must be greater than 0."];
}
if (coefficient == 0) {
return self.zero;
}
int coefficientsLen = degree + 1;
int coefficients[coefficientsLen];
coefficients[0] = coefficient;
for (int i = 1; i < coefficientsLen; i++) {
coefficients[i] = 0;
}
return [[ZXModulusPoly alloc] initWithField:self coefficients:coefficients coefficientsLen:coefficientsLen];
}
- (int)add:(int)a b:(int)b {
return (a + b) % self.modulus;
}
- (int)subtract:(int)a b:(int)b {
return (self.modulus + a - b) % self.modulus;
}
- (int)exp:(int)a {
return [self.expTable[a] intValue];
}
- (int)log:(int)a {
if (a == 0) {
[NSException raise:NSInvalidArgumentException format:@"Argument must be non-zero."];
}
return [self.logTable[a] intValue];
}
- (int)inverse:(int)a {
if (a == 0) {
[NSException raise:NSInvalidArgumentException format:@"Argument must be non-zero."];
}
return [self.expTable[self.size - [self.logTable[a] intValue] - 1] intValue];
}
- (int)multiply:(int)a b:(int)b {
if (a == 0 || b == 0) {
return 0;
}
int logSum = [self.logTable[a] intValue] + [self.logTable[b] intValue];
return [self.expTable[logSum % (self.modulus - 1)] intValue];
}
- (int)size {
return self.modulus;
}
@end