KR100300357B1 - apparatus and method for generating walsh code in cdma communication system - Google Patents

apparatus and method for generating walsh code in cdma communication system Download PDF

Info

Publication number
KR100300357B1
KR100300357B1 KR1019990036172A KR19990036172A KR100300357B1 KR 100300357 B1 KR100300357 B1 KR 100300357B1 KR 1019990036172 A KR1019990036172 A KR 1019990036172A KR 19990036172 A KR19990036172 A KR 19990036172A KR 100300357 B1 KR100300357 B1 KR 100300357B1
Authority
KR
South Korea
Prior art keywords
orthogonal code
bits
chip
count value
index
Prior art date
Application number
KR1019990036172A
Other languages
Korean (ko)
Other versions
KR20000017625A (en
Inventor
김종돈
Original Assignee
윤종용
삼성전자 주식회사
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 윤종용, 삼성전자 주식회사 filed Critical 윤종용
Priority to KR1019990036172A priority Critical patent/KR100300357B1/en
Publication of KR20000017625A publication Critical patent/KR20000017625A/en
Application granted granted Critical
Publication of KR100300357B1 publication Critical patent/KR100300357B1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J13/00Code division multiplex systems
    • H04J13/10Code generation
    • H04J13/12Generation of orthogonal codes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J13/00Code division multiplex systems
    • H04J13/0007Code type
    • H04J13/004Orthogonal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J13/00Code division multiplex systems
    • H04J13/0007Code type
    • H04J13/004Orthogonal
    • H04J13/0048Walsh

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Mobile Radio Communication Systems (AREA)

Abstract

본 발명은 이동통신시스템에서 심볼 레이트에 따라 길이가 다른 직교부호를 생성할 수 있는 장치 및 방법에 관한 것으로, 가변하는 심볼 레이트에 대응한 직교부호 길이를 산출하여 유효 비트 수를 결정하고, 유효 비트 수의 이진부호로 변환한 직교부호 인덱스와 유효 비트 수로 카운트될 수 있는 최상 카운트 값까지 상기 칩 카운터 값을 순차적으로 발생하여 논리 연산을 통해 직교부호를 생성하는 이동통신시스템의 직교부호 생성장치 및 방법을 구현함을 특징으로 한다.The present invention relates to an apparatus and method for generating an orthogonal code having a different length according to a symbol rate in a mobile communication system. The present invention relates to an orthogonal code length corresponding to a variable symbol rate to determine an effective number of bits. Orthogonal code generation apparatus and method for generating an orthogonal code through a logical operation by generating the chip counter value sequentially up to the orthogonal code index converted to the number binary code and the highest count value that can be counted by the number of significant bits Characterized in that implements.

Description

이동 통신시스템에서 직교부호 생성장치 및 방법{apparatus and method for generating walsh code in cdma communication system}Apparatus and method for generating walsh code in cdma communication system}

본 발명은 이동 통신시스템의 직교부호 생성장치 및 방법에 관한 것으로, 다양한 심볼 레이트(symbol rate)에 따라 길이가 다른 직교부호를 생성하기 위한 장치 및 방법에 관한 것이다.The present invention relates to an apparatus and method for generating an orthogonal code in a mobile communication system, and to an apparatus and method for generating an orthogonal code having a different length according to various symbol rates.

통상적으로 직교부호는 채널의 확산 및 각 채널을 구분하는 식별자의 용도로 사용되는 부호를 말한다. IS-95 CDMA 방식을 이용한 종래의 송신기에서는 여러 채널간의 직교성을 유지하는 것과 함께 대역확산을 위하여 64 chip의 길이를 갖는 직교부호(Walsh code)를 사용하였다. 이는 송신기의 변조기(Modulator)에서 확산기로 입력되는 여러 채널들의 코드화된 데이터(coded data symbol)의 심볼 레이트가 모두 일정한 레이트(19.2kbps)로 유지되었기 때문에 단지 길이가 64chip인 직교부호를 이용하여 1.2288cpss의 레이트를 만들었다. 이를 실제 구현하는 방법으로는 64×64의 직교부호 테이블(Walsh code table)을 만들어 각 채널에 할당된 직교부호의 인덱스에 대응하는 직교부호를 상기 메모리 테이블로부터 읽어와 사용하는 방식이다.Orthogonal code generally refers to a code used for the spread of the channel and the purpose of the identifier for distinguishing each channel. In the conventional transmitter using the IS-95 CDMA scheme, a 64 chip length Walsh code is used for spreading the spectrum while maintaining orthogonality between channels. This is because the symbol rate of the coded data symbols of the various channels inputted from the transmitter's modulator to the spreader was all maintained at a constant rate (19.2 kbps), so it was only 1.2288 cpss using a 64-chip orthogonal code. Made the rate of In order to actually implement this method, a 64 × 64 Walsh code table is created and an orthogonal code corresponding to an index of an orthogonal code assigned to each channel is read and used from the memory table.

하지만 IMT-2000에 적용되는 CDMA2000과 같은 방식에서는 순방향 채널의 변조과정 중 확산기로 입력되어지는 심볼 레이트가 채널의 종류마다 서로 다르고 이에 따라 채널마다 길이가 다른 직교부호가 필요하게 된다.However, in the same method as CDMA2000 applied to the IMT-2000, the symbol rate input to the spreader during the modulation process of the forward channel is different for each type of channel, and accordingly, orthogonal codes having different lengths are required for each channel.

따라서, 종래의 방법으로 IMT-2000을 구현하기 위해 서로 다른 길이의 직교부호를 만들어 내려면 각 길이에 대응하는 직교부호 테이블을 따로 만들어서 사용해야 된다. 이를 실제 하드웨어적으로 구현할 경우 매우 많은 메모리가 요구되며, 다양한 심볼 레이트에 따른 길이가 다른 직교부호에 융통성 있게 대처하지 못하는 문제점이 있었다.Therefore, in order to generate orthogonal codes of different lengths in order to implement IMT-2000 according to the conventional method, an orthogonal code table corresponding to each length should be separately used. In the real hardware implementation, very much memory is required, and there is a problem in that it cannot flexibly cope with orthogonal codes having different lengths according to various symbol rates.

따라서 상기한 바와 같은 문제점을 해결하기 위한 본 발명의 목적은 이동 통신시스템에서 다양한 심볼 레이트에 따라 길이가 다른 직교부호를 생성하는 직교부호 생성장치 및 방법을 제공함에 있다.Accordingly, an object of the present invention is to provide an orthogonal code generation apparatus and method for generating orthogonal codes having different lengths according to various symbol rates in a mobile communication system.

본 발명의 다른 목적은 이동통신시스템에서 직교부호 인덱스 값과 칩 카운터 값을 가지고 직교부호를 생성하는 직교부호 생성장치 및 방법을 제공함에 있다.Another object of the present invention is to provide an orthogonal code generation apparatus and method for generating an orthogonal code having an orthogonal code index value and a chip counter value in a mobile communication system.

상기한 목적들을 달성하기 위한 이동통신시스템의 직교부호 생성장치가, 유효 비트 수와 직교부호 인덱스 및 칩 카운트 값을 각각 저장하는 레지스터를 가지는 메모리와, 상기 유효 비트 수로 카운트될 수 있는 최상 카운트 값까지 상기 칩 카운터 값을 순차적으로 발생하여 상기 칩 카운트 값으로 설정하고, 상기 직교부호 인덱스와 상기 칩 카운터 값들을 읽어 소정 논리 연산을 수행하여 직교부호를 생성하는 직교부호 생성부로 구성함을 특징으로 한다.An orthogonal code generating apparatus of a mobile communication system for achieving the above objects includes a memory having registers for storing a valid bit number, an orthogonal code index, and a chip count value, and up to a maximum count value that can be counted with the valid bit number. And an orthogonal code generation unit that generates the orthogonal code by sequentially generating the chip counter value and setting the chip counter value as the chip count value, reading the orthogonal code index and the chip counter values, and performing a predetermined logical operation.

