Routine ID: M427 | |
---|---|
Author(s): J. Zoll | Library: KERNLIB |
Submitter: | Submitted: 01.06.1973 |
Language: Fortran or Assembler | Revised: 16.09.1991 |
PKCHAR allows packing of integers into continuous byte-strings on zoned memory across word boundaries. The term continuous byte-string is used here to designate n-bit bytes, stored from left to right, as opposed to the objects handled by PKBYT (M422), which are stored right to left within each word. The inverse unpacking is performed by UPKCH. Leading and trailing bits of each zone can be ignored.
Structure:
SUBROUTINE subprograms
User Entry Names: PKCHAR, UPKCH
External References: JBYT, SBYT, CBYT (M421)
COMMON Block Names and Lengths: /SLATE/ NWU,DUMMY(39)
Usage:
CALL PKCHAR(INT,MPK,N,IPAR) CALL UPKCH (MPK,INT,N,IPAR)PKCHAR packs the N--word vector INT of integers into the continuous byte-string supported by the vector MPK according to the packing specifications given in IPAR.
UPKCH is the exact inverse of PKCHAR.
The packing parameters are given in the 5-element vector IPAR:
On return from either routine, NWU in COMMON block /SLATE/ indicates the number of words in MPK actually used. PKCHAR sets to IPAR(5) each word of MPK before filling it, but it does not clear any trailing unused words which logically belong to the last zone.
Examples:
DATA IPACK6 /6,0,0,0,0/ DATA IPACK7 /7,0,36,0,0/ CALL UPKCH(HOLL,INT,N,IPACK6)unpacks the Hollerith string HOLL into INT, where INT(I) is a small integer giving the display-code value of the I-th character. After conversion to ASCII, one may pack:
CALL PKCHAR(INT,MPK,N,IPACK7)giving the vector MPK ready to be written out. If for some reason one required the first and the last (5th) character in each 36-bit PDP10 word to be zero, one could use:
DATA IPACK7 /7,3,36,7,0/
DATA IPACK /8,0,120,0,0/ CALL UPKCH(A,INT,N,IPACK)
DATA IPACK /16,2,0,32,0/ CALL UPKCH(I32,I16,N,IPACK)The same operation on the Apollo, which has 32-bit words, could be done with
DATA IPACK /16,0,0,0,0/
IPACK(1) = NBITS IPACK(2) = 0 IPACK(3) = NBYTES*NBITS + 127 IPACK(4) = 0 IPACK(5) = 0 CALL UPKCH(SOURCE,TARGET,NBYTES,IPACK)