用JS写了一个模拟串行加法器

在重温《编码:隐匿在计算机软硬件背后的语言》第12章——二进制加法器时,心血来潮用JS写了一个模拟串行加法器。

测试断言工具TestUtils.js

function assertTrue(actual){if(!actual)throw "Error actual: " + actual + " is not true."
}function assertFalse(actual){if(actual)throw "Error actual: " + actual + " is not false."
}function assertIntEquals(expected, actual){if(typeof expected != "number")throw "Error expected: " + expected +" is not a number."if(typeof actual != "number")throw "Error actual: " + actual +" is not a number."if(expected != actual)throw "Error expected: " + expected + " and actual: " + actual +" is different."
}

十进制数与二进制数之间转换工具utils.js

function int2LowEightBitArray(num){var result = []for(var i = 0; i < 8; i++)result.push(((num >> i) & 1) == 1)return result
}function lowEightBitArray2Int(array){var result = 0for(var i = 0; i < 8; i++){if(array[i])result += (1 << i)}return result
}function lowNineBitArray2Int(array){var result = 0for(var i = 0; i < 9; i++){if(array[i])result += (1 << i)}return result
}//用补码表示负数
function int2EightBitArray(num){if(num < -128 || num > 127){throw "Out of boundary(-128, 127)."}var result = []for(var i = 0; i < 8; i++)result.push(((num >> i) & 1) == 1)return result
}function eightBitArray2Int(array){var result = 0for(var i = 0; i < 7; i++){if(array[i])result += (1 << i)}if(array[i])result += -128return result
}function int2SixteenBitArray(num){if(num < -(1 << 15) || num > (1 << 15) - 1){throw "Out of boundary({left}, {right}).".replace("{left}", -(1 << 15)).replace("{right}", (1 << 15) - 1)}var result = []for(var i = 0; i < 16; i++)result.push(((num >> i) & 1) == 1)return result
}function sixteentBitArray2Int(array){var result = 0for(var i = 0; i < 15; i++){if(array[i])result += (1 << i)}if(array[i])result += -(1 << 15)return result
}

加法器模型model.js