상기 목적들을 달성하기 위한 이동통신시스템의 직교부호 생성방법이, 가변하는 심볼 레이트에 대응한 직교부호 길이를 산출하여 유효 비트 수를 결정하고, 유효 비트 수의 이진부호로 변환한 직교부호 인덱스와 유효 비트 수로 카운트될 수 있는 최상 카운트 값까지 상기 칩 카운터 값을 순차적으로 발생하여 논리 연산을 통해 직교부호를 생성하는 과정으로 이루어짐을 특징으로 한다.Orthogonal code generation method of the mobile communication system to achieve the above object, orthogonal code length corresponding to a variable symbol rate to determine the effective number of bits, and the orthogonal code index and the effective number converted to binary code of the effective number of bits The chip counter value is sequentially generated up to the highest count value that can be counted by the number of bits, and a quadrature code is generated through a logical operation.

도 1은 본 발명의 일 실시 예에 따른 이동통신시스템의 변조기(modulator) 구성을 도시한 도면.1 is a diagram illustrating a modulator configuration of a mobile communication system according to an embodiment of the present invention.

도 2는 본 발명의 일 실시 예에 따른 직교부호 생성 방법을 설명한 도면.2 is a diagram illustrating a method for generating an orthogonal code according to an embodiment of the present invention.

도 3은 도 1에서 도시한 직교부호 생성기의 일 예를 도시한 도면.3 is a diagram illustrating an example of an orthogonal code generator illustrated in FIG. 1.

이하 본 발명의 바람직한 실시 예를 첨부된 도면의 참조와 함께 상세히 설명한다.Hereinafter, exemplary embodiments of the present invention will be described in detail with reference to the accompanying drawings.

우선 각 도면의 구성요소들에 참조부호를 부가함에 있어서, 동일한 구성요소들에 한해서는 비록 다른 도면상에 표시되더라도 가능한 동일 부호를 가지도록 하였다. 또한 본 발명을 설명함에 있어서, 관련된 공지기능 혹은 구성에 대한 구체적인 설명이 본 발명의 요지를 불필요하게 흐릴 수 있다고 판단된 경우 그 상세한 설명은 생략한다.First, in adding the reference numerals to the components of each drawing, the same components have the same reference numerals as much as possible even if displayed on different drawings. In describing the present invention, when it is determined that a detailed description of a related known function or configuration may unnecessarily obscure the subject matter of the present invention, the detailed description thereof will be omitted.

도 1은 본 발명의 실시 예에 따른 변조기(Modulation)의 구성을 도시한 도면이다. 이하 상기 변조기의 구성 중 직교확산에 관한 부분만을 설명한다.1 is a diagram illustrating a configuration of a modulator according to an embodiment of the present invention. Hereinafter, only a portion related to orthogonal diffusion among the configurations of the modulator will be described.

상기 도 1을 참조하면, 신호변환기(DEMUX & signal power mapping part)111은 입력되는 심볼 데이터(symbol data; coded data)를 I채널 및 Q채널로 나누어 송신할 수 있도록 디멀티플렉싱하여 제1채널신호 및 제2채널신호로 출력한다. 또한 상기 신호변환기111은 심볼 데이터의 레벨을 변환하는데, 일 예로서 0을 +1로 변환하고 1을 -1로 변환하는 기능을 수행한다. 제1채널 이득조정기115는 상기 신호변환기111에서 출력되는 제1채널신호를 입력하며, 제어부113으로부터 제공되는 이득제어신호에 의해 상기 제1채널신호의 이득을 조정하여 출력한다. 제2채널 이득조정기116은 상기 신호변환기111에서 출력되는 제2채널신호를 입력하며, 상기 제어부113으로부터 제공되는 이득제어신호에 의해 상기 제2채널신호의 이득을 조정하여 출력한다. 메모리112는 각종 프로그램 데이터 및 상기 프로그램 수행 중에 발생하는 일시적인 데이터를 저장한다. 특히 본 발명에 따라 상기 메모리112는 각 채널의 심볼 레이트에 따라 달라지는 직교부호 길이(length)에 대한 정보를 가진 레지스터와, 채널에 할당된 직교부호의 인덱스(walsh code index)를 가진 레지스터와, 직교 확산할 하나의 심볼을 이에 해당하는 칩 클럭으로 카운터한 칩 카운트 값(chip count)을 가진 레지스터를 구비한다. 상기 직교부호 길이에 대한 정보는 후술하겠지만 직교부호 인덱스와 칩 카운트 값의 실제 유효한 비트 수를 한정하는의미로 정의될 수 있다. 제어부113은 변조기의 전반적인 동작을 제어하며, 특히 본 발명에 따라 상기 메모리112로부터 직교부호 발생에 관한 변수값을 읽어서 각 채널발생기의 직교부호생성기114로 제공한다. 직교부호 생성기(orthogonal code generator)114는 상기 제어부113으로부터 제공되는 직교부호 길이(length) 정보(유효 비트 수), 직교부호 인덱스(walsh code index) 및 칩 카운트(chip count)에 따라 대응되는 직교부호를 생성하여 출력한다. 곱셈기117은 상기 제1채널 이득조정기115에서 출력되는 제1채널 신호와 상기 직교부호를 곱하여 직교 변조된 제1채널신호를 발생한다. 곱셈기118은 상기 제2채널 이득조정기116에서 출력되는 제2채널 신호와 상기 직교부호를 곱하여 직교 변조된 제2채널신호를 발생한다.Referring to FIG. 1, a signal converter (DEMUX & signal power mapping part) 111 demultiplexes input symbol data (coded data) into I and Q channels so as to transmit the first channel signal and Output as a second channel signal. In addition, the signal converter 111 converts the level of symbol data. For example, the signal converter 111 converts 0 into +1 and 1 into -1. The first channel gain adjuster 115 inputs a first channel signal output from the signal converter 111 and adjusts and outputs a gain of the first channel signal by a gain control signal provided from the controller 113. The second channel gain adjuster 116 inputs a second channel signal output from the signal converter 111, and adjusts and outputs a gain of the second channel signal by a gain control signal provided from the controller 113. The memory 112 stores various program data and temporary data generated during the execution of the program. In particular, according to the present invention, the memory 112 includes a register having information on an orthogonal code length that varies according to the symbol rate of each channel, a register having an orthogonal code index assigned to the channel, and a orthogonal code. And a register having a chip count that counts one symbol to be spread with a corresponding chip clock. The information on the orthogonal code length will be described later. However, the information on the orthogonal code length may be defined to mean an actual number of valid bits of the orthogonal code index and the chip count value. The control unit 113 controls the overall operation of the modulator. In particular, according to the present invention, the controller 113 reads a variable value related to the orthogonal code generation from the memory 112 and provides it to the orthogonal code generator 114 of each channel generator. An orthogonal code generator 114 corresponds to an orthogonal code corresponding to orthogonal code length information (effective number of bits), orthogonal code index, and chip count provided from the control unit 113. Create and print The multiplier 117 multiplies the first channel signal output from the first channel gain adjuster 115 and the orthogonal code to generate a first channel signal that is orthogonally modulated. The multiplier 118 multiplies the second channel signal output from the second channel gain adjuster 116 by the orthogonal code to generate a quadrature modulated second channel signal.

상술한 구성 중 본 발명에서 제안하고자 하는 직교부호 생성장치를 구현함에 있어 필수 구성이라 할 수 있는 것은 메모리112, 제어부113 및 직교부호 생성기114가 될 것이다. 또한, 상기 제어부113과 직교부호 생성기114를 통칭하고자 하는 때에는 직교부호 생성부라는 용어를 사용하도록 한다.Among the above-described configurations, essential components in implementing the orthogonal code generation device proposed by the present invention will be a memory 112, a control unit 113, and an orthogonal code generator 114. In addition, when the control unit 113 and the orthogonal code generator 114 are to be collectively referred to, the term orthogonal code generator is used.

