RI_SDK_sensor_VoltageSensor_ExtendToModel

!!! ИНФОРМАЦИЯ

RI_SDK - библиотека Robo Intellect Software Development Kit

sensor - название группы устройств датчиков

VoltageSensor - название устройства датчика тока, напряжения и мощности

ExtendToModel - название метода расширения компонента датчика тока, напряжения и мощности до конкретной модели

Сигнатура функции #

  • Shared object
RI_SDK_sensor_VoltageSensor_ExtendToModel(base, modelName, descriptor, errorText):errorCode
  • Golang gRPC
RI_SDK_sensor_VoltageSensor_ExtendToModel(base int64, modelName string) (descriptor int64, errorText string, errorCode int64, err error)

Описание метода #

Расширение датчика тока, напряжения и мощности до конкретной модели.

Расширяет компонент датчика тока, напряжения и мощности с дескриптором base. Записывает в параметр descriptor дескриптор нового компонента (компонент конкретной модели датчика тока, напряжения и мощности)

Доступные модели сервопривода: ina219

Параметры и возвращаемые значения #

Параметр Тип для Shared object Тип для Golang gRPC Описание
base int (тип C) int64 Компонент датчика тока, напряжения и мощности, который будет расширятся
modelName char[] (тип C) string Модель компонента ("ina219")
descriptor *int (тип C) int64 Указатель на компонент датчика тока, напряжения и мощности конкретной модели, который получится в результате расширения
errorText char[1000] (тип C) string Текст ошибки (передается как параметр, если происходит ошибка метод записывает в этот параметр текст ошибки)
errorCode int (тип C) int64 Код ошибки

Примеры #

Пример №1 - Расширение компонента датчика тока, напряжения и мощности до модели ina219 #

В данном примере осуществляется расширение датчика тока, напряжения и мощности с дескриптором, записанным в переменную voltageSensor и вывод дескриптора нового компонента устройства сервопривода модели ina219, который получится в результате расширения.

  • Python
# Расширение компонента датчика тока, напряжения и мощности до модели ina219
errCode = lib.RI_SDK_sensor_VoltageSensor_ExtendToModel(voltageSensor, "ina219".encode(), descriptor, errTextC)
if errCode != 0:
    print(errCode, errTextC.raw.decode())
    sys.exit(2)

    
  • C
      // Расширение компонента датчика тока, напряжения и мощности до модели ina219
      errCode = RI_SDK_sensor_VoltageSensor_ExtendToModel(sensorDeviceDescriptor, "ina219", &sensorDescriptor, errorText);
      if (errCode) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }
  • C++
      // Расширение компонента датчика тока, напряжения и мощности до модели ina219
      char ina219[] = "ina219";
      errCode = RI_SDK_sensor_VoltageSensor_ExtendToModel(sensorDeviceDescriptor, ina219, &sensorDescriptor, errorText);
      if (errCode) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }
  • Golang
        // Расширение компонента датчика тока, напряжения и мощности до модели ina219
        errCode = C.sensor_VoltageSensor_ExtendToModel(sensorDeviceDescriptor, C.CString("ina219"), &sensorDescriptor, &errorText[0])
        if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorText[0]))
        return
    }
  • Golang gRPC
      // Расширение компонента группы датчиков до датчика тока, напряжения и мощности
      inaSensorDescriptor, errText, errCode, err := client.RoboSdkApi.RI_SDK_Sensor_VoltageSensor_ExtendToModel(sensorDescriptor, "ina219")
      if errText != "" || errCode != 0 || err != nil {
      fmt.Printf("errText: %s; errCode:%d; err: %s", errText, errCode, err)
      return
  }
  • PHP
        // Расширение компонента датчика тока, напряжения и мощности до модели ina219
        $errCode = $ffi->RI_SDK_sensor_VoltageSensor_ExtendToModel($sensorDescriptor->cdata, "ina219", FFI::addr($inaSensorDescriptor), $errorText);
        if ($errCode) {
        print("errorText:" . FFI::string($errorText) . " errCode: " . $errCode . " \n");
        return;
    }
Полный текст примера
  • Python
from ctypes.util import find_library
import platform
import sys
from ctypes import *

# Подключаем внешнюю библиотеку для работы с SDK
platform = platform.system()
if platform == "Windows":
    libName = "librisdk.dll"
if platform == "Linux":
    libName = "librisdk.so"