class DoubleInGate{#id#in1#in2#gateTypeName#func#out#lastOut#outReceiver#outReceiverInNameconstructor(id, gateTypeName, in1 = false, in2 = false, func){this.#id = idthis.#gateTypeName = gateTypeNamethis.#in1 = in1this.#in2 = in2this.#func = functhis.#out = this.#func(this.in1, this.in2)// this.#lastOut = this.#out}updateIn1(flag){this.#in1 = flagthis.#updateOut()}updateIn2(flag){this.#in2 = flagthis.#updateOut()}getOut(){return this.#out;}updateBothIn(in1 = false, in2 = false){this.#in1 = in1this.#in2 = in2this.#updateOut()}setOutReceiver(outReceiver, inName){this.#outReceiver = outReceiverthis.#outReceiverInName = inName}#updateOut(){this.#lastOut = this.#outthis.#out = this.#func(this.#in1, this.#in2)if(this.#out != this.#lastOut){this.#send(this.#out)}}#send(flag){if(this.#outReceiver){this.#outReceiver.receive(this.#outReceiverInName, flag)}}receive(inName, flag){if(inName == "in1"){this.updateIn1(flag)}else if(inName == "in2"){this.updateIn2(flag)}}toString(){return "{gateTypeName} id: {id}, in1: {in1}, in2: {in2}, out:{out}".replace("{gateTypeName}", this.#gateTypeName).replace("{id}", this.#id).replace("{in1}", this.#in1).replace("{in2}", this.#in2).replace("{out}", this.#out)}
}//与门
class AndGate extends DoubleInGate{constructor(id, in1 = false, in2 = false){super(id, "AndGate", in1, in2, (i1, i2) => i1 && i2)}
}//或门
class OrGate extends DoubleInGate{constructor(id, in1 = false, in2 = false){super(id, "OrGate", in1, in2, (i1, i2) => i1 || i2)}
}//异或门
class XorGate extends DoubleInGate{constructor(id, in1 = false, in2 = false){//^在js按位异或, 而在java中不是super(id, "XorGate", in1, in2, (i1, i2) => (i1 || i2) && !(i1 && i2)) }
}class SingleInGate{#id#in#out#lastOut#func#outReceiver#outReceiverInNameconstructor(id, in_, func){this.#id = idthis.#in = in_this.#func = functhis.#out = this.#func(this.#in)// this.#lastOut = this.#out}updateIn(flag){this.#in = flagthis.#updateOut()}getOut(){return this.#out}//注册输出端口接收者,(类观察者模式)setOutReceiver(outReceiver, inName){this.#outReceiver = outReceiverthis.#outReceiverInName = inName}#updateOut(){this.#lastOut = this.#outthis.#out = this.#func(this.#in)if(this.#out != this.#lastOut){this.#send(this.#out)}}#send(flag){if(this.#outReceiver){this.#outReceiver.receive(this.#outReceiverInName, flag)}    }receive(inName, flag){if(inName == "in"){ //TODO 或许有更灵活的写法this.updateIn(flag)}}
}class NullGate extends SingleInGate{constructor(id, in_= false){super(id, in_, a=>a)}
}class NotGate extends SingleInGate{constructor(id, in_= false){super(id, in_, a=>!a)}
}class Adder{#id#inA#inB#outS#outC#lastOutS#lastOutC#outSReceiver#outSReceiverInName#outCReceiver#outCReceiverInNameconstructor(id, inA=false, inB=false, outS, outC){this.#id = idthis.#inA = inAthis.#inB = inBthis.#outS = outSthis.#outC = outC}updateInA(flag, func){this.#inA = flagthis.updateOutSAndOutC(func)}updateInB(flag, func){this.#inB = flagthis.updateOutSAndOutC(func)}updateBothIn(inA, inB, func){this.#inA = inAthis.#inB = inBthis.updateOutSAndOutC(func)}getOutS(){return this.#outS}getOutC(){return this.#outC}#updateOutS(flag){this.#lastOutS = this.#outSthis.#outS = flagif(this.#outS != this.#lastOutS){this.#sendOutS(this.#outS)}}#updateOutC(flag){this.#lastOutC = this.#outCthis.#outC = flagif(this.#outC != this.#lastOutC){this.#sendOutC(this.#outC)}}updateOutSAndOutC(func){if(func){var results = func()this.#updateOutS(results[0])this.#updateOutC(results[1])}}setOutSReceiver(outSReceiver, inName){this.#outSReceiver = outSReceiverthis.#outSReceiverInName = inName}setOutCReceiver(outCReceiver, inName){this.#outCReceiver = outCReceiverthis.#outCReceiverInName = inName}receive(inName, flag){if(inName == "inA"){this.updateInA(flag)}else if(inName == "inB"){this.updateInB(flag)}}#sendOutS(flag){if(this.#outSReceiver){this.#outSReceiver.receive(this.#outSReceiverInName, flag)}}#sendOutC(flag){if(this.#outCReceiver){this.#outCReceiver.receive(this.#outCReceiverInName, flag)}}
}class HalfAdder extends Adder{#xorGate#andGateconstructor(id, inA=false, inB=false){var xorGate = new XorGate(undefined, inA, inB);var andGate = new AndGate(undefined, inA, inB);super(id, inA, inB, xorGate.getOut(), andGate.getOut())this.#xorGate = xorGatethis.#andGate = andGate }#returnOutArray(){return [this.#xorGate.getOut(), this.#andGate.getOut()]}updateInA(flag){super.updateInA(flag, ()=>{this.#xorGate.updateIn1(flag)this.#andGate.updateIn1(flag)return this.#returnOutArray()})}updateInB(flag){super.updateInB(flag, ()=>{this.#xorGate.updateIn2(flag)this.#andGate.updateIn2(flag)return this.#returnOutArray()})}updateBothIn(inA, inB){super.updateBothIn(inA, inB, ()=>{this.#xorGate.updateBothIn(inA, inB)this.#andGate.updateBothIn(inA, inB)return this.#returnOutArray()})}}class FullAdder extends Adder{#inC#halfAdder1#halfAdder2#orGateconstructor(id, inA = false, inB = false, inC = false){var halfAdder1 = new HalfAdder(undefined, inA, inB)var halfAdder2 = new HalfAdder(undefined, inC, halfAdder1.getOutS())var orGate = new OrGate(undefined, halfAdder1.getOutC(), halfAdder2.getOutC())super(id, inA, inB, halfAdder2.getOutS(), orGate.getOut())this.#inC = inCthis.#halfAdder1 = halfAdder1this.#halfAdder2 = halfAdder2this.#orGate = orGatethis.#halfAdder1.setOutSReceiver(halfAdder2, "inB")this.#halfAdder1.setOutCReceiver(orGate, "in1")this.#halfAdder2.setOutCReceiver(orGate, "in2")}#returnOutArray(){return [this.#halfAdder2.getOutS(), this.#orGate.getOut()]}updateInA(flag){super.updateInA(flag, ()=>{this.#halfAdder1.updateInA(flag)return this.#returnOutArray()})}updateInB(flag){super.updateInB(flag, ()=>{this.#halfAdder1.updateInB(flag)return this.#returnOutArray()})}updateInC(flag){this.#inC = flagthis.#halfAdder2.updateInA(flag)this.updateOutSAndOutC(()=>{return this.#returnOutArray()})}updateBothIn(inA, inB){super.updateBothIn(inA, inB, ()=>{this.#halfAdder1.updateBothIn(inA, inB)return this.#returnOutArray()})}updateThreeIn(inA, inB, inC){super.updateBothIn(inA, inB)this.#inC = inCthis.#halfAdder1.updateBothIn(inA, inB)this.#halfAdder2.updateBothIn(inC, this.#halfAdder1.getOutS())this.#orGate.updateBothIn(this.#halfAdder1.getOutC(), this.#halfAdder2.getOutC())this.updateOutSAndOutC(()=>{return this.#returnOutArray()})}receive(inName, flag){super.receive(inName, flag)if(inName == "inC"){this.updateInC(flag)}}
}class EightBitBinaryAdder{#inC#outC#lastOutC#inA#inB#outS#fullAdders#fullAdderNum#outCReceiver#outCReceiverInName#outCInOutSFlagconstructor(outCInOutSFlag = false){this.#outCInOutSFlag = outCInOutSFlagthis.#inC = falsethis.#fullAdderNum = 8this.#fullAdders = []this.#inA = []this.#inB = []for(var i = 0; i < this.#fullAdderNum; i++){this.#inA.push(false)this.#inB.push(false)}//新键8个全加器for(var i = 0; i < this.#fullAdderNum; i++){this.#fullAdders.push(new FullAdder("f" + i))if(i != 0){this.#fullAdders[i - 1].setOutCReceiver(this.#fullAdders[i], "inC")}}this.updateOut()}updateBothIn(arrayA, arrayB){// this.#inC = inCthis.#inA = arrayAthis.#inB = arrayBfor(var i = 0; i < this.#fullAdderNum; i++){if(i == 0){this.#fullAdders[i].updateInC(this.#inC)}this.#fullAdders[i].updateBothIn(arrayA[i], arrayB[i])}this.updateOut()}//输出默认值updateOut(){this.#outS = []for(var i = 0; i < this.#fullAdderNum; i++){this.#outS.push(this.#fullAdders[i].getOutS())if(i == this.#fullAdderNum - 1){this.#lastOutC = this.#outCthis.#outC = this.#fullAdders[i].getOutC()if(this.#lastOutC != this.#outC)this.#sendOutC(this.#outC)if(this.#outCInOutSFlag)this.#outS.push(this.#outC)}}}updateInC(flag){this.#inC = flagthis.updateBothIn(this.#inA, this.#inB, flag)}receive(inName, flag){if(inName == "inC"){this.updateInC(flag)}}#sendOutC(flag){if(this.#outCReceiver){this.#outCReceiver.receive(this.#outCReceiverInName, flag)}}setOutCReceiver(outCReceiver, inName){this.#outCReceiver = outCReceiverthis.#outCReceiverInName = inName}getOut(){return this.#outS}
}class SixteenBitBinaryAdder{#inC#outC#lastOutC#inA#inB#outS#eightBitBinaryAdder1#eightBitBinaryAdder2#bitNum = 16#outCReceiver#outCReceiverInName#outCInOutSFlagconstructor(outCInOutSFlag){this.#outCInOutSFlag = outCInOutSFlagthis.#inC = falsethis.#eightBitBinaryAdder1 = new EightBitBinaryAdder()this.#eightBitBinaryAdder2 = new EightBitBinaryAdder()this.#inA = []this.#inB = []for(var i = 0; i < this.#bitNum; i++){this.#inA.push(false)this.#inB.push(false)}this.#eightBitBinaryAdder1.setOutCReceiver(this.#eightBitBinaryAdder2, "inC")this.updateOut()}updateBothIn(arrayA, arrayB){this.#inA = arrayAthis.#inB = arrayBthis.#eightBitBinaryAdder1.updateBothIn(arrayA.slice(0, 8), arrayB.slice(0, 8))this.#eightBitBinaryAdder2.updateBothIn(arrayA.slice(8), arrayB.slice(8))this.updateOut()}updateOut(){this.#outS = this.#eightBitBinaryAdder1.getOut().concat(this.#eightBitBinaryAdder2.getOut())//发送send(OutC)}getOut(){return this.#outS}//TODO// updateInC(flag){//     this.#inC = flag//     this.updateBothIn(this.#inA, this.#inB, flag)// }// receive(inName, flag){//     if(inName == "inC"){//         this.updateInC(flag)//     }// }#sendOutC(flag){if(this.#outCReceiver){this.#outCReceiver.receive(this.#outCReceiverInName, flag)}}setOutCReceiver(outCReceiver, inName){this.#outCReceiver = outCReceiverthis.#outCReceiverInName = inName}}

运行验证代码

验证通过判据:后台没有打印输出异常。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Test</title><script src="../js/test/TestUtils.js"></script><script src="../js/model.js"></script><script src="../js/utils.js"></script>
</head>
<body><script>var g1 = new NullGate("g1")var g2 = new NullGate("g2")var g3 = new NullGate("g3")var g4 = new NullGate("g4")var g5 = new NullGate("g5")var g6 = new NullGate("g6")g1.setOutReceiver(g2, "in")g2.setOutReceiver(g3, "in")g3.setOutReceiver(g4, "in")g4.setOutReceiver(g5, "in")g5.setOutReceiver(g6, "in")g1.updateIn(true)assertTrue(g6.getOut())</script><script>//与门var andGate = new AndGate("a01")assertFalse(andGate.getOut())andGate.updateIn1(true)assertFalse(andGate.getOut())andGate.updateIn2(true)assertTrue(andGate.getOut())//或门var orGate = new OrGate("o01")assertFalse(orGate.getOut())orGate.updateIn1(true)assertTrue(orGate.getOut())orGate.updateIn2(true)assertTrue(orGate.getOut())//异或门var xorGate = new XorGate("x01")assertFalse(xorGate.getOut())xorGate.updateIn1(true)assertTrue(xorGate.getOut())xorGate.updateIn2(true)assertFalse(xorGate.getOut())xorGate.updateBothIn(false, true)assertTrue(xorGate.getOut())</script><script>//半加器var ha = new HalfAdder("h01")assertFalse(ha.getOutS())assertFalse(ha.getOutC())ha.updateInB(true)assertTrue(ha.getOutS())assertFalse(ha.getOutC())ha.updateInA(true)assertFalse(ha.getOutS())assertTrue(ha.getOutC())ha.updateBothIn(true, false)assertTrue(ha.getOutS())assertFalse(ha.getOutC())</script><script>//全加器var fa = new FullAdder("fa01")assertFalse(fa.getOutC())assertFalse(fa.getOutS())function test(inA, inB, inC, expectedS, expectedC){fa.updateThreeIn(inA, inB, inC)if(expectedS)assertTrue(fa.getOutS())elseassertFalse(fa.getOutS())if(expectedC)assertTrue(fa.getOutC())elseassertFalse(fa.getOutC())}test(false, false, false, false, false)test(false, true, false, true, false)test(true, false, false, true, false)test(true, true, false, false, true)test(false, false, true, true, false)test(false, true, true, false, true)test(true, false, true, false, true)test(true, true, true, true, true)</script><script>for(var i = 0 ; i < 256; i++){assertIntEquals(i, lowEightBitArray2Int(int2LowEightBitArray(i)))}</script><script>var ebba = new EightBitBinaryAdder(true)for(var i = 0; i < 256; i++){for(var j = 0; j < 256; j++){iebba.updateBothIn(int2LowEightBitArray(i), int2LowEightBitArray(j))assertIntEquals(i + j, lowNineBitArray2Int(ebba.getOut()))}}</script><script>for(var i = -128; i <= 127; i++){assertIntEquals(i, eightBitArray2Int(int2EightBitArray(i)))}</script><script>var ebba = new EightBitBinaryAdder()for(var i = -64; i < 64; i++){for(var j = -64; j < 64; j++){ebba.updateBothIn(int2EightBitArray(i), int2EightBitArray(j))assertIntEquals(i + j, eightBitArray2Int(ebba.getOut()))}}</script><script>for(var i = -(1<<15); i <= (1<<15) - 1; i++){assertIntEquals(i, sixteentBitArray2Int(int2SixteenBitArray(i)))}</script><script>var sbba = new SixteenBitBinaryAdder()sbba.updateBothIn(int2SixteenBitArray(1156), int2SixteenBitArray(9999))assertIntEquals(9999 + 1156, sixteentBitArray2Int(sbba.getOut()))//‭16384‬ * ‭16384‬ = 268435456 如果这样算会十分耗时// for(var i = -(1<<14); i < (1<<14); i++){//     for(var j = -(1<<14); j < (1<<14); j++){//         sbba.updateBothIn(int2SixteenBitArray(i), int2SixteenBitArray(j))//         assertIntEquals(i + j, sixteentBitArray2Int(sbba.getOut()))//     }// }for(var i = -100; i < 100; i++){for(var j = -100; j < 100; j++){sbba.updateBothIn(int2SixteenBitArray(i), int2SixteenBitArray(j))assertIntEquals(i + j, sixteentBitArray2Int(sbba.getOut()))}}</script>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/445568.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android学习路线总结

title: Android学习路线总结&#xff0c;绝对干货 tags: Android学习路线,Android学习资料,怎么学习android grammar_cjkRuby: true --- 一、前言 不知不觉自己已经做了几年开发了&#xff0c;由记得刚出来工作的时候感觉自己能牛X&#xff0c;现在回想起来感觉好无知。懂的越…

双栈

利用栈底位置相对不变的特性&#xff0c;可以让两个顺序栈共享一个空间。 具体实现方法大概有两种&#xff1a; 一种是奇偶栈&#xff0c;就是所有下标为奇数的是一个栈&#xff0c;偶数是另一个栈。但是这样一个栈的最大存储就确定了&#xff0c;并没有起到互补空缺的作用&a…

Error when loading the SDK:解决方案

错误情况&#xff1a; 当打开eclipse时出现如下窗口&#xff08;内容如下&#xff09; Error when loading the SDK: Error: Error parsing \Android\adt-bundle-windows-x86_64-20140702\sdk\system-images\android-22\android-wear\armeabi-v7a\devices.xml cvc-complex-type…

单调队列优化的背包问题

对于背包问题&#xff0c;经典的背包九讲已经讲的很明白了&#xff0c;本来就不打算写这方面问题了。 但是吧。 我发现&#xff0c;那个最出名的九讲竟然没写队列优化的背包。。。。 那我必须写一下咯嘿嘿&#xff0c;这么好的思想。 我们回顾一下背包问题吧。 01背包问题 …

用Python去除扫描型PDF中的水印

内容概述 含水印扫描型PDF文件&#xff0c;其中某页如下图所示&#xff0c;用Python去除其页顶及页底的水印。 处理思路&#xff1a;PDF中的每一页的水印的相对位置基本相同&#xff0c;将PDF每一页输出成图片&#xff0c;然后进行图片编辑&#xff0c;用白色填充方形覆盖水印…

链表实现栈

栈&#xff0c;是操作受限的线性表&#xff0c;只能在一端进行插入删除。 其实就是带尾指针的链表&#xff0c;尾插 #include <stdio.h> #include <stdlib.h> #define OK 1 #define ERROR 0 #define Status int #define SElemType int //只在头部进行插入和删除(…

二阶有源滤波器

滤波器是一种使用信号通过而同时抑制无用频率信号的电子装置, 在信息处理、数据传送和抑制干扰等自动控制、通信及其它电子系统中应用广泛。滤波一般可分为有源滤波和无源滤波, 有源滤波可以使幅频特性比较陡峭, 而无源滤波设计简单易行, 但幅频特性不如滤波器, 而且体积较大。…

用JS写了一个30分钟倒计时器

效果图 额外功能 左键单击计时器数字区&#xff0c;不显示或显示秒钟区。左键双击计时器数字区&#xff0c;暂停或启动计时器。计时完毕&#xff0c;只能刷新页面启动计时器。输入框可输入备注信息&#xff0c;输入框失去焦点或计时完毕后&#xff0c;时间戳附带备注信息会存入…

为什么高手离不了Linux系统?我想这就是理由!

通过本文来记录下我在Linux系统的学习经历&#xff0c;聊聊我为什么离不了Linux系统&#xff0c;同时也为那些想要尝试Linux而又有所顾忌的用户答疑解惑&#xff0c;下面将为你介绍我所喜欢的Linux系统&#xff0c;这里有一些你应该知道并为之自豪的事实。 这里你应该首先抛开W…

python学习实例(1)

# #1.2 计算机编程的基本概念 ## #1.2.2 从Python语言进入计算机语言的世界 ##<程序&#xff1a;例子1> def F(x,y):return(x*xy*y) print("F(2,2)",F(2,2)) print("F(3,2)",F(3,2))#<程序&#xff1a;例子2> def Pr():for i in range(0,10)…

用JS写一个电影《黑客帝国》显示屏黑底绿字雨风格的唐诗欣赏器

效果图 放码过来 <!DOCTYPE HTML> <html><head><meta http-equiv"Content-Type" content"text/html;charsetutf-8"/><title>Black Screen And Green Characters</title><style type"text/css">table…

python学习实例(2)

# #2.2 不同进制间的转换 ## #2.2.1. 二进制数转换为十进制数 ##<程序&#xff1a;2-to-10进制转换> binput("Please enter a binary number:") d0; for i in range(0,len(b)):if b[i] 1:weight 2**(len(b)-i-1)d dweight; print(d)#<程序&#xff1a;改…

元器件封装大全:图解+文字详述

先图解如下&#xff1a; 元器件封装类型&#xff1a; A.Axial  轴状的封装&#xff08;电阻的封装&#xff09;AGP &#xff08;Accelerate raphical Port&#xff09; 加速图形接口 AMR(Audio/MODEM Riser) 声音/调制解调器插卡BBGA&#xff08;Ball Grid Array&#xff09;…

python学习实例(3)

# #3.4 关于Python的函数调用 ## #3.4.2 Python函数入门 ##<程序&#xff1a;计算43*22> #函数f def f(x, y):return x*y*y#主函数部分 c4f(3, 2) print (c)# #3.4.3 局部变量(Local variables)与全局变量(Global variables) ##<程序&#xff1a;打印局部变量a和全局…

用JS写一个丐版《2048》小游戏

效果图 放马过来 <!DOCTYPE HTML> <html><head><meta http-equiv"Content-Type" content"text/html;charsetutf-8"/><title>2048</title><style type"text/css">.basic{height:80px;width:80px;back…

如何有效申请TI的免费样片

转自如何有效申请TI的免费样片 TI公司愿意为支持中国大学的师生们的教学、实验、创新实践、竞赛和科研项目&#xff0c;提供有限数量的免费样片。首先需要指出的是&#xff1a;所有的样片申请应该是诚实正当的&#xff0c;所有不恰当的申请&#xff08;包括不必要或多余的&…

python学习实例(4)

# #第四章的python程序 ## #4.1 简洁的Python ##<程序&#xff1a;Python数组各元素加1> arr [0,1,2,3,4] for e in arr:tmpe1print (tmp)## #4.2 Python内置数据结构 ## #4.2.1 Python基本数据类型 ##<程序&#xff1a;产生10-20的随机浮点数> import random f …

用Python批量生成字幕图片用于视频剪辑

说明 视频剪辑时需要为视频添加字幕&#xff0c;添加字幕方法之一&#xff1a;根据字幕文本文件批量生成透明底只有字幕内容的图片文件&#xff0c;如下图&#xff0c;然后将这些图片文件添加到视频剪辑软件轨道中。 于是用pillow这Python图片工具库执行本次批量生成工作。 …

关于接地:数字地、模拟地、信号地、交流地、直流地、屏蔽地、浮

除了正确进行接地设计、安装,还要正确进行各种不同信号的接地处理。控制系统中&#xff0c;大致有以下几种地线&#xff1a; &#xff08;1&#xff09;数字地&#xff1a;也叫逻辑地&#xff0c;是各种开关量&#xff08;数字量&#xff09;信号的零电位。 &#xff08;2&…

python学习实例(5)

# #5.1 计算思维是什么 ##<程序: 找假币的第一种方法> by Edwin Sha def findcoin_1(L):if len(L) <1:print("Error: coins are too few"); quit()i0while i<len(L):if L[i] < L[i1]: return (i)elif L[i] > L[i1]: return (i1)ii1print("All…