當前位置: 首頁>>代碼示例>>Python>>正文


Python ImageChops.difference方法代碼示例

本文整理匯總了Python中PIL.ImageChops.difference方法的典型用法代碼示例。如果您正苦於以下問題:Python ImageChops.difference方法的具體用法?Python ImageChops.difference怎麽用?Python ImageChops.difference使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在PIL.ImageChops的用法示例。


在下文中一共展示了ImageChops.difference方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: compare_images

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def compare_images(img1, img2):
    """Calculate the difference between two images of the same size
    by comparing channel values at the pixel level.
    `delete_diff_file`: removes the diff image after ratio found
    `diff_img_file`: filename to store diff image

    Adapted from Nicolas Hahn:
    https://github.com/nicolashahn/diffimg/blob/master/diffimg/__init__.py
    """

    # Don't compare if images are of different modes or different sizes.
    if (img1.mode != img2.mode) \
            or (img1.size != img2.size) \
            or (img1.getbands() != img2.getbands()):
        return None

    # Generate diff image in memory.
    diff_img = ImageChops.difference(img1, img2)
    # Calculate difference as a ratio.
    stat = ImageStat.Stat(diff_img)
    diff_ratio = sum(stat.mean) / (len(stat.mean) * 255)

    return diff_ratio * 100 
開發者ID:victordomingos,項目名稱:optimize-images,代碼行數:25,代碼來源:img_dynamic_quality.py

示例2: test_draw_bell_state

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def test_draw_bell_state():
    return circuit.H @ circuit.Id(1) >> circuit.CX


# def test_Diagram_to_gif():
#     file = 'EckmannHilton.gif'
#     path_ref = os.path.join(IMG_FOLDER, file)
#     path_test = os.path.join(IMG_FOLDER, '.' + file)
#
#     step0 = Box('s0', Ty(), Ty()) @ Box('s1', Ty(), Ty())
#     step1 = next(step0.normalize())
#     Diagram.to_gif(
#         step0, step1,
#         loop=True, margins=(0.1, 0.1), figsize=(3, 3),
#         path=path_test)
#
#     img_ref = Image.open(path_ref).convert('RGB')
#     img_test = Image.open(path_test).convert('RGB')
#     assert ImageChops.difference(img_ref, img_test).getbbox() is None
#     os.remove(path_test) 
開發者ID:oxford-quantum-group,項目名稱:discopy,代碼行數:22,代碼來源:test_drawing.py

示例3: analyze_difference_smartly

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def analyze_difference_smartly(img):
    "Make an evaluation of a difference image"
    result_flag = False
    if not os.path.exists(img):
        print('Could not locate the image to analyze the difference smartly: %s'%img)
    else:
        my_image = Image.open(img)   
        #Not an ideal line, but we dont have any enormous images
        pixels = list(my_image.getdata())
        pixels = [1 for x in pixels if x!=0]
        num_different_pixels = sum(pixels)
        print('Number of different pixels in the result image: %d'%num_different_pixels)
        #Rule 1: If the number of different pixels is <10, then pass the image
        #This is relatively safe since all changes to objects will be more than 10 different pixels
        if num_different_pixels < 10:
            result_flag = True

    return result_flag 
開發者ID:qxf2,項目名稱:makemework,代碼行數:20,代碼來源:Image_Compare.py

示例4: _compute_diff_box

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def _compute_diff_box(cls, a, b, round_to=2):
        '''
        Find the four coordinates giving the bounding box of differences between a and b
        making sure they are divisible by round_to

        Parameters
        ----------

        a : PIL.Image
            The first image

        b : PIL.Image
            The second image

        round_to : int
            The multiple to align the bbox to
        '''
        box = ImageChops.difference(a, b).getbbox()
        if box is None:
            return None
        return cls._round_bbox(box, round_to) 
開發者ID:soonuse,項目名稱:epd-library-python,代碼行數:23,代碼來源:display.py

示例5: test_transforms

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def test_transforms(self):
        settings = get_settings(IMAGE_PROCESS=self.transforms)

        def test_transform(d, i, tmpdir):
            path, name = os.path.split(i)
            destination = os.path.join(tmpdir, d, name)
            image = (i, destination, settings["IMAGE_PROCESS"][d])

            process_image(image, settings)

            transformed = Image.open(destination)

            expected_path = os.path.join(path, "results", d, name)
            expected = Image.open(expected_path)

            img_diff = ImageChops.difference(transformed, expected).getbbox()

            self.assertEqual(img_diff, None)

        with temporary_folder() as tmpdir:
            [
                test_transform(d, i, tmpdir)
                for d in self.transforms
                for i in TEST_IMAGES
            ] 
