File: test_compress_swirl.py

package info (click to toggle)
basis-universal 2.0.2-3
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 216,436 kB
  • sloc: cpp: 163,224; ansic: 51,368; python: 2,824; javascript: 2,637; lisp: 1,026; sh: 161; makefile: 17
file content (82 lines) | stat: -rw-r--r-- 2,343 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#!/usr/bin/env python3
import numpy as np
from PIL import Image
from math import sin, cos, atan2, hypot

from basisu_py.codec import Encoder, EncoderBackend
from basisu_py.constants import BasisTexFormat, BasisQuality, BasisEffort, BasisFlags


# --------------------------------------------------------------
# Procedural swirl pattern (RGBA8)
# --------------------------------------------------------------
def make_swirl_image(w=256, h=256):
    arr = np.zeros((h, w, 4), dtype=np.uint8)

    cx = w / 2.0
    cy = h / 2.0

    for y in range(h):
        for x in range(w):
            dx = x - cx
            dy = y - cy

            dist = hypot(dx, dy)
            angle = atan2(dy, dx)

            r = int((sin(dist * 0.15) * 0.5 + 0.5) * 255)
            g = int((sin(angle * 3.0)   * 0.5 + 0.5) * 255)
            b = int((cos(dist * 0.10 + angle * 2.0) * 0.5 + 0.5) * 255)

            arr[y, x] = (r, g, b, 255)

    return arr


# --------------------------------------------------------------
# Test encode using a given backend
# --------------------------------------------------------------
def compress_swirl(backend, outfile):
    print(f"\n========== Testing {backend} backend ==========")

    # Build procedural image
    swirl = make_swirl_image(256, 256)
    print("Generated swirl image:", swirl.shape)

    # Create encoder
    enc = Encoder(backend=backend)

    # Compress
    blob = enc.compress(
        swirl,
        format=BasisTexFormat.cUASTC_LDR_4x4,
        quality=BasisQuality.MAX,
        effort=BasisEffort.DEFAULT,
        flags=BasisFlags.KTX2_OUTPUT | BasisFlags.SRGB
    )

    print(f"Compressed blob size: {len(blob)} bytes")

    # Save output
    with open(outfile, "wb") as f:
        f.write(blob)

    print(f"Wrote: {outfile}")
    print("==============================================")


# --------------------------------------------------------------
# Main
# --------------------------------------------------------------
if __name__ == "__main__":
    # Test native backend
    try:
        compress_swirl(EncoderBackend.NATIVE, "swirl_native.ktx2")
    except Exception as e:
        print("Native backend ERROR:", e)

    # Test WASM backend
    try:
        compress_swirl(EncoderBackend.WASM, "swirl_wasm.ktx2")
    except Exception as e:
        print("WASM backend ERROR:", e)