상기 도 1의 구성에 근거한 변조기의 직교확산 동작을 살펴보면, 먼저, 코드화된 데이터(심볼 데이터)는 신호변환기111을 거쳐 제1채널신호 및 제2채널신호로 분리된다. 상기 분리된 신호는 각각 상기 제어부113의 제어 하에 상기 제1채널조정기115 및 제2채널조정기116에서 이득 조정된다. 상기 이득 조정된 제1 및 제2채널신호는 대응하는 곱셈기117 및 118로 출력된다. 이때 상기 제어부113은 상기 코드화된 데이터(심볼 데이터)의 심볼 레이트에 대응하는 직교부호 길이(length), 칩 카운트의 값, 그리고 채널에 할당될 직교부호 인덱스를 얻는다. 상기 정보들은 상기 메모리112에 구비된 레지스터를 억세스하여 얻어지며, 이렇게 얻어진 정보들은 해당 채널발생기의 직교부호생성기114로 제공된다. 그러면 상기 직교부호생성기114는 상기한 세 개의 정보를 가지고 내부에 구비된 DSP상에 구현된 프로그램 또는 ASIC 등을 통해 대응되는 직교부호를 생성한다. 상기 생성된 직교부호는 곱셈기117 및 118로 출력한다. 그리고 상기 곱셈기117은 상기 제1채널이득조정기115에서 출력되는 제1채널신호와 상기 직교부호를 곱하여 직교 변조된 제1채널신호(IW)를 발생한다. 또한 상기 곱셈기118은 상기 제2채널 이득조정기116에서 출력되는 제2채널신호와 상기 직교부호를 곱하여 직교 변조된 제2채널신호(QW)를 발생한다. 이때, 상기 직교 변조된 제1채널신호는 I 채널에 대응한다고 할 수 있으며, 상기 직교 변조된 제2채널신호는 Q 채널에 대응한다고 할 수 있다.Referring to the orthogonal diffusion operation of the modulator based on the configuration of FIG. 1, first, coded data (symbol data) is separated into a first channel signal and a second channel signal through a signal converter 111. The separated signals are gain adjusted by the first channel regulator 115 and the second channel regulator 116 under the control of the controller 113, respectively. The gain adjusted first and second channel signals are output to corresponding multipliers 117 and 118. At this time, the controller 113 obtains an orthogonal code length corresponding to a symbol rate of the coded data (symbol data), a value of a chip count, and an orthogonal code index to be allocated to a channel. The information is obtained by accessing a register provided in the memory 112, and the obtained information is provided to an orthogonal code generator 114 of the corresponding channel generator. Then, the orthogonal code generator 114 generates an orthogonal code corresponding to the three pieces of information through a program or an ASIC implemented on a DSP provided therein. The generated orthogonal codes are output to the multipliers 117 and 118. The multiplier 117 multiplies the first channel signal output from the first channel gain adjuster 115 by the orthogonal code to generate a first channel signal IW orthogonally modulated. The multiplier 118 multiplies the second channel signal output from the second channel gain adjuster 116 by the orthogonal code to generate a second channel signal QW that is orthogonally modulated. In this case, the orthogonally modulated first channel signal may correspond to an I channel, and the orthogonally modulated second channel signal may correspond to a Q channel.

이하 본 발명의 일 실시 예에 따른 직교부호 발생 과정을 보다 상세히 설명한다. 우선 이하 설명될 직교부호 생성 과정은 앞에서 개시한 구성인 제어부113과 직교부호 생성기114로 이루어진 직교부호 생성부에서 수행되는 과정임을 밝혀둔다. 한편, 본 발명의 실시 예를 설명함에 있어 직교부호의 길이 정보와 유효 비트 수를 혼용하여 사용한다고 하더라도 동일한 의미로서 사용되었음에 주의하여야 할 것이다.Hereinafter, an orthogonal code generation process according to an embodiment of the present invention will be described in detail. First, the orthogonal code generation process to be described below is a process performed by the orthogonal code generation unit including the control unit 113 and the orthogonal code generator 114, which have been described above. On the other hand, in the description of the embodiment of the present invention, it should be noted that even if the orthogonal code length information and the effective number of bits are used interchangeably, the same meaning is used.

상기 직교부호를 발생하는 과정은 크게 2가지 단계로 이루어진다. 그 첫 번째가 직교부호 발생을 위해 요구되는 정보를 생성하는 단계이며, 그 두 번째가 생성된 정보에 의해 직교부호를 발생하는 단계이다. 이때, 상기 요구되는 정보는 각 채널마다 할당되는 직교부호 인덱스와 하나의 심볼 주기를 칩 클럭으로 카운트한값 및 직교부호의 길이로 이루어진다.The generation of the orthogonal code consists of two steps. The first step is to generate the information required for generating the orthogonal code, and the second step is to generate the orthogonal code based on the generated information. In this case, the required information includes an orthogonal code index allocated to each channel, a value obtained by counting one symbol period with a chip clock, and a length of an orthogonal code.

먼저, 상기 첫 번째 단계에 의해 직교부호 인덱스, 카운트 값 및 직교부호 길이로 이루어지는 정보를 생성하여 제공하는 일련의 동작을 구체적으로 설명하면 다음과 같다.First, a series of operations for generating and providing information including an orthogonal code index, a count value, and an orthogonal code length by the first step will be described in detail.

종래의 IS-95와 같은 CDMA 방식과는 달리 새로운 방식의 CDMA-2000과 같은 경우, 순방향 채널의 변조 과정에서는 채널 종류마다 확산기로 입력되어지는 심볼 데이터의 심볼 레이트가 다르다. 이 때문에 일정한 대역 확산 레이트를 맞추기 위해서는 상이한 심볼 레이트마다 직교부호의 길이가 달라지는데 그 범위는 4에서부터 배수인 8, 16, 32, 64, 128, 256, 512, 1024를 가지게 된다. 예를 들어 대역확산 레이트가 3,6864Mcps인 경우 확산기로 입력되는 심볼 레이트가 14.4kbps, 28.8kbps, 57.6kbps, 115.2kbps 등으로 다르다. 이에 따라 직교부호의 길이가 각기 256 chip, 128 chip, 64chip, 32chip 등으로 달라지게 되어 하기와 같이 3.6864Mcps의 대역확산 레이트를 맞추게 된다.Unlike the CDMA scheme of the conventional IS-95, in the case of the CDMA-2000 of the new scheme, the symbol rate of the symbol data input to the spreader is different for each channel type in the modulation process of the forward channel. Therefore, in order to match a constant spread spectrum rate, the length of the orthogonal code varies for different symbol rates, and the range is from 4 to 8, 16, 32, 64, 128, 256, 512, and 1024. For example, when the spread spectrum rate is 3,6864 Mcps, the symbol rates input to the spreader differ by 14.4kbps, 28.8kbps, 57.6kbps, 115.2kbps, and the like. As a result, the length of the orthogonal code is changed to 256 chips, 128 chips, 64 chips, 32 chips, etc., respectively, to match the spread spectrum rate of 3.6864 Mcps.

14.4kbps × 256 chip = 3.686Mcps14.4kbps × 256 chip = 3.686Mcps

28.8kbps × 128 chip = 3.686Mcps28.8 kbps × 128 chip = 3.686 Mcps

57.6kbps × 64 chip = 3.686Mcps57.6kbps × 64 chip = 3.686Mcps

115.2kbps × 32 chip = 3.686Mcps115.2kbps × 32 chip = 3.686Mcps

상기와 같이 일정한 대역확산 레이트를 맞추기 위해 확산기로 입력되는 여러 종류의 심볼 레이트에 따라 길이가 다른 직교부호를 생성하게 된다. 따라서, 변조기를 제어하는 프로세서에서는 심볼 레이트에 따라 달라지는 직교부호의 길이와 관련된 정보를 만들어 변조기로 제공하도록 한다. 그 일 예로서, 심볼 레이트에 따라 필요한 직교부호의 길이는 위에서 언급하였듯이 4의 배수이므로 각 직교부호의 길이를 2를 밑으로 하고, 소정 승수를 가지는 지수로 표시할 수 있다. 그 예를 개시하면 다음과 같다.As described above, in order to match the constant spreading rate, orthogonal codes having different lengths are generated according to various types of symbol rates input to the spreader. Therefore, in the processor controlling the modulator, information related to the length of an orthogonal code that depends on the symbol rate is generated and provided to the modulator. As an example, since the length of the orthogonal code required according to the symbol rate is a multiple of 4 as mentioned above, the length of each orthogonal code can be expressed as an index having a predetermined multiplier with a length of 2 below. The example is as follows.