開發者ID:whiskyechobravo,項目名稱:image_process,代碼行數:27,代碼來源:test_image_process.py

示例6: analyze_difference_smartly

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def analyze_difference_smartly(img):
    "Make an evaluation of a difference image"
    result_flag = False
    if not os.path.exists(img):
        print('Could not locate the image to analyze the difference smartly: %s'%img)
    else:
        my_image = Image.open(img)
        #Not an ideal line, but we dont have any enormous images
        pixels = list(my_image.getdata())
        pixels = [1 for x in pixels if x!=0]
        num_different_pixels = sum(pixels)
        print('Number of different pixels in the result image: %d'%num_different_pixels)
        #Rule 1: If the number of different pixels is <10, then pass the image
        #This is relatively safe since all changes to objects will be more than 10 different pixels
        if num_different_pixels < 10:
            result_flag = True

    return result_flag 
開發者ID:qxf2,項目名稱:qxf2-page-object-model,代碼行數:20,代碼來源:Image_Compare.py

示例7: ela

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def ela(filename, output_path):
    print "****ELA is in BETA****"
    if magic.from_file(filename, mime=True) == "image/jpeg":
        quality_level = 85
        tmp_img = os.path.join(output_path,os.path.basename(filename)+".tmp.jpg")
        ela = os.path.join(output_path,os.path.basename(filename)+".ela.jpg")
        image = Image.open(filename)
        image.save(tmp_img, 'JPEG', quality=quality_level)
        tmp_img_file = Image.open(tmp_img)
        ela_image = ImageChops.difference(image, tmp_img_file)
        extrema = ela_image.getextrema()
        max_diff = max([ex[1] for ex in extrema])
        scale = 255.0/max_diff
        ela_image = ImageEnhance.Brightness(ela_image).enhance(scale)
        ela_image.save(ela)
        os.remove(tmp_img)
    else:
        print "ELA works only with JPEG"


#Modified version of a gist by: https://github.com/erans 
開發者ID:redaelli,項目名稱:imago-forensics,代碼行數:23,代碼來源:extractor.py

示例8: assertImagesAreEqual

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def assertImagesAreEqual(self, current, expected, diff_tolerance=0.001):
        """Checks if both images are similar enough to be considered equal.
        Similarity is controlled by the ```diff_tolerance``` argument."""
        from PIL import Image, ImageChops

        if isinstance(current, str):
            current = Image.open(current)
        if isinstance(expected, str):
            expected = Image.open(expected)

        diff = ImageChops.difference(expected, current)
        black_pixels = _get_black_pixels(diff)
        total_pixels = diff.size[0] * diff.size[1]
        similarity_ratio = black_pixels / total_pixels
        self.assertTrue(
            1 - similarity_ratio < diff_tolerance,
            'The images are different by {}%'.format((1 - similarity_ratio) * 100) +
            ' which is more than the allowed {}%'.format(diff_tolerance * 100)) 
開發者ID:Qiskit,項目名稱:qiskit-terra,代碼行數:20,代碼來源:visualization.py

示例9: get_diff_at_quality

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def get_diff_at_quality(photo, quality):
    """Return a difference score for this JPEG image saved at the specified quality

    A SSIM score would be much better, but currently there is no pure Python
    implementation available.
    """
    diff_photo = BytesIO()
    # optimize is omitted here as it doesn't affect
    # quality but requires additional memory and cpu
    photo.save(diff_photo, format="JPEG", quality=quality, progressive=True)
    diff_photo.seek(0)
    diff_score = compare_images(photo, Image.open(diff_photo))

    # print("================> DIFF1 == DIFF2? ", diff_score==diff_score2)

    if diff_score < 0:
        return -1 + diff_score / 100
    else:
        return 1 - diff_score / 100 
開發者ID:victordomingos,項目名稱:optimize-images,代碼行數:21,代碼來源:img_dynamic_quality.py

