相機 ITS 測試

本頁面提供 Camera Image Test Suite (ITS) 的完整測試清單,該套件是 Android 相容性測試套件 (CTS) 驗證工具的一部分。ITS 測試是功能測試,也就是說,它們不會評估影像品質,而是檢查所有宣傳的相機功能是否正常運作。這份文件可讓開發人員和測試人員瞭解個別測試的功能,以及如何偵錯測試失敗情形。

Camera ITS 會根據必要的相機屬性、API 級別和媒體效能類別 (MPC) 級別,控管測試。針對 API 級別,ITS 會使用 ro.product.first_api_level 來控管在特定 API 級別中新增的測試,以便測試較低 API 級別的功能是否會帶來負面使用者體驗。ITS 會使用 ro.vendor.api_level 為特定 API 層級中新增的功能設定測試門檻,這些功能需要新的硬體功能。如果已為裝置定義 ro.odm.build.media_performance_class,ITS 就需要根據 MPC 等級執行特定測試。

測試會按以下場景分組:

請參閱各個部分,瞭解各個場景的說明。

場景 0

Scene0 測試不需要特定場景資訊。不過,手機必須保持靜止才能進行陀螺儀和震動測試。

測試時基誤差

評估攝影機時間戳記中的雜訊。

測試的 API:

通過:每個影格之間至少有 30 毫秒的差異。

test_jitter_plot.png

test_jitter_plot.png (請注意 y 軸範圍很小。在這個圖表中,抖動其實很小。)

test_metadata

測試中繼資料項目的有效性。查看擷取結果和相機特性物件。這項測試會使用 auto_capture_request 曝光和增益值,因為圖片內容並不重要。

測試的 API:

通過:硬體層級、rollingShutterSkewframeDuration 標記、timestampSourcecroppingTypeblackLevelPatternpixel_pitch、視野範圍、超焦距離均已存在且有有效值。

test_request_capture_match

透過讀取擷取中繼資料,測試裝置是否寫入正確的曝光和增益值。

測試的 API:

通過:要求並擷取所有鏡頭的中繼資料值。

test_sensor_events

測試裝置查詢,並針對宣傳感應器融合支援的裝置列印感應器事件。預期的感應器是加速計、陀螺儀和磁力儀。只有在螢幕開啟 (也就是裝置未處於待機模式) 時,這項測試才會生效。

測試的 API:

通過:已收到每個感應器的事件。

test_solid_color_test_pattern

系統會針對鏡頭靜音產生正確產生純色測試模式的測試。如果相機支援靜音功能,則必須支援單色測試圖案。如果系統不支援攝影機靜音功能,則只有在宣告此功能時,系統才會測試單色測試圖案。

如果支援 RAW 圖片,系統也會測試顏色指派。測試的顏色包括黑色、白色、紅色、藍色和綠色。如果相機不支援 RAW 圖片,則只能測試黑色。

測試的 API:

通過:支援的單色測試圖案顏色正確,且圖片變異度低。

test_test_pattern

測試 android.sensor.testPatternMode 參數,擷取每個有效測試圖案的幀,並檢查是否正確產生固色和色條的幀。這項測試包含下列步驟:

  1. 擷取所有支援的測試模式的圖片。
  2. 針對純色測試圖案和色條執行簡單的正確性檢查。

測試的 API:

通過:系統已正確產生支援的測試圖案。

test_test_patterns_2

test_test_patterns_2.jpg

test_tonemap_curve

測試從 RAW 到 YUV 的測試模式,轉換使用線性色調貼圖。這項測試需要 android.sensor.testPatternMode = 2 (COLOR_BARS) 才能產生完美的色調對應轉換圖片模式。確保管道具有線性色調映射和理想圖片輸入的適當顏色輸出內容 (取決於 test_test_patterns)。

測試的 API:

通過:YUV 和 RAW 看起來很像,

test_tonemap_curve_raw_2

test_tonemap_curve_raw_2.jpg

test_tonemap_curve_yuv_2.jpg

test_tonemap_curve_yuv_2.jpg

test_unified_timestamp

測試圖片和動作感應器事件是否位於相同時間網域。

測試的 API:

通過:動態時間戳記介於兩個圖片的時間戳記之間。

test_vibration_restriction

測試裝置的震動功能是否正常運作。

測試的 API:

通過:當裝置因相機音訊限制 API 而靜音時,裝置不會震動。

場景 1

scene1 是灰色圖表。灰色圖必須涵蓋攝影機視野的中央 30%。灰色圖表的挑戰程度為中等,因為中心區域沒有任何特徵。不過,擷取要求會指定整個場景,其中包含足以讓 3A 收斂的功能。

RFoV 攝影機可在 WFoV 或 RFoV 測試支架中進行測試。如果 RFoV 攝影機在 WFoV 測試組中進行測試,圖表會以 2⁄3 縮放,確保 FoV 中灰色圖表的部分邊界,以協助 3A 收合。如要進一步瞭解攝影機測試裝置,請參閱「攝影機 ITS-in-a-box」。

scene1

場景 1:完整大小的圖表 (左側)。2⁄3 縮放的圖表 (右側)。

test_ae_precapture_trigger

測試使用預擷取觸發事件時的 AE 狀態機器。在停用 AE 的情況下擷取五個手動要求。最後一個要求含有 AE 預擷取觸發事件,但由於 AE 已停用,因此應忽略該觸發事件。

測試的 API:

通過:AE 收斂。

test_auto_vs_manual

自動和手動拍攝的測試結果看起來相同。

測試的 API:

通過:每個擷取結果中回報的手動白平衡增益和轉換,與相機 3A 演算法中的自動白平衡 estimate 相符。

test_auto_vs_manual_auto

test_auto_vs_manual_auto.jpg

test_auto_vs_manual_wb

test_auto_vs_manual_wb.jpg

test_auto_vs_manual_manual_wb_tm

test_auto_vs_manual_manual_wb_tm.jpg

test_black_white

測試裝置是否能產生全黑白圖片。拍攝兩張相片,第一張增益極低且曝光極短,即產生黑色相片;第二張採用極高增益和長時間曝光,並產生白色相片。

測試的 API:

通過:產生黑白圖片。白色圖片的飽和通道 RGB 值為 [255, 255, 255],誤差範圍小於 1%。

test_black_white_black test_black_white_black
test_black_white_black.jpg test_black_white_white.jpg

test_black_white_plot_means

test_black_white_plot_means.png

test_burst_capture

驗證整個擷取管道是否能跟上原尺寸擷取速度和 CPU 作業時間。

測試的 API:

通過:擷取一系列全尺寸圖片,檢查影格掉落和圖片亮度。

test_burst_sameness_manual

使用手動拍攝設定拍攝 5 個 50 張連拍相片,並檢查相片是否完全相同。這項測試可用於判斷是否有零星影格以不同方式處理或出現雜訊。

測試的 API:

通過:圖片在視覺和 RGB 值上完全相同。

失敗:顯示每次爆發開始時,RGB 平均圖表的尖峰或驟降情形

  • first_API_level < 30 時,容許誤差為 3%
  • first_API_level 大於等於 30 時,容許值為 2%

test_burst_sameness_manual_mean

test_burst_sameness_manual_mean.jpg

test_burst_sameness_manual__means

test_burst_sameness_manual_plot_means.png

test_capture_result

測試 CaptureResult 物件是否傳回有效資料。是否執行自動、手動和自動擷取。

測試的 API:

通過:中繼資料適用於所有擷取,且手動設定不會洩漏到第二次自動擷取中。為擷取影像繪製鏡頭陰影校正。

test_capture_result_plot_lsc_auto_ch0

test_capture_result_plot_lsc_auto_ch0.png

test_crop_region_raw

測試 RAW 串流是否可丟棄。

測試的 API:

通過:YUV 圖片會裁剪至中心,但 RAW 圖片不會。

test_crop_region_raw_comp_raw_crop

test_crop_region_raw_comp_raw_crop.jpg

