//
convert RGB colorspace to Homochromy(Black/whit)
static
public
int
ConvertRGBtoHomochromy(
int
x,
int
bw)
data:image/s3,"s3://crabby-images/de7ee/de7eef6dd557a6cf50d5eb0d3e6f38664a183b7f" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/8abd2/8abd229fb819c2d6ef3ac7e413fc94bef26793a7" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
String rgbString = Integer.toHexString(x).toUpperCase();
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
if (rgbString.length()!=6)
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
return Integer.parseInt("000000", 16);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
}
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
String strR,strG,strB;
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
strR = rgbString.substring(0, 2);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
strG = rgbString.substring(2, 4);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
strB = rgbString.substring(4, 6);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
int intR,intG,intB;
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
intR = Integer.parseInt(strR, 16);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
intG = Integer.parseInt(strG, 16);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
intB = Integer.parseInt(strB, 16);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
//get lum value from RGB
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
int y = (int)(0.299 * intR + 0.587 * intG + 0.114 * intB);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
if(y>bw)
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
y = 255;
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
}
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
else
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
y = 0;
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
}
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
String result = Integer.toHexString(y).toUpperCase()+ Integer.toHexString(y).toUpperCase()
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
+ Integer.toHexString(y).toUpperCase();
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
return Integer.parseInt(result, 16);
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
}
data:image/s3,"s3://crabby-images/de7ee/de7eef6dd557a6cf50d5eb0d3e6f38664a183b7f" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
ColorModel cm =image.getColorModel();
if((image.getType()!=BufferedImage.TYPE_BYTE_BINARY)||(cm.getPixelSize()!=1)){
//BufferedImage grayImage=new BufferedImage(image.getWidth(),image.getHeight(),BufferedImage.TYPE_BYTE_BINARY);
//grayImage.getGraphics().drawImage(image,0,0,null);
WritableRaster raster =image.getRaster();
//image = grayImage;
DataBufferInt buffer=(DataBufferInt)raster.getDataBuffer();
int[] imgdata=(int[])buffer.getData();
for(int i=0; i<imgdata.length;i++)
{
imgdata[i] = ConvertRGBtoHomochromy(imgdata[i],190);
//i=0;
}
image.setData(raster);
//image = convert(image,BufferedImage.TYPE_BYTE_BINARY);
File jpgFile = new File("C:""Documents and Settings""ar""My Documents","afterbw.jpg");jpgFile.delete();
ImageIO.write(image, "jpg", jpgFile);
below code is how to get threshold value from image for convertor.
static
public
int
getThreshold(BufferedImage image)
data:image/s3,"s3://crabby-images/8abd2/8abd229fb819c2d6ef3ac7e413fc94bef26793a7" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
int thresholdValue=1; // threshold
int[] ihist = new int[256]; //
int i, j, k; // various counters
int n, n1, n2, gmin, gmax;
double m1, m2, sum, csum, fmax, sb;
// reset
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
for(i=0;i<256;i++)
{
ihist[i] = 0;
}
gmin=255; gmax=0;
for (i = 1; i < image.getWidth()-1 ; i++)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
for (j = 1; j < image.getHeight()-1 ; j++)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
//get gray value base on RGB value
int cn = getGrayValue(image.getRGB(i, j));
ihist[cn]++;
if(cn > gmax) gmax=cn;
if(cn < gmin) gmin=cn;
}
}
// set up everything
sum = csum = 0.0;
n = 0;
for (k = 0; k <= 255; k++)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
sum += (double) k * (double) ihist[k]; /**//* x*f(x) */
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
n += ihist[k]; /**//* f(x) */
}
if (n==0)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
// if n has no value, there is problemsdata:image/s3,"s3://crabby-images/fda40/fda40bbdfd58281ae80d47105a6fec9063d4f060" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
return (60);
}
// do the otsu global thresholding method
fmax = -1.0;
n1 = 0;
for (k = 0; k < 255; k++)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
n1 += ihist[k];
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
if (n1==0)
{ continue; }
n2 = n - n1;
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
if (n2 == 0)
{ break; }
csum += (double) k *ihist[k];
m1 = csum / n1;
m2 = (sum - csum) / n2;
sb = (double) n1 *(double) n2 *(m1 - m2) * (m1 - m2);
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
/**//* bbg: note: can be optimized. */
if (sb > fmax)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
fmax = sb;
thresholdValue = k;
}
}
// at this point we have our thresholding value
return thresholdValue;
}
and the orginal codes be changed:
int
thresholdValue
=
getThreshold(image);
for
(
int
i
=
0
; i
<
imgdata.length;i
++
)
data:image/s3,"s3://crabby-images/8abd2/8abd229fb819c2d6ef3ac7e413fc94bef26793a7" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
//imgdata[i] = ConvertRGBtoGray(imgdata[i]);
imgdata[i] = ConvertRGBtoHomochromy(imgdata[i],thresholdValue);
//i=0;
}
添加 edge detect ,用来找到边界去掉背景块
data:image/s3,"s3://crabby-images/8abd2/8abd229fb819c2d6ef3ac7e413fc94bef26793a7" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
static
public
BufferedImage edgeDetect(BufferedImage img)
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
int w = img.getWidth(null);
int h = img.getHeight(null);
BufferedImage newImage = new BufferedImage(w,h,1);
for (int y=0;y<h;y++)
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
for (int x=0;x<w;x++)
{
int c=img.getRGB(x,y);
newImage.setRGB(x,y,c);
}
int c,red,green,blue,avg,d=3;
for (int y=0;y<h;y++)
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
for (int x=0;x<w;x++)
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
c=img.getRGB(x,y);
red=getRed(c);
green=getGreen(c);
blue=getBlue(c);
avg=(red+green+blue)/d;
newImage.setRGB(x,y,createRGB(avg,avg,avg));
}
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
Kernel k = new Kernel(3, 3, new float[]
{ 0.0f, 1.0f, 0.0f,
1.0f, -4.0f, 1.0f,
0.0f, 1.0f, 0.0f });
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
ConvolveOp op = new ConvolveOp(k);
BufferedImage img2 = op.filter(newImage, null);
return img2;
}
添加去杂点的处理方法:
data:image/s3,"s3://crabby-images/8abd2/8abd229fb819c2d6ef3ac7e413fc94bef26793a7" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
static
private
int
getMiddleValue(
int
[] arrayValue)
{
int v;
for(int i=0;i<=7;i++)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
for(int j=0;j<=7;j++)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
if (arrayValue[j]<arrayValue[j+1])
{
v = arrayValue[j];
arrayValue[j] = arrayValue[j+1];
arrayValue[j+1] = v;
}
}
}
return arrayValue[5];
}
static
private
BufferedImage Opt(BufferedImage image)
data:image/s3,"s3://crabby-images/8abd2/8abd229fb819c2d6ef3ac7e413fc94bef26793a7" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
int width = image.getWidth();
int height = image.getHeight();
int[] c = new int[9];
for(int i=1;i<width-1;i++)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
{
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
for(int j=1;j<height-1;j++)
{
int cc = image.getRGB(i, j);
c[0] = image.getRGB(i-1, j-1);
c[1] = image.getRGB(i, j-1);
c[2] = image.getRGB(i+1, j-1);
c[3] = image.getRGB(i-1, j);
c[4] = image.getRGB(i, j);
c[5] = image.getRGB(i+1, j);
c[6] = image.getRGB(i-1, j+1);
c[7] = image.getRGB(i, j+1);
c[8] = image.getRGB(i+1, j+1);
cc = getMiddleValue(c);
image.setRGB(i,j,cc);
}
}
return image;
}
更新edge detect 算法
static
public
int
[] apply_sobel(
int
[] src_1d,
int
width,
int
height,
double
sobscale,
data:image/s3,"s3://crabby-images/8abd2/8abd229fb819c2d6ef3ac7e413fc94bef26793a7" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
float
offsetval)
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
int i_w = width;
int i_h = height;
int d_w = width;
int d_h = height;
int[] dest_1d = new int[d_w * d_h];
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
for(int i=0;i<src_1d.length;i++)
{
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
try
{
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
int a = src_1d[i] & 0x000000ff;
int b = src_1d[i+ 1] & 0x000000ff;
int c = src_1d[i+ 2] & 0x000000ff;
int d = src_1d[i + i_w] & 0x000000ff;
int e = src_1d[i + i_w + 2] & 0x000000ff;
int f = src_1d[i + 2*i_w ] & 0x000000ff;
int g = src_1d[i + 2*i_w + 1] & 0x000000ff;
int h = src_1d[i + 2*i_w + 2] & 0x000000ff;
int hor = (a+d+f) - (c+e+h);
if (hor < 0) hor = -hor;
int vert = (a+b+c) - (f+g+h);
if (vert < 0) vert = -vert;
short gc = (short) (sobscale * (hor + vert));
gc = (short) (gc + offsetval);
if (gc > 255) gc = 255;
dest_1d[i] = 0xff000000 | gc<<16 | gc<<8 | gc;
data:image/s3,"s3://crabby-images/489b9/489b95536c074375dd5d0046262593610fa6280c" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
//reached borders of image so goto next row
//(see Convolution.java)
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
if (((i+3)%i_w)==0)
{
dest_1d[i] = 0;
dest_1d[i+1] = 0;
dest_1d[i+2] = 0;
i+=3;
}
data:image/s3,"s3://crabby-images/c35fa/c35fab94d48b96d3957016d3c494c0f101cca19e" alt="convert RGB colorspace to Homochromy(Black/whit) convert RGB colorspace to Homochromy(Black/whit)"
} catch (ArrayIndexOutOfBoundsException e)
{
//if reached row boudary of image return.
i = src_1d.length;
}
}
return dest_1d;
}