示例10: test_size

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def test_size(font_awesome, image, size):
    """Test size option"""
    original_file = os.path.join(BASE_DIR, 'files', image)

    font_awesome.export_icon(icon='rocket', size=size)
    exported_file = os.path.join('exported', 'rocket.png')

    img1 = Image.open(original_file)
    img2 = Image.open(exported_file)

    # Check dimensions
    assert img1.size == (size, size)
    assert img2.size == (size, size)

    # Check if the images are equal
    assert ImageChops.difference(img1, img2).getbbox() is None 
開發者ID:Pythonity,項目名稱:icon-font-to-png,代碼行數:18,代碼來源:test_icon_font.py

示例11: pixel_diff

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def pixel_diff(image_a, image_b):
    """
    Calculates a black/white image containing all differences between the two input images.

    :param image_a: input image A
    :param image_b: input image B
    :return: a black/white image containing the differences between A and B
    """

    if image_a.size != image_b.size:
        raise ImageCompareException(
            "different image sizes, can only compare same size images: A=" + str(image_a.size) + " B=" + str(
                image_b.size))

    if image_a.mode != image_b.mode:
        raise ImageCompareException(
            "different image mode, can only compare same mode images: A=" + str(image_a.mode) + " B=" + str(
                image_b.mode))

    diff = ImageChops.difference(image_a, image_b)
    diff = diff.convert('L')

    return diff 
開發者ID:AXeL-dev,項目名稱:Dindo-Bot,代碼行數:25,代碼來源:imgcompare.py

示例12: verify_data

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def verify_data(client, data, vis, prefix=''):
    res_path = './tests/resources/'
    assert data['input_file_name']
    assert data['predict_probs']
    if data['has_output']:
        assert data['output_file_names']
        i = 1
        for filename in data['output_file_names']:
            actual_image = client.get(url_for('api.download_outputs', filename=filename)).data
            actual_processed_input = Image.open(io.BytesIO(actual_image))
            expected_processed_input = Image.open(res_path + vis.__name__ + '/' + prefix + 'output/' + str(i) + '.png')
            assert ImageChops.difference(actual_processed_input, expected_processed_input).getbbox() is None
            i += 1
    if data['has_processed_input']:
        assert data['processed_input_file_name']
        filename = data['processed_input_file_name']
        actual_image = client.get(url_for('api.download_outputs', filename=filename)).data
        actual_processed_input = Image.open(io.BytesIO(actual_image))
        expected_processed_input = Image.open(res_path + vis.__name__ + '/' + prefix + 'pre/default.png')
        assert ImageChops.difference(actual_processed_input, expected_processed_input).getbbox() is None 
開發者ID:merantix,項目名稱:picasso,代碼行數:22,代碼來源:test_rest.py

示例13: image

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def image(self, im):
        for p in range(8):
            pr = self.im.crop((0,8*p,128,8*p+8)).transpose(Image.ROTATE_270)
            bb = im.crop((0,8*p,128,8*p+8)).transpose(Image.ROTATE_270)
            diff = ImageChops.difference(pr, bb)
            di = diff.getbbox()
            if di is not None:
                (x0, y0, x1, y1) = di
                self.command(COLUMNADDR)
                self.command(y0)
                self.command(y1 - 1)
                self.command(PAGEADDR)
                self.command(p)
                self.command(p + 1)
                self.i2.start(self.a, 0)
                self.i2.write([0x40])
                self.i2.write(bb.tobytes()[y0:y1])
                self.i2.stop()
        self.im = im
        self.command(DISPLAYON) 
開發者ID:jamesbowman,項目名稱:i2cdriver,代碼行數:22,代碼來源:oled.py

示例14: get_mask

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def get_mask(raw_pil, clean_pil):
        raw = raw_pil.convert("L")
        clean = clean_pil.convert("L")
        mask = ImageChops.difference(raw, clean)
        return mask 
開發者ID:yu45020,項目名稱:Text_Segmentation_Image_Inpainting,代碼行數:7,代碼來源:Dataloader.py

示例15: trim

# 需要導入模塊: from PIL import ImageChops [as 別名]
# 或者: from PIL.ImageChops import difference [as 別名]
def trim(im, bg=None):
    if bg is None:
        bg = get_bg(im)
    diff = ImageChops.difference(im, bg)
    bbox = diff.getbbox()
    if bbox:
        return im.crop(bbox), bbox 
開發者ID:tmr232,項目名稱:GraphGrabber,代碼行數:9,代碼來源:graphgrabber.py


注:本文中的PIL.ImageChops.difference方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。