4 = 22, 8 =23, 16 =24, …, 1024 = 210 4 = 2 2 , 8 = 2 3 , 16 = 2 4 ,. , 1024 = 2 10

상술한 바와 같이 모든 직교부호의 길이에 대응하는 밑은 2로서 공통되고, 승수의 차이를 가짐에 따라 심볼 레이트에 의해 결정되는 직교부호의 길이에 대한 정보는 앞에서 개시한 승수를 이용한다. 따라서, 프로세서에서는 승수를 직교부호의 길이에 관련한 정보로 생성하여 변조기로 제공한다.As described above, the base corresponding to the length of all orthogonal codes is common as 2, and the information on the length of the orthogonal code determined by the symbol rate as having a difference in the multiplier uses the multiplier disclosed above. Therefore, the processor generates a multiplier as information related to the length of the orthogonal code and provides the modulator.

이때, 각 채널마다 할당되는 직교부호 인덱스(n)와 하나의 심볼 주기를 칩 클럭으로 카운트한 값(t)의 범위는 직교부호의 길이에 의해 확장 또는 감소 할 수 있도록 한다. 즉, 4,8,16,64,128,… 등의 다양한 직교부호의 길이로 융통성 있게 이용할 수 있도록 하였다.At this time, the range of the orthogonal code index (n) allocated to each channel and the value (t) of counting one symbol period by a chip clock can be extended or reduced by the length of the orthogonal code. 4,8,16,64,128,... It can be used flexibly with various orthogonal codes.

이를 보다 구체적으로 설명하면, 상기 직교부호 인덱스와 카운트 값은 '0≤n≤2l-1, 0≤t≤2l-1'의 범위에서 결정된다. 즉, 상기 직교부호 인덱스는 상기 범위내의 정수 중 어느 하나의 정수를 l 비트의 2진수로 표현한 값으로 제공되며, 상기 카운트 값은 상기 범위 내의 정수를 순차적으로 지정하여 l 비트의 2진수로 표현한 값으로 제공된다. 예컨대, 상기 직교부호 길이에 대한 정보가 '4'로서 결정되었다고 가정하면 직교부호 인덱스는 0에서 15범위 내의 정수 중 어느 하나의 정수를 4비트로 표현한 2진수 값이 될 것이다. 한편, 카운트 값은 '24', 즉 16이 최종 카운트 값으로 결정되어 0에서 15범위 내의 정수를 순차적으로 지정하는 4비트로 표현된 2진수 값이 될 것이다. 즉, '0000 내지 1111'의 2진수 값이 순차적으로 제공된다. 한편, 상기 일 예에서는 직교부호 인덱스와 카운트 값의 비트 수를 l 비트로 한정하고 있으나 반드시 한정되어질 필요는 없다. 그 이유는 후술하겠으나 상기 직교부호 인덱스와 카운트 값의 비트 수를 최대 비트 수로 할당하고, 상기 할당된 비트 수 중 실제 유효한 비트를 제외한 모든 비트에는 '0'을 설정하여 제공하는 방법으로도 구현이 가능하다. 상기 최대 비트 수는 이동 통신시스템에서 사용되는 가장 긴 월시코드를 기준으로 하여 결정된다. 또한, 상기 실제 유효한 비트는 앞에서 개시한 직교부호 인덱스와 카운트 값의 비트 수를 의미한다. 예를 들어 이동 통신시스템에서 사용이 가능한 가장 긴 월시코드가 128(27)칩인 경우 결정되는 비트 수는 7비트가 될 것이다.If this More specifically, the orthogonal code index and the count value is determined in the range of '0≤n≤2 l -1, 0≤t≤2 l -1 '. That is, the orthogonal code index is provided as a value representing an integer of any one of the integers in the range as a binary number of l bits, and the count value is a value expressed as a binary number of l bits by sequentially specifying an integer within the range. Is provided. For example, assuming that the information on the orthogonal code length is determined as '4', the orthogonal code index will be a binary value representing any one of integers in the range of 0 to 15 as 4 bits. On the other hand, the count value will be a binary value represented by 4 bits that '2 4 ', that is, 16 is determined as the final count value and sequentially specifies an integer in the range of 0 to 15. That is, binary values of '0000 to 1111' are provided sequentially. Meanwhile, in the above example, the number of bits of the orthogonal code index and the count value is limited to 1 bit, but it is not necessarily limited. The reason for this will be described later, but the method can be implemented by allocating the bit number of the orthogonal code index and the count value as the maximum number of bits and setting '0' to all bits except the actual valid bits among the allocated number of bits. Do. The maximum number of bits is determined based on the longest Walsh code used in the mobile communication system. In addition, the actual valid bits mean the number of bits of the orthogonal code index and count value described above. For example, if the longest Walsh code available in a mobile communication system is 128 (2 7 ) chips, the number of bits determined will be 7 bits.

결론적으로, 심볼 레이트가 지정되면 지정된 심볼 레이트에 의해 직교부호 길이가 결정되며, 상기 결정된 직교부호 길이에 의해 카운트 값의 범위와 함께 직교부호 인덱스가 결정된다. 상기 카운트 값의 범위가 결정되면 상기 결정된 범위 내에서 카운트 값이 순차적으로 증가할 것이며, 상기 카운트 값이 증가되는 시점을 주기로 하여 상기 직교부호 길이, 직교부호 인덱스 및 증가된 카운트 값이 직교부호를 생성하기 위한 정보로서 제공된다. 한편, 상기 직교부호 생성기114가 제공받은 직교부호 인덱스를 통해 직교부호 길이를 유추할 수 있는 처리 기능을 가지고있다면 상기 제어부113은 굳지 상기 직교부호 길이를 제공하지 않아도 될 것이다.In conclusion, if the symbol rate is specified, the orthogonal code length is determined by the designated symbol rate, and the orthogonal code index is determined with the range of count values by the determined orthogonal code length. When the range of the count value is determined, the count value is sequentially increased within the determined range, and the orthogonal code length, the orthogonal code index, and the increased count value generate orthogonal codes at a time point at which the count value is increased. It is provided as information for. On the other hand, if the orthogonal code generator 114 has a processing function capable of inferring the orthogonal code length through the provided orthogonal code index, the controller 113 may not provide the orthogonal code length.

다음으로, 상기 두 번째 단계에 의해 직교부호를 생성하는 일련의 동작을 상세히 설명하면 다음과 같다.Next, a series of operations for generating an orthogonal code by the second step will be described in detail.

본 발명은 프로세서에서 제공하는 직교부호 길이에 관련한 상기 정보와 채널마다 할당되는 직교부호 인덱스 그리고 칩 카운터 값을 이용하여 다음과 같은 알고리즘을 활용하여 필요한 직교부호를 생성한다. 즉, 직교부호 인덱스 및 칩 카운터 값과 함께 직교부호 길이가 가변되어 생성될 수 있도록 직교부호 길이에 대한 정보를 새로이 추가하여 알고리즘을 개선한 것이다.The present invention generates the required orthogonal code using the following algorithm using the information related to the orthogonal code length provided by the processor, the orthogonal code index assigned to each channel, and the chip counter value. That is, the algorithm is improved by adding new information about the orthogonal code length so that the orthogonal code length is variable with the orthogonal code index and the chip counter value.

상술한 바와 같이 변조기를 제어하는 프로세서에서 심볼 레이트에 따라 직교부호의 길이에 대한 정보를 결정하고, 이를 직교부호 생성기로 제공하여 고정된 길이가 아닌 심볼 레이트에 따라 직교부호의 길이가 바뀔 수 있는 직교부호 생성기를 만든다. 즉, 하기 <수학식 2>와 같이 n과 t의 값을 bit로 나타낼 때 bit 자리수를 길이에 대한 정보를 통하여 제한함으로서 필요한 길이의 직교부호를 만들어낸다.As described above, the processor controlling the modulator determines information about the length of the orthogonal code according to the symbol rate, and provides the orthogonal code generator to the orthogonal code generator to change the length of the orthogonal code according to the symbol rate rather than the fixed length. Create a sign generator. That is, when the values of n and t are expressed in bits as shown in Equation 2, an orthogonal code having the required length is generated by limiting the number of bit digits through the information on the length.

