Exemplo n.º 1
0
def save(t_canvas_image):
    #function used to save imaages to a csc file.
    #It takes in the full canvas. It separates the grid squares
    # (via separate_digits), refromats them (via reformat_mnist) and
    # reshapes then into a one dimensional vector that is written to
    # a csv file that can be used as input to different machine
    # learning programs. The output includes a class label. The label
    # has the same value for all the digits on the filled out grid sqaures.
    # Only one class at a time can be entered for each set of grid squares
    import pandas as pd
    import cv2
    import numpy as np
    from digit_capture import get_global_settings as gs
    d_2=gs('d_2')
    grid_count=gs('grid_count')
    t_dest=set_file_name_prefix(0)
    fname_pfx=t_dest[0]
    t_path=t_dest[1]
    t_class=gs('t_class')
    final_side_size=gs('final_side_size')
    df_class=make_class_list(t_class,(grid_count*grid_count))
    df_column_names=make_col_list((final_side_size*final_side_size))
    out_array = np.zeros(((grid_count*grid_count),(d_2*d_2)),dtype='uint8')
    (t_digits,t_reformat_dg)=separate_digits(t_canvas_image,d_2,grid_count)
    new_data=reformat_mnist(t_reformat_dg,0)
    df_dta=pd.DataFrame(data=new_data)
    df_dta=pd.concat([df_class,df_dta],axis=1)
    write_digit_data(df_dta,fname_pfx+'digit_data.csv')
Exemplo n.º 2
0
def separate_digits(t_image,t_dim,grid_count):
    #Takes in the image drawn on the canvas and cuts each grid square out,
    #Returns a list of the separate grids and a 3D array with an
    #entry for each grid square
    import numpy as np
    import cv2
    from digit_capture import get_global_settings as gs
    final_side_size=gs('final_side_size')
    grid_count=gs('grid_count')
    row_count=grid_count*grid_count
    #print("separate "+str(t_image.shape))
    #print("row_count "+row_count)
    #print("final_side_size "+final_side_size)
    im_list=[]
    im_reshaped=np.zeros((row_count,final_side_size,final_side_size))
    dim_list=[]
    for i in range(0,grid_count):
        dim_list.append((i+1)*t_dim)    
    st_1=0
    st_2=0
    t_index=0
    for i in dim_list:
        for j in dim_list:
            t_d=t_image[st_1:i,st_2:j]
            if(check_if_enough_pixels(t_d)==1):
                t_rs=cv2.resize(t_d,(final_side_size,final_side_size))
                im_list.append(t_d)
                im_reshaped[t_index,]=t_rs
                t_index=t_index+1
            st_2=st_2+t_dim
        st_1=st_1+t_dim
        st_2=0
    return (im_list,im_reshaped[0:t_index,])
Exemplo n.º 3
0
def reshape_mnist(tData):
    import numpy as np
    from digit_capture import get_global_settings as gs
    fss=gs('final_side_size')
    entries=tData.shape[0]
    new_format=np.zeros((entries,(fss*fss)),dtype='float')
    for i in range(0,entries):
        (thresh, gray) = cv2.threshold(tData[i,:,:],gs('threshold_low'), 255, cv2.THRESH_BINARY | cv2.THRESH_OTSU)
        new_format[i,:]=np.reshape(gray,(1,fss*fss))
    return new_format    
Exemplo n.º 4
0
def load_and_threshold_file(t_file):
    #Reads in an image file and thresholds it. 
    import cv2
    import numpy as np
    from digit_capture import get_global_settings as gs
    fss=gs('final_side_size')
    gray1=cv2.imread(t_file,0)
    gray=cv2.imread(t_file,0)
    gray = cv2.resize(gray,(fss, fss))
    (thresh, gray) = cv2.threshold(gray,gs('threshold_low'), 255, cv2.THRESH_BINARY | cv2.THRESH_OTSU)
    gray = 255-gray
    gray=np.round((gray/255),decimals=0)
    gray=255*gray
    gray=np.uint8(gray)
    return gray