test_crop_region_raw_comp_raw_full

test_crop_region_raw_comp_raw_full.jpg

test_crop_region_raw_comp_yuv_crop

test_crop_region_raw_comp_yuv_crop.jpg

test_crop_region_raw_yuv_full

test_crop_region_raw_yuv_full.jpg

test_crop_regions

測試裁剪區域是否正常運作。擷取完整圖片,並建立 5 個不同區域 (角落和中心) 的補丁。擷取裁剪區域已設定的 5 張圖片。比較修補圖片和裁剪圖片的值。

測試的 API:

通過:裁剪區域的圖片與裁剪圖片對應的修補程式。

test_dng_noise_model

驗證 DNG 原始模型參數是否正確。這張圖表顯示在不同感光度下拍攝的原始影像中,灰卡中心區域的變化量,並將這些值與相機 HAL 中 DNG 雜訊模型在每個感光度下預期的變化量進行比較 (根據擷取結果物件中傳回的 O、S 參數)。如要進一步瞭解 DNG 雜訊模型,請下載以下關於 DNG 雜訊模型的文件。

測試的 API:

通過:DNG 原始模型參數正確無誤。預期的 RGB 值與實際測量到的 RGB 值相符。

test_dng_noise_model_plog

test_dng_noise_model_plog.png

test_ev_compensation_advanced

測試是否套用了曝光值 (EV) 補償。這項測試會以八個步驟增加曝光,並檢查測得的亮度與預期亮度。預期值是從未套用電動車補償的圖像亮度計算而來,如果計算的值超過實際圖像值範圍,預期值會飽和。如果預期值和測量值不符,或圖像在五個步驟內過度曝光,則測試會失敗。

測試的 API:

通過:圖片顯示曝光值逐漸增加,且在五個步驟內不會過度曝光。

test_ev_compensation_advanced_plot_means

test_ev_compensation_advanced_plot_means.png

test_ev_compensation_basic

測試使用 CONTROL_AE_COMPENSATION_STEP 建立的範圍套用 EV 補償效果。系統會在每個補償值擷取八個影格。

測試的 API:

通過:隨著 EV 補償設定增加,亮度值會增加,且為每個 EV 補償設定所擷取的八個影格具有穩定的亮度值。

test_ev_compensation_basic

test_ev_compensation_basic.png

test_exposure_x_iso

測試在 ISO 和曝光時間變化時,是否能達到恆定的曝光效果。拍攝一系列影像,並選擇適當的 ISO 和曝光時間,以便平衡各個影像。結果的亮度應相同,但圖片順序應會較為雜訊。確認樣本像素平均值彼此相近。請確保圖片不會限制為 0 或 1,以免圖片看起來像平面線。您也可以在設定檔中設定 debug 標記,以便使用 RAW 圖片執行測試。

測試的 API:

通過:圖片的亮度相同,但 ISO 感提高,看起來更清晰。如果 ISO*曝光 值在測試增益空間中保持不變,RGB 平面就會變得平坦。

失敗機制:

  • test_exposure_plot_means.png 中,隨著增益乘數值 (x 軸) 增加,經過標準化的 RGB 平面平均值 (y 軸) 開始偏離低增益乘數值。

test_exposure_plot_means

test_exposure_plot_means.png

test_exposure_mult=1.00 test_exposure_mult=64.00
test_exposure_mult=1.00.jpg test_exposure_mult=64.00.jpg

test_jpeg

測試轉換的 YUV 圖片和裝置 JPEG 圖片是否相同。測試會使用圖像的 10% 進行計算,並計算 RGB 值,確認兩者是否相符。

測試的 API:

通過:每張圖片之間的平均 RGB 差異小於 3%。

test_jpeg_fmt=jpg.jpg test_jpeg=fmt=yuv.jpg
test_jpeg_fmt=jpg.jpg test_jpeg=fmt=yuv.jpg

test_latching

測試 FULLLEVEL_3 攝影機右側影格的設定 (曝光和增益) 閂鎖。使用連續要求拍攝一系列影像,並在影像之間變更擷取要求參數。檢查圖片是否具有預期的屬性。

測試的 API:

通過:圖片 [2, 3, 6, 8, 10, 12, 13] 的 ISO 或曝光值較高,在 test_latching_plot_means.png 上顯示的 RGB 平均值也較高。

test_latching_i=00.jpg test_latching_i=01.jpg test_latching_i=02.jpg
test_latching_i=00.jpg test_latching_i=01.jpg test_latching_i=02.jpg
test_latching_i=03.jpg test_latching_i=04.jpg test_latching_i=05.jpg
test_latching_i=03.jpg test_latching_i=04.jpg test_latching_i=05.jpg
test_latching_i=06.jpg test_latching_i=07.jpg test_latching_i=08.jpg
test_latching_i=06.jpg test_latching_i=07.jpg test_latching_i=08.jpg
test_latching_i=09.jpg test_latching_i=10.jpg test_latching_i=11.jpg
test_latching_i=09.jpg test_latching_i=10.jpg test_latching_i=11.jpg
test_latching_i=12.jpg
test_latching_i=12.jpg

test_latching_plot_means

test_latching_plot_means.png

test_linearity

測試裝置處理作業是否可反轉為線性像素。將裝置對準單一目標,擷取一系列連續鏡頭。

測試的 API:

通過:R、G、B 值必須隨著靈敏度增加而線性增加。

test_linearity_plot_means

test_linearity_plot_means.png

test_locked_burst

測試 3A 鎖和 YUV 爆發 (使用自動設定)。這項測試的設計目的是即使在沒有 MANUAL_SENSORPER_FRAME_CONTROLS 的裝置上也能通過測試。這個測試會檢查 YUV 圖像的一致性,而影格速率檢查是 CTS。

測試的 API:

通過:擷取畫面看起來一致。

test_locked_burst_frame0

test_locked_burst_frame0.jpg

test_locked_burst_frame1

test_locked_burst_frame1.jpg

test_locked_burst_frame2

test_locked_burst_frame2.jpg

test_param_color_correction

測試在設定時套用 android.colorCorrection.* 參數。使用不同的轉換和增益值拍攝相片,並測試相片是否有相應的差異。選擇轉換和增益時,系統會讓輸出內容變為紅色或藍色。使用線性色調圖。色調對應是在圖片處理作業中使用的技術,將一組顏色對應至另一個顏色,可在動態範圍有限的媒介中,模擬高動態範圍圖片的外觀。

測試的 API:

通過:R 和 B 值會根據轉換而增加。

test_param_color_correction_plot_means

test_param_color_正確的繪圖_means.png

*X 軸為擷取要求:0 = 統一、1=紅色加強、2= 藍色加強

test_param_color_correction_req=0

test_param_color_correction_req=0.jpg

test_param_color_correctness_req=1

test_param_color_correctness_req=1.jpg (R 加強版)

test_param_color_correction_req=2

test_param_color_correction_req=2.jpg (B 增強)

test_param_flash_mode

測試是否套用 android.flash.mode 參數。手動將曝光值設為較暗,以便清楚判斷閃光燈是否已觸發,並使用線性色調圖。使用圖塊圖片檢查中心,看看是否有大型漸層效果,以便確認閃光燈是否已啟動。

測試的 API:

通過:圖塊圖片的中心有大型漸層,表示已觸發閃光燈。

test_param_flash_mode_1

test_param_flash_mode_1.jpg

test_param_flash_mode_1_tile

test_param_flash_mode_1_tile.jpg

test_param_flash_mode_2

test_param_flash_mode_2.jpg

test_param_flash_mode_2_tile

test_param_flash_mode_2_tile.jpg

test_param_noise_reduction

測試 android.noiseReduction.mode 參數在設定時是否正確套用。在光線昏暗的環境下拍攝相片。使用高類比增益,確保擷取的圖像有雜訊。拍攝三張圖片,分別為 NR 關閉、"快速"和 "高品質"。同時以低增益和 NR 關閉的設定拍攝圖片,並使用這項變化的差異做為基準。SNR (訊號雜訊比) 越高,圖像品質越好。