pathLib = find_library(libName)
lib = cdll.LoadLibrary(pathLib)


# Указываем типы аргументов для функций библиотеки RI_SDK
lib.RI_SDK_InitSDK.argtypes = [c_int, c_char_p]
lib.RI_SDK_CreateDeviceComponent.argtypes = [c_char_p, c_char_p, POINTER(c_int), c_char_p]
lib.RI_SDK_sensor_VoltageSensor_ExtendToModel.argtypes = [c_int, c_char_p, POINTER(c_int), c_char_p]

def main():
    errTextC = create_string_buffer(1000)  # Текст ошибки. C type: char*
    descriptor = c_int()
    voltageSensor = c_int()


    # Инициализация библиотеки RI SDK с уровнем логирования 3
    errCode = lib.RI_SDK_InitSDK(3, errTextC)
    if errCode != 0:
        print(errCode, errTextC.raw.decode())
        sys.exit(2)

    # Создание компонента датчика тока, напряжения и мощности
    errCode = lib.RI_SDK_CreateDeviceComponent("sensor".encode(), "voltage_sensor".encode(), voltageSensor, errTextC)
    if errCode != 0:
        print(errCode, errTextC.raw.decode())
        sys.exit(2)

    print("voltage_sensor: ", voltageSensor.value)

    # Расширение компонента датчика тока, напряжения и мощности до модели ina219
    errCode = lib.RI_SDK_sensor_VoltageSensor_ExtendToModel(voltageSensor, "ina219".encode(), descriptor, errTextC)
    if errCode != 0:
        print(errCode, errTextC.raw.decode())
        sys.exit(2)

    print("descriptor: ", descriptor.value)

    print("Success")