Exemplo n.º 5
0
def shift_2(img,t_invert):
    # gets the best shift base on matrix center of gravity
    # and places in a 28 by 28 pixel field
    import cv2
    from digit_capture import get_global_settings as gs
    fss=gs('final_side_size')
    import numpy as np
    t_paste=np.zeros((fss,fss),dtype='int')
    r,c=img.shape
    x,y=getBestShift(img)
    cv2.imwrite('bad_image.jpg',img)
    #print(str(y)+" "+str(x)+" "+str(r)+" "+str(c))
    if((r+y)>fss):
        import time;
        ts = time.time()
        ts = time.ctime(ts)
        y=fss-r
        f = open("digit_capture_log.txt", "a")
        f.write("had to modify center y "+str(ts)+" \n")
        f.close()
    if((c+x)>fss):
        import time;
        ts = time.time()
        ts = time.ctime(ts)
        x=fss-c
        f = open("digit_capture_log.txt", "a")
        f.write("had to modify center x "+str(ts)+"\n")
        f.close()    
    t_paste[y:(y+r),x:x+c]=img[0:r,0:c]
    if(t_invert==1):
        t_paste=255-t_paste
    return t_paste
Exemplo n.º 6
0
def cross_ref_replace_dict(t_file_name):
    #This function creates the cross reference dictionary used by
    #insert_mods_into_js_file
    import pandas as pd
    from digit_capture import set_file_name_prefix
    from digit_capture import get_global_settings as gs
    colab_choice_save=['not_colab_output(imgData)','colab_output(imgData)']
    colab_choice_label=['change_class_label_no_colab()',
                        'change_class_label_colab()']
    t_full_side_size=gs('grid_count')*gs('pxl')
    cross_ref_dict={'?width?':t_full_side_size,'?height?':t_full_side_size}
    test_keys = ["?class00?",
                 "?class01?",
                 "?class02?",
                 "?class03?",
                 "?class04?",
                 "?class05?",
                 "?class06?",
                 "?class07?",
                 "?class08?",
                 "?class09?",
                 "?selval?",
                 "?width?",
                 "?height?"]
    test_values = [0,0,0,0,0,0,0,0,0,0,3,t_full_side_size,t_full_side_size] 
    # using dictionary comprehension 
    # to convert lists to dictionary 
    res = {test_keys[i]: test_values[i] for i in range(len(test_keys))}
    res['?selval?']=get_val_from_dict_csv('?selval?')
    #fname_pfx=set_file_name_prefix(0)[0]
    #print(fname_pfx)
    #df=pd.read_csv(fname_pfx+t_file_name,header=None)
    #t_df=df.iloc[:,0:2]
    #t_list=['class','replace_dict']
    #t_df.columns = t_list
    #dd=t_df.groupby('class').count().to_dict()
    dd=get_class_counts(t_file_name)
    #print(dd['replace_dict'])
    for k, v in dd['replace_dict'].items():
        #print(k,dd['replace_dict'][k])
        res[k]=dd['replace_dict'][k]
    res['?grid_count?']=get_dict()['grid_count']
    res['?pxl?']=get_dict()['pxl']
    res['?line_wd?']=get_dict()['line_wd']
    res['?output_data?']=colab_choice_save[in_colab()]
    res['?class_label_choice?']=colab_choice_label[in_colab()]
    return res
Exemplo n.º 7
0
def check_if_enough_pixels(t_image):
      # The function counts the number of pixels in the figure.
      # It returns '1' if there are enough pixels, '0' if not enough.
      # Enough defined as greater than min_pxl_count in global_settings
      # A canvas with no figure will have no 'figure pixels'
    import cv2
    import numpy as np
    from digit_capture import get_global_settings as gs 
    (thresh,gray) = cv2.threshold(t_image,gs('threshold_low'),255,cv2.THRESH_BINARY)
    gray=255-gray
    t_sum=np.sum(gray)/255
    #print('t_sum '+str(t_sum))
    #print(gray)
    rtn=0
    if(t_sum>gs('min_pxl_count')):
        rtn=1
    return rtn                        