測試的 API:

通過:SNR 會因不同的降噪模式而異,且行為類似下方圖表所示。

test_param_noise_reduction_chart_SNRs

test_param_noise_reduction_chart_SNRs.png

0:關閉, 1: 快速, 2: 總部, 3: 分鐘 , 4: ZSL

test_param_noise_reduction_high_gain_nr=0

test_param_noise_reduction_high_gain_nr=0.jpg

test_param_noise_reduction_high_gain_nr=1

test_param_noise_reduction_high_gain_nr=1.jpg

test_param_noise_reduction_high_gain_nr=2

test_param_noise_reduction_high_gain_nr=2.jpg

test_param_noise_reduction_high_gain_nr=3

test_param_noise_reduction_high_gain_nr=3.jpg

test_param_noise_reduction_low_gain

test_param_noise_reduction_low_gain.jpg

test_param_shading_mode

測試是否套用 android.shading.mode 參數。

測試的 API:

通過:著色模式會切換,鏡頭陰影地圖也會依預期修改。

test_param_shading_mode_ls_maps_mode_0_loop_0

test_param_shading_mode_ls_maps_mode_0_loop_0.png

test_param_shading_mode_ls_maps_mode_1_loop_0

test_param_shading_mode_ls_maps_mode_1_loop_0.png

test_param_shading_mode_ls_maps_mode_2_loop_0

test_param_shading_mode_ls_maps_mode_2_loop_0.png

test_param_tonemap_mode

測試是否套用了 android.tonemap.mode 參數。為每個 R、G、B 管道套用不同的色調對應曲線,並檢查輸出圖片是否正常修改。這個測試包含兩個測試:test1 和 test2。

測試的 API:

Pass:

  • test1:兩張圖片都有線性色調對應表,但 n=1 的漸層較陡峭。在 n=1 的圖像中,G (綠色) 通道較亮。
  • test2:同樣使用同一個色調圖,但長度不同。圖片相同。
test_param_tonemap_mode_n=0.jpg test_param_tonemap_mode_n=1.jpg
test_param_tonemap_mode_n=0.jpg test_param_tonemap_mode_n=1.jpg

test_post_raw_sensitivity_boost

檢查 RAW 感光度提升後的結果。擷取一組不同靈敏度的 RAW 和 YUV 圖片,然後發布 RAW 靈敏度增強組合,並檢查輸出像素是否代表與要求設定相符。

測試的 API:

通過:當 RAW 圖片增加時,RAW 圖片會變暗,而 YUV 圖像的亮度會保持不變

test_post_raw_sensitivity_boost_raw_s=3583_boost=0100

test_post_raw_sensitivity_boost_raw_s=3583_boost=0100.jpg

test_post_raw_sensitivity_boost_raw_s=1792_boost=0200

test_post_raw_sensitivity_boost_raw_s=1792_boost=0200.jpg

test_post_raw_sensitivity_boost_raw_s=0896_boost=0400

test_post_raw_sensitivity_boost_raw_s=0896_boost=0400.jpg

test_post_raw_sensitivity_boost_raw_s=0448_boost=0800

test_post_raw_sensitivity_boost_raw_s=0448_boost=0800.jpg

test_post_raw_sensitivity_boost_raw_s=0224_boost=1600

test_post_raw_sensitivity_boost_raw_s=0224_boost=1600.jpg

test_post_raw_sensitivity_boost_raw_s=0112_boost=3199

test_post_raw_sensitivity_boost_raw_s=0112_boost=3199.jpg

test_post_raw_sensitivity_boost_raw_繪圖_means

test_post_raw_sensitivity_boost_raw__means.png

test_post_raw_sensitivity_boost_yuv_s=0112_boost=3199

test_post_raw_sensitivity_boost_yuv_s=0112_boost=3199.jpg

test_post_raw_sensitivity_boost_yuv_s=0448_boost=0800

test_post_raw_sensitivity_boost_yuv_s=0448_boost=0800.jpg

test_post_raw_sensitivity_boost_yuv_s=0896_boost=0400

test_post_raw_sensitivity_boost_yuv_s=0896_boost=0400.jpg

test_post_raw_sensitivity_boost_yuv_s=1792_boost=0200

test_post_raw_sensitivity_boost_yuv_s=1792_boost=0200.jpg

test_post_raw_sensitivity_boost_yuv_s=3585_boost=0100

test_post_raw_sensitivity_boost_yuv_s=3585_boost=0100.jpg

test_post_raw_sensitivity_boost_yuv_plot_means

test_post_raw_sensitivity_boost_yuv_caption_means.png

test_raw_burst_sensitivity

擷取一組可提高增益的原始圖片,並測量雜訊。 以連拍模式拍攝純 RAW 相片。

測試的 API:

Pass:隨著增益增加,每張影像的雜訊都會比前一張影像更高。

使用中心統計資料格線儲存格的變異數。

test_raw_burst_sensitivity_variance

test_raw_burst_sensitivity_variance.png

test_raw_exposure

以逐漸增加的曝光時間拍攝一組原始影像,並測量像素值。

測試的 API:

通過:提高 ISO (增益) 會讓像素對光線更敏感,因此圖表會向左移動。

test_raw_exposure_s=55

test_raw_exposure_s=55.png

(10⁰ 是 1 毫秒、10¹ 是 10 毫秒、10⁻¹ 是 0.1 毫秒)

test_raw_exposure_s=132

test_raw_exposure_s=132.png

test_raw_exposure_s=209

test_raw_exposure_s=209.png

test_raw_exposure_s=286

test_raw_exposure_s=286.png

test_raw_exposure_s=363

test_raw_exposure_s=363.png

test_raw_exposure_s=440

test_raw_exposure_s=440.png

test_raw_sensitivity

以逐漸增加的靈敏度擷取一組原始圖片,並測量圖片中心 10% 的雜訊 (變異)。測試每個鏡頭的雜訊是否比前一個鏡頭更大。

測試的 API:

Pass:每拍攝一張相片,變化量就會增加。

test_raw_sensitivity_variance

test_raw_sensitivity_variance.png

test_reprocess_noise_reduction

用於重新處理要求的測試。android.noiseReduction.mode在相機光線昏暗的情況下,拍攝經過重新處理的圖像。使用高類比增益,確保擷取的圖像有雜訊。擷取三張經過重新處理的圖片,分別為 NR 關閉、"快速" 和 "高品質"。以低增益和關閉降噪功能重新處理圖像,並使用這項變化做為基準。

測試的 API:

Pass:FAST >= OFF, HQ >= FAST, HQ >> OFF

典型的 SNR 與 NR_MODE 圖表

典型的 SNR 與 NR_MODE 圖表

test_tonemap_sequence

以不同色調圖曲線測試一系列的畫面。以線性色調圖拍攝 3 張手動相片使用預設色調地圖拍攝 3 張手動相片,計算每個連續影格組合之間的差異。

測試的 API:

通過:有 3 個相同的畫面,後面接著另一組 3 個相同的畫面。

test_tonemap_sequence_i=0

test_tonemap_sequence_i=0.jpg

test_tonemap_sequence_i=1

test_tonemap_sequence_i=1.jpg

test_tonemap_sequence_i=2

test_tonemap_sequence_i=2.jpg

test_tonemap_sequence_i=3

test_tonemap_sequence_i=3.jpg

test_tonemap_sequence_i=4

test_tonemap_sequence_i=4.jpg

test_tonemap_sequence_i=5

test_tonemap_sequence_i=5.jpg

test_yuv_jpeg_all

測試圖片拍攝工作中所有回報的尺寸與格式。使用含有線性色調對應的人工要求,以便在透過 image_processing_utils 模組轉換時,YUV 和 JPEG 看起來相同。根據預設,系統不會儲存圖片,但您可以啟用 debug_mode 來儲存圖片。

測試的 API:

通過:所有圖片中心在 RGB 轉換圖片中具有 3% 的最高解析度 YUV 圖片差異,RMS (信號的平方根均方值) 為最大值。

test_yuv_jpeg_all

test_yuv_jpeg_all.png

test_yuv_plus_dng

測試圖片擷取工作回報的大小和格式。

測試的 API:

通過:測試完成並傳回要求的圖片。

test_yuv_plus_dng

test_yuv_plus_dng.jpg

test_yuv_plus_jpeg

測試將單一影格擷取為 YUV 和 JPEG 輸出。使用含有線性色調對應表的手動要求,讓 YUV 和 JPEG 在 image_processing_utils 模組轉換後看起來相同。

測試的 API:

通過:YUV 和 JPEG 圖片相似,RMS (信號的平方根均方值) 差異小於 1%。

test_yuv_plus_jpg_jpg.jpg test_yuv_plus_jpeg_yuv.jpg
test_yuv_plus_jpg_jpg.jpg test_yuv_plus_jpeg_yuv.jpg

test_yuv_plus_raw

測試同時擷取單一影格做為 RAW/RAW10/RAW12 和 YUV 輸出 (如果支援的話)。使用手動要求搭配線性色調對應,以便原始和 YUV 相同。比較 RGB 轉換圖像的中心 10% RGB 值。記錄android.shading.mode

測試的 API:

通過:YUV 和原始圖片相似,且 RMS (信號的均方根值) 差異小於 3.5%。

test_yuv_plus_raw_shading=1_raw.jpg test_yuv_plus_raw_shading=1_yuv.jpg
test_yuv_plus_raw_shading=1_raw.jpg test_yuv_plus_raw_shading=1_yuv.jpg

scene2_a

scene2_a 有三張臉孔,背景為灰色,人物穿著中性色調的衣服。這些臉孔可以呈現出各種膚色。圖表必須有正確的方向,才能讓臉部偵測功能發揮最佳效能。

scene2_a

scene2_a

test_autoframing

測試相機裝置的自動取景行為。執行大縮放,讓畫面中沒有任何臉孔可見,然後將 CaptureRequest 中的 AUTOFRAMING 設為 True,啟用自動構圖模式,並驗證在狀態收斂時,是否能偵測到原始場景中的所有臉孔 (也就是 CaptureResult 中的 AUTOFRAMING_STATE 設為 AUTOFRAMING_STATE_CONVERGED 時)。

測試的 API:

通過:偵測到全部三個臉孔。

test_display_p3

使用 ColorSpaceProfiles API 測試 JPEG 中的 Display P3 擷取作業。測試擷取的 JPEG 是否在標頭中含有適當的 ICC 設定檔,以及圖片是否含有 sRGB 色域以外的顏色。

測試的 API:

通過:JPEG 包含 Display P3 ICC 設定檔,以及 sRGB 色域以外的顏色。

test_effects

針對支援的相機效果擷取影格,並檢查是否正確產生。這項測試只會檢查效果 OFFMONO,但會為所有支援的效果儲存圖片。

測試的 API:

Pass:擷取效果為 OFF 的場景圖片,以及效果設為 MONO 的單色圖片。

test_effects_MONO

test_effects_MONO.jpg

test_format_combos

測試不同的輸出格式組合。

測試的 API:

通過:已成功擷取所有組合。

test_num_faces

測試臉部偵測。

測試的 API:

通過:找到三個臉孔。

test_num_faces_fd_mode_1

test_num_faces_fd_mode_1.jpg

test_reprocess_uv_swap

測試 YUV 重新處理不會交換 U 和 V 飛機。系統會計算重新處理圖片和非重新處理拍攝內容之間的絕對差異 (SAD) 總和,藉此偵測出這個結果。如果交換重新處理擷取結果的輸出 U 和 V 平面,SAD 會增加,系統會假設輸出內容具有正確的 U 和 V 平面。

測試的 API:

通過:U 和 V 平面並未互換。

test_reprocess_uv_swap

test_reprocess_uv_swap.png

場景 2_b

test_num_faces

測試臉部偵測功能,在臉部場景中增加膚色多樣性。

測試的 API:

通過:偵測到 3 張臉孔。

test_num_faces_fd_mode_1

test_num_faces_fd_mode_1.jpg

test_yuv_jpeg_capture_sameness

使用最大常見 YUV 和 JPEG 格式擷取兩張圖片,顯示比例與最大 JPEG 格式相同,解析度不超過 1920x1440。將 jpeg.quality 設為 100,並擷取雙重途徑要求。將兩張圖片轉換成 RGB 陣列,並計算兩張圖片之間的 3D 根平均平方 (RMS) 差異。

此外,這項測試會驗證所有支援的串流用途的 YUV 輸出內容,是否與 STILL_CAPTURE 用途的 YUV 相似。

測試的 API:

通過:STILL_CAPTURE 用途的 YUV 和 JPEG 圖片的 RMS (訊號的根平方值) 差異小於 3%;所有支援用途的 YUV 圖像與採用 STILL_CAPTURE 用途的 YUV 圖片相比,差異不大 10%。

情境 2_c

test_num_faces

測試臉部偵測功能,在臉部場景中增加膚色多樣性。

測試的 API:

通過:偵測到 3 張臉孔。

test_num_faces_fd_mode_1

test_num_faces_fd_mode_1.jpg

test_jpeg_capture_perf_class

測試 JPEG 擷取延遲時間,符合 CDD 中 第 2.2.7.2 節 Camera 所指定的 S 效能類別。

通過:兩個主要相機在 ITS 照明條件 (3000K) 下,使用 CTS 相機 PerformanceTest 測試,相機 2 JPEG 擷取延遲時間必須小於 1000 毫秒 (解析度為 1080p)。

test_camera_launch_perf_class [測試相機]

根據 CDD 的 2.2.7.2 節 Camera 指定,測試 S 效能類別的相機啟動延遲時間。

通過:兩部主相機在 ITS 照明條件 (3000K) 下,使用 CTS 相機 PerformanceTest 測量時,相機 2 的啟動延遲 (開啟相機至第一個預覽影格) 必須小於 600 毫秒。

test_default_camera_hdr

根據 CDD 第 2.2.7.2 節相機中的效能類別 15 所述,測試預設相機擷取為 Ultra HDR。

通過:效能等級 15 裝置的預設相機套件擷取畫面必須為 Ultra HDR。

scene2_d

test_num_faces

測試臉部偵測功能,在臉部場景中增加膚色多樣性。

測試的 API:

通過:偵測到 3 張臉孔。

scene2_e

test_continuous_picture

使用「擷取要求優先」設定,擷取 50 個 VGA 解析度影格 android.control.afMode = 4 (CONTINUOUS_PICTURE).

測試的 API:

通過:在 50 張影格擷取結束時,3A 系統已穩定。

test_num_faces

測試臉部偵測功能,在臉部場景中增加膚色多樣性。

測試的 API:

通過:偵測到 3 張臉孔。

scene2_f

route2_f 有三個臉孔,背景是白色,背景是白色。臉部有各種膚色,且與背景形成高對比。

scene2_f.png

scene2_f

test_num_faces

測試臉部偵測功能,在臉部場景中增加膚色多樣性。

測試的 API:

通過:偵測到 3 張臉孔。

test_num_faces_fd_mode_1

test_num_faces_fd_mode_1.jpg

scene3

Scene3 使用 ISO12233 圖表,且大多數測試都會使用圖表擷取方法,在場景中找出圖表。因此,大多數已儲存的圖片都沒有邊框,只有圖表,例如場景 1、2 或 4 的圖片。圖表必須朝正確的方向排列,圖表尋找器才能以最佳方式運作。

test_edge_enhance

測試 android.edge.mode 參數是否套用正確。針對每個邊緣模式擷取非重新處理的圖片,並傳回輸出圖片和擷取結果中繼資料的銳利度。使用指定的邊緣模式、敏感度、曝光時間、焦點距離和輸出表面參數,處理擷取要求。

