# ***************************************************************************** # This program is free software; you can redistribute it and/or modify it under # the terms of the GNU General Public License as published by the Free Software # Foundation; either version 2 of the License, or (at your option) any later # version. # # This program is distributed in the hope that it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS # FOR A PARTICULAR PURPOSE. See the GNU General Public License for more # details. # # You should have received a copy of the GNU General Public License along with # this program; if not, write to the Free Software Foundation, Inc., # 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # # Module authors: # Markus Zolliker # Jael Celia Lorenzana # ***************************************************************************** """Powersupply B&K Precision BK168xB The following lines are part of a config file for the frappy-server process The frappy server creates the following modules and refreshes the values with a refresh rate of 1 sec. The communication with the powersupply is established via serial over USB. The manual can be found here https://www.vectortechnologies.gr/images/products/2022/02/168xB_programming_manual.pdf Mod('htr_io', 'frappy_psi.bkpower.IO', 'powersupply communicator', uri = 'serial:///dev/ttyUSBupper', ) Mod('htr', 'frappy_psi.bkpower.Power', 'heater power', io= 'htr_io', ) Mod('out', 'frappy_psi.bkpower.Output', 'heater output', io = 'htr_io', maxvolt = 50, maxcurrent = 2, ) """ from frappy.core import StringIO, Readable, Parameter, FloatRange, Writable, HasIO, BoolType # define the IO class class IO(StringIO): end_of_line = ('OK\r', '\r') default_settings = {'baudrate': 9600} class Power(HasIO, Readable): value = Parameter(datatype=FloatRange(0,300,unit='W')) def read_value(self): reply = self.communicate('GETD') volt = float(reply[0:4])/100 current = float(reply[4:8])/100 return volt*current class Output(HasIO, Writable): value = Parameter(datatype=FloatRange(0,100,unit='%'), default=0) target = Parameter(datatype=FloatRange(0,100,unit='%')) p_value = Parameter(datatype=FloatRange(0,100,unit='%'), default=0) maxvolt = Parameter('voltage at 100%',datatype=FloatRange(0,60,unit='V'),default=50,readonly=False) maxcurrent = Parameter('current at 100%',datatype=FloatRange(0,5,unit='A'),default=2,readonly=False) output_enable = Parameter('control on/off', BoolType(), readonly=False) def initModule(self): super().initModule() self.write_output_enable(False) def write_target(self, target): self.write_output_enable(target != 0) self.communicate(f'VOLT{round(max(8,(target)**0.5 * self.maxvolt)):03d}') self.communicate(f'CURR{round((target)**0.5* 10 * self.maxcurrent):03d}') #self.communicate(f'VOLT{round(max(8,target*self.maxvolt/10)):03d}') #self.communicate(f'CURR{round(target*self.maxcurrent):03d}') self.value = target def write_output_enable(self, value): self.communicate(f'SOUT{int(not value)}') def write_maxvolt(self, maxvolt): self.communicate(f'SOVP{round(maxvolt*10):03d}') def write_maxcurrent(self, maxcurrent): self.communicate(f'SOCP{round(maxcurrent*100):03d}') def shutdown(self): self.write_target(0)