Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix for backwards compatibility, new feature ROIs and RODs for AutoFocus and new timeout mechanic for all clients #34

Merged
merged 18 commits into from
Apr 4, 2024
Merged
Changes from 1 commit
Commits
Show all changes
18 commits
Select commit Hold shift + click to select a range
8429898
Fixed backwards compatibility and added new unittests for device client
Galoshi Mar 26, 2024
5005ac2
Added new feature for usage of ROIs and RODs for AutoFocus
Galoshi Mar 26, 2024
e92e4df
Fixed backwards compatibility
Galoshi Mar 26, 2024
f0131e4
Added new config flag importDeviceConfigUnittests for avoiding applic…
Galoshi Mar 26, 2024
498bfb4
Set config flag importDeviceConfigUnittests to default value True
Galoshi Mar 26, 2024
5968368
Incrementing setup.py version from 0.4 to 0.5
Galoshi Mar 26, 2024
da511aa
Moved module imports to top level for RPC client
Mar 27, 2024
c402920
Setting default ip in config file for unittests
Mar 27, 2024
a1a6a86
Changed input argument saturatedRatio for method startCalculateExposu…
Mar 27, 2024
18696db
Modified timeout mechanic for RPC so timeout is only set for its own …
Mar 27, 2024
f45574b
Removed method socket_exception_handler which is not needed anymore s…
Mar 27, 2024
3985d90
Replaced unsecure method eval() to json.loads()
Mar 27, 2024
4d73fe6
Fixed proxy issues for RPC timeout mechanic
Mar 27, 2024
f66a283
Replaced update methods for startCalculateExposureTime and startCalcu…
Mar 27, 2024
b07a070
Removed method rpc_exception_handler which is not needed anymore sinc…
Mar 27, 2024
3f24e51
Removed unnecessary comments in RPC client
Mar 28, 2024
a75903d
Fixed stack overflow error for overloaded __gettattr__ proxy method, …
Apr 4, 2024
8f1f108
Fixed versionioning of package so it equals the tagged package
Apr 4, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 15 additions & 4 deletions source/rpc/imager.py
Original file line number Diff line number Diff line change
Expand Up @@ -358,6 +358,10 @@ def startCalculateExposureTime(self, minAnalogGainFactor: int = None, maxAnalogG
inputAutoExposure.update({"saturatedRatio": saturatedRatio})
bnozka marked this conversation as resolved.
Show resolved Hide resolved
if ROIs:
inputAutoExposure.update({"ROIs": ROIs})
if RODs and not ROIs:
bnozka marked this conversation as resolved.
Show resolved Hide resolved
defaultROIsZone = [{"id": 0, "group": 0, "type": "Rect", "width": 1280,
"height": 960, "angle": 0, "center_x": 640, "center_y": 480}]
inputAutoExposure.update({"ROIs": defaultROIsZone})
bnozka marked this conversation as resolved.
Show resolved Hide resolved
if RODs:
inputAutoExposure.update({"RODs": RODs})
self._imagerProxy.startCalculateExposureTime(json.dumps(inputAutoExposure))
Expand All @@ -374,16 +378,23 @@ def getProgressCalculateExposureTime(self) -> float:
result = self._imagerProxy.getProgressCalculateExposureTime()
return result

def startCalculateAutofocus(self) -> None:
def startCalculateAutofocus(self, ROIs: list = None, RODs: list = None) -> None:
"""
Starting "autofocus" calculation with ROI-definition.
The autofocus will be optimized for the center of the image (HWROI).

:return: None
"""
# This is required due to the long autofocus progress which may take longer than 10 seconds (default)
# self._device.sessionProxy.heartbeat(heartbeatInterval=300)
self._imagerProxy.startCalculateAutofocus()
inputAutoFocus = {}
if ROIs:
inputAutoFocus.update({"ROIs": ROIs})
if RODs and not ROIs:
bnozka marked this conversation as resolved.
Show resolved Hide resolved
defaultROIsZone = [{"id": 0, "group": 0, "type": "Rect", "width": 1280,
"height": 960, "angle": 0, "center_x": 640, "center_y": 480}]
inputAutoFocus.update({"ROIs": defaultROIsZone})
if RODs:
inputAutoFocus.update({"RODs": RODs})
self._imagerProxy.startCalculateAutofocus(json.dumps(inputAutoFocus))
while self.getProgressCalculateAutofocus() < 1.0:
time.sleep(1)

Expand Down