通過: HQ 模式 (2) 的銳利比 OFF 模式 (0) 來得高。FAST 模式 (1) 比 OFF 模式更清晰。HQ模式的銳利度提高或等於 FAST 模式。

測試的 API:

受影響的攝影機參數:

  • EDGE_MODE

test_edge_enhancement_edge=0

test_edge_enhancement_edge=0.jpg

test_edge_enhancement_edge=1

test_edge_enhancement_edge=1.jpg (快速模式)

test_edge_enhancement_edge=2

test_edge_enhancement_edge=2.jpg (高畫質模式)

test_flip_mirror

測試圖片是否正確對齊,符合CDD 7.5.2 前置鏡頭 [C-1-5] 的規定。

您可以透過中心附近的菱形圖示,辨識鏡像、翻轉或旋轉的圖片。

通過:圖片未經過翻轉、鏡像或旋轉。

test_flip_mirror_scene_patch

test_flip_mirror_scene_patch.jpg

test_imu_drift

測試裝置處於靜止狀態並擷取高畫質預覽畫面時,慣性測量單元 (IMU) 是否有 30 秒的穩定輸出。

測試的 API:

Pass:

  • 在測試期間,陀螺儀的漂移量小於 0.01 弧度。
  • 在測試期間,陀螺儀讀數的變化量低於 1E-7 rad/s2/Hz。
  • 在測試期間,旋轉向量的偏移量小於 0.01 弧度。
  • (尚未強制規定) 陀螺儀的漂移率低於每秒 1 度。

test_imu_drift_gyro_drift.png

test_imu_drift_gyro_drift.png

test_imu_drift_rotation_vector_drift.png

test_imu_drift_rotation_vector_drift.png

test_landscape_to_portrait

測試橫向至直向覆寫功能是否可正確運作,適用於橫向感應器。

測試的 API:

通過:測試能夠找到旋轉角度符合預期的圖表 (停用橫向至直向覆寫值時為 0 度,啟用時為 90 度)。

測試橫向_橫向

test_landscape_to_portrait.png

test_lens_movement_reporting

測試鏡頭移動旗標是否已正確回報。以連拍模式拍攝 24 張影像,其中前 12 張影像的焦距距離為最佳焦距 (由 3A 偵測),後 12 張影像的焦距距離為最小焦距。在第 12 個影格左右,鏡頭會移動,導致清晰度降低。當鏡頭移動到最終位置時,清晰度最終會穩定下來。在所有影格中,如果在前幾個影格中,鏡頭在最佳焦距距離處靜止時,影像清晰度介於中等至清晰之間,以及在最後幾個影格中,鏡頭在最小焦距距離處靜止時,影像清晰度介於中等至清晰之間,則應宣告鏡頭移動標記。鏡頭移動的確切畫面並不重要:檢查的重點在於鏡頭移動時,動作旗標已宣告。

測試的 API:

通過:在有銳利度變化的影格中,鏡頭移動標記為 True