W(l,n,t)=(nl-1×tl-1)…(n4×t4)xor(n3×t3)xor(n2×t2)xor(n1×t1)xor(n0×t0)W (l, n, t) = (n l-1 × t l-1 )... (n 4 × t 4 ) xor (n 3 × t 3 ) xor (n 2 × t 2 ) xor (n 1 × t 1 ) xor (n 0 × t 0 )

여기서, l ; 직교부호 길이에 대한 정보(2,3,4,…)Where l; Information about orthogonal code lengths (2,3,4,…)

n ; 각 채널마다 할당되는 직교부호 인덱스n; Orthogonal Index Assigned to Each Channel

t ; 하나의 심볼 주기를 칩 클럭으로 카운트한 값t; Count of one symbol period in chip clock

상기한 <수학식 1>을 이용하여 직교부호 길이에 대한 정보와 직교부호 인덱스 및 카운트 값을 지정하면 이에 대응한 한 칩(1 chip)의 직교부호가 생성된다. 즉, 상기 <수학식 1>에서 알 수 있는 바와 같이 직교부호 길이에 대한 정보 'l'에 의해 유효 계산범위가 결정된다. 한편, 상기 결정된 유효 계산범위 내에서 제공받은 칩 카운트 값을 구성하는 비트와 직교부호 인덱스를 구성하는 비트를 비트 단위로 논리 연산하여 직교부호의 한 비트를 얻게 된다. 이때, 상기 논리 연산은 상기 <수학식 1>에서도 개시하고 있는 바와 같이 칩 카운트 값과 직교부호 인덱스를 비트 단위로 논리 곱 연산을 취한 후 그 결과 값들을 배타적 논리 합 연산을 취하여 구성으로 이루어진다.When the information on the length of the orthogonal code, the orthogonal code index, and the count value are specified by using Equation 1, an orthogonal code of one chip is generated. That is, as can be seen from Equation 1, the effective calculation range is determined by the information '1' of the orthogonal code length. On the other hand, one bit of the orthogonal code is obtained by performing a logical operation on a bit-by-bit basis between bits constituting the chip count value and bits constituting the orthogonal code index provided within the determined effective calculation range. In this case, as described in Equation 1, the logical operation is configured by performing a logical multiplication operation on a chip count value and an orthogonal code index in units of bits, and then performing exclusive logical sum operations on the resultant values.

상기 <수학식 1>에서 직교부호 길이 정보 l에 따라 유효 계산범위가 결정되는데 이는 도 2에서 나타내고 있는 바와 같다. 상기 도 2를 참조하여 일 예를 들면, 직교부호 길이 정보 l이 3(011)이고, 이에 따라 칩 카운터 t가 8(0-7)이며, 직교부호 인덱스 n이 3(n2,n1,n0= 0,1,1)이라고 가정하면, 도시된 바와 같이, 참조부호 214에 해당하는 범위를 이용하여 1 칩의 직교부호를 생성한다.In Equation 1, an effective calculation range is determined according to the orthogonal code length information l, as shown in FIG. Referring to FIG. 2, for example, the orthogonal code length information l is 3 (011), so that the chip counter t is 8 (0-7), and the orthogonal code index n is 3 (n 2 , n 1 , Assume that n 0 = 0, 1, 1), as shown in the drawing, an orthogonal code of one chip is generated using a range corresponding to reference numeral 214.

상기한 가정에 대한 <수학식 1>을 순차적으로 증가되어 제공되는 칩 카운트 값에 의해 나타내 보면 하기와 같다.Equation (1) for the above assumption is shown as a chip count value provided sequentially increased.

W(3,3,t)=(n2×t2)xor(n1×t1)xor(n0×t0)W (3,3, t) = (n 2 × t 2 ) xor (n 1 × t 1 ) xor (n 0 × t 0 )

여기서 n = (0 1 1), 카운터 범위는 (0≤ t ≤ 7)Where n = (0 1 1), the counter range is (0≤ t ≤ 7)

따라서, t = 0(0 0 0), W(3,3,0) = (0×0)xor(1×0)xor(1×0) = 0Thus t = 0 (0 0 0), W (3,3,0) = (0x0) xor (1x0) xor (1x0) = 0

t = 1(0 0 1), W(3,3,1) = (0×0)xor(1×0)xor(1×1) = 1t = 1 (0 0 1), W (3,3,1) = (0 × 0) xor (1 × 0) xor (1 × 1) = 1

t = 2(0 1 0), W(3,3,2) = (0×0)xor(1×1)xor(1×0) = 1t = 2 (0 1 0), W (3,3,2) = (0 × 0) xor (1 × 1) xor (1 × 0) = 1

t = 3(0 1 1), W(3,3,3) = (0×0)xor(1×1)xor(1×1) = 0t = 3 (0 1 1), W (3,3,3) = (0 × 0) xor (1 × 1) xor (1 × 1) = 0

t = 4(1 0 0), W(3,3,4) = (0×1)xor(1×0)xor(1×0) = 0t = 4 (1 0 0), W (3,3,4) = (0 × 1) xor (1 × 0) xor (1 × 0) = 0

t = 5(1 0 1), W(3,3,5) = (0×1)xor(1×0)xor(1×1) = 1t = 5 (1 0 1), W (3,3,5) = (0 × 1) xor (1 × 0) xor (1 × 1) = 1

t = 6(1 1 0), W(3,3,6) = (0×1)xor(1×1)xor(1×0) = 1t = 6 (1 1 0), W (3,3,6) = (0 × 1) xor (1 × 1) xor (1 × 0) = 1

t = 7(1 1 1), W(3,3,7) = (0×1)xor(1×1)xor(1×1) = 0t = 7 (1 1 1), W (3,3,7) = (0 × 1) xor (1 × 1) xor (1 × 1) = 0

결국, 최종적으로 생성되는 직교부호는 (0 1 1 0 0 1 1 0)이 된다.As a result, the orthogonal code generated finally becomes (0 1 1 0 0 1 1 0).

또한 상기의 <수학식 1>을 기반으로 개선된 방법에 대한 내용을 C-언어로 나타내면 하기 <수학식 2>와 같다.In addition, the contents of the improved method based on Equation 1 are expressed in Equation 2 below.

walsh(int length, int index, int count)walsh (int length, int index, int count)