main()
 
 

  • C
      #include <stdlib.h>
      #include <stdio.h>
      #include <unistd.h>
      #include <string.h>
      #include <dlfcn.h>

      int (*RI_SDK_InitSDK)(int logLevel, char *errorText);

      int (*RI_SDK_CreateDeviceComponent)(char *group, char *device, int *descriptor, char *errorText);

      int
      (*RI_SDK_sensor_VoltageSensor_ExtendToModel)(int baseDescriptor, char *modelName, int *descriptor, char *errorText);

      int initLibrary() {
      void *handle;
      char *LIB_RISDK = getenv("LIB_RISDK");
      handle = dlopen(strcat(LIB_RISDK, "librisdk.so"), RTLD_NOW);
      if (!handle) {
      /* fail to load the library */
      fprintf(stderr, "Error: %s\n", dlerror());
      return -1;
  }

      *(void **) (&RI_SDK_InitSDK) = dlsym(handle, "RI_SDK_InitSDK");
      *(void **) (&RI_SDK_CreateDeviceComponent) = dlsym(handle, "RI_SDK_CreateDeviceComponent");
      *(void **) (&RI_SDK_sensor_VoltageSensor_ExtendToModel) = dlsym(handle,
      "RI_SDK_sensor_VoltageSensor_ExtendToModel");
      return 0;
  }

      char errorText[1000]; // текст ошибки. Передается как входной параметр,при возникновении ошибки в эту переменную будет записан текст ошибки
      int sensorDeviceDescriptor;
      int sensorDescriptor;

      int main() {
      int initErr;
      initErr = initLibrary();
      if (initErr != 0) {
      printf("fail to load init library");
      return initErr;
  }

      int errCode; //код ошибки

      // Инициализация библиотеки RI SDK
      errCode = RI_SDK_InitSDK(3, errorText);
      if (errCode != 0) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }

      // Создание компонента датчика тока, напряжения и мощности
      errCode = RI_SDK_CreateDeviceComponent("sensor", "voltage_sensor", &sensorDeviceDescriptor, errorText);
      if (errCode) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }

      // Расширение компонента датчика тока, напряжения и мощности до модели ina219
      errCode = RI_SDK_sensor_VoltageSensor_ExtendToModel(sensorDeviceDescriptor, "ina219", &sensorDescriptor, errorText);
      if (errCode) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }

      printf("sensorDescriptor: %d", sensorDescriptor);
      return 0;
  }
  • C++
      #include <stdlib.h>
      #include <stdio.h>
      #include <unistd.h>
      #include <string.h>
      #include <dlfcn.h>

      int (*RI_SDK_InitSDK)(int logLevel, char *errorText);

      int (*RI_SDK_CreateDeviceComponent)(char *group, char *device, int *descriptor, char *errorText);

      int
      (*RI_SDK_sensor_VoltageSensor_ExtendToModel)(int baseDescriptor, char *modelName, int *descriptor, char *errorText);

      int initLibrary() {
      void *handle;
      char *LIB_RISDK = getenv("LIB_RISDK");
      handle = dlopen(strcat(LIB_RISDK, "librisdk.so"), RTLD_NOW);
      if (!handle) {
      /* fail to load the library */
      fprintf(stderr, "Error: %s\n", dlerror());
      return -1;
  }

      *(void **) (&RI_SDK_InitSDK) = dlsym(handle, "RI_SDK_InitSDK");
      *(void **) (&RI_SDK_CreateDeviceComponent) = dlsym(handle, "RI_SDK_CreateDeviceComponent");
      *(void **) (&RI_SDK_sensor_VoltageSensor_ExtendToModel) = dlsym(handle,
      "RI_SDK_sensor_VoltageSensor_ExtendToModel");
      return 0;
  }

      char errorText[1000]; // текст ошибки. Передается как входной параметр,при возникновении ошибки в эту переменную будет записан текст ошибки
      int sensorDeviceDescriptor;
      int sensorDescriptor;

      int main() {
      int initErr;
      initErr = initLibrary();
      if (initErr != 0) {
      printf("fail to load init library");
      return initErr;
  }

      int errCode; //код ошибки

      // Инициализация библиотеки RI SDK
      errCode = RI_SDK_InitSDK(3, errorText);
      if (errCode != 0) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }

      // Создание компонента датчика тока, напряжения и мощности
      char sensor[] = "sensor";
      char voltage_sensor[] = "voltage_sensor";
      errCode = RI_SDK_CreateDeviceComponent(sensor, voltage_sensor, &sensorDeviceDescriptor, errorText);
      if (errCode) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }

      // Расширение компонента датчика тока, напряжения и мощности до модели ina219
      char ina219[] = "ina219";
      errCode = RI_SDK_sensor_VoltageSensor_ExtendToModel(sensorDeviceDescriptor, ina219, &sensorDescriptor, errorText);
      if (errCode) {
      printf("errorText:%s\n", errorText);
      return errCode;
  }

      printf("sensorDescriptor: %d", sensorDescriptor);
      return 0;
  }
  • Golang
        package main

        /*
        #cgo LDFLAGS: -ldl
        #include <stdlib.h>
        #include <stdio.h>
        #include <unistd.h>
        #include <string.h>
        #include <dlfcn.h>

        int (*RI_SDK_InitSDK)(int logLevel, char *errorText);

        int (*RI_SDK_CreateDeviceComponent)(char *group, char *device, int *descriptor, char *errorText);

        int (*RI_SDK_sensor_VoltageSensor_ExtendToModel)(int baseDescriptor, char *modelName, int *descriptor, char *errorText);

        int InitSDK(int logLevel, char *errorText){
        return RI_SDK_InitSDK(logLevel,errorText);
    }

        int CreateDeviceComponent(char *group, char *device, int *descriptor, char *errorText){
        return RI_SDK_CreateDeviceComponent(group,device,descriptor,errorText);
    }

        int sensor_VoltageSensor_ExtendToModel(int baseDescriptor, char *modelName, int *descriptor, char *errorText){
        return RI_SDK_sensor_VoltageSensor_ExtendToModel(baseDescriptor,modelName,descriptor,errorText);
    }

        int initLibrary() {
        void *handle;
        char *LIB_RISDK = getenv("LIB_RISDK");
        handle = dlopen(strcat(LIB_RISDK, "librisdk.so"), RTLD_NOW);
        if (!handle) {
        fprintf(stderr, "Error: %s\n", dlerror());
        return -1;
    }

        *(void **) (&RI_SDK_InitSDK) = dlsym(handle, "RI_SDK_InitSDK");
        *(void **) (&RI_SDK_CreateDeviceComponent) = dlsym(handle, "RI_SDK_CreateDeviceComponent");
        *(void **) (&RI_SDK_sensor_VoltageSensor_ExtendToModel) = dlsym(handle, "RI_SDK_sensor_VoltageSensor_ExtendToModel");
        return 0;
    }
        */
        import "C"
        import "fmt"

        func main() {
        var (
        initErr                C.int
        errorText              [1000]C.char
        sensorDeviceDescriptor C.int
        sensorDescriptor       C.int
        errCode                C.int
        )

        initErr = C.initLibrary()
        if initErr != 0 {
        fmt.Printf("fail to load init library")
        return
    }

        // Инициализация библиотеки RI SDK
        errCode = C.InitSDK(3, &errorText[0])
        if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorText[0]))
        return
    }

        // Создание компонента датчика тока, напряжения и мощности
        errCode = C.CreateDeviceComponent(C.CString("sensor"), C.CString("voltage_sensor"), &sensorDeviceDescriptor, &errorText[0])
        if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorText[0]))
        return
    }

        // Расширение компонента датчика тока, напряжения и мощности до модели ina219
        errCode = C.sensor_VoltageSensor_ExtendToModel(sensorDeviceDescriptor, C.CString("ina219"), &sensorDescriptor, &errorText[0])
        if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorText[0]))
        return
    }

        fmt.Printf("sensorDescriptor: %d\n", sensorDescriptor)
    }
  • Golang gRPC