失敗機制:

  • test_log.DEBUG 中的 lens_moving: True (android.hardware.camera2.CaptureResult#LENS_STATE = 1) 只會在清晰度未變更的影格中宣告。
  • test_log.DEBUG 中的前幾個影格相比,lens_moving: False 中的影格 (android.hardware.camera2.CaptureResult#LENS_STATE = 0) 具有銳利度差異,或最後幾個影格在最小焦距處。

test_reprocess_edge_enhancement

測試支援的重新處理方法,確保邊緣強化功能正常運作。 使用指定的重新處理邊緣模式處理擷取要求,並比較不同的模式,以便在停用重新處理邊緣模式時擷取。

測試的 API:

通過:不同邊緣模式的銳利度正確無誤。HQ (模式 2) 比 OFF (模式 0) 更清晰,不同模式之間的改善幅度也相近。

test_reprocess_edge_enhancement_plot

test_reprocess_edge_enhancement_plot.png

場景 4

場景 4 包含方塊內白色背景上的黑色圓圈。scene4 中的測試可能會對對齊方式過於敏感,因此從 15 開始,您可以在 tools 目錄中使用 check_alignment.py,啟用對 DUT 和圖表對齊方式的檢查。

scene4

場景 4

test_30_60fps_preview_fov_match

測試 30 FPS 和 60 FPS 預覽影片是否具有相同的 FoV。這項測試擷取了兩部影片,一部影格 30 的每秒影格數,另一組為 60 FPS。系統會從每部影片中選取代表性影格並進行分析,確保兩部影片中的 FoV 變化符合規格。測試圓形的顯示比例是否維持不變、圓形中心是否保持穩定,以及圓形半徑是否維持不變。

測試的 API:

通過:圖片不會拉長,圖片中心的差異不超過 3%,且 30 FPS 和 60 FPS 影片的最大顯示比例變更幅度不超過 7.5%

失敗機制:

  • 30 FPS 影片中的圓形與 60 FPS 影片中的圓形大小差異明顯。
  • 處理管道會扭曲擷取圖像中的圓形。
  • 由於擷取影像要求的顯示比例過高,導致圖片的高度或寬度減少,因此擷取的圖片中的圓形會遭到裁剪。
  • 擷取的圖像中,圓形的中心有反光,且看起來並未完全填滿。

test_aspect_ratio_and_crop

測試圖片在圖片處理管道中是否發生扭曲或意外裁剪的情形。拍攝圓形的相片,以所有格式呈現。驗證圓形不會扭曲、不會從圖片中心移動,且不會因顯示比例或解析度不同而錯誤變更大小。

測試的 API:

通過:圖片不會拉伸,圖片中心的差異不超過 3%,且保留最大可能的 FoV (視野)。

失敗機制:

  • 相機未對準平板電腦上顯示的圓圈,該圓圈位於拍攝畫面中央。
  • 擷取圖片中的圓形遭處理管道變形。
  • 在圖像處理管線中,解析度較低的圖像會經過兩次裁剪,因此高解析度圖像和低解析度圖像之間的 FoV 會有所不同。
  • 由於擷取影像要求的顯示比例過高,導致圖片的高度或寬度減少,因此擷取的圖片中的圓形會遭到裁剪。
  • 擷取的圖像中,圓形的中心有反光,且看起來並未完全填滿。

test_multi_camera_alignment

測試攝影機校正參數,與攝影機位置相關,適用於多攝影機系統。使用多鏡頭實體子相機,使用其中一個實體相機拍照。找到圓形中心點。將圓形中心投影至每個攝影機的世界座標。比較攝影機在世界座標中的圓心差異。將世界座標重新投影至像素座標,並與原始值進行有效性檢查。比較圓圈大小,確認攝影機的焦距是否不同。

測試的 API:

通過:在投影圖像中,圓形中心和大小與使用相機校正資料和焦距拍攝的圖像相符。

失敗機制:

  • LENS_INTRINSIC_CALIBRATIONLENS_POSE_TRANSLATIONLENS_POSE_ROTATION 是設計值,而非實際校正資料。
  • 相機系統不適合測試設定。舉例來說,您可以使用 RFoV 測試 rig 測試廣角和超廣角鏡頭系統。詳情請參閱 Camera ITS-in-a-box 常見問題 1

test_preview_aspect_ratio_and_crop

與靜態影像擷取的 test_aspect_ratio_and_crop 測試類似,這項測試會檢查支援的預覽格式,確保預覽影格不會過度拉伸或裁剪。驗證圓形的顯示比例不會變更、裁剪圖片會將圓形置於影格中央,且圓形大小不會因固定格式或不同解析度而變更 (檢查視野)。

測試的 API:

通過:圖片不會拉伸,圖片中心的差異不超過 3%,且保留盡可能大的 FoV (視野)。

test_preview_stabilization_fov

檢查支援的預覽大小,確保 FoV 已適當裁剪。這項測試會擷取兩部影片,一部使用預覽防震功能 ON,另一部使用預覽防震功能 OFF。系統會從每部影片中選取代表性影格,並進行分析,確保兩部影片的 FoV 變化符合規格。

測試的 API:

通過:圓形的顯示比例大致保持不變,圓形的中心位置保持穩定,且圓形的大小變動幅度不超過 20%。

test_video_aspect_ratio_and_crop

在所有影片格式中,拍攝正方形內圓形的影片。擷取關鍵影格,並驗證圓形的顯示比例不會改變、裁剪的圖片會將圓形置中,且圓形大小不會因固定格式或不同解析度而改變 (檢查視野)。

測試的 API:

通過:影片畫格不會拉長,畫格中心的差異不超過 3%,且保留盡可能大的 FoV (視野)。

scene5

場景 5 需要均勻照明的灰色場景。方法是將散光器放在相機鏡頭上。我們建議使用下列擴散器:www.edmundoptics.com/optics/window-diffusers/optical-diffusers/opal-diffusing-glass/46168

如要準備場景,請在相機前方安裝擴散板,並將相機對準約 2000 勒克斯的光源。為場景 5 拍攝的圖片必須使用漫射光源,且沒有明顯特徵。以下是示例圖片:

scene5

場景 5 拍攝

test_lens_shading_and_color_uniformity

測試鏡頭陰影校正是否適當套用,以及單色均勻場景的顏色是否均勻分布。在使用自動 3A 的 YUV 影格上執行這項測試。鏡頭陰影會根據 y 通道進行評估。測量每個指定樣本區塊的平均值 y 值,並比較中心 y 值以判定通過或失敗。顏色均勻度測試會在 r/g 和 b/g 空間中進行評估。

測試的 API:

通過:在圖片的指定半徑範圍內,r/g 和 b/g 值的差異必須小於 20%,才能通過測試。

scene6

Scene6 是小圓形的網格,其中一個角落有方塊,用來表示方向。小圓圈可用於測試大範圍的縮放功能。在場景 6 中進行的測試可能會對對齊方式敏感,因此從 15 開始,您可以在工具目錄中使用 check_alignment.py,啟用對 DUT 和圖表對齊方式的檢查。

scene6

場景 6

test_in_sensor_zoom

測試相機感測器內縮放功能的行為,產生經過裁剪的 RAW 圖片。

將串流用途設為 CROPPED_RAW 後,測試會在變焦範圍內拍攝兩張相片,分別是完整視野 (FoV) RAW 圖片和裁剪的 RAW 圖片。這項測試會將圖片轉換為 RGB 陣列,將原尺寸裁剪的 RAW 圖片縮減為 SCALER_RAW_CROP_REGION 回報的大小,並計算兩張圖片之間的 3D 根平均平方 (RMS) 差異。

測試的 API:

通過:縮小裁剪的 RAW 圖片與完整 FoV RAW 圖片之間的 3D 均方根 (RMS) 差異低於測試中設定的閾值。

test_zoom

測試相機變焦行為。在縮放範圍內拍攝,並檢查圓圈是否會隨著相機縮放而變大。針對每種格式 (YUV、JPEG),都使用相同的相機擷取工作階段來串連 3A 並擷取內容。

測試的 API:

通過:相對於要求的縮放比例,擷取圓形的相對大小正確無誤,可確保相機正確縮放。

test_zoom

test_zoom 來找出最靠近中心的圓形輪廓。

test_low_latency_zoom

測試相機低延遲變焦行為。使用 android.control.settingsOverride = 1 (SETTINGS_OVERRIDE_ZOOM) 在縮放範圍內進行擷取,並檢查輸出圖片中的圓形是否與擷取中繼資料中的縮放比例相符。使用相同的相機拍攝工作階段來串連 3A 及拍攝。

測試的 API:

通過:相對於縮放比例結果中繼資料,擷取圓形的相對大小正確無誤。

test_preview_video_zoom_match

測試在錄製和縮放時,影片預覽畫面和影片輸出畫面是否顯示及錄製相同的輸出內容。以不同的縮放比例計算最接近中心的圓形尺寸,並檢查圓形尺寸是否隨著縮放比例增加。

測試的 API:

通過:相對於影片和預覽畫面中要求的縮放比例,擷取圓形的相對大小正確無誤。

VGA_640x480_key_frame.png

VGA_640x480_key_frame.png (縮放前)

preview_640x480_key_frame.png

Preview_640x480_key_Frame.png (縮放前)

VGA_640x480_key_frame_zoomed.png

VGA_640x480_key_frame.png (縮放後)

preview_640x480_key_frame_zoomed.png

preview_640x480_key_frame.png (縮放後)

test_preview_zoom

測試每個預覽影格縮放比例是否與對應的擷取中繼資料相符。這項測試會擷取縮放範圍中的預覽影格,找出最靠近中心的圓形輪廓。接著,測試會檢查所選圓形是否會變大,以及圓形中心是否會在相機縮放時離開圖片中心。

測試的 API:

通過:所選圓圈的相對大小與所有預覽影格中對應的擷取結果所回報的縮放比例相符。所選圓形與圖片中心的相對距離準確,是根據所有預覽影格相應擷取結果回報的縮放比例,準確呈現。

test_zoom

test_preview_zoom 圖片顯示選取距離中央最近的圓形

test_session_characteristics_zoom

測試 CameraCharacteristics#INFO_SESSION_CONFIGURATION_QUERY_VERSION 中列出的所有支援工作階段設定的縮放比例範圍。如果 CameraDeviceSetup#isSessionConfigurationSupported 傳回 True,這項測試會驗證是否能達到 CameraDeviceSetup#getSessionCharacteristics 傳回的縮放比例範圍。

測試的 API:

通過:可達到 CameraCharacteristics#INFO_SESSION_CONFIGURATION_QUERY_VERSION 中列出的每個支援 SessionConfiguration 的最小和最大縮放比例。

場景 7

Scene7 是一個由四個相等象限的矩形影格,每個象限都填入不同的顏色。矩形中央是傾斜的邊緣圖,可供進行銳利檢查。四個 ArUco 標記會與矩形的四個外角對齊,以便在不同縮放比例下取得主矩形框架的正確座標。

場景 7

場景 7

test_multi_camera_switch

這項測試會驗證在以不同變焦比率錄製預覽畫面時,超廣角 (UW) 和廣角 (W) 鏡頭之間的切換會產生類似的 RGB 值。

這項測試會在預先定義的範圍內使用不同的縮放比例,執行動態預覽錄影,並找出實體相機變更的時間點。這個點代表從超廣角鏡頭切換到廣角鏡頭。

系統會分析在交叉點前後拍攝的畫面,以便進行自動曝光 (AE)、自動白平 (AWB) 和自動對焦 (AF) 的分析。

自動曝光檢查可確保 UW 和 W 鏡頭圖像的亮度變化都落在預期範圍內。AWB 檢查會驗證 R/G 和 B/G 的比例是否在 UW 和 W 鏡頭圖片的閾值範圍內。自動對焦檢查會根據 UW 和 W 鏡頭圖像之間的平均漸層大小,評估銳利度預估值。

測試的 API:

通過:AE、AWB 和 AF 檢查都必須通過,測試才能通過。每個檢查作業的標準如下:

  • AE 檢查:UW 和 W 鏡頭圖像之間的亮度變化必須小於 0.5%。
  • AWB 檢查:UW 和 W 鏡頭圖片的 R/G 和 B/G 值差異必須小於 0.5%。
  • AF 檢查:UW 和 W 鏡頭圖像之間的圖像清晰度變化必須小於 2%。

scene8

Scene8 是劃分成四個相等區域的矩形頁框,每個畫面都內含以不同曝光方式拍攝的肖像,或是以不同顏色深淺的重疊 (藍色陰影、曝光增加、曝光降低、黃色陰影)。四個 ArUco 標記會與矩形的四個外角對齊,以便取得主矩形框架的正確座標。

scene8

場景 8

test_ae_awb_regions

測試在不同自動曝光 (AE) 和自動白平衡 (AWB) 區域進行預覽記錄時,RGB 和亮度值是否不同。

測試會記錄八秒的預覽錄製,每個象限各執行 2 秒的 AE 和 AWB 測光。接著,測試會從每個區域的預覽記錄中擷取影格,並使用擷取的影格來執行下列 AE 和 AWB 檢查:

  • AE 檢查:確認曝光度降低的區域影格測量值,其亮度值增加幅度超過 1%,且高於曝光度增加的區域影格測量值。這可驗證在測量暗區時,圖像是否會變亮。
  • AWB 檢查:驗證在具有藍色計量區域的影格中,紅色至藍色 (圖片平均 RGB 值) 的比率高於黃色計量區域的影格高出 2%。這樣會驗證在計算黃色 (暖) 或藍色 (冷) 區域時,圖片是否具有平衡的 RGB 值。

測試的 API:

通過:AE 和 AWB 檢查都通過。

scene9

場景 9 包含數千個隨機大小和顏色的圓形,用於建立重複性極低的場景,以便測試 JPEG 壓縮演算法。

scene9

場景 9

test_jpeg_high_entropy

測試相機 JPEG 壓縮功能是否可在高熵的場景 9 中運作,並將 JPEG 品質係數設為 100%。系統會增加縮放係數,確保平板電腦顯示的場景會填滿攝影機視野。

測試的 API:

通過:JPEG 檔案已正確壓縮、寫入,並從磁碟讀取。

test_jpeg_quality

測試攝影機的 JPEG 壓縮畫質。透過 android.jpeg.quality 調整 JPEG 品質,並確保量化表正確變更。

測試的 API:

通過:量化矩陣會隨著品質提升而減少。(矩陣代表除數)。

test_jpeg_quality

Pixel 4 後置鏡頭 luma/chroma DQT 矩陣平均值與 JPEG 畫質

test_jpeg_quality 失敗

失敗的測試範例

請注意,如果圖片畫質非常低 (jpeg.quality < 50),量化矩陣中的壓縮不會增加。

scene_video

scene_video 場景是影片場景。這張圖片包含四個不同顏色的圓圈,以不同的影格速率在白色背景上來回移動。

scene_video

test_preview_frame_drop

測試要求的預覽影格速率是否在動態場景中維持不變。這項測試會在所有開放給第三方應用程式的攝影機上執行。

測試的 API:

通過:預覽影格速率低於要求的畫面更新率範圍,且連續影格間的平均差異低於測試中的相對容忍度。

scene_extensions

scene_extensions 測試適用於相機擴充功能,必須使用相機 ITS 內箱,因為這類測試需要精確控制測試環境。此外,所有漏光都必須妥善控制。這可能需要用防水布蓋住測試架、DUT 和平板電腦,並消除 DUT 前螢幕的光線洩漏。

scene_hdr

scene_hdr 情境包含左側的肖像和右側的低對比 QR code。

scene_hdr

scene_hdr

test_hdr_extension

測試 HDR 擴充功能。在啟用和未啟用擴充功能時擷取擷取,並檢查擴充功能是否讓 QR code 更容易偵測。

測試的 API:

通過:HDR 擴充功能可減少偵測 QR code 所需的對比度變更次數,或減少 QR code 的漸層。

scene_low_light

scene_low_light 場景由黑色背景上的灰色方塊網格組成,而方塊網格則以紅色輪廓框住。正方形會以 Hilbert 曲線方向排列。

情境_低光源

scene_low_light

test_night_extension

測試夜間擴充功能。啟用擴充功能後進行擷取,並執行下列操作:

  • 偵測是否含有 20 個正方形
  • 計算每個平方範圍限制的亮度
  • 根據 Hilbert 曲線格線方向,計算前 6 個方塊的平均亮度值
  • 計算連續方塊 (例如方塊 2 減去方塊 1) 到方塊 5 和 6 (方塊 6 減去方塊 5) 的亮度差異,並找出這 5 個計算差異的平均值。

測試的 API:

通過:前 6 個方塊的平均亮度值至少須為 85,且連續方塊的平均亮度值差異 (至第 5 和 6 個方塊) 至少須為 17。

下列亮度圖表顯示通過測試的結果。

scene_low_light_night_pass

test_low_light_boost_extension

測試低光源增強 AE 模式。如果 Camera2 支援低光增強 AE 模式,則會為 Camera2 執行這項測試。如果支援夜間模式相機擴充功能,且擴充功能支援低光源增強 AE 模式,那麼這項測試也會對夜間模式相機擴充功能執行。這項測試會將 AE 模式設為低光源增強模式,從預覽畫面擷取影格,然後執行下列步驟:

  • 偵測 20 個盒子
  • 計算每個方塊內的亮度
  • 根據 Hilbert 曲線格線方向,計算前 6 個方塊的平均亮度值
  • 計算連續方塊 (例如方塊 2 減去方塊 1) 到方塊 5 和 6 (方塊 6 減去方塊 5) 的亮度差異,並找出這 5 個計算差異的平均值。

測試的 API:

通過:前 6 個方塊的平均亮度值至少須為 70,且連續方塊 (至第 5 和 6 個方塊) 的亮度值平均差至少須為 17。

scene_flash

scene_flash 測試需要在感應器融合方塊中顯示黑暗場景。

test_auto_flash

測試後置鏡頭和前置鏡頭在昏暗場景中是否會觸發自動閃光燈。對於前置鏡頭,自動閃光燈會使用螢幕照亮場景,而不是實體閃光燈。這項測試會檢查啟用自動閃光功能時,圖塊圖片的中心是否較亮,藉此驗證系統是否已觸發自動閃光功能。如要觸發自動閃光功能,必須關閉測試架中的燈光。您可以使用 Arduino 控制器自動關閉燈光。場景必須完全黑暗,測試才能正常運作。您必須先在裝置上安裝 Jetpack Camera 應用程式 (JCA),才能進行測試。後置鏡頭的自動閃光燈會依據 AE 狀態觸發,但前置鏡頭的自動閃光燈不會依據 AE 狀態觸發,且一律會觸發。

測試的 API:

通過:啟用自動閃光燈的圖塊圖片中心比所有攝影機的原始場景圖片更亮。

test_flash_strength

測試 SINGLE 模式中的閃光燈強度控制項是否已正確實作。

確認裝置在 SINGLE 模式下使用相機時,是否支援閃光燈強度控制功能,並根據不同的要求強度等級變更閃光燈強度。驗證閃光燈強度控制功能是否可與不同的 AE_MODES 搭配運作。舉例來說,如果自動曝光模式為 ONOFF,閃光燈強度等級會對亮度產生影響;如果模式為 ON_AUTO_FLASH,則閃光燈強度等級不會對亮度造成任何影響。如要進行測試,必須關閉測試架中的燈光。燈光可透過 Arduino 控制器自動關閉。場景必須完全偏暗,測試才能正常運作。

測試的 API:

通過:

當自動曝光模式為 ONOFF 時,圖片修補程式的亮度會隨著閃光燈強度等級從無閃光燈提升到 FLASH_SINGLE_STRENGTH_MAX_LEVEL 而增加。當自動曝光模式為 ON_AUTO_FLASH 時,隨著閃光燈強度從無閃光到 FLASH_SINGLE_STRENGTH_MAX_LEVEL 的等級增加,圖片區塊的亮度差異會在容許值範圍內。

test_led_snapshot

測試 LED 快照是否不會使圖像過飽和或產生色調。

這項測試會在感應器融合盒中新增照明控制器,用於控制燈光。當燈光設為 OFF 時,測試會擷取設定為 AUTO_FLASHAUTO_FLASH 模式。ON在這個擷取期間,測試會執行預擷取序列,並將 aePrecapture 觸發條件設為 START,並將擷取意圖設為 Preview,以便使用閃光燈擷取相片。

由於擷取作業因為閃光燈而有不同的熱點,因此測試會計算整個拍攝的 Flash 圖像平均數,並驗證該值是否在 (68, 102) 範圍內。為檢查圖片是否有合理的白平衡,這項測試會計算 R/G 和 B/G 比率,並驗證比率是否介於 0.95 和 1.05 之間。

測試的 API:

通過:R/G 和 B/G 比率介於 0.95 和 1.05 之間。閃光圖片的平均值介於 (68, 102) 之間。

test_preview_min_frame_rate

測試預覽畫面在昏暗場景中是否正確降低影格速率。為確保這項測試能正常運作,測試裝置中的燈光必須由控制器關閉,或由測試操作員手動關閉。

測試的 API:

通過:預覽影格速率達到要求影格速率範圍的下限,且影格之間的差異小於測試中設定的絕對容差。

test_torch_strength

測試 TORCH 模式中的閃光燈強度控制項是否已正確實作。

確認裝置在 TORCH 模式下使用相機時,是否支援閃光燈強度控制功能,並根據不同的要求強度等級變更手電筒強度。驗證閃光燈強度控制項適用於不同的 AE_MODES。舉例來說,如果自動曝光模式為 ONOFF,閃光燈強度等級會影響亮度,如果模式為 ON_AUTO_FLASH,閃光燈強度等級就不會影響亮度。驗證在連拍期間,手電筒強度是否維持不變,模擬錄影工作階段。如要進行測試,必須關閉測試架中的燈光。您可以使用 Arduino 控制器自動關閉燈光。場景必須完全偏暗,測試才能正確執行。

測試的 API:

Pass:

當自動曝光模式為 ONOFF 時,閃光燈強度等級從無閃光燈到 FLASH_TORCH_STRENGTH_MAX_LEVEL 時,圖片快連影像亮度會隨之增加。當自動曝光模式為 ON_AUTO_FLASH 時,隨著閃光燈強度等級從無閃光到 FLASH_TORCH_STRENGTH_MAX_LEVEL,圖片連拍區塊的亮度差異會在容許範圍內。

感應器融合

感應器融合測試需要在格狀圖案和 ArUco 標記前,以特定方式移動手機。為獲得最佳結果,請確定測試圖表是以固定方式掛接。非平面圖表會影響許多測試的旋轉計算。圖表必須以 17 英寸 x 17 英寸 (43 公分 x 43 公分) 的尺寸列印,填滿感應器融合盒的背面。sensor_fusion 測試可透過 Sensor Fusion Box 自動執行。

感應器融合圖表

感應器融合圖表

Rig 中的感應器整合圖表

填滿感應器融合方塊背面的感應器融合圖表

test_lens_intrinsic_calibration

測試鏡頭因光學影像穩定技術 (OIS) 而移動時,鏡頭內在的光學中心是否會變更。如果支援鏡頭內在樣本,請測試鏡頭內在樣本的光學中心,當鏡頭因光學影像穩定技術 (OIS) 而移動時,是否會改變。

測試的 API:

通過:鏡頭的光學中心有內在的變動,變動幅度為 1 像素以上。如果支援鏡頭內建函式的範例,鏡頭內建樣本的光學中心就會增加 1 像素以上。

test_lens_intrinsic_calibration_example.png

test_lens_intrinsic_calibration 圖表示例,顯示每個影格在像素中的主要點變化

test_multi_camera_Frame_sync

透過計算格狀圖中的正方形角度來判斷時間戳記,測試邏輯攝影機擷取的影格時間戳記是否在 10 毫秒內。

測試的 API:

通過:手機旋轉時,每個相機圖像之間的位置不會明顯改變。

test_preview_distortion

測試在不同縮放等級下拍攝的每個預覽影格,是否已修正失真情形。每個預覽影格都會根據相機內建函式和極端主義計算理想點。在範例圖片中,理想點以綠色顯示,實際點則以紅色顯示。系統會根據實際點與理想點之間的均方根誤差 (RMS) 像素距離,計算失真誤差。圖片上的綠色和紅色醒目提示可用於視覺偵測失真錯誤的區域。

test_preview_distortion_example.jpg

圖片:棋盤格圖,其中理想點為綠色,實際點為紅色

測試的 API:

通過:每個預覽影格的正規化變形錯誤低於測試設定的門檻。

test_preview_stabilization

測試穩定的預覽影片旋轉角度是否小於陀螺儀。

測試的 API:

通過:影格中角度旋轉的最大值小於陀螺儀旋轉的 70%。

以下是含有及不含穩定功能的影片範例。

  • 含防震功能的影片範例

  • 未使用防震功能的影片範例

test_sensor_fusion

測試 AR 和 VR 應用程式相機與陀螺儀之間的時間戳記差異。在棋盤格圖案前,手機旋轉 90 度 10 次。移動時間約為 2 秒。如果沒有包含陀螺儀,或未啟用時間戳記來源 REALTIME 參數,系統會略過這項測試。

test_sensor_fusion 測試會產生多個圖表。偵錯時最重要的兩個圖表如下:

  • test_sensor_fusion_gyro_events:顯示手機在測試期間的陀螺儀事件。在 x 和 y 方向的移動表示手機未穩固地固定在固定板上,因此測試通過的機率會降低。圖表中的週期數取決於儲存影格時的寫入速度。

    test_sensor_fusion_gyro_events.png

    test_sensor_fusion_gyro_events

  • test_sensor_fusion_plot_rotations:顯示陀螺儀和攝影機事件的對齊方式。這張圖表必須顯示相機和陀螺儀之間的移動相符,誤差範圍為 +/-1 毫秒。

    test_sensor_fusion_繪圖_rotations.png

    test_sensor_fusion_plot_rotations

測試的 API:

通過:根據 CDD 7.3.9 高保真感應器 [C-2-14] 章節,相機和陀螺儀時間戳記的偏移量小於 1 毫秒。

失敗機制:

  • 偏移錯誤:攝影機陀螺儀偏移未正確校正至 +/-1 毫秒內。
  • 影格掉落:管道速度不夠快,無法連續擷取 200 個影格。
  • 通訊端錯誤:adb 無法可靠地連線至 DUT,連線時間不足以執行測試。
  • 圖表未平整安裝。圖表 test_sensor_fusion_plot_rotations 包含影格,當相機旋轉至圖表中非平坦的部分時,陀螺儀和相機旋轉角度會大幅變化。
  • 攝影機未平放。圖表 test_sensor_fusion_gyro_events 會顯示 X 和 Y 平面的移動情形。這種故障最常發生在前置鏡頭,因為後置鏡頭通常會比手機機身其他部分突出,因此當手機背面安裝在固定板時,會產生傾斜。

test_video_stabilization

測試穩定的影片旋轉角度是否小於陀螺儀。

測試的 API:

通過:影格上角旋轉的最大角度小於陀螺儀旋轉的 60%。

以下是含有及不含穩定功能的影片範例。

  • 含防震功能的影片範例

  • 未使用防震功能的影片範例

feature_combination

feature_combination 測試會驗證在同時啟用多個攝影機功能時,功能是否正常運作。這些測試使用在感應器融合場景中相同的打板映像檔。

test_feature_combination

測試相機裝置支援的所有串流組合、預覽穩定性、目標 FPS 範圍、10 位元 HDR 影片和超高動態範圍組合。這項測試會大量占用記憶體,因此建議您使用至少 128 GB RAM 的主機。

在 Android 15 以上版本中,設定檔包含 log_feature_combo_support 欄位,預設為 False。當 log_feature_combo_support 欄位設為 True 時,測試會執行所有支援功能的組合,並將結果記錄到 proto 檔案中,而不會導致測試失敗。如要進行法規遵循測試,log_feature_combo_support 欄位必須設為 False

測試的 API:

通過:針對每個支援的功能組合:

  • 開啟預覽防震功能後,預覽串流會保持穩定。
  • 預覽影格速率落在設定的 AE_TARGET_FPS_RANGE 內。
  • 錄製的預覽串流色彩空間與設定相符。
  • Ultra HDR 擷取畫面含有有效的增益對應圖。