{{

int i, wc = 0;int i, wc = 0;

for(i = 0; i<length; i++)for (i = 0; i <length; i ++)

wc = wc^( ((index >> i) & 0x01) & ((count >> I) & 0x01)wc = wc ^ (((index >> i) & 0x01) & ((count >> I) & 0x01)

return(wc);return (wc);

}}

여기서 i : 임시 count 변수Where i: temporary count variable

wc : 최종 결과값이 저장될 변수wc: Variable to store final result

length : symbol rate에 따라 결정되어지는 직교부호 길이에 대한 정보값을가진 변수length: A variable with information about the length of an orthogonal code, determined by the symbol rate

index : 채널에 할당된 직교부호 인덱스index: Orthogonal code index assigned to the channel

count : 1 symbol 주기를 칩 클럭(chip clock)으로 카운트한 값으로 위의 함수를 호출하였을 때의 chip count 값이 사용된다.count: The value of counting 1 symbol period as chip clock is used as the chip count value when the above function is called.

여기서는 앞에서도 개시한 바와 같이 length 값에 따라 주어지는 count 값의 범위가 달라진다. 예를 들어 설명하면 하기 <표 1>과 같다.Here, as described above, the range of count values given depends on the length value. For example, as shown in Table 1 below.

lengthlength 카운트 범위Count range 직교부호 길이Orthogonal length 22 0 - 30-3 44 33 0 - 70-7 88 44 0 - 150-15 1616 55 0 - 310-31 3232

또한 본 발명은 상기 <수학식 2>에 나타낸 바와 같이 프로그램으로 작성하여 디지털신호프로세서(DSP; Digital Signal Processor) 상에서 실제 구현할 수도 있으며, HDL(Hardware Development Language)과 같은 알고리즘을 작성하여 ASIC(Application-specific IC)으로 구현시킬 수 있다.In addition, the present invention may be actually implemented on a digital signal processor (DSP) by writing a program as shown in Equation (2), or by writing an algorithm such as HDL (Hardware Development Language) to create an ASIC (Application- specific IC).

상기 직교부호 생성기를 ASIC(Application-specific IC)으로 구현한 일 예에 따른 구성은 도 3에서 도시하고 있는 바와 같다. 상기 도 3에서 도시하고 있는 직교부호 생성기의 구성은 다수의 논리 곱 게이트310과 배타적 논리 합 게이트320으로 구성된다. 이때, 상기 논리 곱 게이트310의 수는 가장 긴 월시코드를 기준으로 하여 결정되는 최대 비트 수와 동일하다. 즉, 직교부호의 길이가 4, 8, 16, 32, 64, 128 chip인 경우 가장 긴 128 chip을 기준으로 하여 상기 논리 곱 게이트310의 개수를 결정한다. 이때, 결정되는 상기 논리 곱 게이트310의 개수는 직교부호 인덱스와 칩 카운트 값의 비트 수인 7비트에 대응하는 7개가 될 것이다. 따라서, 상기 정의된 가작 긴 직교부호 길이보다 짧은 직교부호 길이에 대한 직교부호를 생성하는 경우 실제 유효 값 이외의 비트는 '0'이라 간주한다. 즉, 실제 유효 값 이외의 비트는 '0'으로 마스킹(masking)되는 효과를 얻는다.A configuration according to an example of implementing the orthogonal code generator as an application-specific IC (ASIC) is as shown in FIG. 3. The orthogonal code generator illustrated in FIG. 3 includes a plurality of logical product gates 310 and exclusive logical sum gates 320. In this case, the number of the logical product gate 310 is equal to the maximum number of bits determined based on the longest Walsh code. That is, when the length of the orthogonal code is 4, 8, 16, 32, 64, 128 chips, the number of logical product gates 310 is determined based on the longest 128 chip. In this case, the number of the logical product gates 310 to be determined will be seven corresponding to 7 bits, which is the number of bits of the orthogonal code index and the chip count value. Accordingly, when generating an orthogonal code for an orthogonal code length shorter than the above defined pseudo long orthogonal code length, bits other than the actual valid value are regarded as '0'. In other words, bits other than the actual valid values are masked with '0'.

상기 논리 곱 게이트310 각각은 제공되는 직교부호 인덱스와 칩 카운트 값의 해당 비트를 논리 곱하여 출력한다. 상기 배타적 논리 합 게이트320은 상기 논리 곱 게이트310 각각으로부터 출력되는 값들을 배타적 논리 합 연산하여 직교부호를 구성하는 하나의 비트를 출력한다. 한편, 도면상에 개시하고 있는 Walsh_Index는 계산하고자 하는 직교부호 인덱스 값을 저장하는 레지스터로 볼 수 있으며, Chip_count는 현재의 칩 카운트 값이 저장되는 레지스터로 볼 수 있다. Walsh_code는 계산되어진 현재의 직교부호 값을 나타낸다. M은 사용되는 직교부호 길이 중에서 가장 긴 길이를 비트로 표현한 값으로 직교부호 길이가 128 chip의 경우 M은 7 비트가 된다.Each of the logical product gates 310 logically multiplies corresponding bits of a provided orthogonal code index and a chip count value and outputs the result. The exclusive logical sum gate 320 outputs one bit constituting an orthogonal code by performing an exclusive logical sum operation on values output from each of the logical product gates 310. On the other hand, Walsh_Index disclosed in the figure can be seen as a register that stores the orthogonal code index value to be calculated, Chip_count can be seen as a register that stores the current chip count value. Walsh_code represents the current orthogonal code value computed. M is the value representing the longest length of the orthogonal code length used in bits. If the orthogonal code length is 128 chips, M is 7 bits.

상기한 구성을 참조하여 동작의 일 예를 설명하면 다음과 같다. 이때, 제어부113으로부터 제공되는 정보는 앞에서 제시한 값과 동일하다고 가정한다. 즉, 직교부호 길이 정보 l이 3(011)이고, 이에 따라 칩 카운터 t가 8(0-7)이며, 직교부호 인덱스 n이 3(n2,n1,n0= 0,1,1)이라고 가정한다.An example of the operation will be described with reference to the above configuration. In this case, it is assumed that the information provided from the control unit 113 is the same as the value presented above. That is, the orthogonal code length information l is 3 (011), so that the chip counter t is 8 (0-7), and the orthogonal code index n is 3 (n 2 , n 1 , n 0 = 0 , 1 , 1 ). Assume that

이때, 이동 통신시스템에서 사용되는 가장 긴 직교부호 길이는 128chip이라고 가정하여 M은 7이라고 본다. 따라서, 상기 M의 값에 의해 결정되는 7개의 논리곱 게이트310 중 상기 l의 값 '3'에 의해 실질적으로 요구되는 논리 곱 게이트310은 3개로 한정된다.In this case, it is assumed that the longest orthogonal code length used in the mobile communication system is 128 chips, and M is 7. Therefore, among the seven logical product gates 310 determined by the value of M, the logical product gate 310 substantially required by the value '3' of l is limited to three.

상기와 같은 상태에서 직교부호 인덱스로는 0으로 마스킹된 4비트와 실제 직교부호 인덱스 정보인 0,1,1이 지속적으로 제공된다. 한편, 칩 카운트 값으로는 0으로 마스킹된 4비트는 지속적으로 제공되며, 실질적으로 칩 카운트 값을 나타내는 하위 3비트 값만이 변화되어 제공된다. 상기 제공되는 하위 3비트 값은 000에서 111까지 변화하게 될 것이다. 상기와 같이 제공되는 직교부호 인덱스와 칩 카운트 값에 따른 상기 논리 곱 게이트310의 출력은 하기 <표 2>와 같이 나타낼 수 있다.In the above state, as the orthogonal code index, 4 bits masked with 0 and 0,1,1, which are actual orthogonal code index information, are continuously provided. Meanwhile, four bits masked with zero are continuously provided as the chip count value, and only the lower 3 bit values representing the chip count value are changed and provided. The provided lower 3 bit value will vary from 000 to 111. The output of the logical product gate 310 according to the orthogonal code index and the chip count value provided as described above may be represented as shown in Table 2 below.

직교부호 인덱스(n)Cartesian index (n) 칩 카운트 값(t)Chip count value (t) 논리 곱 게이트 출력(q)Logic Product Gate Output (q) n6 n 6 n5 n 5 n4 n 4 n3 n 3 n2 n 2 n1 n 1 n0 n 0 t6 t 6 t5 t 5 t4 t 4 t3 t 3 t2 t 2 t1 t 1 t0 t 0 q6 q 6 q5 q 5 q4 q 4 q3 q 3 q2 q 2 q1 q 1 q0 q 0 00 00 00 00 00 1One 1One 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 1One 00 00 00 00 00 00 1One 00 00 00 00 00 1One 00 00 00 00 00 00 1One 00 00 00 00 00 00 1One 1One 00 00 00 00 00 1One 1One 00 00 00 00 1One 00 00 00 00 00 00 00 00 00 00 00 00 00 1One 00 1One 00 00 00 00 00 00 1One 00 00 00 00 1One 1One 00 00 00 00 00 00 1One 00 00 00 00 00 1One 1One 1One 00 00 00 00 00 1One 1One

상기한 <표 2>와 같이 얻어지는 논리 곱 게이트들의 출력(q0내지 q6)은 배타적 논리 합 게이트320으로 제공된다. 따라서, 상기 배타적 논리 합 게이트320은 모든 비트에 대해 배타적 논리 합 연상을 취하여 최종적으로 '01100110'의 직교부호가 생성된다.The outputs q 0 to q 6 of the logical product gates obtained as shown in Table 2 are provided as an exclusive logical sum gate 320. Thus, the exclusive logical sum gate 320 takes an exclusive logical sum association for all bits, resulting in an orthogonal code of '01100110'.

한편, 상술한 본 발명의 일 실시 예에 따른 구성 및 동작은 제어부113에서 칩 카운트 값을 포함한 직교부호 생성 정보를 결정하여 직교부호 생성기114로 제공하고, 상기 직교부호 생성기114는 제공되는 정보에 의해 직교부호를 생성하였다.하지만, 다른 실시 예로서 제어부113이 직교부호 생성기114로 직교부호 길이와 직교부호 인덱스만을 제공하고, 카운트 값은 상기 직교부호 생성기114에서 생성하도록 구현한다. 이때, 상기 직교부호 생성기114는 내부에 카운터를 구비하여야 하여 상기 직교부호 길이에 의해 칩 카운트 값을 생성하도록 한다.On the other hand, the configuration and operation according to an embodiment of the present invention described above to determine the orthogonal code generation information including the chip count value in the control unit 113 to provide to the orthogonal code generator 114, the orthogonal code generator 114 by the information provided Orthogonal code is generated. However, in another embodiment, the control unit 113 provides the orthogonal code length and the orthogonal code index to the orthogonal code generator 114, and the count value is generated by the orthogonal code generator 114. At this time, the orthogonal code generator 114 has to have a counter therein to generate a chip count value by the orthogonal code length.

상술한 바와 같이 본 발명은 심볼 레이트에 따라 길이가 다른 직교부호를 생성할 수 있어, 채널의 종류에 따라 심볼 레이트가 다른 CDMA2000 이동통신시스템에서 유용하게 사용될 수 있다. 또한 직교부호의 길이가 다른 여러 종류의 직교부호 테이블을 만들지 않아도 되기 때문에 실제 구현시 많은 메모리가 필요하지 않아 하드웨어를 다양한 심볼 레이트에 적용될 수 있는 공통의 구조로 구현할 수 있는 이점이 있다.As described above, the present invention can generate orthogonal codes having different lengths according to symbol rates, and thus can be usefully used in CDMA2000 mobile communication systems having different symbol rates according to channel types. In addition, since it is not necessary to create various kinds of orthogonal code tables having different lengths of orthogonal codes, there is an advantage in that hardware can be implemented in a common structure that can be applied to various symbol rates since much memory is not required in actual implementation.

Claims (10)

유효 비트 수와 직교부호 인덱스 및 칩 카운트 값을 각각 저장하는 레지스터를 가지는 메모리와,A memory having a register for storing a valid bit number, an orthogonal code index, and a chip count value, respectively; 상기 유효 비트 수로 카운트될 수 있는 최상 카운트 값까지 상기 칩 카운터 값을 순차적으로 발생하여 상기 칩 카운트 값으로 설정하고, 상기 직교부호 인덱스와 상기 칩 카운터 값들을 읽어 소정 논리 연산을 수행하여 직교부호를 생성하는 직교부호 생성부로 구성함을 특징으로 하는 이동통신시스템의 직교부호 생성장치.The chip counter value is sequentially generated and set to the chip count value up to the highest count value that can be counted as the number of significant bits, and the orthogonal code is generated by performing a predetermined logical operation by reading the orthogonal code index and the chip counter values. Orthogonal code generation device of a mobile communication system, characterized in that consisting of an orthogonal code generation unit. 제1항에 있어서, 상기 유효 비트 수는,The method of claim 1, wherein the number of significant bits is 가변하는 심볼 레이트에 대응한 직교부호 길이를 2를 밑으로 하는 지수로 표현하여 상기 표현된 지수의 승수임을 특징으로 하는 이동통신시스템의 직교부호 생성장치.And an orthogonal code length corresponding to a varying symbol rate as an exponent of 2 below, which is a multiplier of the expressed exponent. 제1항에 있어서, 상기 직교부호 생성부는,The method of claim 1, wherein the orthogonal code generation unit, 상기 유효 비트 수와 직교부호 인덱스 및 칩 카운트 값을 제공받아 하기 수학식 3에 의해 직교부호를 생성함을 특징으로 하는 이동통신시스템의 직교부호 생성방법.Orthogonal code generation method according to Equation 3 below receiving the effective number of bits, an orthogonal code index, and a chip count value. W(l,n,t)=(nl-1×tl-1)…(n4×t4)xor(n3×t3)xor(n2×t2)xor(n1×t1)xor(n0×t0)W (l, n, t) = (n l-1 × t l-1 )... (n 4 × t 4 ) xor (n 3 × t 3 ) xor (n 2 × t 2 ) xor (n 1 × t 1 ) xor (n 0 × t 0 ) 여기서, 상기 l은 유효 비트 수, 상기 n=(nl-1,…,n4,n3,n2,n1,n0)은 직교부호 인덱스, 상기 t=(tl-1,…,t4,t3,t2,t1,t0)는 칩 카운트 값을 의미함.Where l is the number of significant bits, n = (n l-1 ,..., N 4 , n 3 , n 2 , n 1 , n 0 ) is an orthogonal code index, and t = (t l-1 ,... , t 4 , t 3 , t 2 , t 1 , t 0 ) means the chip count value. 제2항에 있어서, 상기 직교부호 생성부는,The method of claim 2, wherein the orthogonal code generation unit, 상기 유효 비트 수를 결정하여 상기 결정한 유효 비트 수로 카운트될 수 있는 최상 카운트 값까지 상기 칩 카운터 값을 순차적으로 발생하고, 상기 직교부호 인덱스를 상기 유효 비트 수의 이진부호로 변환하는 제어부와,A controller configured to determine the valid number of bits and sequentially generate the chip counter value up to the highest count value that can be counted by the determined valid number of bits, and convert the orthogonal code index into a binary code of the valid number of bits; 상기 이진부호로 변환된 직교부호 인덱스와 상기 순차적으로 발생하는 칩 카운터 값들을 논리 연산하여 직교부호를 생성하는 직교부호 생성기로 구성함을 특징으로 하는 이동통신시스템의 직교부호 생성장치.And an orthogonal code generator configured to generate an orthogonal code by performing a logical operation on the orthogonal code index converted to the binary code and the chip counter values sequentially generated. 제4항에 있어서, 상기 직교부호 생성기는,The method of claim 4, wherein the orthogonal code generator, 상호 대응되는 상기 이진부호로 변환된 직교부호 인덱스의 비트들과 상기 순차적으로 발생하는 칩 카운트 값들의 비트들 각각을 논리 곱 연산하는 논리 곱 게이트들과,Logical product gates for performing a logical product operation on each of bits of the orthogonal code index converted to the binary code corresponding to each other and bits of the sequentially generated chip count values; 상기 논리 곱 게이트들의 출력 비트들을 배타적 논리 합 연산하여 칩 단위의 직교부호를 생성하는 배타적 논리 합 게이트로 구성함을 특징으로 하는 이동통신시스템의 직교부호 생성장치.And an exclusive logic sum gate configured to generate an orthogonal code in chip units by performing an exclusive logic sum operation on the output bits of the logical product gates. 가변하는 심볼 레이트에 대응한 직교부호 길이를 산출하는 과정과,Calculating an orthogonal code length corresponding to a variable symbol rate; 상기 산출한 직교부호 길이에 의해 유효 비트 수를 결정하는 과정과,Determining an effective number of bits based on the calculated orthogonal code length; 상기 유효 비트 수로 카운트될 수 있는 최상 카운트 값까지 상기 칩 카운터 값을 순차적으로 발생하는 과정과,Sequentially generating the chip counter value up to the highest count value that can be counted as the number of significant bits; 입력되는 직교부호 인덱스를 상기 유효 비트 수의 이진부호로 변환하는 과정과,Converting an input orthogonal code index into a binary code of the effective number of bits; 상기 이진부호로 변환된 직교부호 인덱스와 상기 순차적으로 발생하는 칩 카운터 값들을 논리 연산하여 직교부호를 생성하는 과정으로 이루어짐을 특징으로 하는 이동통신시스템의 직교부호 생성방법.And generating an orthogonal code by performing a logical operation on the orthogonal code index converted to the binary code and the chip counter values sequentially generated. 제6항에 있어서, 상기 유효 비트 수는,The method of claim 6, wherein the number of significant bits, 상기 직교부호 길이를 2를 밑으로 하는 지수로 표현하여 상기 표현된 지수의 승수임을 특징으로 하는 이동통신시스템의 직교부호 생성방법.Orthogonal code generation method of claim 2, wherein the orthogonal code length is represented by an exponent of 2 below. 제6항에 있어서, 상기 논리 연산은,The method of claim 6, wherein the logical operation, 상호 대응되는 상기 이진부호로 변환된 직교부호 인덱스의 비트들과 상기 순차적으로 발생하는 칩 카운트 값들의 비트들을 논리 곱 연산하는 과정과,Performing a logical multiplication operation on the bits of the orthogonal code index converted to the binary code corresponding to each other and the bits of the sequentially generated chip count values; 상기 논리 곱 연산하여 출력되는 비트들을 배타적 논리 합 연산하여 직교부호로 생성하는 과정으로 이루어짐을 특징으로 하는 이동통신시스템의 직교부호 생성방법.And generating an orthogonal code by performing an exclusive logical sum operation on the output bits by the logical multiplication operation. 가변하는 심볼 레이트에 대응한 직교부호 길이를 산출하여 유효 비트 수를 결정하는 과정과,Determining an effective number of bits by calculating an orthogonal code length corresponding to a variable symbol rate; 상기 유효 비트 수와 직교부호 인덱스 및 칩 카운트 값을 제공받아 하기 수학식 4에 의해 직교부호를 생성하는 과정으로 이루어짐을 특징으로 하는 이동통신시스템의 직교부호 생성방법.And receiving an effective number of bits, an orthogonal code index, and a chip count value, to generate an orthogonal code by Equation 4 below. W(l,n,t)=(nl-1×tl-1)…(n4×t4)xor(n3×t3)xor(n2×t2)xor(n1×t1)xor(n0×t0)W (l, n, t) = (n l-1 × t l-1 )... (n 4 × t 4 ) xor (n 3 × t 3 ) xor (n 2 × t 2 ) xor (n 1 × t 1 ) xor (n 0 × t 0 ) 여기서, 상기 l은 유효 비트 수, 상기 n=(nl-1,…,n4,n3,n2,n1,n0)은 직교부호 인덱스, 상기 t=(tl-1,…,t4,t3,t2,t1,t0)는 칩 카운트 값을 의미함.Where l is the number of significant bits, n = (n l-1 ,..., N 4 , n 3 , n 2 , n 1 , n 0 ) is an orthogonal code index, and t = (t l-1 ,... , t 4 , t 3 , t 2 , t 1 , t 0 ) means the chip count value. 제9항에 있어서, 상기 유효 비트 수는,The method of claim 9, wherein the number of significant bits is 상기 직교부호 길이를 2를 밑으로 하는 지수로 표현하여 상기 표현된 지수의 승수임을 특징으로 하는 이동통신시스템의 직교부호 생성방법.Orthogonal code generation method of claim 2, wherein the orthogonal code length is represented by an exponent of 2 below.
KR1019990036172A 1998-08-28 1999-08-28 apparatus and method for generating walsh code in cdma communication system KR100300357B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1019990036172A KR100300357B1 (en) 1998-08-28 1999-08-28 apparatus and method for generating walsh code in cdma communication system

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
KR1019980035118 1998-08-28
KR19980035118 1998-08-28
KR1019990036172A KR100300357B1 (en) 1998-08-28 1999-08-28 apparatus and method for generating walsh code in cdma communication system

Publications (2)

Publication Number Publication Date
KR20000017625A KR20000017625A (en) 2000-03-25
KR100300357B1 true KR100300357B1 (en) 2001-11-01

Family

ID=26634062

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019990036172A KR100300357B1 (en) 1998-08-28 1999-08-28 apparatus and method for generating walsh code in cdma communication system

Country Status (1)

Country Link
KR (1) KR100300357B1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100463512B1 (en) * 2000-03-13 2004-12-29 엘지전자 주식회사 Method and apparatus for finding Walsh index of communication system receiver

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20030007996A (en) * 2001-07-11 2003-01-24 삼성전자 주식회사 Orthogonal code generating device and method thereof in a code division multiple access communication system

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH06204973A (en) * 1993-01-07 1994-07-22 Ricoh Co Ltd M value spread spectrum communication system
KR970011471U (en) * 1995-08-18 1997-03-29 삼성전자주식회사 Walsh code generation circuit of cellular system with direct diffusion/code division multiple access method
US5751761A (en) * 1993-07-20 1998-05-12 Qualcomm Incorporated System and method for orthogonal spread spectrum sequence generation in variable data rate systems
JPH10164009A (en) * 1996-12-05 1998-06-19 Nec Corp Variable rate cdma diffusion circuit

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH06204973A (en) * 1993-01-07 1994-07-22 Ricoh Co Ltd M value spread spectrum communication system
US5751761A (en) * 1993-07-20 1998-05-12 Qualcomm Incorporated System and method for orthogonal spread spectrum sequence generation in variable data rate systems
KR970011471U (en) * 1995-08-18 1997-03-29 삼성전자주식회사 Walsh code generation circuit of cellular system with direct diffusion/code division multiple access method
JPH10164009A (en) * 1996-12-05 1998-06-19 Nec Corp Variable rate cdma diffusion circuit

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100463512B1 (en) * 2000-03-13 2004-12-29 엘지전자 주식회사 Method and apparatus for finding Walsh index of communication system receiver

Also Published As

Publication number Publication date
KR20000017625A (en) 2000-03-25

Similar Documents

Publication Publication Date Title
US7443906B1 (en) Apparatus and method for modulating data message by employing orthogonal variable spreading factor (OVSF) codes in mobile communication system
US6937559B1 (en) Apparatus and method for allocating Walsh codes in CDMA communication system having variable rate channel structure
KR19980079272A (en) Code Division Multiple Access (CDMA) Communication Method and Group Spreading Modulator
CN1269933A (en) Channelization code allocation for radio communication system
US8462614B2 (en) Buffer-based generation of OVSF code sequences
US6646579B2 (en) Method and device for generating OVSF code words
KR20020090722A (en) Method for producing scrambling code and apparatus thereof in mobile system
KR100406531B1 (en) Apparatus and method for modulating data message by employing orthogonal variable spreading factor (ovsf) codes in mobile communication system
KR100300357B1 (en) apparatus and method for generating walsh code in cdma communication system
US7308104B1 (en) Forward multiple scrambling code generating method and apparatus
US6052404A (en) Radio communication system employing a spread-spectrum technique
KR100327856B1 (en) Circuit and method for arbitrarily shifting M series
KR100594754B1 (en) Apparatus for generating ovsf code for uplink channel spreading in umts
AU732063B2 (en) Device and method for generating orthogonal codes in mobile communication system
KR100308887B1 (en) Layered orthogonal code generator and generating method
US20070041433A1 (en) Method and apparatus for compact OVSF despreading
KR100273048B1 (en) Method for generating spread code having orthogonality
US6910056B1 (en) Method and apparatus for implementing a multi-step pseudo random sequence generator
KR200151261Y1 (en) Walsh code generating circuit of ds/cdma cellular system
US7173900B1 (en) Method and apparatus for chip generation of a chip sequence
US6958712B1 (en) Low gate count 3GPP channelization code generator
KR960003101B1 (en) Walsh-hadamard generator
KR100511294B1 (en) Symbol mapping and channelization apparatus for asynchronous cdma
KR100246999B1 (en) Apparatus for generating frame pulse for multiplexing of ds-1e signal
KR20040009939A (en) Direct generation apparatus of channelization code

Legal Events

Date Code Title Description
A201 Request for examination
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20080513

Year of fee payment: 8

LAPS Lapse due to unpaid annual fee