Exemplo n.º 8
0
def set_in_bounding_square(t_image,t_side,i):
    # takes in a grayscale image and returns the same
    # image within its bounding square
    import numpy as np
    import cv2
    from digit_capture import get_global_settings as gs
    fss=gs('final_side_size')
    t_image=t_image.astype('uint8')
    t_image = cv2.resize(t_image,(fss,fss))
    #print("bounding "+str(type(t_image[0,0]))+"   "+str(i))
    #(thresh, t_image) = cv2.threshold(t_image, 20, 255, cv2.THRESH_BINARY | cv2.THRESH_OTSU)
    #if(t_invert==0):        
    #    t_image = 255-t_image
    t_image = 255 - t_image
    while np.sum(t_image[0]) == 0:
        t_image = t_image[1:]

    while np.sum(t_image[:,0]) == 0:
        t_image = np.delete(t_image,0,1)

    while np.sum(t_image[-1]) == 0:
        t_image = t_image[:-1]

    while np.sum(t_image[:,-1]) == 0:
        t_image = np.delete(t_image,-1,1)
    rows,cols=t_image.shape
    nrows=0
    ncols=0
    if(rows>cols):
        factor=t_side/rows
        nrows=t_side
        ncols=int(factor*cols)
    else:
        factor=t_side/cols
        ncols=t_side
        nrows=int(factor*rows)
    #print(nrows)
    #print(ncols)
    #print((t_image.shape))
    new_image=cv2.resize(t_image,(ncols,nrows))
    (thresh, new_image) = cv2.threshold(new_image,gs('threshold_low'), 255, cv2.THRESH_BINARY | cv2.THRESH_OTSU)
    return new_image
Exemplo n.º 9
0
def getBestShift(img):
    #Used to help center the image. The goal is to
    #align the images.
    import numpy as np
    import scipy.ndimage as ndi
    from digit_capture import get_global_settings as gs
    fss=gs('final_side_size')
    cy,cx = ndi.measurements.center_of_mass(255-img)
    shiftx = np.round(fss/2.0-cx).astype(int)
    shifty = np.round(fss/2.0-cy).astype(int)
    return shiftx,shifty
Exemplo n.º 10
0
def reformat_mnist(tData,t_invert):
    # Finds the bounding square ff the image and
    # then centers the the image in a 28 by 28 field
    import numpy as np
    from digit_capture import get_global_settings as gs
    fss=gs('final_side_size')
    entries=tData.shape[0]
    new_format=np.zeros((entries,(fss*fss)),dtype='uint8')
    for i in range(0,entries):
        t_image=set_in_bounding_square(tData[i,:,:],20,i)
        shifted=shift_2(t_image,t_invert)
        shifted=np.reshape(shifted,(fss*fss,))
        new_format[i,:]=shifted
    return new_format    
Exemplo n.º 11
0
def output_data(t_data):
    #Outputs the image to a csv file
    from digit_capture import get_global_settings as gs
    t_dest=set_file_name_prefix(0)
    fname_pfx=t_dest[0]
    dmy=len(t_data)
    import numpy as np
    import cv2
    tAry=np.asarray(t_data)
    #tAry
    final_side_size=gs('final_side_size')
    grid_count = gs('grid_count')
    t_class=gs('t_class')
    df_class=make_class_list(t_class,(grid_count*grid_count))
    df_column_names=make_col_list((final_side_size*final_side_size))
    pxl=gs('pxl')
    line_wd=gs('line_wd')
    canvas_width = grid_count*pxl
    canvas_height = grid_count*pxl
    prev_x=-999999;
    prev_y=-999999;
    x_coords=[]
    y_coords=[]
    width = canvas_width  # canvas width
    height = canvas_height # canvas height
    center = height/2
    white = (255, 255, 255) # canvas back
    t_bd1=5
    t_bd2=175
    d_1=1
    d_2=gs('d_2')
    d_3=120
    d_4=180
    wdh=1
    #print(type(t_data))
    tAry=np.asarray(t_data,dtype="uint8")
    #tAry.shape
    #tAry2_dim0=int(len(tAry)/4)
    #tAry2=np.reshape(tAry,(tAry2_dim0,4))
    #nw_image=np.reshape(tAry2[0:tAry2_dim0,0],(canvas_width,canvas_width))
    #cv2.imwrite(fname_pfx+'python_version.jpg',nw_image)
    #print(' point 3 '+str(nw_image.shape))
    #print(type(nw_image[0,0]))
    nw_image=np.reshape(tAry,(canvas_width,canvas_width))
    save(nw_image)