package main
  import (
  "fmt"
  "github.com/rbs-ri/go-risdk"
  )

  func main() {
  //Открываем соединение для работы с API SDK по RPC
  client := risdk.GetClientRPC()
  //Закрываем соединение с RPC
  defer client.Client.Kill()

  // Создание компонента датчика тока, напряжения и мощности
  sensorDescriptor, errText, errCode, err := client.RoboSdkApi.RI_SDK_CreateDeviceComponent("sensor", "voltage_sensor")
  if errText != "" || errCode != 0 || err != nil {
  fmt.Printf("errText: %s; errCode:%d; err: %s", errText, errCode, err)
  return


}

  // Расширение компонента группы датчиков до датчика тока, напряжения и мощности
  inaSensorDescriptor, errText, errCode, err := client.RoboSdkApi.RI_SDK_Sensor_VoltageSensor_ExtendToModel(sensorDescriptor, "ina219")
  if errText != "" || errCode != 0 || err != nil {
  fmt.Printf("errText: %s; errCode:%d; err: %s", errText, errCode, err)
  return


}

  fmt.Println("inaSensorDescriptor: ", inaSensorDescriptor)
  return

}
  • PHP
        <?
        // Подключаем внешнюю библиотеку для работы с SDK
        $RELATIVE_PATH = '';
        $headers = file_get_contents(__DIR__ . $RELATIVE_PATH . '/librisdk.h');
        $headers = preg_replace(['/#ifdef __cplusplus\s*extern "C" {\s*#endif/i', '/#ifdef __cplusplus\s*}\s*#endif/i'], '', $headers);
        $ffi = FFI::cdef($headers, __DIR__ . $RELATIVE_PATH . '/librisdk.dll');
        $errorText = $ffi->new('char[1000]', 0); // Выделяем память на строку с ошибкой. Передается как входной параметр,при возникновении ошибки в эту переменную будет записан текст ошибки
        $sensorDescriptor = $ffi->new('int', 0);
        $inaSensorDescriptor = $ffi->new('int', 0);
        $logLevel = 3; // уровень логирования

        // Инициализируем SDK
        $errCode = $ffi->RI_SDK_InitSDK($logLevel, $errorText);
        if ($errCode) {
        print("errorText:" . FFI::string($errorText) . " errCode: " . $errCode . " \n");
        return;
    }

        // Создание компонента датчика тока, напряжения и мощности
        $errCode = $ffi->RI_SDK_CreateDeviceComponent("sensor", "voltage_sensor", FFI::addr($sensorDescriptor), $errorText);
        if ($errCode) {
        print("errorText:" . FFI::string($errorText) . " errCode: " . $errCode . " \n");
        return;
    }

        // Расширение компонента датчика тока, напряжения и мощности до модели ina219
        $errCode = $ffi->RI_SDK_sensor_VoltageSensor_ExtendToModel($sensorDescriptor->cdata, "ina219", FFI::addr($inaSensorDescriptor), $errorText);
        if ($errCode) {
        print("errorText:" . FFI::string($errorText) . " errCode: " . $errCode . " \n");
        return;
    }

161 просмотров0 комментариев

Комментарии (0)

Для участия в обсуждении Вы должны быть авторизованным пользователем
Разделы

Навигация

ВойтиРегистрация